summaryrefslogtreecommitdiff
path: root/src/auditor
diff options
context:
space:
mode:
Diffstat (limited to 'src/auditor')
-rw-r--r--src/auditor/.gitignore3
-rw-r--r--src/auditor/Makefile.am75
-rw-r--r--src/auditor/auditor-basedb-libeufin.sql140
-rw-r--r--src/auditor/auditor-basedb.age1
-rw-r--r--src/auditor/auditor-basedb.conf187
-rw-r--r--src/auditor/auditor-basedb.mpub1
-rw-r--r--src/auditor/auditor-basedb.sql16023
-rw-r--r--src/auditor/auditor.conf6
-rw-r--r--src/auditor/batch.conf2
-rwxr-xr-xsrc/auditor/batch.sh22
-rw-r--r--src/auditor/generate-auditor-basedb-template.conf1
-rw-r--r--src/auditor/generate-auditor-basedb.conf202
-rwxr-xr-xsrc/auditor/generate-auditor-basedb.sh324
-rw-r--r--src/auditor/generate-kyc-basedb.conf4
-rwxr-xr-xsrc/auditor/generate-revoke-basedb.sh389
-rw-r--r--src/auditor/generate_auditordb_home/.local/share/taler/exchange-offline/master.priv1
-rw-r--r--src/auditor/report-lib.c70
-rw-r--r--src/auditor/report-lib.h48
-rw-r--r--src/auditor/revoke-basedb-libeufin.sql161
-rw-r--r--src/auditor/revoke-basedb.age1
-rw-r--r--src/auditor/revoke-basedb.conf8
-rw-r--r--src/auditor/revoke-basedb.mpub1
-rw-r--r--src/auditor/revoke-basedb.sql16039
-rwxr-xr-xsrc/auditor/setup.sh93
-rw-r--r--src/auditor/taler-auditor-dbinit.c4
-rw-r--r--src/auditor/taler-auditor-exchange.c224
-rw-r--r--src/auditor/taler-auditor-httpd.c76
-rw-r--r--src/auditor/taler-auditor-httpd.h6
-rw-r--r--src/auditor/taler-auditor-httpd_deposit-confirmation-get.c166
-rw-r--r--src/auditor/taler-auditor-httpd_deposit-confirmation-get.h70
-rw-r--r--src/auditor/taler-auditor-httpd_deposit-confirmation.c148
-rw-r--r--src/auditor/taler-auditor-httpd_deposit-confirmation.h1
-rw-r--r--src/auditor/taler-auditor-httpd_exchanges.c116
-rw-r--r--src/auditor/taler-auditor-httpd_exchanges.h46
-rw-r--r--src/auditor/taler-auditor-sync.c19
-rw-r--r--src/auditor/taler-auditor.in7
-rw-r--r--src/auditor/taler-helper-auditor-aggregation.c165
-rw-r--r--src/auditor/taler-helper-auditor-coins.c723
-rw-r--r--src/auditor/taler-helper-auditor-deposits.c237
-rw-r--r--src/auditor/taler-helper-auditor-purses.c1451
-rw-r--r--src/auditor/taler-helper-auditor-render.py12
-rw-r--r--src/auditor/taler-helper-auditor-reserves.c1447
-rw-r--r--src/auditor/taler-helper-auditor-wire.c1105
-rwxr-xr-xsrc/auditor/test-auditor.sh2805
-rwxr-xr-xsrc/auditor/test-kyc.sh751
-rwxr-xr-xsrc/auditor/test-revocation.sh953
-rwxr-xr-xsrc/auditor/test-sync.sh184
47 files changed, 7571 insertions, 36947 deletions
diff --git a/src/auditor/.gitignore b/src/auditor/.gitignore
index 59088a1b3..11c875dc6 100644
--- a/src/auditor/.gitignore
+++ b/src/auditor/.gitignore
@@ -23,3 +23,6 @@ auditor-basedb.sqlite3
taler-auditor-test.sqlite3
libeufin-nexus.pid
libeufin-sandbox.pid
+taler-helper-auditor-purses
+generate-kyc-basedb.conf.edited
+generate-auditor-basedb.conf.edited
diff --git a/src/auditor/Makefile.am b/src/auditor/Makefile.am
index a74e0ad2a..381c0b115 100644
--- a/src/auditor/Makefile.am
+++ b/src/auditor/Makefile.am
@@ -16,12 +16,12 @@ clean-local:
bin_PROGRAMS = \
taler-auditor-dbinit \
- taler-auditor-exchange \
taler-auditor-httpd \
taler-auditor-sync \
taler-helper-auditor-aggregation \
taler-helper-auditor-coins \
taler-helper-auditor-deposits \
+ taler-helper-auditor-purses \
taler-helper-auditor-reserves \
taler-helper-auditor-wire
@@ -65,9 +65,9 @@ taler_auditor_dbinit_CPPFLAGS = \
-I$(top_srcdir)/src/pq/ \
$(POSTGRESQL_CPPFLAGS)
-taler_helper_auditor_reserves_SOURCES = \
- taler-helper-auditor-reserves.c
-taler_helper_auditor_reserves_LDADD = \
+taler_helper_auditor_coins_SOURCES = \
+ taler-helper-auditor-coins.c
+taler_helper_auditor_coins_LDADD = \
$(LIBGCRYPT_LIBS) \
$(top_builddir)/src/util/libtalerutil.la \
$(top_builddir)/src/json/libtalerjson.la \
@@ -80,9 +80,9 @@ taler_helper_auditor_reserves_LDADD = \
-lgnunetutil \
$(XLIB)
-taler_helper_auditor_coins_SOURCES = \
- taler-helper-auditor-coins.c
-taler_helper_auditor_coins_LDADD = \
+taler_helper_auditor_aggregation_SOURCES = \
+ taler-helper-auditor-aggregation.c
+taler_helper_auditor_aggregation_LDADD = \
$(LIBGCRYPT_LIBS) \
$(top_builddir)/src/util/libtalerutil.la \
$(top_builddir)/src/json/libtalerjson.la \
@@ -95,9 +95,9 @@ taler_helper_auditor_coins_LDADD = \
-lgnunetutil \
$(XLIB)
-taler_helper_auditor_aggregation_SOURCES = \
- taler-helper-auditor-aggregation.c
-taler_helper_auditor_aggregation_LDADD = \
+taler_helper_auditor_deposits_SOURCES = \
+ taler-helper-auditor-deposits.c
+taler_helper_auditor_deposits_LDADD = \
$(LIBGCRYPT_LIBS) \
$(top_builddir)/src/util/libtalerutil.la \
$(top_builddir)/src/json/libtalerjson.la \
@@ -110,9 +110,24 @@ taler_helper_auditor_aggregation_LDADD = \
-lgnunetutil \
$(XLIB)
-taler_helper_auditor_deposits_SOURCES = \
- taler-helper-auditor-deposits.c
-taler_helper_auditor_deposits_LDADD = \
+taler_helper_auditor_purses_SOURCES = \
+ taler-helper-auditor-purses.c
+taler_helper_auditor_purses_LDADD = \
+ $(LIBGCRYPT_LIBS) \
+ $(top_builddir)/src/util/libtalerutil.la \
+ $(top_builddir)/src/json/libtalerjson.la \
+ $(top_builddir)/src/bank-lib/libtalerbank.la \
+ $(top_builddir)/src/exchangedb/libtalerexchangedb.la \
+ $(top_builddir)/src/auditordb/libtalerauditordb.la \
+ libauditorreport.la \
+ -ljansson \
+ -lgnunetjson \
+ -lgnunetutil \
+ $(XLIB)
+
+taler_helper_auditor_reserves_SOURCES = \
+ taler-helper-auditor-reserves.c
+taler_helper_auditor_reserves_LDADD = \
$(LIBGCRYPT_LIBS) \
$(top_builddir)/src/util/libtalerutil.la \
$(top_builddir)/src/json/libtalerjson.la \
@@ -125,6 +140,8 @@ taler_helper_auditor_deposits_LDADD = \
-lgnunetutil \
$(XLIB)
+
+
taler_helper_auditor_wire_SOURCES = \
taler-helper-auditor-wire.c
taler_helper_auditor_wire_LDADD = \
@@ -145,7 +162,7 @@ taler_helper_auditor_wire_LDADD = \
taler_auditor_httpd_SOURCES = \
taler-auditor-httpd.c taler-auditor-httpd.h \
taler-auditor-httpd_deposit-confirmation.c taler-auditor-httpd_deposit-confirmation.h \
- taler-auditor-httpd_exchanges.c taler-auditor-httpd_exchanges.h \
+ taler-auditor-httpd_deposit-confirmation-get.c taler-auditor-httpd_deposit-confirmation-get.h \
taler-auditor-httpd_mhd.c taler-auditor-httpd_mhd.h
taler_auditor_httpd_LDADD = \
$(LIBGCRYPT_LIBS) \
@@ -161,15 +178,6 @@ taler_auditor_httpd_LDADD = \
-lz \
$(XLIB)
-taler_auditor_exchange_SOURCES = \
- taler-auditor-exchange.c
-taler_auditor_exchange_LDADD = \
- $(LIBGCRYPT_LIBS) \
- $(top_builddir)/src/util/libtalerutil.la \
- $(top_builddir)/src/auditordb/libtalerauditordb.la \
- -lgnunetutil \
- $(XLIB)
-
taler_auditor_sync_SOURCES = \
taler-auditor-sync.c
taler_auditor_sync_LDADD = \
@@ -189,31 +197,22 @@ taler_auditor_sync_CPPFLAGS = \
check_SCRIPTS = \
test-auditor.sh \
+ test-kyc.sh \
test-revocation.sh \
test-sync.sh
.NOTPARALLEL:
-# revocation test disabled for now: need working wallet first!
-TESTS = $(check_SCRIPTS)
+# TESTS = $(check_SCRIPTS)
EXTRA_DIST = \
taler-auditor.in \
taler-helper-auditor-render.py \
auditor.conf \
+ setup.sh \
test-sync-in.conf \
test-sync-out.conf \
generate-auditor-basedb.sh \
- generate-revoke-basedb.sh \
generate-auditor-basedb.conf \
- generate-auditor-basedb-template.conf \
- $(check_SCRIPTS) \
- auditor-basedb.age \
- auditor-basedb.conf \
- auditor-basedb.sql \
- auditor-basedb-libeufin.sql \
- auditor-basedb.mpub \
- revoke-basedb.age \
- revoke-basedb.conf \
- revoke-basedb.sql \
- revoke-basedb-libeufin.sql \
- revoke-basedb.mpub
+ generate-kyc-basedb.conf \
+ generate-revoke-basedb.sh \
+ $(check_SCRIPTS)
diff --git a/src/auditor/auditor-basedb-libeufin.sql b/src/auditor/auditor-basedb-libeufin.sql
deleted file mode 100644
index 361bfe531..000000000
--- a/src/auditor/auditor-basedb-libeufin.sql
+++ /dev/null
@@ -1,140 +0,0 @@
-PRAGMA foreign_keys=OFF;
-BEGIN TRANSACTION;
-CREATE TABLE DemobankConfigs (id INTEGER PRIMARY KEY AUTOINCREMENT, currency TEXT NOT NULL, allowRegistrations BOOLEAN NOT NULL, withSignupBonus BOOLEAN NOT NULL, bankDebtLimit INT NOT NULL, usersDebtLimit INT NOT NULL, hostname TEXT NOT NULL, suggestedExchangeBaseUrl TEXT NULL, suggestedExchangePayto TEXT NULL, uiTitle TEXT NOT NULL);
-INSERT INTO DemobankConfigs VALUES(1,'TESTKUDOS',1,0,1000000,1000,'default','http://localhost:8081/','payto://iban/SANDBOXX/DE546854?receiver-name=Exchange+Company','Demo Bank');
-CREATE TABLE EbicsSubscriberPublicKeys (id INTEGER PRIMARY KEY AUTOINCREMENT, rsaPublicKey BLOB NOT NULL, "state" INT NOT NULL);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(1,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100adebb8232ffe4ece51c1a65c374a20c6004219b8db8d1233341b41ec906ee63dad98eee2f8c38bae21ed04072b5019f2b000aca7ddb185b8a0635d9c54bd77dac31404a900609e4006af945d3016f027a8d5c05f9ed005142d4f23d4bae53fcce4e5915dd572bfcd0888c6bb4282906fd322c9114079ab00be9831a43d437be25773e0eaeb169aedc63d685f3fa5b0e20f2ff4f9a5190890749d44112488c44e8611c177743e4d6a8d8f3396af843bd3daf46a2d952070285172957514d60ec3020b93f6c462adb16cc198a797c687dc2702d659264ce4b0ae80f8f78fe1352cdd69ba4cff1ea36afa9ad9eee9478e240f2fa590410ff7118059db35077a6baf0203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(2,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100937fbca30748f24ccfb1dde9cca6611f2c9df47546ab506176654fd858c8d0090a56c8be6af7b7681a1270172453435449c977099f881a0f0ffff68164166416cd15c7af6b977aebff6f7ca287eabed7d62c3c11089ce5315404c05c4eba61e3a354b1824bda85916db3f7a28f92767fddc2db43f02bdcd86d97aec3390263f774ed3ce828f40dddcbb5bc944b906c94ba8721f89853a8013cd06fce7f37666bdf88b759b38ba4842ed5cdd33b32964ced03149b4b6e13213a434946f4b4e4a444fd9681a61709ef013fa0f1b9d67f23278c709ac81bd9ad7a7ef410f7a1a9a818bd76119c1676cddef0296d7c069ea9cc4279cb24c7d2e3264ba7708ecef1dd0203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(3,X'30820122300d06092a864886f70d01010105000382010f003082010a028201010096f42ff3697c7a030140e705b1060365690cb42ca1763d2d6326ee7f0c8a04d8f0e0d651144df51f965864e7b32328756f92b599e3a97457f3b4c22f1e2332443c35f9145495cf581076054ff9f5e4214eef6756d410262164f67c09c502c6a98b3bc3ac36625d885a85f55c92fdb39272c5beb4e5c2ee9ede9dfcd42cf5fa1d67b5e7f3d5e7e50a4bb6d4e7242b6a5dba075ff8e90786fc06ee304cd20a728891df2e9cc006c22343dd53cc3992e6134bc566f9472451d54b595e49f737fb61a55e0269b3ecbf4789f990d8212de2774d1843047d873261ac8c1aadaf55bb6fedceb70cd35f8bd2504bd04d972b479b6bf092391d67099f8a23f070a3ebe5f10203010001',1);
-CREATE TABLE BankAccountTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, creditorIban TEXT NOT NULL, creditorBic TEXT NULL, creditorName TEXT NOT NULL, debtorIban TEXT NOT NULL, debtorBic TEXT NULL, debtorName TEXT NOT NULL, subject TEXT NOT NULL, amount TEXT NOT NULL, currency TEXT NOT NULL, "date" BIGINT NOT NULL, accountServicerReference TEXT NOT NULL, pmtInfId TEXT NULL, direction TEXT NOT NULL, account INT NOT NULL, demobank BIGINT NOT NULL, CONSTRAINT fk_BankAccountTransactions_account_id FOREIGN KEY (account) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_BankAccountTransactions_demobank_id FOREIGN KEY (demobank) REFERENCES DemobankConfigs(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccountTransactions VALUES(1,'DE546854','SANDBOXX','Exchange Company','DE687184','SANDBOXX','Name unknown','V1GYZXE262Q9CMW4MBYW24WJDFX4TZH9D5G9BZ0NV0YM73M80W50','10','TESTKUDOS',1660251773783,'0I6W616I',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(2,'DE546854','SANDBOXX','Exchange Company','DE687184','SANDBOXX','Name unknown','V1GYZXE262Q9CMW4MBYW24WJDFX4TZH9D5G9BZ0NV0YM73M80W50','10','TESTKUDOS',1660251773783,'0I6W616I',NULL,'DBIT',9,1);
-INSERT INTO BankAccountTransactions VALUES(3,'DE546854','SANDBOXX','Exchange Company','DE871507','SANDBOXX','Name unknown','6DHWMK9VNR61HNFSWZZZKKBNN6FG9W1TA0QK4245CJWB9NVMKEB0','18','TESTKUDOS',1660251781133,'TKXY6UEK',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(4,'DE546854','SANDBOXX','Exchange Company','DE871507','SANDBOXX','Name unknown','6DHWMK9VNR61HNFSWZZZKKBNN6FG9W1TA0QK4245CJWB9NVMKEB0','18','TESTKUDOS',1660251781133,'TKXY6UEK',NULL,'DBIT',10,1);
-CREATE TABLE BankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, iban TEXT NOT NULL, bic TEXT DEFAULT 'SANDBOXX' NOT NULL, label TEXT NOT NULL, owner TEXT NOT NULL, isPublic BOOLEAN DEFAULT 0 NOT NULL, demoBank BIGINT NOT NULL, lastTransaction BIGINT NULL, CONSTRAINT fk_BankAccounts_demoBank_id FOREIGN KEY (demoBank) REFERENCES DemobankConfigs(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_BankAccounts_lastTransaction_id FOREIGN KEY (lastTransaction) REFERENCES BankAccountTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccounts VALUES(1,'DE048530','SANDBOXX','bank','bank',0,1,NULL);
-INSERT INTO BankAccounts VALUES(2,'DE637274','SANDBOXX','fortytwo','fortytwo',0,1,NULL);
-INSERT INTO BankAccounts VALUES(3,'DE899910','SANDBOXX','fortythree','fortythree',0,1,NULL);
-INSERT INTO BankAccounts VALUES(4,'DE546854','SANDBOXX','exchange','exchange',0,1,3);
-INSERT INTO BankAccounts VALUES(5,'DE476398','SANDBOXX','tor','tor',0,1,NULL);
-INSERT INTO BankAccounts VALUES(6,'DE292745','SANDBOXX','gnunet','gnunet',0,1,NULL);
-INSERT INTO BankAccounts VALUES(7,'DE274624','SANDBOXX','tutorial','tutorial',0,1,NULL);
-INSERT INTO BankAccounts VALUES(8,'DE567303','SANDBOXX','survey','survey',0,1,NULL);
-INSERT INTO BankAccounts VALUES(9,'DE687184','SANDBOXX','testuser-eql8x46y','testuser-eql8x46y',0,1,2);
-INSERT INTO BankAccounts VALUES(10,'DE871507','SANDBOXX','testuser-qsgidrbb','testuser-qsgidrbb',0,1,4);
-CREATE TABLE EbicsSubscribers (id INTEGER PRIMARY KEY AUTOINCREMENT, userID TEXT NOT NULL, partnerID TEXT NOT NULL, systemID TEXT NULL, hostID TEXT NOT NULL, signatureKey INT NULL, encryptionKey INT NULL, authorizationKey INT NULL, nextOrderID INT NOT NULL, "state" INT NOT NULL, bankAccount INT NULL, CONSTRAINT fk_EbicsSubscribers_signatureKey_id FOREIGN KEY (signatureKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_encryptionKey_id FOREIGN KEY (encryptionKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_authorizationKey_id FOREIGN KEY (authorizationKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO EbicsSubscribers VALUES(1,'exchangeebics','talerpartner',NULL,'talerebics',1,3,2,1,3,4);
-CREATE TABLE EbicsHosts (id INTEGER PRIMARY KEY AUTOINCREMENT, hostID TEXT NOT NULL, ebicsVersion TEXT NOT NULL, signaturePrivateKey BLOB NOT NULL, encryptionPrivateKey BLOB NOT NULL, authenticationPrivateKey BLOB NOT NULL);
-INSERT INTO EbicsHosts VALUES(1,'talerebics','2.5',X'308204be020100300d06092a864886f70d0101010500048204a8308204a402010002820101009274cc2b5c26f33cfa521bd4a9fd42df48c3e25a49583f9db525c31d5c77bfdeee727f14b5165fb4ae806f1aa0df51a02f73842e67fb22bff60552a3a9c64e1beeec561529b43f25e9755815473c2307eb4db833d6ed3494145e0accef34f642464beb9244a5d6b74779643931d1845e4929e8e69661778a9cf413d1bd3af92fca6c24f217a3a720337679f1aacb1a21fbbab1a8423a40e92ae30d579ff036f5b64da5d26d0152327ce0beac85a1d0b7384ca8b713db5c7b82332e68632d6319956cb0f84da386553efb0b1ac043e1ec77a70733be0b62d279c1f17c5a60e33ebbfb6a4ca97cadddd26e7425eae1768bb6a9466d96ee69af2c1ef3cfe34e6771020301000102820100716fa7c819db4d61389daa52c0cb9a2529ce171f4959e2043c0fa09db8464445deb8ae3792bf5ea7aad56db8d94bbf846bdc74502157c2259edfa68f7f6b4a8a963755c19488b8b49babb8eada3ef8ff244111608da332ab534f37dc5d96cefaac4a178f363ea11d5a6deab3e6235afc507cf698cb7778c8d322b5cb295f692b6756ef07b3a935576b0ddd6b15e4a2b07eea57701e56b5eea116c5fccb8a8ee1b4344da7ae152fbb0a93b1f53e84447df70ff40076c5d9aad5f10ae120e23d1b0b0059d5ba514a8ff21a96679b6c76a5e2de8291594aca34d137ffdd87add293fe446ae4622827aee945cdc4722473227a4f024ab07fc34271e3bd7a75d93b0502818100f64edef4348f0504c4bd48799d277632602552a2d4a76ff69a6902aa3bae1389dfe3fe4602673681641a8cf70d0a2955c164e1f5d63432bb181282aeb48ed5411d4bdc61184ba1e75f07a5ceeef18c072f7148abb6a65d86a37861b699c24ec7e764b7886e797848591d0bf9dcd71d25f5ca1032093f526ff56a9836ed055dcf028181009838176c9e35e6004c41a7eb79f44f2363822cc0bd7d54a3d58e98fac70b28ec0e76989d9473942896fcd9a24de9f5a167aa44c88a1f4023e11d0a62d7fe048590177c7313ebf2861bf905793ceb38966c5f7ebc2d3d07c262eb48672371ee4a5083a10680e6293a44601f7660a78011c567415c0b06c23a16c8effa8ff076bf02818100cdfc37c8d30ba88ecc59dffa94cb23b60d622931b3d6337470bdd154bc846022b5f2ddfb7e9702a64329512a6ae54c9c431833407cdb3a71ed37cdc27d8dd61a967d92d840913fdd5743f60e9115c09d61b7c3a697219aa5b6a03e578f4f48c33568ad7493af52406f0633b5ca52bc35bad039ab1ec0ae18a38d79aeb599ff51028180672ef6a9f9611de52bcc01d0fc9d609be3935554ddde3c66c697e019769d9902d3170f831a2372d644eb6777bf0b0e27784712534255c6bbcb984cf70de532197bc07feade213e082ca41452c7b9c76528575f689dddd609add642013024c5dbf85211f07fa605626b0121b2b3f8373754b216bb16fa60e4d1972a1d963ef1af02818100cd81d6bb39c32e5f52d0c14ef29dff47b94a4edcb9137f99f770460a36f82c08f7eb664d27df2ef3c69907989d744e9b6865f41733185d321ca36ef14a33cb22e04c0e293decd93b697e7837d5868314db6fe8996c45e33262cf1708e6e99235c6b106213e8fbec26d4244f41746c8d02624645a36e6f2c4ba282e0aeb98d6cd',X'308204bc020100300d06092a864886f70d0101010500048204a6308204a20201000282010100bf9f496026bdb5f879db509bbc5110a233b39b73f62646ec961226fb2375d25f89e744d7df6e259744fb8f36d70e22bad8e0a7203151813359759c028843328c5e87e8b480566ed95e56bd91b5d09503fe019b0f719db801d2cc4585f031461cc56ac9dd1dbd570fc87b8344dc578919343696a645f4ded449dbedec483b54ece29eac39fbef30aad2fd012151093fc958bdab1c34fb53acd62421cc13dfb828973f654500f43876dd1b3c622dd07d28ea7502a2f7b428a1a04cf6fd7905db893994a1af3ce6997010286cb1b04b9abe6145573913889ca15038176e7bad9ccc6eb285cd85d7f11092c39cec340f48e46287f251c9383adaeaa0f6db08096b75020301000102820100610527439599ec2e98942066199cf9cd065c63d2fcc83894c50effc99c14a5a555cf509df43472b7fa675c05aa3130086692a84bb66ccbfbd1c9a869e7d00e21e022f401a0112322cf8f1f804d0c04c6f6ae9d71de56bab9c19f477c1f36f386d1b5d5eb2c8997311892e0cdd6ba43620d7bae1f15c07baa0493640d842cf63bf0e3d6fa59f74ab787a98c71bd8520ba61d26b2d1c60059418415c1e775bae91f9a36996d80a3295ec60bb97a59f8452c10c7350254b466dd1fa17136c3a19e761d44773d0ac506061d6772bd1b9470bb435ecbbf547073241f551fa1062e2874447b8ba1d84945e0ef8b2b1f32d28242f7ee2d7ad9adb114d3769386f51750102818100f34e982fa9d4e04c6dd5649acce5de75f3ef05c480c1030ce3bd52856c42eb7392cb6d3bf15d387b28cdab9cd637e047c70cf103e0fad061ed8f7f22063409f03126c041a95d25b0a77df852b9291c0f8d961131dfb7a24f5ccf092c7c7672e0fdde6220263cb6effc5426fe1a56425c07c4852a886026580f87b98a0d281fe102818100c99e6ee024a217d794708481a0076f37721a0b7a4d39344f4b976d47f473f8e6c3246ed452e733556057cfb112b90c14ed291c86a0a0793ec8e2077fd48ab35bdec93f599bde3f635def77256b78087b2c3d97d2e106c75c33f12e1c34b836b1d195392839c439c086759ead047b82db8e62528c2d85823ba8ce7a4034108e1502818013ad2379974e73e53a6cab7a295fdda1c45c6c26fc129fe086fa64960daf4bc348f7d299aa67538e023abfca2b38d1967c6e7b7f48ce7fd3ab96933d792af432cc86c9bd85a8d6c776842574eb2c7bec7612d0c92bc27a09d903954657ba6c87ed7ff2878f1011eb4e88afae950aaccb2c85a40f50801619c107c4e57932e9810281801de1964b3002ba07e05f20b45974609e5611d81ba33054396059abff9b124914625d96f36eea0728a323c08b5cdc021763e2d0f07f03e9944d8f7a4f0ec013bf0cf0c4abd237092bfff30ab4880dfd2bcc2dc0bfa74c2ae5d668eb4d90deb074803c5e8140b67d5cb450e058822e90015c43e43a14511231275e9aadc349a4d5028180436738701be9d8cebfa486382c77e17d367ddce2313bf6e89f24b5ea070e647a0300b22ffc062ca3cb7e74a4fc4dadba68f69183cc6eb512cc8d9239135c3f91c8325d488eb12cfbbfb59f37bb5398c45cf4bfe725f161a28297d900d0295a829ac910569b146fd080321ff431375649eca535e9fe49aab3fd77511025c6e316',X'308204bc020100300d06092a864886f70d0101010500048204a6308204a202010002820101008c902f9333ebc3535389a793d6224f1c8882955ada65fd516e2fda399227a7f45f7bc50854939c0a00ad06774ad44f69fd4709d002655381607b69487a57763d5539a603f3a5c9577f1c1872e13f1e6c4305b4e1aa4b7fc77b97cea20f4e85771ba30f50a1b6a0fb50683360168d7fdca2900fe7cbe5f593ba14f63834a173ae2857255674934c5523eb361adc143c391c7ac7190627407a9f5ec1044db1fa29c921465a5a9e75f1852b89414e7972e8eeb5ff26ad1f5e6de7c9fe64acb98ee162c72bf85804a3847f0467083c99916ac4d0d7b78f4602be0325274f43f3dffc84e02fa76b99575bb1ddf4fb7d8c2123eb314086e690019e61770b8dff1c64ab02030100010282010027f51cf1158361c5202c336cfd2447a4eed1602fb181e89eeb59c3093698fb4fa68d0297b9a3346a4b82e421a92ded5d4dd891db85b2d428250b3004a07298741af406537d419598bfd376c7c16c35f3c4a1aca7b1c7408dae7e9b08ca9d21a7983da42ee1a98edda21fdceae5be57a89ab5a52fd970877cf51adc5b61eabb7d4c7049408887e27da997c5be2551f91cb52948583dc434b56da169e9e0e090087019bfbb92ec4be04e998636361f5a4b72b7547e272da3a6c8e84e2940bc00ef99ea5a8e9217b3093f18d5585d4a3dcb5183dfe3ed175d0de557a7e362155956e002c87d4bb2970b62e0c5d4f270bcacfe02b366d432056de9615f7172ffb28102818100cb8c5def3c765e0b19d089cdc5105b22cdb20bcaee46520cb81d5309e1df6afee654ad1b2cd53da8303337c82d9580dd16a7ef27843ba374ea494684509d34a9c16c58fb151b32cd00a2dca7c62841071e3b962def2f0f539c2970d365ca683df27b3a3baaf62faceba86217cbbd7e4324f5e8c6e49de7795e8fd114f2d3a98b02818100b0c8d4f7e3ed9e8a832c30460324c519bd439cea77ad3aeb14eb86809b8dbafd0b0effaeff1144a53316192336a29614213af3ce8526bfb8a559ecfa90dc285e8fb62b7164cb4dcd09c57d0f0cf4cd9b17af5150b914c00f982ee55ad58cc528e2203ed362fa74f6c794ca8499e6d541dc5c071155822bbbfd477604289a5561028180325163d34546199f72e53b7bb3b0846709246f87ddf9624524aa93218945dac4629a2224eaa35857a07ab8da727257e5cfb8fa04f1ca7070f18de5b1c5dfe6e9e417edb33c177a2a7572cd4b6850012b4a4cfea6224fa6e14b646f30c324133ae51b935cb6b99f3587181c0fb7dd033e83ff8a68c891446c9b74c00206b94e5b02818051caf9ce1fa4e73f8ae53d088797d1a1d111a15e5234d217c63c1aa5125386fa60cd75bb0fc47b903b8cb3e0b8fc8c978fb068f15a65cd3aaf366610a0495c5c33fdc327d9ccbe986936f85fa84cf37c187f430e2833d390e3867f1381ce79c22aad64a4051d8054558f200c2df0c12691bffa7d28a4eb7b34fa853df35344c10281802f0dc2ac1feabf84fc80ff064d4f5b216cfc642c35703068307f984c4682cf33885f8339973faa48a0ee75cd4601edf4aa4190ef0a78cab6802ffbbaa88e4eebd90f23bed7ec87d12043aee4150aa44309de4ecad900665781420bda250558feeb285f5cad6a2042e208b2de4592514cb82ca681e13001bba51940b41841e88e');
-CREATE TABLE EbicsDownloadTransactions (transactionID TEXT NOT NULL, orderType TEXT NOT NULL, host INT NOT NULL, subscriber INT NOT NULL, encodedResponse TEXT NOT NULL, transactionKeyEnc BLOB NOT NULL, numSegments INT NOT NULL, segmentSize INT NOT NULL, receiptReceived BOOLEAN NOT NULL, CONSTRAINT fk_EbicsDownloadTransactions_host_id FOREIGN KEY (host) REFERENCES EbicsHosts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsDownloadTransactions_subscriber_id FOREIGN KEY (subscriber) REFERENCES EbicsSubscribers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO EbicsDownloadTransactions VALUES('2231AFE5232A661E4105EC13CFA96265','HTD',1,1,'QSAzo5xnz/01iix0AmCJK+myzTETNW0ZBBbN5N9auIQecR5daQ20wn0gkqLhMnuTAZRr1GAP0/GM6qB84Oe+SlXdEy8J8UFmUHBOQEZcsIxffRblmHhdjxrQj9mMzRyTyliHPbO7+1K1sHTTtxSg4iI+zIp59HQL8Ug8oImxEZL2TCQjI77BH+yZ37rxztK5+vHmbVwM/8ExJco9oRmdRjWzv4JveVJktxGbH1FzuiTiby/OPZ0xs9AmRSp3vOt7unhOrGiYemZg3X4usYtGuXIUKsxAjgAOP0kw4nxr34JTRORFDDKnvVrxZX6hXWKi//cD0QQgfTffP064Nh0TB59qQR/hPi06zMdnng2uqO0947bZW4SLww1h/mrI02ZtiAzZJrRFuRu3GFq473q0JwntdwuQ8AV3Lu2p5jRBraw2G+OlbdkA0ZqCv8opH9H43fdTqe8AaRqdjOisOEnwQVcsC7/ClIRzH3kIvjGbaQifPin9DjKFy8+OyQrxkaYhZ7gf/AH9cU4iqdvqcZdEOgNYns3v39ZiQpppvvyyrInJcGzfROqxGA4cRLe82esHWyv3DP3ui1oHsZcfIc1nRAbZmXly8xiUsnEX4UKE687zhwgvGBWE2XfJ74qv3qCCHNt3kaa9Qhvn9fWHzgGbbpZS/v0NBq8nL/ps68UroWOgDkZ+LH0PJkKJKWf4CN+le3HidTyRqXOccCX0/zwgnA==',X'3c97d5504fe1459e6cc16eb97749a3ee1d117a2a4966a70f486cc5301305e4e50d8ae10bcb66daef611a15614953584cadc6421c612663adba88da68837e0e0d295d9f859cda6feff4673d139da15de7b712f2add2327aaf757fc64a2d7c51e5d8d8180106f6e632a8566b85a9938b987de10c29448ccaff248c15f9e487743760163717b56ec99650f6a5317cff2e14c3e0033ed584d03fa877316b125b83dabd4c164b2e4a605ba6617ec11e9a1722bbe64355852a6cb9ee3d816886fb525c8bfd789355e6a2a03b4303ab7752dac52f2dafac84d4266ae2aa66b63f055dc70cf0a98aa45a1924a32a4bb3e6adb14eb30ad2ebc04fc722d5eb8283ed5f07ce',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('1FEF0E8F67D82254AD05D1F7961149C8','C52',1,1,'TCoZrEfB6J61DkOIguRh5mnDKpUMVreNSfECcB/9y0qnlhf6vHCZZGSviqlYawcNe7kTsM0G9rEjlxisZwXDWBgC279OkpJ3vQlttEfl4MV1FOYpKm7V0gIDX10c4OCEPxLAmXPv7vtEWfunrViSJHGkbIYpB1Z+l+o7aXSfMgDVd/y8952/iVuzu/flb6WExS3CT+k3wT8l4hwPl4TkoNDsbJQgmsMXAgCYOq0Tpz45/YOmci22gazixkCBv57pq554+wCS+Rm/nR9zgpUd1ktSns+a1JhXHc8UvPJRxfLJ1hP2E/v7l4H2yjQ4ByPTdaepFcFw71AWu4C8zV+7zjJE6ykzwNPv4mc1rU5Y8opWbpRjl3HQSAngmgeWshP4+6dKMs89GNGjuTwsrKDZpqfa0pUweX6Q9uFTR9uSMUfhju2dFzwGxnOBn0JNQkK3i4WPl/puSkxq++UA8SBNTcsSoCZlRuWp+2kKqh3k6jaIlctnqKab40h7cvhedyiHu/bkw4hY+/HTlNb1ahUSF3VN9h9JxVwOjD5m3N72Rcu2w56p+uj3PznCkcxBKCfPQb6zL3UiFcJjn7lHuYyABSWSoCreUxebqKmm8uuX2dbI+FzyjtALshRYn0QxB06XyVLbusnQrOO8JF6aD9BzP5QcSoDSPEfY9ieVvXbSho2t/X/I8irY2tkyCklENCrztiVNLB/fE/r9InwCbwSV+jHfWPfqMliZkUWjHZq1aCqcf0N/YacyOQwmYipkfUsQd9mkghWEmgxlJIopDTc2YnFF5K9OVJJyH66/FladpJW++5Zb424iz9vDMZ/nDR24shCOVKcPFPtHPi+7b9I4bpArth6x6JsX0IAUBCZFrpA=',X'514ddca7663244eb0587c34eb83b828581b991eee3ba3674c19be46579265fdd49289f8e15045e7cf5b4e20f7c68f30f686b5684a166451edbe3d7a99c0d976d7132768718b3cb56b9a57b3e735dc78318dccbd5f798bb64c7bbf257ed4ec5a900b1e40f9f9f845f12a6273d9e7cff48a847a970c823a59edd029e4437ef1751b1dd6333775cf07d1b6ce6c9e73e7a7533e0521580a4ad2abe0ce53f4663487bdd6cf8c94342387035994e11cdd477e505625cfcae721beb82ece851959934570a7226d3e5771353a985e07db9aef72c1a5ec9a91e313727a713a79e7bee5c073bd3c8dc5c6840effee2905437120daa81ae5386b2e50e0fc9fdf4462019d3dd',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('C7FA37C207E423A85D26D60C2D817F95','C52',1,1,'ApRAAaTRVvKBm8oelMPn5ktIibp+Inyn96reIqB+QuQW5qieTU+8+abgAzEjZuVMbWdXldXNI5l16yez59cyBCUiNV4Uy5CMTI7w+ZM3WRF8b3xXdahXI/8LnoY0kuVSy9VVnS1i/bj7KhiLTYl7FjspiAeQuNHUUoQ7bpiMB2Q18vytdln2PixMMVCrv4i+YSheYKt3c+3llx5zgTUaJi2MUi532U7H/BZlxqNbXdFOFUabLk9DsIFpUmDxtlyH3WUHpgVnaElRVXEJ/C/a3Q1UaQDAThz4tvxsSOYXrYJK6XX1G/nEpQ4MWaLr9CmMDZyorg0+zMEDcJeVAX9H35JoSNeX/hL99tsedknH8ejS6JtY0LpZWEd0vXdwXxQxvFH3ovqzmdnIdrmXrliTHpbU7MgIm3Wc573V3THCqyqiSBfq47fMXTXcqapqHHfgdfail13A0KS2+GTXPXGRI6HMUr1phB4xgG19y0ieBshJVm0oRaiMJwCRWNwPLTY7lLRCH0/Lxu6qJRhU3Yuq1WxJ2E8Qd8OgViNHK5a4Fshk/ReH1RWBz7sGUn/Vh0iPGALkWAokg4JkkIm/FAmL0+227tWCIAlbF1ata9p3AsylIHfYctZAYI0LByf0qVMJz0A6ctcQyQ1YX1QIDbh7x5W+zO9J0fDrT0Kak1C55aLnPx02E9SrSIZhiP3L06+H1RmGA/ryCBXhVN598hOpqq7Aeo3GMk0MXzTXK1jE4DTnDzTwMjxW4KX3cdduSLkaCMI8sPLAwXJGhaxEJFRXSb66uiTuLksSAuVa9XZPqW+LXAxdDgIi+7DEOFyX82Qqd7v9Tn7wqAo14zLQEj6Xje+sEt98apj+O3sJZrQvo1A=',X'88575a1c4e833628cab5914a867a387b03b93e214fa2aab1b1b48b609753e28b1247256c8abed68fc113d20108eac9ca67ab3298f791dbe6b9730a3b299e296e96066f2b86afaf418e7e9a38f717d17713d94f8f8f51a225058d8066ad88f1bf9822ea9ee6b93d594c2770b1e975c6e097565d9f090076e5707a01f71a360ad5f9bef9811ba4a7f45925bdb741461357f2b68399bf9ae47b0d6487f21faa450f66eaaeefde5fe8101b74f88b94bb742ca000f1bd76e514430f56f2875520711418709e0d558efbc5d811fde1f43b9a458dcae34a9f7fe8db59c46047b8d54203757e69caebe4715f37e06c148958802e92566f81fdaad3f88a7f8fde5f813734',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('22D37DB11D4607CC231B264FB0EA48F3','C52',1,1,'a1vEL3TCa7q1NRMFeXCQisOPdBH6MPVsIEY6REOPA3di6oeof1iM8qw7QyQ4SRp14d9ZtsErC2Cm3i3Hm1iUqz1k1qfSZf5RqxHhGWMAS2HJLnG6dgxx/GslwxX1qjCUukeIeas2VRPaYsxrRXeblRowu8pAXtOo0hyHm3FQ33M2PoYeInd+x56lxIws9fS1z/SG7ThS6s49r/td2lUNRW8zcRFu10peQOkwmjg+6bU/xSvesh8tlzkLZ3zVZJU1ZYAHahOGu26wgGiKwiOH0h60L3Nr4s62EKiaS9Hvs4ZJJXDvv+1cmnHRw97VuNR3tw5aa03rpyeYy1fxAKHxTznEHoiMMScVp/3e9hzDSVdeFxuSPFu5hSWxuUguCp309m7HDNVesPeAWrMNWuUSdM+j+6FX6yPByc6DjQSIUhH9IhsMqNShi40IgmTm3er4pPf9ryVUZhmxRgn6Pajfhbf3eYcvvFKwx19/4dEOJLSa3iVVnNbwdhKi/UluGEhDjS7RYrHNFydpgv3qPw9/T0Vgb0QHuYKM/Ir+5lUAagXzu0ztdN5JF58RIsQAd3AeJsxAWOvAuE8Kr0Mwi/1rYvThLb7C//+S5hAa7qQN/M4UeA4DeSdpSU4pbjV65ZrPHnUh6TzJRK8Bnu4pFOEfoCyLEY24kjdBRKb4jFRN7bcyzv44nSHl1IUmQje8gLYuXXU/OsPMGPxurl/3Fx68rQ+/XSK92gUx9uteRuYrXQBsaX1+uOFTzhQyleAAJuIMS/+lmsdZE/pzLlC3RpZRDzMGlO5w4siIt7uby1TYyu1h0n3BM5WyFmkaltZMM3opGBqYHdn5JF6SGgBR+QePR7NUu82Rje6sthfIBjrO7SY=',X'1b3dde2e3f4310691c9513237eb1ed03991cff992bd0ac9e3097181d340d6c02dc64373411cd77d0ab724cc947f8199fc09aa7e1272d0e7babaa85d649f0e620703377f8f80ebbaa32f11eca12fe5816bdb6af25e755f15d391d913e360b1adcde17322c78458f48ef726ad58f997cf5fa29c9352ace5cf04a952c917b535e36204342801106cf37c79ca5778ea6f394d06b28080451b8898e286a3e12b5abddb02a0ee8e292a0348832e4d4b4719a2d44c04b15974463601cd27c0ca72391d4729d283f9483e7b5b54a99be1e252c1d217c4a5ceaac4a29ce80075ee3fc72d697fdb55715b8945ffbd707051bd41ab79b4915959173809fc853001fb0fc4791',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B667F1E9438C075AE724B2098DFDD8A9','C52',1,1,'8h+i3ch3Z7bOo2iPDYNPmo0/a0iGpzE5S7eCs+/xAp6ouj4NAcV7fb+IAAYuvpyz1s9KFmYah2ch4Kpc7YjSkQ/noEO8B4LcAzVHAI2UTqL3/UYC70Yitwz9ran5h/aqc+wU1eXio+TOqo2S3o5ORJDHmcDOI8QKmbWPDu+5R7sJreHHbKYHvtzVWUnX3SHhcrMW13ERcUUZJ3qa4b3TfA6mp33PWO/KxvaRmZO7+9S6skVJ1gpLEXuMf/SEyOBAShT16j92u+bfL/aqOM7kBoC0isvX+IeCggD5+lu9G9sfsew5j7HHiro1PIqV3dxE+PbByXYl6RZQnX7vmX+ol98R35sy86qle/QtwcwIAxmL4+gvd5qoxF+htdotlwdDuCS+2EFh2TXHftxI9EPRqxLSi0hTq4UP57cRFAagtDzMg/5+V8H9gOYdAH4yBiNGooAZmslmBG9MjS6eEAVcVCTYB0R0boZFEaZ/nbLYItcKYgvQf7H96TBv/zg6OfSthp+bZlgRmrdJDauSAiTPLiYgmteikHu1wFioYUuSCHD3VnQZwGHBIFDTN3E2CBQrgWKBFVYNB8q9HwzWQM0NVkLKtWHxNOnGUHH39mJ50mF0iaBMyYPbRz7hkozuwGEfF+1+8BmlrWJ4JbMiTCWyktINZEg8gtQBVQIgh/hQTVCZh9ajMYKKurQZOKYMT4gMGhWyx1zKDQm6SImrxvWgqFiWJnYwuIdO5zfe8boehRgPTH9xPVR/Ue3IGDeEuHAyCjl2sUZij9PxOGQsqiw+3JjWNWfTD6MmJcfvolZx7XqWcfVhG3hhl2Ic605cPgWdDTOpGSYUPOQ+bSya0P+zZFli2sbOisKMNHkCBQPaTGE=',X'1842f4ca68ef1d70249d11a8b0e41d88cafac899ec23fd3868e04cbd9ba3b3cbdc2993043be4450af7006a6d2ba0d2eb47f2339ab8ca4000f5074a63bcb87f282b4c20f49e400ebb9401d53f6dac1266f8c8ec82ed01e8cc8cc72740d5ae454750538c4d403ccdab5cdfaf916908e1652d390c3c7df2cb193d779942c6b8b54c61cefde9d20421f542c3a8fb11704032d5a4a6f0cc2be134f0f54ffbc383752a6b55cf3beb29a318df40e4aed1c78c7232b83af39e79ac7acf5a84936507b5ad2d2efad392bb68c14586c2ef3a551320f36e260a7b709996801bb711ff3e068ead7976b02c0a14f7163e50ce161f5411e8faf79ba24f1bf94020c21d496ffb26',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B7093B4BBBD758A85C9B046B36A4515B','C52',1,1,'fXRx1BdcCfqg7zGrCYsBNm8PUU3DM7VSE4fFIJZIjZsHbAz3oESsj0RMbmkXQWCI9Pssp7saDkgL7bV8oH+z7rzJoqxql7rqFlgqY9dDfNyhTL82VK0DNzAs+v/WhB22JRTuM5lfzu4lukPYv8ZRpy+9kwdBGQTISQ5rNNtmoCJqz6uWm89xEElAKlfypTJvXOE11fHLR1iQzL/3bYxP16DpXoLoxchReW7DFHVj6gWRRs3K1u/JsTGxuucMq8kwVeN+9ZyaNVJ//7cHxslD5GXlAyQd1tg8OkSRoDwdbYJWjIoI462OatL7tSVQXDqt7TMejFx5KsomTprjyn3h+WLNOAHpdf7isN/swa9J1uxFpNeSzUU5tgspAh+nP0Z2zy3zuDmT3VrfRo/uxYAknv9zb8BIY2EMppRZFRjehgS8LlwXPI8T+i11wk5Ytkd2NVeyQ//LgkvjO6hhxPrWAVjMd2QCyPrT1AZwUsx3sLDNQPqDJ1w23P2VLMT7A3XEeNkzkgCnNUs3foNU7e9zLQUc5J90s27cEyZ/HrlXNzrnbhW8WU8jY0yygyJXivf8MCH2L5AJfQgRQv/TgleZdTbwBpa1t5gA0ZafIJ0n6wJwxGUxbKf2QFIHZ6nT2A7yUSBLZ51/fLboAjqJaTfjO8oDzPQTOmMVbNKaSAJx1HLny7nVZgau8pJS1kiO//K02QaiVt7adi+NWRGY7jsUZ6GjCUxHo0ldE4cmOnyMio8L4z8gt0gOcnbjUXN2Cftbsn8KdePIeQ0xIxaAsUwvw9WOsVOFCMn+yRGp/Tg2NnqPZ9qdeORH/og4ape+rmpUiSzyYqqJh9P35h/ExRvLe4W6G0XnyxdIMuuQ+zyDehw=',X'73e4c9afc333cff55702dc9efa179db3ee92c616dd1bbd6133dbadf4b354dbbc5d9e03cdf3498a4e454f4a05b76efd12c578b33cabf658788ba5f8cbaa3db24af2cf3abdd491bfa1dbec8cba906510f5d183c5eae40c28677826f8858f54c740b8e3be0a3cfc78565cb053a851785be208d6dcaa5d453b8bee398cc449993640cfac5d63b1937acafadedddf455112f5d2fac5c1db1423269e778621b2058c5210a3dfee865753639ced2661d9783b05a630e69dca44d6e78e94c286d62fb5f14219aa01e1e4bdf8d7a44e73f75ae5cbdf63375bebafd75efd771c6b440df7cdd5bc718b9561a0a9d95679ca7ac2491d06bfec36b6024833007bee612c40a832',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('3203D0CCDB94928D46E48504A4A37260','C52',1,1,'j/9+7UkuAw0dJQUQBPpe+0SmPnhOrcEKe/Wk3KoO36lpFZgtUwBDnOfF2z5DnQQgEvzh6YLEQXC2XW3GLAm3+20fgFr0SdigMFI1ByQ4zSvJBmTb+xdEgHUZMV/HFxHVfNpG2UCO40S1nIwuQATNuFPIbFtFJcji3NXZ9z3+7vjsN8Y4T4vSmM1Yf5Q2E3xWse6n4Ks6E9usDn3AIQ0AHybSuj5BlZxh0QDaOGTbWlkICpKIsH+CMqFhOQD0LrOdTOlFkhJVEPKZOYwfOXKzwj9oGwUu5OWLlwQXjqVe2WRmnC7LAz1/HOevC48MGPcRWHnIoz3QJFIsOfiSDxMkc61ynD/8AZWto3JQHgsPHOV6tgfo5o2fXZUYnlVywKaStOTc0lcSYxsvWMTxC0Rdg2sCzmolMqU31z1apcYlek9bgfI3Onl+7xudv60AbmwCCtMU8WNCJvDNylorASwp8l9zZeQ71g6BqZGa/v4pzgAMp9UO7OimuOhAqMgauVhk8nzUMLk6eKBSRPeJCSEjezgmo9BUJtV/YUD5tzazUA+kW71AnluMzq4uQjj47lYA3jQUbMt2fpLAn8x6yOnAdDpu7cSodYinbkP/xY0L8FzCQxfpi4e/tx4O2KJAAZFFbGwVlMuSNmpIiQxld/oxUjd+QKUxDonqpxlU6mlOUtnX8bN3EalvpqQMtHFZG6cXEm7ie2+rXu/AFkSJnHB+qDnvDIOFDEJSP6N5lBmEXvwZFnq+868C6jvRVHS3eVW3qEDYnFJjWKGwWU1toI3ESOhuob/pFDYDAp0+DGX8uTDJwjGyYZu45Q7Cgwbh+oE7HofFt8vKnBVd6gj9+y1pAtaW7xQeYyQ/TDG97BNDY8AH6y+wuK3b9aRrYCjyRi+d4WEX64OAIJbHlJ86pMoUSY981xe7Z1sQObwXX/yM+s4iCjtkP5g9ZBR8S1xcUT+HgWXs9hFV5cmaTa2M8rsf+zhAjI1+qaHRfuUM1hW6W8/M1Qyqe/kn6V7MtToTOtCQojC+whAAbvxi6uuV5jw1j3ttYqXtTyLuRYrW6dhwH+wj9XJd4UN1X3sJaT+HXm0W+hD3wOjlyOAH8byPofawty1jlsDNH6viOXweBxypf/YVTEOY0JKtryqTjvGXXh5Uny67J7F2u5nZl1uhCNiopIMqmYlrIMhGijblye0VJDgK8BKZuxwSUrN19+Yu1XtwY9az1p/NYWlkJZ3I2cLL0X24wWIHrS/jqp7HBmBkAt/JU2hxJSkW45iTu+etD7ZObpJPeSFiF2gzmPD9v3BWktS4kdfN+9N8cqoCT57p6tDK1OtaRVoAksa+hE2xuw5PfwCzpufsuo9n68lNtgtvvGEgqC/EMRq51HnRz9rPGiN3npO9QQiUPOZ7Sgg3GQLBdXEJZT8R/kXrRNOxfd/Z2JKqsABPMcm/krRPGheJunFGUwLxbLpqlr5W4NrZ0qET3aaY1NRIjhbjq+nsVIHeZw==',X'40c15547dcd913134b1de7237565dfb85d0dac6d2bce715a881910e38d2de85ca78b3ded305f177feeb8f5f011b53f70f9572367b6a768f16659180e8a09ebb2aa52e574455b90bbeaffeacece1bad03e2d53ac70a52de0505b680acad99182f41ef6bf79b17ca1dd7cf8bb6ec366280945cc905e2f527699f71ad8c2b854478c7c3b08fabbb0a5a317d8ebec967c70eab5081b02d5a99d3e1ff7fe5778445131bf1026e16be1284aa23314848374397c61f900de67dc84b5087d71012941b5f734489bd2d03fdba7ef6f5c78aa2168936aef39c992441230de5255d20f8f801714672fcaebe07968bc03f99bf5beac71b0f60bd3dd77eb924a64b383126ed96',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('4EEC55CF111F83DD2F6AF2AFD38081CE','C52',1,1,'krjpmDvHvRBF/g/bSSiNdjWktYpnXsySWQNukRufP7WH4s1dYFux5jcDsoYK5EldC5JfQ7FirVWnqdArRtR5hBpMiRr4tk3JOA0KmEyCvwrIIsEbQXTEKaddy3+twSX9cBUJsMD9VyfTzgOGMuF3zQSMYBSIfAXGG7LH/bnc47j5hjGuGjI0KWP4G44YXVep+AoP8PHWn8Pr0QjoWRsack5zRSJVhRXHklLunM6sZ5r0/V3o0N2QRUtyAFgwE01VB4DRZ56PJ+Zw+TW1KjJXHVdJGa3ODaBtfNL5WE0dR3KLY/OOqB8K4kQy7bHwcVFilSzRV5L5kFjGGeGytRu+5isjC9oFYBFj0oXhKcJxDKJIdYdLUXmz8TNh3b9yxDKNZXvl8UDksxORiAurjqLQMf75g4CRFBKrd2n3fGhkgu1WNOiu0qd6PLb3ymrUfmR0kWpkrAwil39807JNX6ofBwpiPcxuG1qzD66IjGm0Rzc93wsg3dQIg5KRlH3kVq5wewEmohdWYyxTqlaDkmSb2/GYhiYCe9aLDoqgKgY67w3H1R4o2/uMdSUYagTluZcSRHvG9vRh+SNHcd3mbxpTWZ9T0nts+OPZ0sf6ry2aCOhdCckWzug9qyE9jwhd8Qk9JfohjpfTdVk+PKs3s/KCf7Fkt95FOQv/UXJ8xg+awzpORdsq0l+TdksB12Y6qpMjKyXCGrWY5H20YNte+bmNq7/DgaLr8snxIqTGTLiwOYeKInaMETjWdajy9CBt0foaQrppL04rKQzZ6W68cl2k2ktmuX7w+7G+J6jOr0IitLekzgtjgDtDXyvgIspNKmUqwxbQVVQ6hlv11U0JJYyZNTgmhC5mU/OjcwE3ZI2XHrc3FUcPtoWQrTxbtBqQ6vhZ1CvOUZzy4h+9/unYZ78IJtWK+BF4WKfHcqi9pDEsRacuhau2wIAk8yt9z7oIJF9DPx4nEtN3Tj7rcjf8568IlwXslagl/giW4oUhw0KSYBRRia5zV4EYeYN65OiNRGQAnqlcwZmI1FGnule10/jMhtj1pitWMDftI6T7WUZXPU2LeCXnP0PniiykRAlh3CJKyDDzTmBALKjTOJesyUxFJal+tGaU/b5gnw6sbNrZerKh1mV/4PyaeHXptIu74wz6Q84K2XRb6qRZpVmFrAoyeLIdpqVElfoD+0CepDU5/9Crr+smYYeAvMPIinZJjZFAPDqKhv2XJbwHpz0BYhzuH/bRYltKPMf+KAk6cbjT9Eqacjx1wG2Rb0syAW8rQ0RQM0vLOqsOCCCoaSOMMNa3tcEFpKhJdWBpcflOXplhF/9pE58pFW8oTR+yP9lDk2tsaTQGdxl2IkPXJBCUfAAWsDhIDvwV761LCNOxld73Ymuvlp8jZRYXKW6xIHnVwNNXrpyEFDWAzrStyeO8RUHI7MpqFdUooXGhebzIND3EMx4FFyD7z7YKuv11W4g0PKz9y3UG+PFTuJqb01DdBk/7GQ==',X'152248928391d339a6aff494c8a8e6b2c52cca89dc36ce5fc5e4bab38e7a6aea962bb6e62a108d8aa7837fd7b27505c74e1f246139c63a904fb0e46f7658fb8717bc6bcae662311c86769af3d2342855ab4c6f54533c6806c0a425cc7133891295c9a8b5e98f400cab68671e7327951c7b4dec552486aa17a3f59d54b1cabbcfcb0b771e6af60180dd4dcb346990427c42947897b23d3b9c4ab385ba8ef9e12bdf0676a0e9aa65853d738f792a9c234de0936129aab5c24df7b80f2c1c365b3ea27eac8809cedfd1f5a18535c2e3ac9e446b63205bff8da3c766945fa3e420d7da3e9616718a2a3c3140666672c0cf9afcbe7025ee34b50d84c6f2b48a631bc2',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B966F48629C273B70B4E86083C6BDE57','C52',1,1,'lPKlp3J1PJBwpZgnULn62Mthkdo/rSDISfhAZm9yGTYdESbR0t/Dn8NMhidMRDLTead4TAlqTOJ7UMByXLhS10z+6qhe3E/oIk9Y1uFwSjKPWgZ91t9MMTnnPOKOPOR6jLFUhjOzwl9dcvmNqSqdiQvEkNNUMnJp1ya/Q4T4Z4gJB3gGdiRi6b3F2PHywu0KJeEfmORNcLlnX8sxK0VKf2Nlq7aYXbJzBuOHuPSXqh+tuoi1hF2kMTF3EkEd2++nf7xOiHl3G4Q96n7Vao61WVOvJcMEgKOFyf+CbNxo3mOzOPffWB7W71ObDPIrbFuJ2FklMbgBsL3vGM30G4uM2qs6AuP/f1lxwBotly6fUg6rLGjfDNFfQwD0h8UxYkD2PCaGBRZdS24bUMoMkMrJWjBSGSE9I/DczeE1DTTDe7LciABuQvTEulzM+Wc4UjixCqJA/wSg4r7p/iUIGF64YGuXLDD1hG3OdTdXBPQzY1L62JC/Od3g63Qf1m/teFr0gEnlgIeRfFf63w34aXCyKIxBqBzM+EZuLAVML1fKvaR2P7ULb9mxzvhBSfgejKiIEGCW2arGDX7vgT/flbSJpFJtHX0G7ihbAfAhIjOPeiOTEfZOh09V8ynkIz/OVdlP2yD7XUKjN81kxsXh9SceejhZtnp6M14xgbMLqmuBJyyeh5xblEse7PzV30adQNPgVWOYoUFVrIr9zRAgypV8i3cdtlTLobUGmRqSSrleUayQCmIxxl7sBTA4Zl+vgMfUkX6vdfxgt79vIHCmXp7r+W8PROQGT2IRw//FqQuf98m3N/wu8LFLT3Z/d82lgwcvCN6WCP/7FqUHpHsXWiztS2jAmvZz1vRwQUKZOUKO/gQ3sZBOBezsTkHzJIcCqFN+t29hhLcEzNnzj7QEYkKtjgWUdPO8owU8XIE2PTDwup2i6Jt/uSyqb7hnY98HRt/5FtGrDcJVsjgcOQI27DaxvSNXQLTevVL5KxqxMxHDzN0fTCUl2az+wN0CTR7QLquJ8dYoP4B4MAItLYp9By8zSZwjAjkDQvzXcBO1d2F8A4rkBZpx/55k/3/hSbf3dUa3kE7OvTG1yNvZ/a6KHnjhj56jhUStcqewByUuaGQ83DdVkkWUdOmMiTA8m8zApZ150k3D9oRdsCbzQKez9e/ix7PQtP0tlJ08m+89i4tMFWetnnUPMLEnzccI2cpHPFrJWMdg0a6Iqw4uxhodrBwUvLjzOaBgapV5Vo+m7gM7wuYhAke1tfoZco56JidcfTX32U/Rf0DOSRV57HbCB96TYWPxsvHVCnzPjHmdJ+cQ0A2g2JvGvifZbyXmCtxJwgj2SnxDH2rsEL/xxs0eBfLoMZNRg5roeIdOJvNtTxdu6Op08u3L6IzWl/WLonHpgjv/fDpv7Aqecp+swqnGXcC9mlQTeNWQe/nOw6h25cwrqhxDn8CBGiETsBq2ufAN20mHiKCvjXzdoSCH0X/7VAUwNw==',X'848a9f657f95940cb3020547d344f9a9a6b23fbf2f52fe49138e83c40fe4ef781101cb4ea9a206720b7669a70d58c2f1d2c1a941643cb3efc62f8d901c190e5ba378d5348df9d92794e1343e20a77bc1f129089d3d76c7bb66aa1f136b8444978284bd260ba51a9ac066eeaf9cc5cb3dfc82a3367a770ec7955bdcda7a38ec1e386509744f14f3563557d393f76c724d742037688c0289cc90255cb17331b04f5739f83e4a1d05156090797b9d90c5c260bc235c0fc1f9c9b7be20b03fe61b893f7fac1b0ad7e741b559f613a2c5d037a8f5d24fbd9adfba0c4403114cabffb1bd90c15b68e6079e7405fc10627e62561289074a652776189bf4c85330bc6c7e',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('BE8AA44861ABC2DA2C832DF350200610','C52',1,1,'IH4Hy3xXGKJSyMckB9mOY8JAHdXErG5EXiWV8vTdrRC/nCPbPCW6rZHyZRsOoRuAySDaAKDzqvGcb7U2cN44Fo6yq1A0QvWlnaoQrx5/MJc7FyyLzJEjY4UiLXHd1+x2HCMku+JSIvyzm/79A7fPk0xwChmroxWaOvV27IKfXvMesChf+nFpxyKfaC5iyCujBrjEfx9ornYf3zaQkyOXlYHOmqjRFlRsJdtXM17kFgAht6sfwZjH0O+z1iS4vYGn0+Sq1LEIS1pT/F9YtCFVarfA1k4xqWT7e9bAeNbOFfIuQECaZdviLT+8tDCm96xDAToa64fhTgUctU1+GsiyU36sP3xVBYp+i4D9ujhkfqqQuq8FvVaRxCJnF602HCXVoQkjgc/qyV8LTr9PbkFmYkKC/EltsXUdioRfY0J/CpVQch6aXHO/iB1RHk8nWzKdXhhhyGtqLOwSzR9uOrC5iMP+bO9deI52djlINd2A9Ods/8Q+oe1aGSDcaO5gbYX+jZu7stigKYHDFJsENwg92Inxq/iFnsCxvZ6qt/7NtvO1Y5/3qvGti8R8qJtoUSRrC1PDPiZ0V3Sx7GwYpwG3ePXSOY6cDj3M6L3OVdK6DSQxp89PuEYe8MllRLBMiOgSUaaNnCKyQSstOIahyWjvWliGyE+KrqalK23+sIOzdF/1fBazu6UQhlC3lUwxyAxP6UeqnTDdHwAyQ/9f/4/lXESxcirT3sSyn8zBJSk19j6NEE+QiOlh9zMQYNsDUaoqtv4T8X5t4CGUutKHDSVlMhXC8qBmelWZ6lcsGkXV3GfjGbzuD5Fd6eaV/lEjlBokP3zqPZZRTA1OgrObiJrkDLliCqYgCLIojlMzAXuxzaanpIRrP+D0QGrYEmaTbHOXLwOSdQ2LiG3Y+h1Wo+xpPF5ItIrqtGRmsEo56tzbY3XqqY+KibrOzM30025uNhm8n7NQ+0D3fTWRikuQFYwGE5HC5/AObSdcF7okU0zz3zdUagaOgur28I4cz4yGSnEsdw8bG4Y7FhaTAhesFLXTOqMLTwsDQ5MqnjPRFzCqpDbSerAIrAOOBZiyhsUVDWVl6gNQZKNEfssV9bZlICRHkSaBIeZ2V+P7/vQS8NINt1h++5s37MUSbBNzeGW4Qxqvx73MsMHIenQNZ6i60IcD+PbQZMpx+N1lpMiktGwGrsRepU/rLYUDkxspIwUWfXGv24s1RPqNu0tdz8rA4ZA3YeChCeeCKXwEDvcCVhpSat5qtexzLxkwzIIzlr8wnQMNsE09Mjt2RarGGj3IIKl7dOo3OV/mhhdcgEkN6jZtIMghUeS2wg+jwm+htlqqDSGD4Lm4AYi7IJ7AVBOiWzk40q5QqoY39r8kJky8ZwooCGO6MG+gsFzCbom0B63kG24MRF1t9rZ6Xi2gKBxVgMBnmfleqoFEy01imCcye1i0HD2rG3A+JNsSuOPZPziz5OUrjttqrLDwZ5kD2tJnNUWs0g==',X'23930f63b655a7d12f61a0e8a2216784415533c36bae407bf8634665005f1974b41053f84b205af61be4ababb6e063cd474d2d91bf6f5f0eeb6d38b6aefff07c51f200ebc00f600fdfbd8c21987f1b0d9af49d8555fd3d5d744bb5ee6549855dc21876b6901e7ab06ec08b96292d242f6a6d43b04f89d7a78c7079119aae4f867a59d05c7267e0a9e2c5cdcaf50738636c55a0073c1504f9b4cd165f7b236a6e21a8df85a9611f382f73eee392846602426546e81b25a214b1756a626bd121daf04ba5353363966d0d77e63afff0ce237bc15788c01834557eef7e649dae75da3ab07c5f4d89a77671e1fb4ba89e093682983b793c797896880794991cdadcaf',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('661BBE0989488602BCE5DA3E2D65B488','C52',1,1,'rpmzbruXrjRQ9dbrq5RG4gjYQjqPs2LRtMI+EaDv9WhQgW0a5RQQVRaj0JjaWQyGd6F1iU1CtyhGlPgmemeahiLG1Qf3zUzHo413L4K2yf06IdkD5Ods6L3RAQBjbRSuwjFjXtFxIDCniv5+OWx2vok5GGQG7A0TNPNu5iuHfByqRog1zAFALfUT9wdTbPr7YLC4lnbiFubiV9rFjL9X2USx9Xz2d7V+m0dV85sDmW7aPRj4Tq9J4ZTwF1kFqYiqelK97m+koQhWvsyW7Fq7jlfBO95vjDg4QHT++A5e+z6ScShMVQw58WVgD3VHOtBR0U7Pa4aMscRPXETSu/VP5Qug8HFqzKvzH1Blz14BNE/lNTuusXjBZGjTxqOvWAIrbvzp9rEMrsO4Mf5J9B2svk2GUhBkGofEfNGqXn9wbfTl/zVbQG6xgN8rMfWi3GrNp04/wgEjEkgoBsCF74eQ/kLnNJHTcWl16bTZL93M3baC8JQ2OS524WLb61VZcHRshWMOZ3vUk0qCqMybsQoP8rxbics3jwEmwMi6dSvVAXUBbEG8kNNwT1vUMZb+QnBG723Rf216VB0ROn0bhJurFUSGBkpnrktOv6fiuWlBhP+Qt3lAuynWFP1LlZOwwXdOgD0ENNNikqVj5rFX01YuHrDxKGiErp1iD1+of7MUXv4gooEfslSHOPC9dXbpnIQy4AMprLDQy9I4/s2v9U1z3L1c3poAzBc7syhCW8qVMo1r94K1SIfiyLY8irUzIROSkcTnN+Mcomm8qAaCbDV8blTtr25z8Yc9q0Rb5r8P81eQ6aVECRtFbOKemetlUlUsALVvbsUafBv4uEUccFNwP/ruqXiAgZdbBhdRQbdgAPGbTWnGkcwfipjnEGp9EZGF8JYf88hzjF+1mA1ySt4wK0cxKl4UjuH8PO/Y95nWdUWAfByR0d4JOtlfyIiaKC1a0kKcXdnbFDAas+rQvwy2hoVlT+F80Q+8ASkKP9+WkL+wjR2O+tEIWVUglsR6CRF4xXgceYm0nEAtxqISrqdFLHRnZBDP/uRTcPrMCtiRiRA2yQ2jXayu8crpnKVJvcIQWMSt+HLp7Hn1Gnc0DBXFaV/x8Rc3ElPZtu1Lvw3y43KdTbExf3X/vwWcXCsZiKlXmTmdsFOg+sGqKjb8LEugb6+GeHHI1hLeXVqWS86TZ8naW3qKx5qw8aiXy/A6urpUuYH01+bwuomfszT6KzfTwf0HuQ8eTkPpuQXfW2WNt4Y6irYv7zqy+Au80jAxFLGG0eBNLgrv0rJ+p8XWvATPlanheELsQ3qvnq98g7q0agA0cLXWIzBmyYFDFiwtCTDevFOFCVswojYOCI8VtaMCc+vycP8cftSXuh719bZ77bv6y5OH/WLzNk0k88i90MRGCXfwLJGfbNRdMhVGxQ3TvVjVxqQHhL+EalZF3QtkhbF3PVFmLpZ6wqKuz+bJRNCLctiTN3SlpgyNU8N5m/eEYML/vKkTbT3zU54LuV53P662jxMCWiEwFD/iDl1IIeTgG5b139xR32ZJDQqH+tE7GrSevXoAd+ME8Z/95PaDK8YgE7/sJtdS42wFIj8WuzxXkE0h1aZUc3xc5UO8xM67LbFHkntKvrvZIRuxklAMdTY=',X'92eaeb330b74fdcc05207c21e6b9c1001425654d9344c4ded5e37b3c458d840024f4d49cb1158d999fd1e3097650e2538851c0ec5f37b8d5313eed2dfc1bf354b545cbdb712ae1d3294ca626992e4c4e0f29247bbebe01a6fb571435c5778ccbdc89442c7c56234f340a7bfb5e47f34c373caafa3be1b715d3b62283260351f0daf38b2e5c63651749224351ec5a1697dcd4a4ec6976f561defe8625c738f41034d64b61794c0b57ab69e1b7b213c07471a138e17e2eebf4ae02fe249a74198530d9e9d3dfd412fdeee8dd858ba61728fb15767a6a468a9cca070ac00dc2266c1d92a92dfa04cbebc16a21aa6504c14189ef405b817954d91f6b6203058ab2ea',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('A45487E6E29A53BBC597A690A0779D22','C52',1,1,'HrredcEaoRQjyVq8qEVTvKd+zG3o6pxtS18JxxXYZBtthJTmiHBghLSndl/FBP6o8JUZnVVQNi2ElYs4AoQ6G3t7+Gpsl58mdyCyXAoGqfeDYebK9dv2NDYabe9IUHxfw1ZjYwakSMNBLdZWt2xrvRcNZ7SGCV+lutDigyKU9Z0bP65k9kcf7Dr0sIbFxAei2UTobADVhHDNRVqwi1cd3DJwJks6KD8RNhv97taVfItCitZHzTVeDtjzGMRtTzBpHvwcU7UVfnlplx3Ch6Y00QFcUh0p2zDMj3Z/HBbxBle+vUi29dKenIlOSTqm4ienySZDP5aweWBTqXCKSCCTFzAVUg+J76LQHlDYUKd+EG5Q4VmWPniKO+6o+SfyWmEMxHdxvAkO2QJEVA4PpP4NNC8HvPfvKvMXgKAWiAtpgzHmOJdgcV2bfFcVrLGwE5pqod1Tgrg4L6RTz2iDtLD0pbt2pR1FviELECKrZ7RsnW6podoONSvoT33MUYtoJMHcCbLhGbfTD8e8yjFjxh1EjaRNfp2n6tuc685ArdfPRr7dkkOu4RRWBZaZlMIaN7qiNaXWzo1yOJ+a4xoAtAUqvI7D8bZ+ZB997FZ4iUC1ALvc3UsYk4WN3i8+2znTu53aIxRVZlbsvaGlaQ6Jk/sagdX9Jrh5W5WmqZfxoZzLMKZtwIFZ5aoFOiGf/kX5jsLq1Jo4rNNVR/p6lJy1rlbp+/ii4uu17L2QDYd1q0E9JUCVYC6eaMxyfQNB9vAJN5GAGYDIuL2MDf8HI47zoeSftXDdcV2qF4wVCp3EI+QVOEb5WX43AO2DtGAVcPBVs0ImmFV50qgqiH8sVPvFA/BldpRdW8TSEK1pFDU6oGwl0jDU+lUzI31MoXZuDMtdzB4NUEQdHKLQMndaOl/hGr4nVYM/4ug2uKTIb5KE/sdPzFErBIU7rrvxQSno1DnQWIkXhWZxNn6XXb4n5Hl9ZCLAHiXEetATso6Eo3H2RMq7wflPSbV5kl41GlB49AGjVDzWG8XsH3fQOdqgYOQ2dwk8dsG4hMSimORX06ay+6JLQ9zuSbi5Xj1pOUcDsAu6DJr4UXSoIwHtJPawpofcxfcDjsjEvqiYLpMpxCT1cYF63On0sESr4Lr9+n99T6JJelJOQUQogylwM6c0RXS0di3PClp9XW30FgMDukQExJYvdj5+s1061f4GNBMDSkCooKBXbCZItCMQ6qihnP8xaDLEDYvdimW5d9SpH5P30X7v8f+EDQ4jb+YPjWMs7dxP3thMbYO4GwR2DQI9yD9VxoVnu/E/u8FV3AWvJMZHZ3bFQiSa0SHM5E4nhOuesGP4kHn12f3JYnV4GvXoZKcNxnhM/t5qLbHB/ke15Glxqn3dFagwsCuZc8qOUdnlOnhz+sQoxtY7tZLN+UHMVh0bj0wTxJ/ZNfVxBb5BZ3BI7k2NSzZKU3DM4PWU0GnAqUijI9jizUG0idVznnPfRtlSqI7nWQUOQQaot/J5l/n+vdG12Bbf7koURF697/e4sNWDN16Qvd1j37xhHhM10wvOImKw65sgvtxKgW23rcewu3/a45KDmQJp/kGbQ9BX2uwZyXkP3zGivjQRtjr9MjjTVfsCgOSEPHnY3kylsf07BR2Wq+M=',X'817ca74d9c23f82ec66c97057436f52c08122587886b5490950326fcbf20b48ff2c83870452ecc85f8dc4caa522342f5b42fa3be23a30fd91413a1b6785f2948aaf7288c2fb9f5d6ace12e6c35335b60e40ff13d29436059f938008d8ae172f1260bfce0abec81b0746c8c864191140fbc2408f6283fb72f3f343b9b97e0b36ac781c153794aee97f03231759c8edcc7a046b4bced7c00bcd2e4ca5066e1539be77cf2184c62c225c9b297cf05e127d9a9134d206a93221694b5ec3b01472a612dc421ae5820ba576b12027eb66bc0d479c6ae6cfaa1c3a6dcfc5b297a18496e6749803e6fa750293580f931d0957a783ac0b0fa432dd949159981ce3db734e0',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('D5769BEA0E406B1673A164D76F509159','C52',1,1,'VCwBFAHyvH4TbdbUZPrAz2RQvT0wZRrE62RWKO4aPiqUbwnVBO2qzKzZodEX8/erRFVZPWBx4tzvF/HWaE6SdQOs8vAF5u0FlhnQ5UWB2FPzgUELeftGqSMXvQr5SLofdTkCLzCYydtH2113T0Ixn2ZHxcGCMeVWIjEN3n6vyGhEe424JxZ6SDd3ZYUvJtJD5vH6gCrPqBtfcrP8sXJzs0daFNwCF2Wi9M1PpbqDLCxeluMQxfEDRuR6cjBCg8A8fF1k/gV3FlfoI5o7wc2NPKfIm/DL7Nqhcit6j2bM+MfQNF3ABw5gZKq4D/NsKImulv3v9QIQT/bP0LqtqxYOlMBQu2C75I5boxTSAW8Ngkif0+Y1xNKPpTk37Po1Cv3BpMC/5QZEmEB4Eo12j+ZS19nQy/2bc7Gcq4OgzHZfgaswvN7W2mAbpiyYt09euvLboCI6hq0jCbGwTRzQ4NhuCUgPGuJ4qJNZwNZAIBqUN2hv7YLC7ITqa/mzDVLdLzq4rOlcFtrrYn3zbsz58wH+/bJp4uoWRZJxy6hG9hbzswaEUsAuKN2rFV0LFvRlwXtUyrI6Jy+eUbP+0GiDRiF0R0RkjJ/rT/lVZFu0PjXRxoJYJ/skp6IIl14uiqiJxgay0vqozW00LFr4HCRUrGpCb4KdxAKKxD4VXi2VkAZqj1XR011U5Dw5TcTXYIfVWWjMiMaAX6pkeXMLWa+wL72s1B528EC0UhDSgTgo7Xuv5qSlmUs5o5ciQM/BFW0yILV2FDPJF81rCBPowjJUaKHs3TtSes8inbZY3FMltptyqkwI8pMl59G1/TlL/4oMEWpf8mbF+Z6wf9/1L8l+vDz+LkMoLyVSlsEs29nwle7fQkcCLw0cPVvr6QEF84C7Kg95ZHqKgSvFmTPy9ERCG5z2/iAyGICJmFvFpqMtGJOipkocB/0HbZF6ytnphljZSvx8hX1l8gUUmipSOMDBzXj4n54x8/DNER7SqE6QhIZtdCy1MVZG0OHtvjas5VvqjhMQAV2A43p9MF2Lm3Xn1vaDvlZLCnbCk9uTmXM+oRenwhtSNUETzH9PzzEOqPX0sLFlBXqpV8OTLLnky44haY/nYf3YcIsgMSqZ90R6aBq1WpLU+HRjkzUWfS/Pt8XKhWvO0Me9NF7E6alPL5pzN1Qu7/JPfeapES2/DAk/0Jec5rqLDHsbxDWIp80UGmaZrLUrug4RXfx3wem3GKzDOJ2MV4CG8Hesf8dpAhUKTdGz7eu6y2Lq9M55GNn8A/jylAUnY0/ASwF+sr/L93v2ME7cZpb6MdhftKHVEYXZ9uHFNTvZpx3ocQ1GXUPB8v60ScGIA6Tek1FZK5BfOEdPCQqHipyODRZKW0pB3WV1z6YDb2VOgnsbbclh7xf8scf8SIawsywKyopZLT0ZSVc7UkSY9Zwcgar+VpniF6bcn3T91OwZHB6w+bev2DggQKVut6Kst2Jh8VG2HRoVDDEcXgHleFsTPwWdHcByt0FdBy/703ioIk/j8IMBiTaCj2NElIuV42b8sGzO85v0kOCWYshNcXBXDJ0ERUwVz7Mgif8VQ4Apwr3TG2eL+YBdrL981A4a20XZNAUm38FPXT3bqHjL9GDYdzjXpGpPUJmbrh5lJuU=',X'87ad3fb2cf389ec42f8aba5c4c5c06ff91ae466b577c13a258e3f25b162c05560e62d67c6e3ab6a1538caecb2911742d75cfac08677ea5c96e8b394b5fc215ef4a0336b0ebacb774e576cbffc80cb27fdfadaf89f37aca86b88b3f5855984593336cac38a8affd8fe064eb65f1852bef9dbf47b8741826f173a661e51a655fca4314d6cf15aee43f0ffeec2421a78135d383ff542821893c2d23ab1091e17f902fa7a2220cc21f54f7668f7fa9556142a40c4339378cbd236f2cf7a9a0d98ba3fdd3f915f23eb4b2fd23a758865706d0f0d4c5adbb5b42e586d5ea0f1da624985c836a8842b21284bfae184efdc1d8d2046ca9be8e806b419efeb812e844fcb0',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('AA0D6A1AEF8A78F9365CFFD5863BB918','C52',1,1,'iZOYa0Dh9KH3iP6tzkE2hzPctOoNRl/h/l0pNX31WiDP//yQu6yw5pJbdCM7BRIK1C97WKjByqoaUWxVmRmmaE4cUJxfDr/d6SiUoMyJugJRH4FV31Nt33yOawQqtP7MfHBLUx3soD8OgB+2o/AxKLbBcjB7RaDebFelQUCE5JEKiIAcuLthr+PmHLc2Air0TlTVWywhTWAMwgDHMhn30Yurd8af+TvwFSZ1TaaI61d1FVbKEgM8rFR8g44GN4pe4N3Cxv12sYNUA+pWbNtgGbOTfvs4Cw5t+AvfVxEu5Up/tWnVA0DfpE26iRj0WxzluaSNcdtU6jvDSiYUE83dFLNGT9AguT/UrakfmH0ofzlITQEYUnBkmlnBA05oEYjChH2SDyTI+lk7dn2HsHg0fePAiCEF5RntV9ZMSIUqpCOvB1Nc7ceOuqnAVVtaCnqWzRJbzYpP5A8GG/gLOvkl6i07lkZQSCiPuqw+2qOZfs2t6TsEzOqPojzQDhMibeZE9E0j28r/Xp2q5+nPdgknhu8G5T3vUm8v7SiuP0hrsn6xSq9U6cuKXPNOJUpMm8Jwhcetll/QkQn4aeweGtuW7E3qZspSXjEGcIiX+dj2ae49Cstu6Elqz2NzlWN9UW/feT1NhQ02MAML02M7PtvOW6QI4faZlKyiVWw3D7xRmA1P2FN/zcGVyjAC65n6jDnwSCNRz8DPhan4FnAtuI9hZMquHs1pZ2FQ8BpoNFLRmJ5a4aRb+KX7MXY+rKrOzqtpKAaJa5W9jghunharSsV1V/VOYGqULbNTa4/vpuZ6TDpBrjsBL4XxjZxulHXTxZgxsd3Eam3eB6UqsSPg6Q8dofKyEvRrU0atobBhvRlX+F/TEbVeFZ0VLU/A0mWuuiLwmPQTC2zNqTs4NnMl4arNmSlv2ZwlP8cp+0bdmFirIKfgO3VQjrttUF1UUh5/68VF9nzlecq4nlCrN0umJb7l6OTDtFAfcf5I7KxCRu01liiOCQT/DRhzhpaT29cL6oUWMISbjWUN7DqHjpzsmfZ3PlLO5ggJUQauCxyWSxpJn/f0c4Vncih1uZzJG00anMzw0LDiyw6tSm5EDapelfjVGLQ3EoRiZswDM9SmGIzZpGIb/nJ39epu7zmbdVJOrySGvnxZBUlqL2+Wb1qwfSr59/1zyu5DkvYZl5prk2FuDhIzsmRbt6o805rG0RBhOqUYN58nS1cE1rjRlQkkwkKfa/tqWd0qZ32BmDg9FUqEIsye8ReT4kat/bMhq4ZDxmVZ16bMWQf/qvZXlswDuuTaQ47cGzgq2Op2xA6xT7jJlKf9q/ncTI+nVUkLjZfcBUqM0jyi5KBCPAf3owSh1Nc7/uXNLAREZIwAhlQaw4N6ETOJm9Nh9IGlomX+e9ZLpRow/HedAvywoICHwaV+0s5VUkHVI/TXiZ3gclnRwxDtkYXopqHgXu2pxD9MRQbEcyMWFxpVUyt4cvJpB2m57hpW6F9qkPMol20jWc3qnu/EdqH6DSwnxWopLfWO00oJlxrfxsqVUrClIFyXXWqMEUhZVNroBjc11JArasx0ZNngx1eWlQHOhwAUGibU3J4jBMDtz1pOuN6dcEUXHefGzcoq82jJsDsCyB6NGyXN5ROsqZY=',X'35c83d5dbd73f4bac3a2fedd655261b15759cb4fd37269fa145abf09069ecda895cd24d6249a7e1487915851b9a91b7d0d4a616c1bc2e815178a5a51cd2d22fb7085b468e502ee3b2dc2a54ec1ee02909951d8b95e2cb9792c02a3b65d9670c93a263d72af50ca3b7b7cdc1322431faacf6de02141faabc22f241fa1c9f2659a89bf23f3ecdf26a4272eb0743ef8eed3c2af933742b322a7b3f48d2916c4c9e5896b1d86194c8df29494e44d1005688334f16dd34705d2ca2edc682e8090906500ecea049e4517ca08428ac431d724367c3a84069d5685b79b3466a5473fcbc430defd15926617f10ec7db5ed8eb878b1267b2a5f48abd98c22bcd990b42ee8a',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('66F9FA2EF627824AE964700539D9C8A5','C52',1,1,'BWLl7PdXk1YTyVRga4Rc1LFsHvbi3uvzbrEKkXbGO1PZ1eIKcxH0TOFl2igGuZOQOUjNijGNQCj+2bhgP9HjzSz4el0m9xthhdM27ZlpNgBg/2rw+K5nOINC/xCNA6pQ9y8EZml6IhV7FlTdgFk+d6NDFxV6Oj6AUojllEB4CcSE19nhKMupkE3JMbVDSniiCFH8UZHpqdgIsg3UUunxV7Do1hKP5IBe1I1eSyHIxCMfTBvctmwfapPD7/qvgukU9SNBTW4fret8uiTAIADCziNoeA82rQjy/ersGOGlF6fxtESKa6zAXAegi87/RZBjKox0PM7v+qxaA5NsA9pKLg+hXdMi2mhuwJkP5bCxTjZhW+lAd6/P4LCUbpry4KGjp+Jm3ueEfQfYxEWi7a5pG7gAJ3ve8Xh20VMuAelEehhZKoINiDBCaTTUvFXwQbKRDfYxYwbyOwUia6erMDxj58YkaR59nEkk47YpEX8+LfCfSNzfVokis33p/iIX2jR0Rr5OQ2MICulbuwkUMkLnWMG2KhTWEE/0SkJ9jLWISdDP+l+jIVv5xuypl4DZFVzcHTjuwjUMOmlBF5q+mmSyaA9M8ybyZvhbMZ+/kbih8VJVzXibymxLJB0inbRvo+Y2MEuwRDKXWKzFensUrc6WbEXNL8ttjRvlm4dPvIw5jfbIXBbIKC5KWbPezI/mH7zp2auT1I25gCF/QLsb7NOGj2cFzZ1yxYUgOZ0tF4g08tDMd7rP2eD7RjurXBcsF9FPRaVrkFOnKz6z2AbZdn/QpWwXkN4YwrA6d/F23A7TI8dFAdNVqgNp3I3A3qFu2c+91bzqC9MkH3fFo7ke2IXS3A8PcNSxMLvwSSRjJjlDzcbs8I3Mri6SX6uPY5PgZXG8WyCN9bLO6Gcp7E3vKidXPMzk5NJAttPI2DwsTlO4rk/A/B6c9bjQ54KmTzEun+WY6ABnrab8Jb08edwbvKcMWDIE4FtlayTVHquP/3XOhNAH+/8UTeYMuzm5E2IoJmQYnpwjbgHCoggHE6zJDe4gcb2bSNJZQfY5m4tnC61kXtComlqTIz/YdwNc+GjSoTFTsHEzKl+Dmwa9eCVTKPMGt0TWKDVekN1+6MXkIgzCixcHki9AwEbQ4Zsmz2LwH/UttJMWPOghY3c75I8mPlvM753yPnHXoEsMHxRhLNP5dYdgYsBuQINFZqyljU+B4JHhWKAmlZFaOmeyzWPKC+PBlXcl8LQKomRXam85zPBXJtxXEOKCYyue5blrMu0f1erQibnCjjH6LDP4ueRDVWkKpUbsmk6OcQc1jHkWDwlS6Ket18K4S9pSDKFPVVpTNcWtky/ZjdcXRdT+P17GPXREImUT+vH2sN6oqS4+DK5S/0v6havGX2OYM4EBBgVPa31PiQe1NaVepOHfrpE9OW03RB9p2NgkNr+4IwaWoIfvCdXSvQknMb4lX/ZjOLt+3JqDTW9TBRsl0nC9cbU86JLhyW75IBjB8vf/I3+rU0mwnoe2HsseRfbMwm52e4vmOapJ/+GscUZX9tTyVyNKAYDeUOQpNFWomXsStfMalfeemLdtUeEGnd/eo+0hz8i1dawWP8xnd5zvtnTzvVGEmT8Fp4aPPQktPXOnRLYF3uqxjzA=',X'90711cde9ed8fc56dc855fb3741d03b5e8323035cd7db49bb7d3d47f58844eb3348bb40a283b4bde21d408623eb281efaed6c20bfa4174bfa9ef7fd0c612a56ddc8fd1de6109328a033e10ba5f46cd3f8d6231a0bf7331dbb3c68a1f2cc77baa8229eaf140369f54ea67ab8adf49b351b922fc05beea7cb8220bf0f648a7c0fe80b2221d38a2216fddb3ab564aa19ad6f63bbc9b22e57ceee10d84c2142296478e0ee0928ab480c2221d7b9ee6094f980144c65b80620530173b1dc212d929f09ad033a697c3b849d91f8418f82d649597c04e34adebc4ff7203b3c9c6b8eaa403a8a016a878ec343a45258913164d43371305fd5be1e0193b5fd7d376043a33',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('7585B1F6DEC878CC18B8D52AB0881052','C52',1,1,'aJrwLqIZE6BW9JoInlpqDd9/gxC3iFeYEqn233zJt5x72ORIKFxZGlp3PoFd/ZuvSVV7RTPnf+0b7hlhD6WGMRZhwjRkpPMl0bw73472QnrdgYYOUEeUHxNRaCxgWFX5h9QBfYVZzM7VToxPYBva2Zj2eIRM967FmDEA0Zh8vQ1sa1zP/b0ieCfijbGAjBikDl+NvTF1nQoylwYOCmfHBffDqQ7eO1x1gLcJ4w5xBa8PjqbP9cdGSW59bVoJ8mxaykqdDIx8SjxllMi5cYkSgE0HPxtEV2HP2pBbr1lxmb4ZPYz5wQSk4Amv/2tpxMFgpJJPOxDWmysIVHjqBsPmK1+41QsGYDVB4R+7G56I2ZC1WGRCR/JPyJuB6COv4OAKQyy0TNuWHLVZVUfEiQSK0NcI+gZqmBSQgGDustc1VIUxMoIs0equkGwemp+Iv5tX5/LTzfMiKSn/wOkmtpBOzIrNcxf7x8n8f+9gkCm/XSeqWW0eV+U8G4pf/zCWEQ87zxIpSMO3mr/n5hYQ7cQqMxHu4G73yOBrDI1zIRKAjGGBWJRTRV5+RUrik/X4gr3QONC3PA6+TP0xvmSFvTyascLvUGWKV+aEzy0mmwrRs9k9M2doud9904B2vibxp4pC3TA2LLn/27wL7NhxG+JtRSqa30EtG10DeDbNOnUIkp19pUP6sxOIuekXymtN/VyfsqvTlwxzsTvzCJCO+d18QhxrIF/aglAHyrJuOyUgJ//eJAJfkdI6agm0m9Dvz5NPsOq1QKGzyxApTCODGYNbA5vcDohYZY3/LYiKsc/hOJiHftfJ42FQVN91YsL/G1ecVjGf0H86hCxrCEtieEK3qmwRTFdV0ctS+X0cbQ1JW2brxBbYvwCh8hsG6OlokT1oqrzzNvji6j3GRdthVYeSGgV3vRSSSJ7Vr/BemdkVcv3mqWZwBbL3R/0hpOKsTVKtGabMvtmrw06BIBZ1wsbJLJRYbbwyFGsdPn3hbr5IXdNmbk/5/d20olVK4j23rTR+2y3mhdB6QdSyadtNXIn6WloZNViUpcE1EQPQVeasuSwJbYHbb1x3Mx+VPj6e3H94oRPYkNwDr2iTjhduSkeO2fVkhvaoC9xIK2C0kOGVCFWxfHkFk/E1frc2TrYLTUqn3uhZ09rXrN3p/v7800qZeytuKb1uGnTQKszysGw+V2oosS7/HDmDc7L04KRFfQz94kNvZuQG2ht0IEqUjC57/EqZhG7mQtc80pG2VY3hTOBRqM4po3OITXeCbG+YGthGDT1WvFICGeAa2N9E7ZJFiAEEdWdAhTKXK895Vt12+oPvCNw5YPIfOznmnfunoz0EtVpvrdGAH6S6ppMWjMnzBOHs5ZaENUZ3y0cclB1LP1xTem3da86Wttxd5GJ/jANHY0NpsRHHDa8FKMKo7/wB0JoOLJVEJqVVNrjaBI5AEUg5WsL0UYKXif2j5zBmsrPG5z5jCD4uytP+DA9mcYoF9bNr5PxjU3tKxWMYMpmTxF1H9CWt4LHWyhLeGaCDDbUpzOuIvk6cyKPJKcBPBOjfdj4puiwJ/cIJXaFmWMwhjTLijEHSduO1NBNdAJQB/FfyeeoiC2gDwwqAi5EY8m1gwDEl0HExm1MkJkhT4fNTfns=',X'38a18b429c29727703e0a564796a700410c308c1e9ac2e931f8a8830d2357146ae54ae0940d7ccf135e04f8f156d8e59aad72305c409afdef467645a38a0af2b39a3380591ca06a2d0e94d6a7e6d52b24342fe65fdc61382a3e10330e961b3255e3a6d09968d72cd82cc3acc5ee503dbc2e208b2f9b90dcef9fab0bea4bbfba13228b401ccd1ed3f3cb799101a9ed8bec90630faaa4899212b4ddf2945c512de4e6772d5d83dc343c6e2141a90b66f699d130695d480e831b86fe70f23b5ebdc5615472ee7ce11076967f33660408de7d1fb68e9fe3ee9cbd397e39143e1f303cc1ea0525c68463f9190079a80d01aa7377b30491292e2c2c1019008089e2acb',1,4096,0);
-CREATE TABLE EbicsUploadTransactions (transactionID TEXT NOT NULL, orderType TEXT NOT NULL, orderID TEXT NOT NULL, host INT NOT NULL, subscriber INT NOT NULL, numSegments INT NOT NULL, lastSeenSegment INT NOT NULL, transactionKeyEnc BLOB NOT NULL, CONSTRAINT fk_EbicsUploadTransactions_host_id FOREIGN KEY (host) REFERENCES EbicsHosts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsUploadTransactions_subscriber_id FOREIGN KEY (subscriber) REFERENCES EbicsSubscribers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE EbicsUploadTransactionChunks (transactionID TEXT NOT NULL, chunkIndex INT NOT NULL, chunkContent BLOB NOT NULL);
-CREATE TABLE EbicsOrderSignatures (id INTEGER PRIMARY KEY AUTOINCREMENT, orderID TEXT NOT NULL, orderType TEXT NOT NULL, partnerID TEXT NOT NULL, userID TEXT NOT NULL, signatureAlgorithm TEXT NOT NULL, signatureValue BLOB NOT NULL);
-CREATE TABLE BankAccountFreshTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, "transaction" BIGINT NOT NULL, CONSTRAINT fk_BankAccountFreshTransactions_transaction_id FOREIGN KEY ("transaction") REFERENCES BankAccountTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccountFreshTransactions VALUES(1,1);
-INSERT INTO BankAccountFreshTransactions VALUES(2,2);
-INSERT INTO BankAccountFreshTransactions VALUES(3,3);
-INSERT INTO BankAccountFreshTransactions VALUES(4,4);
-CREATE TABLE BankAccountReports (id INTEGER PRIMARY KEY AUTOINCREMENT, reportId TEXT NOT NULL, creationTime BIGINT NOT NULL, xmlMessage TEXT NOT NULL, bankAccount INT NOT NULL, CONSTRAINT fk_BankAccountReports_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE BankAccountStatements (id INTEGER PRIMARY KEY AUTOINCREMENT, statementId TEXT NOT NULL, creationTime BIGINT NOT NULL, xmlMessage TEXT NOT NULL, bankAccount INT NOT NULL, balanceClbd TEXT NOT NULL, CONSTRAINT fk_BankAccountStatements_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE TalerWithdrawals (id INTEGER PRIMARY KEY AUTOINCREMENT, wopid BINARY(16) NOT NULL, amount TEXT NOT NULL, selectionDone BOOLEAN DEFAULT 0 NOT NULL, aborted BOOLEAN DEFAULT 0 NOT NULL, confirmationDone BOOLEAN DEFAULT 0 NOT NULL, reservePub TEXT NULL, selectedExchangePayto TEXT NULL, walletBankAccount INT NOT NULL, CONSTRAINT fk_TalerWithdrawals_walletBankAccount_id FOREIGN KEY (walletBankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO TalerWithdrawals VALUES(1,X'41453e8934144ef5bbd281c1a341fe52','10',1,0,1,'V1GYZXE262Q9CMW4MBYW24WJDFX4TZH9D5G9BZ0NV0YM73M80W50','payto://iban/SANDBOXX/DE546854?receiver-name=Exchange+Company',9);
-INSERT INTO TalerWithdrawals VALUES(2,X'34ad38e870764c1bb14ea76b46439232','18',1,0,1,'6DHWMK9VNR61HNFSWZZZKKBNN6FG9W1TA0QK4245CJWB9NVMKEB0','payto://iban/SANDBOXX/DE546854?receiver-name=Exchange+Company',10);
-CREATE TABLE DemobankCustomers (id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT NOT NULL, passwordHash TEXT NOT NULL, "name" TEXT NULL);
-INSERT INTO DemobankCustomers VALUES(1,'fortytwo','sha256-salted$GSiOW2beQiU=$I2D+pyiMf9pZLHOT7CJJ2ijV8z7QhAXMOU0wVQbleOY=','Forty Two');
-INSERT INTO DemobankCustomers VALUES(2,'fortythree','sha256-salted$qvzh+qEG3tE=$7wc7jUNKL6uBZp8s+Uj0Z95NwhZW0n7M+HjKCGR8YFc=','Forty Three');
-INSERT INTO DemobankCustomers VALUES(3,'exchange','sha256-salted$as7tmR1r4Ww=$uWlrzhx0lg6lQlwYo1F905pr6kMH2BTdseExdtbyKsQ=','Exchange Company');
-INSERT INTO DemobankCustomers VALUES(4,'tor','sha256-salted$SwCqqsrgrhU=$Dsoi8d9jVR7jvWH7I2VRc6uO6oFpGRwMEmgA3skoWm8=','Tor Project');
-INSERT INTO DemobankCustomers VALUES(5,'gnunet','sha256-salted$0Q1o9z/PY4A=$1ZQah+7QyIHJ3qmNsEccJHHmAd/YIuOgq6tTm+ZF7sc=','GNUnet');
-INSERT INTO DemobankCustomers VALUES(6,'tutorial','sha256-salted$/gd3nz/VNn0=$965qZ/B04oR5dZe43U+8fQhQZb57MHzhysHErXVMXaw=','Tutorial');
-INSERT INTO DemobankCustomers VALUES(7,'survey','sha256-salted$JPxe+WHw7ms=$hv7VYQaNI4KFLSoMeQ3AWYkxKRAlFuvvcAJe4CUwDFg=','Survey');
-INSERT INTO DemobankCustomers VALUES(8,'testuser-eql8x46y','sha256-salted$xPNqcKyTYDg=$e75X8rgvXRi1B+A0LM5AiSdrco92vkpJfmo0UlEWCwY=',NULL);
-INSERT INTO DemobankCustomers VALUES(9,'testuser-qsgidrbb','sha256-salted$8TDMGgpMJ34=$HPkLCiAxBiFfA5z4ZQeTpk74T6U7N3iZFiuaja5lADw=',NULL);
-CREATE TABLE NexusScheduledTasks (id INTEGER PRIMARY KEY AUTOINCREMENT, resourceType TEXT NOT NULL, resourceId TEXT NOT NULL, taskName TEXT NOT NULL, taskType TEXT NOT NULL, taskCronspec TEXT NOT NULL, taskParams TEXT NOT NULL, nextScheduledExecutionSec BIGINT NULL, lastScheduledExecutionSec BIGINT NULL);
-INSERT INTO NexusScheduledTasks VALUES(1,'bank-account','exchange-nexus','exchange-payments','submit','* * *',replace('{\n "rangeType" : null,\n "level" : null\n}','\n',char(10)),1660251795,1660251793);
-INSERT INTO NexusScheduledTasks VALUES(2,'bank-account','exchange-nexus','exchange-history','fetch','* * *',replace('{\n "rangeType" : "latest",\n "level" : "report"\n}','\n',char(10)),1660251795,1660251793);
-CREATE TABLE NexusUsers (id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT NOT NULL, password TEXT NOT NULL, superuser BOOLEAN NOT NULL);
-INSERT INTO NexusUsers VALUES(1,'exchange','sha256-salted$4BgMZjUx4pQ=$RZs3vkmmpEhay+7SeM6iaUyLoqBpT7QZPTXA+4zyLak=',1);
-CREATE TABLE NexusBankConnections (id INTEGER PRIMARY KEY AUTOINCREMENT, connectionId TEXT NOT NULL, "type" TEXT NOT NULL, "user" BIGINT NOT NULL, CONSTRAINT fk_NexusBankConnections_user_id FOREIGN KEY ("user") REFERENCES NexusUsers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankConnections VALUES(1,'talerconn','ebics',1);
-CREATE TABLE NexusBankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccountId TEXT NOT NULL, accountHolder TEXT NOT NULL, iban TEXT NOT NULL, bankCode TEXT NOT NULL, defaultBankConnection BIGINT NULL, lastStatementCreationTimestamp BIGINT NULL, lastReportCreationTimestamp BIGINT NULL, lastNotificationCreationTimestamp BIGINT NULL, highestSeenBankMessageSerialId BIGINT NOT NULL, pain001counter BIGINT DEFAULT 1 NOT NULL, CONSTRAINT fk_NexusBankAccounts_defaultBankConnection_id FOREIGN KEY (defaultBankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankAccounts VALUES(1,'exchange-nexus','Account Holder','DE546854','SANDBOXX',1,NULL,NULL,NULL,15,1);
-CREATE TABLE NexusBankTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, accountTransactionId TEXT NOT NULL, bankAccount BIGINT NOT NULL, creditDebitIndicator TEXT NOT NULL, currency TEXT NOT NULL, amount TEXT NOT NULL, status VARCHAR(16) NOT NULL, updatedBy BIGINT NULL, transactionJson TEXT NOT NULL, CONSTRAINT fk_NexusBankTransactions_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_NexusBankTransactions_updatedBy_id FOREIGN KEY (updatedBy) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankTransactions VALUES(1,'AcctSvcrRef:0I6W616I',1,'CRDT','TESTKUDOS','10','BOOK',NULL,replace('{\n "amount" : "TESTKUDOS:10",\n "creditDebitIndicator" : "CRDT",\n "status" : "BOOK",\n "bankTransactionCode" : "PMNT-ICDT-ESCT",\n "valueDate" : "2022-08-11Z",\n "bookingDate" : "2022-08-11Z",\n "accountServicerRef" : "0I6W616I",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:10",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE687184"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "V1GYZXE262Q9CMW4MBYW24WJDFX4TZH9D5G9BZ0NV0YM73M80W50"\n }\n } ]\n } ]\n}','\n',char(10)));
-INSERT INTO NexusBankTransactions VALUES(2,'AcctSvcrRef:TKXY6UEK',1,'CRDT','TESTKUDOS','18','BOOK',NULL,replace('{\n "amount" : "TESTKUDOS:18",\n "creditDebitIndicator" : "CRDT",\n "status" : "BOOK",\n "bankTransactionCode" : "PMNT-ICDT-ESCT",\n "valueDate" : "2022-08-11Z",\n "bookingDate" : "2022-08-11Z",\n "accountServicerRef" : "TKXY6UEK",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:18",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE871507"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "6DHWMK9VNR61HNFSWZZZKKBNN6FG9W1TA0QK4245CJWB9NVMKEB0"\n }\n } ]\n } ]\n}','\n',char(10)));
-CREATE TABLE PaymentInitiations (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccount BIGINT NOT NULL, preparationDate BIGINT NOT NULL, submissionDate BIGINT NULL, "sum" DECIMAL(20, 2) NOT NULL, currency TEXT NOT NULL, endToEndId TEXT NOT NULL, paymentInformationId TEXT NOT NULL, instructionId TEXT NOT NULL, subject TEXT NOT NULL, creditorIban TEXT NOT NULL, creditorBic TEXT NULL, creditorName TEXT NOT NULL, submitted BOOLEAN DEFAULT 0 NOT NULL, messageId TEXT NOT NULL, rawConfirmation BIGINT NULL, CONSTRAINT fk_PaymentInitiations_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_PaymentInitiations_rawConfirmation_id FOREIGN KEY (rawConfirmation) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE NexusEbicsSubscribers (id INTEGER PRIMARY KEY AUTOINCREMENT, ebicsURL TEXT NOT NULL, hostID TEXT NOT NULL, partnerID TEXT NOT NULL, userID TEXT NOT NULL, systemID TEXT NULL, signaturePrivateKey BLOB NOT NULL, encryptionPrivateKey BLOB NOT NULL, authenticationPrivateKey BLOB NOT NULL, bankEncryptionPublicKey BLOB NULL, bankAuthenticationPublicKey BLOB NULL, nexusBankConnection BIGINT NOT NULL, ebicsIniState VARCHAR(16) NOT NULL, ebicsHiaState VARCHAR(16) NOT NULL, CONSTRAINT fk_NexusEbicsSubscribers_nexusBankConnection_id FOREIGN KEY (nexusBankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusEbicsSubscribers VALUES(1,'http://localhost:18082/ebicsweb','talerebics','talerpartner','exchangeebics',NULL,X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100adebb8232ffe4ece51c1a65c374a20c6004219b8db8d1233341b41ec906ee63dad98eee2f8c38bae21ed04072b5019f2b000aca7ddb185b8a0635d9c54bd77dac31404a900609e4006af945d3016f027a8d5c05f9ed005142d4f23d4bae53fcce4e5915dd572bfcd0888c6bb4282906fd322c9114079ab00be9831a43d437be25773e0eaeb169aedc63d685f3fa5b0e20f2ff4f9a5190890749d44112488c44e8611c177743e4d6a8d8f3396af843bd3daf46a2d952070285172957514d60ec3020b93f6c462adb16cc198a797c687dc2702d659264ce4b0ae80f8f78fe1352cdd69ba4cff1ea36afa9ad9eee9478e240f2fa590410ff7118059db35077a6baf020301000102820101008b338d4fec8bd8bb5dc866c48c2432930785e05c8aad209206f482113b90e78b1a34bb8ec2989065b115a911abe312c1a18908a7dad2c93a7a74cd69e0913d2ac4d472de6944eba44735a4c3e94792b3cb7839dece97a458ffe2c5c4f049a884eff7a61fba457baa39586fe75556771069a6ffd3650d7c86be05c645b41b1d3d37e5e1e459ca47caa1a4d4c62a5329864ca69fb2f58478371da2f7dfad3ba675086aedf5b0211f9096ef709d54d79b26f655fdc74a632193258810ac6c8f6eaf4b801498aba8b58387f99fd9263f4bae05e97e36a69c47090ec3730cbdb8ff3a891d352872bd9b28cd2d62c60d8b1cdbd236c4820daa7148d8b1c67b9df60af102818100f6b29e1b3c442701df89eef088338909b1aaeea913e8fc73accb78c94dabe16e61a59443fe8b32003d70ab1347302e3fb7ad203b04e388adf75a0ea1d9c8036fbe22cc837f025668262ea28ed87551e55448b7aa9d1f9828cbd290144b77c1c12896156da0bd2de51198721731e37ada0787a0ef5aed2161284c8240188016d302818100b47a95453ec0f418fd5bdbb0e16e54810b0b84d4057df35c582eeceee46c8f159940591f4892255a72f2360797be0c0b1dc7460e7099c5193c29b1f4cfe16942cc344a09c38a17aecd3872f46aab11ff99a83f395a10ef76ab0d1ef79ff1040cfe8d64ad32ae44b2689cf862a1e6c334b7702719a190270cb8b62d361368463502818024c7ceb0cad472686216a38c331253ed21131610194ad450bec37b57afffdf5560b39a1e651605b76971a1dff6ee250714f077ecb4b6e3cae4250627755bcfbf5a3ebff51efb8f3c69ecec0996162fc69c415738d5c23f225df91fc816d45d0bda6c3df7a14e734842ce52bc4890dce122dc42cf4ce42be4db6844c71fa0014702818100850ca1a2acc29eb11586748d0f83c0b4692a12c0235458e648f43f23562e59c5787721bc984975541acd48db8c1844d4a51d551e2c1090672c1d28ddebaaa768e115e347136a684f2b6764079fe3819f46edebbe2211be1763be8687d2d7613f1b21ad88a986238acae87d8c6902b001db01c9317213cd55e98e14027b8831c90281802acefc279660aaa8d727730ef5e34ba99e64ec063e748370eef59a1bccc407f14e30ab7ab908b7e449301e72a0ed51cf8ead87de232d544cb9a61fa67f6db2814e232e4a5e10dea2d09511d22a4bb03ac0eb5c76484628c88fc6d881c3f6999fe82de72be788327d194ca69f189506f17fb4a401a613aba6a210af80cccebfb2',X'308204be020100300d06092a864886f70d0101010500048204a8308204a4020100028201010096f42ff3697c7a030140e705b1060365690cb42ca1763d2d6326ee7f0c8a04d8f0e0d651144df51f965864e7b32328756f92b599e3a97457f3b4c22f1e2332443c35f9145495cf581076054ff9f5e4214eef6756d410262164f67c09c502c6a98b3bc3ac36625d885a85f55c92fdb39272c5beb4e5c2ee9ede9dfcd42cf5fa1d67b5e7f3d5e7e50a4bb6d4e7242b6a5dba075ff8e90786fc06ee304cd20a728891df2e9cc006c22343dd53cc3992e6134bc566f9472451d54b595e49f737fb61a55e0269b3ecbf4789f990d8212de2774d1843047d873261ac8c1aadaf55bb6fedceb70cd35f8bd2504bd04d972b479b6bf092391d67099f8a23f070a3ebe5f102030100010282010002150c3447583836a265caca014f1bece22e12ae2aebfe9c09aa17d018d42e8cef85aa6f23e08f690821e002722e21f8bcb941580613e84eee45a8080e5a5def23057b9214389ccb922e8e9433d678771d27a03d4a5f8ea717456f20935f1e6e684542c5b55a55fff37fb58ab95c5685c69f83a9eb216d3933c8ea1be322e17850da0aa623bd585287b514e45eecf8af66d2e760310b811753ce1ff117d03baa70738e802381601495339e458a7d319e9d2549ebdae8cc052a6adf21178ca13c6c952e1859887894a443381da1ba38fe698cb3f3b26cb1b803923dc9f67eec2f19399fb5d74e5792d48d9a780935380fc02eaa2d19112e6209dc7030f5c791a102818100ec3eb87d4f093dab81bbd853c2fa8464450448a7925be41fec807783e7281494a8eab5982df77f3f061db53e8fb2e995dfb668f4a2198d569d31394b4589e823a571d3e79e7981df77fec072460241d1d3f7f6b4b4e0e0e9a6733c30222c5fdb6beee820207e675593920444752a0c2e7fdfae360dca54d5d2b01ad268aa8e9302818100a393a5378cadeda2bec34ffcc6c1ffec00d1c29e3ef80ecd1fae5c1f1349981941e06151076fa96aacb34eeedd34e949aa6314595d7e9c4b043c188b8747e7e6436ed2529d259d5fe6f992fd1f2d1f5575fa7e0a037109e7ccd240fb348e8bb7392c91e87242e030ceba12ef2bd818092bf2c57ebe8abcf029287e0038d707eb0281805b3d72053b64274438cbb2a5cef4eff2c5d0fcba7345381ab83d796b20f892d24356baa1b68712c6e576cdcc06b5a38f35a27e7094b667a6def8e6d6d2598ba550bd6088e0e4aeaafeee0da754b0847924736cfda7a9fe535eecbc7f1e83a2d5dc9e9d59e312ce97f7717a627219b630b3445145211856a16a48876361f7152f028181008720c1fc68a789c6c6a5dc1eea267aff0012481ea7d00d922018ce9b1138db8009ee8d15fdf99d4fb5490eecbe2a2689a74ae0158ee9b7bd34cb5c4f6f3ad47460c25cd6c860b967ef0bbf04814baa35d41751257e8053f97c37385d0ca6b0fe7429c082f0591490dd45d3bc6650c652554ee11d79d46c8e4cc1d98cdf67ab6f028181008b3d68e7dad91fa85cd0844c7293ba8afebeefef2c83aad45464f1c3301e53fdbdbd8c05fe2380911b1b5bb910cce75689bc9a684c0e4b9c94c7c72ca293d97b6506ec1fef0c7ca16b0d42c390206319c302117f9026f99b636977d98bb36963cf49107c22b1a07aa5e7e8fa8558cd854f93425d6e19642354151c1d049997ba',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100937fbca30748f24ccfb1dde9cca6611f2c9df47546ab506176654fd858c8d0090a56c8be6af7b7681a1270172453435449c977099f881a0f0ffff68164166416cd15c7af6b977aebff6f7ca287eabed7d62c3c11089ce5315404c05c4eba61e3a354b1824bda85916db3f7a28f92767fddc2db43f02bdcd86d97aec3390263f774ed3ce828f40dddcbb5bc944b906c94ba8721f89853a8013cd06fce7f37666bdf88b759b38ba4842ed5cdd33b32964ced03149b4b6e13213a434946f4b4e4a444fd9681a61709ef013fa0f1b9d67f23278c709ac81bd9ad7a7ef410f7a1a9a818bd76119c1676cddef0296d7c069ea9cc4279cb24c7d2e3264ba7708ecef1dd02030100010282010100813423c9ab57fae7ce07c09c4ce871ab1d2a40397aee163b49baf5764e4f99ec516233f6993ce52c0baa9b05aa8c452e50746a11c3ed34e67cdd7ad15d1b4011b9149b16cee8a28497fcd0f08e9ed30dbe4e814f6a7c05487090b8f02306a1390699e9e4790db272f1e5f3c6327dd9cfa832485ffac27172248dfa488867cfa85fac7962a53d0ca4ee465e02491a1a0602e62417c6ec1b0d38d3725c6d39e5d2794ba9f70f97c20f27cd7edcf301c1bba19631ea61a0d0b6144d6493becd019bebe5ead479a43ede491e85c06842b986ee872c86ec6e73805099cba7fb083a8e3f87bb34124a4eede13126f7cd387e2a5485499cc0433c9bd70b1e20c8f6600102818100cc0c8c4fbbdcd4ad23253ec5bdb188297d9aa922d2d31146e02714e25d692af78a537f23e39dab3299552b9aa3e73fa5877c79eb9241a2aee596e671264582e2e73594cfa581b7a8dff6b86acacde9c2dcf712efe1317cc6059929ce51b2c9c386c2a8e209ee2b6c28e793431a87c9ebbeef8fb38ec2217e61dd8e78afa3f5bd02818100b90d629d6d3c1a373ec6605f5c5ee0d9d7b25ce023aa63f51099c04f4f157f09bdd0515018ecc0ec14f2558bb4448a096a4c4bea246eb644378c2b090515c408cc38a2f80c0815792e244fb3d231d0b205746cbb0eeb13a25f60625e4d3ed4f294bc52c50ee1f06011cae79b2a32dd6f3311b5b681e6e257d63c7ca936ae5ea10281805a59b80b5a38e7271ee7d00ac8fb023ab4f635ac48c3d2e39a3f53dd03d59c83ed891943eff691a69f047a8147d00e7ba22978e6d9651cbeeac44d978e85baf5f3c0e2faaae36c4a67991c8194f96667b565e5c9b7e22cc8961402d1eb950a07fcf4d6c8f7f2b0e17c9f45b2b1ddac88298c7409e2cd8cfd2422718278eb55d50281802a37528305938b8b84e7aebeb28cf690dbf355dad06823cb9990e9dd6df642780f7481c85b174fdfcbdb8906890685d3260be7d9af9c0e3abbcd5f57fc6ffdbbe0131fa2a4e4073a10fbb9af1549c60986d30ba714fd2e0a81e5b42b3d461340900bf27a002e2d2f4d7fd39c8360fd414c0e433d329f608d97534f412f37526102818100956c2744eff53e1ef0854b84bd9037b92bf4da13d594cca95517ebd15666386f828334bae001fee218ebbbda496fa3854a7cdf220498dbc52a2a4f7794e4e23c4b0502cd1b32bc2799a929560cdd15391056930dc3a6da693aabf5fe702725544762c6ecd0b1c204b15702233dbd91d3b56bb33fc81481abbf4c0ecff52d5030',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100bf9f496026bdb5f879db509bbc5110a233b39b73f62646ec961226fb2375d25f89e744d7df6e259744fb8f36d70e22bad8e0a7203151813359759c028843328c5e87e8b480566ed95e56bd91b5d09503fe019b0f719db801d2cc4585f031461cc56ac9dd1dbd570fc87b8344dc578919343696a645f4ded449dbedec483b54ece29eac39fbef30aad2fd012151093fc958bdab1c34fb53acd62421cc13dfb828973f654500f43876dd1b3c622dd07d28ea7502a2f7b428a1a04cf6fd7905db893994a1af3ce6997010286cb1b04b9abe6145573913889ca15038176e7bad9ccc6eb285cd85d7f11092c39cec340f48e46287f251c9383adaeaa0f6db08096b750203010001',X'30820122300d06092a864886f70d01010105000382010f003082010a02820101008c902f9333ebc3535389a793d6224f1c8882955ada65fd516e2fda399227a7f45f7bc50854939c0a00ad06774ad44f69fd4709d002655381607b69487a57763d5539a603f3a5c9577f1c1872e13f1e6c4305b4e1aa4b7fc77b97cea20f4e85771ba30f50a1b6a0fb50683360168d7fdca2900fe7cbe5f593ba14f63834a173ae2857255674934c5523eb361adc143c391c7ac7190627407a9f5ec1044db1fa29c921465a5a9e75f1852b89414e7972e8eeb5ff26ad1f5e6de7c9fe64acb98ee162c72bf85804a3847f0467083c99916ac4d0d7b78f4602be0325274f43f3dffc84e02fa76b99575bb1ddf4fb7d8c2123eb314086e690019e61770b8dff1c64ab0203010001',1,'SENT','SENT');
-CREATE TABLE NexusBankBalances (id INTEGER PRIMARY KEY AUTOINCREMENT, balance TEXT NOT NULL, creditDebitIndicator TEXT NOT NULL, bankAccount BIGINT NOT NULL, "date" TEXT NOT NULL, CONSTRAINT fk_NexusBankBalances_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE AnastasisIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, subject TEXT NOT NULL, timestampMs BIGINT NOT NULL, incomingPaytoUri TEXT NOT NULL, CONSTRAINT fk_AnastasisIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE TalerIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, reservePublicKey TEXT NOT NULL, timestampMs BIGINT NOT NULL, incomingPaytoUri TEXT NOT NULL, CONSTRAINT fk_TalerIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO TalerIncomingPayments VALUES(1,1,'V1GYZXE262Q9CMW4MBYW24WJDFX4TZH9D5G9BZ0NV0YM73M80W50',1660251774341,'payto://iban/SANDBOXX/DE687184?receiver-name=Name+unknown');
-INSERT INTO TalerIncomingPayments VALUES(2,2,'6DHWMK9VNR61HNFSWZZZKKBNN6FG9W1TA0QK4245CJWB9NVMKEB0',1660251783142,'payto://iban/SANDBOXX/DE871507?receiver-name=Name+unknown');
-CREATE TABLE Facades (id INTEGER PRIMARY KEY AUTOINCREMENT, facadeName TEXT NOT NULL, "type" TEXT NOT NULL, creator BIGINT NOT NULL, CONSTRAINT fk_Facades_creator_id FOREIGN KEY (creator) REFERENCES NexusUsers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO Facades VALUES(1,'test-facade','taler-wire-gateway',1);
-CREATE TABLE TalerRequestedPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, facade BIGINT NOT NULL, payment BIGINT NOT NULL, requestUid TEXT NOT NULL, amount TEXT NOT NULL, exchangeBaseUrl TEXT NOT NULL, wtid TEXT NOT NULL, creditAccount TEXT NOT NULL, CONSTRAINT fk_TalerRequestedPayments_facade_id FOREIGN KEY (facade) REFERENCES Facades(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_TalerRequestedPayments_payment_id FOREIGN KEY (payment) REFERENCES PaymentInitiations(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE FacadeState (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccount TEXT NOT NULL, bankConnection TEXT NOT NULL, currency TEXT NOT NULL, reserveTransferLevel TEXT NOT NULL, facade BIGINT NOT NULL, highestSeenMessageSerialId BIGINT DEFAULT 0 NOT NULL, CONSTRAINT fk_FacadeState_facade_id FOREIGN KEY (facade) REFERENCES Facades(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO FacadeState VALUES(1,'exchange-nexus','talerconn','TESTKUDOS','UNUSED',1,2);
-CREATE TABLE TalerInvalidIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, timestampMs BIGINT NOT NULL, refunded BOOLEAN DEFAULT 0 NOT NULL, CONSTRAINT fk_TalerInvalidIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE NexusBankMessages (id INTEGER PRIMARY KEY AUTOINCREMENT, bankConnection BIGINT NOT NULL, messageId TEXT NOT NULL, code TEXT NOT NULL, message BLOB NOT NULL, errors BOOLEAN DEFAULT 0 NOT NULL, CONSTRAINT fk_NexusBankMessages_bankConnection_id FOREIGN KEY (bankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankMessages VALUES(1,1,'sandbox-1660251762836','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313736323833363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34322e3833363538345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34322e3833363538345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(2,1,'sandbox-1660251765211','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313736353231313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34352e32313131325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34352e32313131325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(3,1,'sandbox-1660251767456','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313736373435363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34372e3435363431375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34372e3435363431375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(4,1,'sandbox-1660251769685','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313736393638353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34392e3638353338355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a34392e3638353338355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(5,1,'sandbox-1660251771886','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313737313838363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35312e3838363637365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35312e3838363637365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(6,1,'sandbox-1660251774087','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313737343038373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35342e3038373235325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35342e3038373235325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(7,1,'sandbox-1660251776440','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313737363434303c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35362e3434303736395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35362e3434303736395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(8,1,'sandbox-1660251778642','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313737383634323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35382e3634323832315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30323a35382e3634323832315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(9,1,'sandbox-1660251780820','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313738303832303c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30302e3832303337385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30302e3832303337385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(10,1,'sandbox-1660251782983','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313738323938333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30322e3938333237335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30322e3938333237335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(11,1,'sandbox-1660251785229','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313738353232393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30352e3232393734335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30352e3232393734335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(12,1,'sandbox-1660251787405','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313738373430353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30372e3430353134385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30372e3430353134385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(13,1,'sandbox-1660251789573','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313738393537333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30392e3537333232315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a30392e3537333232315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(14,1,'sandbox-1660251791722','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313739313732323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a31312e37323234345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a31312e37323234345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(15,1,'sandbox-1660251793886','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313739333838363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a31332e3838363733345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30333a31332e3838363733345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453534363835343c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e30493657363136493c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453638373138343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e563147595a58453236325139434d57344d4259573234574a44465834545a483944354739425a304e5630594d37334d38305735303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e544b58593655454b3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453837313530373c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e364448574d4b39564e523631484e4653575a5a5a4b4b424e4e364647395731544130514b34323435434a5742394e564d4b4542303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-CREATE TABLE OfferedBankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, offeredAccountId TEXT NOT NULL, bankConnection BIGINT NOT NULL, iban TEXT NOT NULL, bankCode TEXT NOT NULL, holderName TEXT NOT NULL, imported BIGINT NULL, CONSTRAINT fk_OfferedBankAccounts_bankConnection_id FOREIGN KEY (bankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_OfferedBankAccounts_imported_id FOREIGN KEY (imported) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO OfferedBankAccounts VALUES(1,'exchange',1,'DE546854','SANDBOXX','Account Holder',1);
-CREATE TABLE NexusPermissions (id INTEGER PRIMARY KEY AUTOINCREMENT, resourceType TEXT NOT NULL, resourceId TEXT NOT NULL, subjectType TEXT NOT NULL, subjectName TEXT NOT NULL, permissionName TEXT NOT NULL);
-DELETE FROM sqlite_sequence;
-INSERT INTO sqlite_sequence VALUES('DemobankConfigs',1);
-INSERT INTO sqlite_sequence VALUES('BankAccounts',10);
-INSERT INTO sqlite_sequence VALUES('DemobankCustomers',9);
-INSERT INTO sqlite_sequence VALUES('EbicsHosts',1);
-INSERT INTO sqlite_sequence VALUES('EbicsSubscribers',1);
-INSERT INTO sqlite_sequence VALUES('NexusUsers',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankConnections',1);
-INSERT INTO sqlite_sequence VALUES('NexusEbicsSubscribers',1);
-INSERT INTO sqlite_sequence VALUES('EbicsSubscriberPublicKeys',3);
-INSERT INTO sqlite_sequence VALUES('OfferedBankAccounts',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankAccounts',1);
-INSERT INTO sqlite_sequence VALUES('NexusScheduledTasks',2);
-INSERT INTO sqlite_sequence VALUES('Facades',1);
-INSERT INTO sqlite_sequence VALUES('FacadeState',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankMessages',15);
-INSERT INTO sqlite_sequence VALUES('TalerWithdrawals',2);
-INSERT INTO sqlite_sequence VALUES('BankAccountTransactions',4);
-INSERT INTO sqlite_sequence VALUES('BankAccountFreshTransactions',4);
-INSERT INTO sqlite_sequence VALUES('NexusBankTransactions',2);
-INSERT INTO sqlite_sequence VALUES('TalerIncomingPayments',2);
-CREATE UNIQUE INDEX accountLabelIndex ON BankAccounts (label);
-CREATE UNIQUE INDEX NexusBankAccounts_bankAccountId ON NexusBankAccounts (bankAccountId);
-CREATE UNIQUE INDEX Facades_facadeName ON Facades (facadeName);
-CREATE UNIQUE INDEX OfferedBankAccounts_offeredAccountId_bankConnection ON OfferedBankAccounts (offeredAccountId, bankConnection);
-CREATE UNIQUE INDEX NexusPermissions_resourceType_resourceId_subjectType_subjectName_permissionName ON NexusPermissions (resourceType, resourceId, subjectType, subjectName, permissionName);
-COMMIT;
diff --git a/src/auditor/auditor-basedb.age b/src/auditor/auditor-basedb.age
deleted file mode 100644
index cb62dd556..000000000
--- a/src/auditor/auditor-basedb.age
+++ /dev/null
@@ -1 +0,0 @@
-1660251795
diff --git a/src/auditor/auditor-basedb.conf b/src/auditor/auditor-basedb.conf
deleted file mode 100644
index 6a226f0a5..000000000
--- a/src/auditor/auditor-basedb.conf
+++ /dev/null
@@ -1,187 +0,0 @@
-[instance-default]
-KEYFILE = ${TALER_DATA_HOME}/merchant/default.priv
-NAME = Merchant Inc.
-
-[exchange-account-1]
-PAYTO_URI = payto://iban/SANDBOXX/DE546854?receiver-name=Exchange+Company
-enable_debit = yes
-enable_credit = yes
-
-[exchange-accountcredentials-1]
-WIRE_GATEWAY_URL = http://localhost:8082/facades/test-facade/taler-wire-gateway/
-WIRE_GATEWAY_AUTH_METHOD = basic
-USERNAME = exchange
-PASSWORD = x
-
-[merchant-account-merchant]
-PAYTO_URI = payto://x-taler-bank/localhost/42
-HONOR_default = YES
-ACTIVE_default = YES
-
-[merchant-exchange-default]
-MASTER_KEY = SA4PMGHM403V1F2TQVFRVKH9BTZ2FBG3V6R7FFVVTYFEFDYG3AX0
-EXCHANGE_BASE_URL = http://localhost:8081/
-CURRENCY = TESTKUDOS
-
-[payments-generator]
-currency = TESTKUDOS
-instance = default
-bank = http://localhost:8082/
-merchant = http://localhost:9966/
-exchange_admin = http://localhost:18080/
-exchange-admin = http://localhost:18080/
-exchange = http://localhost:8081/
-
-[coin_kudos_ct_1]
-value = TESTKUDOS:0.01
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.01
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_ct_10]
-value = TESTKUDOS:0.10
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_1]
-value = TESTKUDOS:1
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.02
-fee_deposit = TESTKUDOS:0.02
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_2]
-value = TESTKUDOS:2
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.03
-fee_deposit = TESTKUDOS:0.03
-fee_refresh = TESTKUDOS:0.04
-fee_refund = TESTKUDOS:0.02
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_4]
-value = TESTKUDOS:4
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.03
-fee_deposit = TESTKUDOS:0.03
-fee_refresh = TESTKUDOS:0.04
-fee_refund = TESTKUDOS:0.02
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_5]
-value = TESTKUDOS:5
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_8]
-value = TESTKUDOS:8
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.05
-fee_deposit = TESTKUDOS:0.02
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.04
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_10]
-value = TESTKUDOS:10
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[benchmark]
-BANK_DETAILS = bank_details.json
-MERCHANT_DETAILS = merchant_details.json
-
-[arm]
-CONFIG = /research/taler/exchange/src/auditor/auditor-basedb.conf
-
-[taler]
-CURRENCY_ROUND_UNIT = TESTKUDOS:0.01
-CURRENCY = TESTKUDOS
-
-[merchantdb-postgres]
-CONFIG = postgres:///auditor-basedb
-
-[merchant]
-WIREFORMAT = default
-DEFAULT_MAX_DEPOSIT_FEE = TESTKUDOS:0.1
-KEYFILE = ${TALER_DATA_HOME}/merchant/merchant.priv
-DEFAULT_MAX_WIRE_FEE = TESTKUDOS:0.10
-WIRE_TRANSFER_DELAY = 1 minute
-FORCE_AUDIT = YES
-UNIXPATH = ${TALER_RUNTIME_DIR}/merchant.http
-
-[exchangedb-postgres]
-CONFIG = postgres:///auditor-basedb
-
-[exchange]
-MASTER_PUBLIC_KEY = SA4PMGHM403V1F2TQVFRVKH9BTZ2FBG3V6R7FFVVTYFEFDYG3AX0
-SIGNKEY_DURATION = 4 weeks
-LOOKAHEAD_SIGN = 32 weeks 1 day
-SIGNKEY_LEGAL_DURATION = 4 weeks
-UNIXPATH = ${TALER_RUNTIME_DIR}/exchange.http
-
-[bank]
-HTTP_PORT = 8082
-SUGGESTED_EXCHANGE = http://localhost:8081/
-SUGGESTED_EXCHANGE_PAYTO = payto://x-taler-bank/localhost/2
-ALLOW_REGISTRATIONS = YES
-SERVE = http
-MAX_DEBT_BANK = TESTKUDOS:100000.0
-MAX_DEBT = TESTKUDOS:50.0
-DATABASE = postgres:///auditor-basedb
-
-[auditordb-postgres]
-CONFIG = postgres:///auditor-basedb
-
-[auditor]
-BASE_URL = http://localhost:8083/
-TINY_AMOUNT = TESTKUDOS:0.01
-PUBLIC_KEY = JZYPE53YY23MQ0HTTV3DYHRABW4RM6SJS1Y0HF2HMSEPEPRJ77WG
-
-[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
deleted file mode 100644
index bedf649c8..000000000
--- a/src/auditor/auditor-basedb.mpub
+++ /dev/null
@@ -1 +0,0 @@
-SA4PMGHM403V1F2TQVFRVKH9BTZ2FBG3V6R7FFVVTYFEFDYG3AX0
diff --git a/src/auditor/auditor-basedb.sql b/src/auditor/auditor-basedb.sql
deleted file mode 100644
index fb5def3ae..000000000
--- a/src/auditor/auditor-basedb.sql
+++ /dev/null
@@ -1,16023 +0,0 @@
---
--- PostgreSQL database dump
---
-
--- 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;
-SET idle_in_transaction_session_timeout = 0;
-SET client_encoding = 'UTF8';
-SET standard_conforming_strings = on;
-SELECT pg_catalog.set_config('search_path', '', false);
-SET check_function_bodies = false;
-SET xmloption = content;
-SET client_min_messages = warning;
-SET row_security = off;
-
---
--- Name: _v; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA _v;
-
-
---
--- Name: SCHEMA _v; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA _v IS 'Schema for versioning data and functionality.';
-
-
---
--- Name: auditor; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA auditor;
-
-
---
--- Name: SCHEMA auditor; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA auditor IS 'taler-auditor data';
-
-
---
--- Name: exchange; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA exchange;
-
-
---
--- Name: SCHEMA exchange; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA exchange IS 'taler-exchange data';
-
-
---
--- Name: merchant; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA merchant;
-
-
---
--- Name: SCHEMA merchant; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA merchant IS 'taler-merchant data';
-
-
---
--- Name: assert_patch_is_applied(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_patch_is_applied(in_patch_name text) RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- t_text TEXT;
-BEGIN
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_patch_name;
- IF NOT FOUND THEN
- RAISE EXCEPTION 'Patch % is not applied!', in_patch_name;
- END IF;
- RETURN format('Patch %s is applied.', in_patch_name);
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_patch_is_applied(in_patch_name text); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_patch_is_applied(in_patch_name text) IS 'Function that can be used to make sure that patch has been applied.';
-
-
---
--- Name: assert_user_is_not_superuser(); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_not_superuser() RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- v_super bool;
-BEGIN
- SELECT usesuper INTO v_super FROM pg_user WHERE usename = current_user;
- IF v_super THEN
- RAISE EXCEPTION 'Current user is superuser - cannot continue.';
- END IF;
- RETURN 'assert_user_is_not_superuser: OK';
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_not_superuser(); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_not_superuser() IS 'Function that can be used to make sure that patch is being applied using normal (not superuser) account.';
-
-
---
--- Name: assert_user_is_one_of(text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_one_of(VARIADIC p_acceptable_users text[]) RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
-BEGIN
- IF current_user = any( p_acceptable_users ) THEN
- RETURN 'assert_user_is_one_of: OK';
- END IF;
- RAISE EXCEPTION 'User is not one of: % - cannot continue.', p_acceptable_users;
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_one_of(VARIADIC p_acceptable_users text[]); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_one_of(VARIADIC p_acceptable_users text[]) IS 'Function that can be used to make sure that patch is being applied by one of defined users.';
-
-
---
--- Name: assert_user_is_superuser(); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_superuser() RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- v_super bool;
-BEGIN
- SELECT usesuper INTO v_super FROM pg_user WHERE usename = current_user;
- IF v_super THEN
- RETURN 'assert_user_is_superuser: OK';
- END IF;
- RAISE EXCEPTION 'Current user is not superuser - cannot continue.';
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_superuser(); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_superuser() IS 'Function that can be used to make sure that patch is being applied using superuser account.';
-
-
---
--- Name: register_patch(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(text) RETURNS SETOF integer
- LANGUAGE sql
- AS $_$
- SELECT _v.register_patch( $1, NULL, NULL );
-$_$;
-
-
---
--- Name: FUNCTION register_patch(text); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(text) IS 'Wrapper to allow registration of patches without requirements and conflicts.';
-
-
---
--- Name: register_patch(text, text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(text, text[]) RETURNS SETOF integer
- LANGUAGE sql
- AS $_$
- SELECT _v.register_patch( $1, $2, NULL );
-$_$;
-
-
---
--- Name: FUNCTION register_patch(text, text[]); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(text, text[]) IS 'Wrapper to allow registration of patches without conflicts.';
-
-
---
--- Name: register_patch(text, text[], text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer) RETURNS SETOF integer
- LANGUAGE plpgsql
- AS $$
-DECLARE
- t_text TEXT;
- t_text_a TEXT[];
- i INT4;
-BEGIN
- -- Thanks to this we know only one patch will be applied at a time
- LOCK TABLE _v.patches IN EXCLUSIVE MODE;
-
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_patch_name;
- IF FOUND THEN
- RAISE EXCEPTION 'Patch % is already applied!', in_patch_name;
- END IF;
-
- t_text_a := ARRAY( SELECT patch_name FROM _v.patches WHERE patch_name = any( in_conflicts ) );
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Versioning patches conflict. Conflicting patche(s) installed: %.', array_to_string( t_text_a, ', ' );
- END IF;
-
- IF array_upper( in_requirements, 1 ) IS NOT NULL THEN
- t_text_a := '{}';
- FOR i IN array_lower( in_requirements, 1 ) .. array_upper( in_requirements, 1 ) LOOP
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_requirements[i];
- IF NOT FOUND THEN
- t_text_a := t_text_a || in_requirements[i];
- END IF;
- END LOOP;
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Missing prerequisite(s): %.', array_to_string( t_text_a, ', ' );
- END IF;
- END IF;
-
- INSERT INTO _v.patches (patch_name, applied_tsz, applied_by, requires, conflicts ) VALUES ( in_patch_name, now(), current_user, coalesce( in_requirements, '{}' ), coalesce( in_conflicts, '{}' ) );
- RETURN;
-END;
-$$;
-
-
---
--- Name: FUNCTION register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer) IS 'Function to register patches in database. Raises exception if there are conflicts, prerequisites are not installed or the migration has already been installed.';
-
-
---
--- Name: unregister_patch(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.unregister_patch(in_patch_name text, OUT versioning integer) RETURNS SETOF integer
- LANGUAGE plpgsql
- AS $$
-DECLARE
- i INT4;
- t_text_a TEXT[];
-BEGIN
- -- Thanks to this we know only one patch will be applied at a time
- LOCK TABLE _v.patches IN EXCLUSIVE MODE;
-
- t_text_a := ARRAY( SELECT patch_name FROM _v.patches WHERE in_patch_name = ANY( requires ) );
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Cannot uninstall %, as it is required by: %.', in_patch_name, array_to_string( t_text_a, ', ' );
- END IF;
-
- DELETE FROM _v.patches WHERE patch_name = in_patch_name;
- GET DIAGNOSTICS i = ROW_COUNT;
- IF i < 1 THEN
- RAISE EXCEPTION 'Patch % is not installed, so it can''t be uninstalled!', in_patch_name;
- END IF;
-
- RETURN;
-END;
-$$;
-
-
---
--- Name: FUNCTION unregister_patch(in_patch_name text, OUT versioning integer); Type: COMMENT; Schema: _v; Owner: -
---
-
-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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_legitimizations_partition(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.add_constraints_to_legitimizations_partition(partition_suffix character varying) RETURNS void
- LANGUAGE plpgsql
- AS $$
-DECLARE
- partition_name VARCHAR;
-BEGIN
- partition_name = concat_ws('_', 'legitimizations', partition_suffix);
- EXECUTE FORMAT (
- 'ALTER TABLE ' || partition_name
- || ' '
- 'ADD CONSTRAINT ' || partition_name || '_legitimization_serial_id_key '
- 'UNIQUE (legitimization_serial_id)');
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || partition_name || '_by_provider_and_legi_index '
- 'ON '|| partition_name || ' '
- '(provider_section,provider_legitimization_id)'
- );
- EXECUTE FORMAT (
- 'COMMENT ON INDEX ' || partition_name || '_by_provider_and_legi_index '
- 'IS ' || quote_literal('used (rarely) in kyc_provider_account_lookup') || ';'
- );
-END
-$$;
-
-
---
--- Name: add_constraints_to_purse_deposits_partition(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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);
- 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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_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
- );
- 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',wallet_h_payto BYTEA NOT NULL CHECK (LENGTH(wallet_h_payto)=32)'
- ',PRIMARY KEY (purse_pub)'
- ') %s ;'
- ,table_name
- ,'PARTITION BY HASH (purse_pub)'
- ,shard_suffix
- );
- table_name = concat_ws('_', table_name, shard_suffix);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',deposit_serial_id INT8 PRIMARY KEY'
- ',wtid_raw BYTEA NOT NULL'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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)'
- ',merchant_pub BYTEA CHECK (LENGTH(merchant_pub)=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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',shard INT8 NOT NULL'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',known_coin_id INT8 NOT NULL'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',denominations_serial INT8 NOT NULL'
- ',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)'
- ,shard_suffix
- );
- table_name = concat_ws('_', table_name, shard_suffix);
-END
-$$;
-
-
---
--- Name: create_table_legitimizations(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.create_table_legitimizations(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
- LANGUAGE plpgsql
- AS $$
-BEGIN
- PERFORM create_partitioned_table(
- 'CREATE TABLE IF NOT EXISTS %I'
- '(legitimization_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY'
- ',h_payto BYTEA NOT NULL CHECK (LENGTH(h_payto)=32)'
- ',expiration_time INT8 NOT NULL DEFAULT (0)'
- ',provider_section VARCHAR NOT NULL'
- ',provider_user_id VARCHAR DEFAULT NULL'
- ',provider_legitimization_id VARCHAR DEFAULT NULL'
- ',UNIQUE (h_payto, provider_section)'
- ') %s ;'
- ,'legitimizations'
- ,'PARTITION BY HASH (h_payto)'
- ,shard_suffix
- );
-END
-$$;
-
-
---
--- Name: create_table_prewire(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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') || ';'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',partner_serial_id INT8'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',coin_pub BYTEA NOT NULL'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 '
- ',partner_serial_id INT8'
- ',reserve_pub BYTEA NOT NULL CHECK(length(reserve_pub)=32)'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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);
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || table_name || '_merge_pub '
- 'ON ' || table_name || ' '
- '(merge_pub);'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA CHECK (LENGTH(coin_pub)=32)'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',known_coin_id BIGINT NOT NULL'
- ',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'
- ') %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_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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',rc BYTEA PRIMARY KEY CHECK (LENGTH(rc)=64)'
- ',old_coin_pub BYTEA NOT NULL'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',melt_serial_id INT8 NOT NULL'
- ',freshcoin_index INT4 NOT NULL'
- ',link_sig BYTEA NOT NULL CHECK(LENGTH(link_sig)=64)'
- ',denominations_serial INT8 NOT NULL'
- ',coin_ev BYTEA NOT NULL'
- ',h_coin_ev BYTEA NOT NULL CHECK(LENGTH(h_coin_ev)=64)'
- ',ev_sig BYTEA NOT NULL'
- ',ewv BYTEA NOT NULL'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',melt_serial_id INT8 PRIMARY KEY'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',deposit_serial_id INT8 NOT NULL'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA PRIMARY KEY'
- ',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);'
- );
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_exch_accnt_section_execution_date_idx '
- 'ON ' || table_name || ' '
- '(exchange_account_section '
- ',execution_date'
- ');'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',h_blind_ev BYTEA CHECK (LENGTH(h_blind_ev)=64) UNIQUE'
- ',denominations_serial INT8 NOT NULL'
- ',denom_sig BYTEA NOT NULL'
- ',reserve_uuid INT8 NOT NULL'
- ',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);'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_in_serial_id INT8'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_out_serial_id INT8'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_id BYTEA PRIMARY KEY CHECK (LENGTH(wad_id)=24)'
- ',partner_serial_id INT8 NOT NULL'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE PROCEDURE exchange.defer_wire_out()
- LANGUAGE plpgsql
- AS $$
-BEGIN
-
-IF EXISTS (
- SELECT 1
- FROM exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_delete_trigger() IS 'Replicate deposit deletions into materialized indices.';
-
-
---
--- Name: deposits_insert_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_insert_trigger() IS 'Replicate deposit inserts into materialized indices.';
-
-
---
--- Name: deposits_update_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_update_trigger() IS 'Replicate deposits changes into materialized indices.';
-
-
---
--- Name: detach_default_partitions(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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;
- 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 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 exchange.reserves
- WHERE reserves.reserve_pub=rpub;
-
-IF NOT FOUND
-THEN
- -- reserve unknown
- reserve_found=FALSE;
- balance_ok=FALSE;
- 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;
- 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;
-
-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 ruuid bigint); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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, bigint, bytea); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.exchange_do_close_request(in_reserve_pub bytea, in_close_timestamp bigint, 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
-
- SELECT
- current_balance_val
- ,current_balance_frac
- INTO
- out_final_balance_val
- ,out_final_balance_frac
- FROM exchange.reserves
- WHERE reserve_pub=in_reserve_pub;
-
- IF NOT FOUND
- THEN
- out_final_balance_val=0;
- out_final_balance_frac=0;
- out_balance_ok = FALSE;
- out_conflict = FALSE;
- END IF;
-
- INSERT INTO exchange.close_requests
- (reserve_pub
- ,close_timestamp
- ,reserve_sig
- ,close_val
- ,close_frac)
- VALUES
- (in_reserve_pub
- ,in_close_timestamp
- ,in_reserve_sig
- ,out_final_balance_val
- ,out_final_balance_frac)
- ON CONFLICT DO NOTHING;
- out_conflict = NOT FOUND;
-
- UPDATE reserves SET
- current_balance_val=0
- ,current_balance_frac=0
- WHERE reserve_pub=in_reserve_pub;
- out_balance_ok = TRUE;
-
-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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.extension_details
- (extension_options)
- VALUES
- (in_extension_details)
- RETURNING extension_details_serial_id INTO xdi;
-ELSE
- xdi=NULL;
-END IF;
-
-
-INSERT INTO exchange.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 exchange.wire_targets
- WHERE wire_target_h_payto=in_h_payto;
-END IF;
-
-
-INSERT INTO exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE PROCEDURE exchange.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 exchange.prewire
- WHERE finished=TRUE;
-
-DELETE FROM exchange.wire_fee
- WHERE end_date < in_ancient_date;
-
--- TODO: use closing fee as threshold?
-DELETE FROM exchange.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 exchange.reserves_out
- ORDER BY reserve_out_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.recoup
- WHERE reserve_out_serial_id < reserve_out_min;
--- FIXME: recoup_refresh lacks GC!
-
-SELECT
- reserve_uuid
- INTO
- reserve_uuid_min
- FROM exchange.reserves
- ORDER BY reserve_uuid ASC
- LIMIT 1;
-
-DELETE FROM exchange.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 exchange.denominations
- WHERE expire_legal < in_now
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.reserves_out)
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.known_coins
- WHERE coin_pub IN
- (SELECT DISTINCT coin_pub
- FROM exchange.recoup))
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.known_coins
- WHERE coin_pub IN
- (SELECT DISTINCT coin_pub
- FROM exchange.recoup_refresh));
-
-SELECT
- melt_serial_id
- INTO
- melt_min
- FROM exchange.refresh_commitments
- ORDER BY melt_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.refresh_revealed_coins
- WHERE melt_serial_id < melt_min;
-
-DELETE FROM exchange.refresh_transfer_keys
- WHERE melt_serial_id < melt_min;
-
-SELECT
- known_coin_id
- INTO
- coin_min
- FROM exchange.known_coins
- ORDER BY known_coin_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.deposits
- WHERE known_coin_id < coin_min;
-
-SELECT
- deposit_serial_id
- INTO
- deposit_min
- FROM exchange.deposits
- ORDER BY deposit_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.refunds
- WHERE deposit_serial_id < deposit_min;
-
-DELETE FROM exchange.aggregation_tracking
- WHERE deposit_serial_id < deposit_min;
-
-SELECT
- denominations_serial
- INTO
- denom_min
- FROM exchange.denominations
- ORDER BY denominations_serial ASC
- LIMIT 1;
-
-DELETE FROM exchange.cs_nonce_locks
- WHERE max_denomination_serial <= denom_min;
-
-END $$;
-
-
---
--- Name: exchange_do_history_request(bytea, bytea, bigint, bigint, integer); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.recoup_refresh
- WHERE rrc_serial IN
- (SELECT rrc_serial
- FROM exchange.refresh_revealed_coins
- WHERE melt_serial_id IN
- (SELECT melt_serial_id
- FROM exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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, bytea, boolean); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_wallet_h_payto 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 exchange.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 exchange.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 exchange.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 exchange.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 exchange.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 exchange.account_merges
- (reserve_pub
- ,reserve_sig
- ,purse_pub
- ,wallet_h_payto)
- VALUES
- (in_reserve_pub
- ,in_reserve_sig
- ,in_purse_pub
- ,in_wallet_h_payto);
-
--- 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_wallet_h_payto 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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_wallet_h_payto 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.reserves
- WHERE reserves.reserve_pub = res_pub;
-
- FOR blind_ev IN
- SELECT h_blind_ev
- FROM exchange.reserves_out_by_reserve
- WHERE reserves_out_by_reserve.reserve_uuid = res_uuid
- LOOP
- SELECT robr.coin_pub
- INTO c_pub
- FROM exchange.recoup_by_reserve robr
- WHERE robr.reserve_out_serial_id = (
- SELECT reserves_out.reserve_out_serial_id
- FROM exchange.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 exchange.known_coins
- WHERE known_coins.coin_pub = c_pub
- ) kc
- JOIN (
- SELECT *
- FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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, bytea, boolean); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_wallet_h_payto 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 exchange.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 exchange.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 exchange.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 exchange.account_merges
- (reserve_pub
- ,reserve_sig
- ,purse_pub
- ,wallet_h_payto)
- VALUES
- (in_reserve_pub
- ,in_reserve_sig
- ,in_purse_pub
- ,in_wallet_h_payto);
-
-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_wallet_h_payto 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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_wallet_h_payto 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 nonce_ok boolean, 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 exchange.denominations
- WHERE denom_pub_hash=h_denom_pub;
-
-IF NOT FOUND
-THEN
- -- denomination unknown, should be impossible!
- reserve_found=FALSE;
- balance_ok=FALSE;
- 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 exchange.reserves
- WHERE reserves.reserve_pub=rpub;
-
-IF NOT FOUND
-THEN
- -- reserve unknown
- reserve_found=FALSE;
- balance_ok=FALSE;
- nonce_ok=TRUE;
- ruuid=2;
- RETURN;
-END IF;
-
--- We optimistically insert, and then on conflict declare
--- the query successful due to idempotency.
-INSERT INTO exchange.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;
- nonce_ok=TRUE;
- 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;
- nonce_ok=TRUE; -- we do not really know
- balance_ok=FALSE;
- 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 exchange.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 exchange.cs_nonce_locks
- WHERE nonce=cs_nonce
- AND op_hash=h_coin_envelope;
- IF NOT FOUND
- THEN
- reserve_found=FALSE;
- balance_ok=FALSE;
- nonce_ok=FALSE;
- RETURN;
- END IF;
- END IF;
-ELSE
- nonce_ok=TRUE; -- no nonce, hence OK!
-END IF;
-
-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 nonce_ok boolean, OUT ruuid bigint); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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 nonce_ok boolean, 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.purse_requests_on_update_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- IF (NEW.finished AND NOT OLD.finished)
- THEN
- IF (NEW.in_reserve_quota)
- THEN
- UPDATE reserves
- SET purses_active=purses_active-1
- WHERE reserve_pub IN
- (SELECT reserve_pub
- FROM exchange.purse_merges
- WHERE purse_pub=NEW.purse_pub
- LIMIT 1);
- NEW.in_reserve_quota=FALSE;
- END IF;
- DELETE FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.recoup_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.recoup_delete_trigger() IS 'Replicate recoup deletions into recoup_by_reserve table.';
-
-
---
--- Name: recoup_insert_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.recoup_insert_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- INSERT INTO exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.recoup_insert_trigger() IS 'Replicate recoup inserts into recoup_by_reserve table.';
-
-
---
--- Name: reserves_out_by_reserve_delete_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.reserves_out_by_reserve_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.reserves_out_by_reserve
- WHERE reserve_uuid = OLD.reserve_uuid;
- RETURN OLD;
-END $$;
-
-
---
--- Name: FUNCTION reserves_out_by_reserve_delete_trigger(); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.reserves_out_by_reserve_insert_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- INSERT INTO exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.wire_out_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.aggregation_tracking
- WHERE wtid_raw = OLD.wtid_raw;
- RETURN OLD;
-END $$;
-
-
---
--- Name: FUNCTION wire_out_delete_trigger(); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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;
-
---
--- Name: patches; Type: TABLE; Schema: _v; Owner: -
---
-
-CREATE TABLE _v.patches (
- patch_name text NOT NULL,
- applied_tsz timestamp with time zone DEFAULT now() NOT NULL,
- applied_by text NOT NULL,
- requires text[],
- conflicts text[]
-);
-
-
---
--- Name: TABLE patches; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON TABLE _v.patches IS 'Contains information about what patches are currently applied on database.';
-
-
---
--- Name: COLUMN patches.patch_name; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.patch_name IS 'Name of patch, has to be unique for every patch.';
-
-
---
--- Name: COLUMN patches.applied_tsz; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.applied_tsz IS 'When the patch was applied.';
-
-
---
--- Name: COLUMN patches.applied_by; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.applied_by IS 'Who applied this patch (PostgreSQL username)';
-
-
---
--- Name: COLUMN patches.requires; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.requires IS 'List of patches that are required for given patch.';
-
-
---
--- Name: COLUMN patches.conflicts; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.conflicts IS 'List of patches that conflict with given patch.';
-
-
---
--- Name: auditor_balance_summary; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_balance_summary (
- master_pub bytea NOT NULL,
- denom_balance_val bigint NOT NULL,
- denom_balance_frac integer NOT NULL,
- deposit_fee_balance_val bigint NOT NULL,
- deposit_fee_balance_frac integer NOT NULL,
- melt_fee_balance_val bigint NOT NULL,
- melt_fee_balance_frac integer NOT NULL,
- refund_fee_balance_val bigint NOT NULL,
- refund_fee_balance_frac integer NOT NULL,
- risk_val bigint NOT NULL,
- risk_frac integer NOT NULL,
- loss_val bigint NOT NULL,
- loss_frac integer NOT NULL,
- irregular_recoup_val bigint NOT NULL,
- irregular_recoup_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_balance_summary; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_balance_summary IS 'the sum of the outstanding coins from auditor_denomination_pending (denom_pubs must belong to the respectives exchange master public key); it represents the auditor_balance_summary of the exchange at this point (modulo unexpected historic_loss-style events where denomination keys are compromised)';
-
-
---
--- Name: auditor_denomination_pending; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_denomination_pending (
- denom_pub_hash bytea NOT NULL,
- denom_balance_val bigint NOT NULL,
- denom_balance_frac integer NOT NULL,
- denom_loss_val bigint NOT NULL,
- denom_loss_frac integer NOT NULL,
- num_issued bigint NOT NULL,
- denom_risk_val bigint NOT NULL,
- denom_risk_frac integer NOT NULL,
- recoup_loss_val bigint NOT NULL,
- recoup_loss_frac integer NOT NULL,
- CONSTRAINT auditor_denomination_pending_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64))
-);
-
-
---
--- Name: TABLE auditor_denomination_pending; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_denomination_pending IS 'outstanding denomination coins that the exchange is aware of and what the respective balances are (outstanding as well as issued overall which implies the maximum value at risk).';
-
-
---
--- Name: COLUMN auditor_denomination_pending.num_issued; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.num_issued IS 'counts the number of coins issued (withdraw, refresh) of this denomination';
-
-
---
--- Name: COLUMN auditor_denomination_pending.denom_risk_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.denom_risk_val IS 'amount that could theoretically be lost in the future due to recoup operations';
-
-
---
--- Name: COLUMN auditor_denomination_pending.recoup_loss_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.recoup_loss_val IS 'amount actually lost due to recoup operations past revocation';
-
-
---
--- Name: auditor_exchange_signkeys; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_exchange_signkeys (
- master_pub bytea NOT NULL,
- ep_start bigint NOT NULL,
- ep_expire bigint NOT NULL,
- ep_end bigint NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT auditor_exchange_signkeys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT auditor_exchange_signkeys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE auditor_exchange_signkeys; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_exchange_signkeys IS 'list of the online signing keys of exchanges we are auditing';
-
-
---
--- Name: auditor_exchanges; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_exchanges (
- master_pub bytea NOT NULL,
- exchange_url character varying NOT NULL,
- CONSTRAINT auditor_exchanges_master_pub_check CHECK ((length(master_pub) = 32))
-);
-
-
---
--- Name: TABLE auditor_exchanges; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_exchanges IS 'list of the exchanges we are auditing';
-
-
---
--- Name: auditor_historic_denomination_revenue; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_historic_denomination_revenue (
- master_pub bytea NOT NULL,
- denom_pub_hash bytea NOT NULL,
- revenue_timestamp bigint NOT NULL,
- revenue_balance_val bigint NOT NULL,
- revenue_balance_frac integer NOT NULL,
- loss_balance_val bigint NOT NULL,
- loss_balance_frac integer NOT NULL,
- CONSTRAINT auditor_historic_denomination_revenue_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64))
-);
-
-
---
--- Name: TABLE auditor_historic_denomination_revenue; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_historic_denomination_revenue IS 'Table with historic profits; basically, when a denom_pub has expired and everything associated with it is garbage collected, the final profits end up in here; note that the denom_pub here is not a foreign key, we just keep it as a reference point.';
-
-
---
--- Name: COLUMN auditor_historic_denomination_revenue.revenue_balance_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_historic_denomination_revenue.revenue_balance_val IS 'the sum of all of the profits we made on the coin except for withdraw fees (which are in historic_reserve_revenue); so this includes the deposit, melt and refund fees';
-
-
---
--- Name: auditor_historic_reserve_summary; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_historic_reserve_summary (
- master_pub bytea NOT NULL,
- start_date bigint NOT NULL,
- end_date bigint NOT NULL,
- reserve_profits_val bigint NOT NULL,
- reserve_profits_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_historic_reserve_summary; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_historic_reserve_summary IS 'historic profits from reserves; we eventually GC auditor_historic_reserve_revenue, and then store the totals in here (by time intervals).';
-
-
---
--- Name: auditor_predicted_result; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_predicted_result (
- master_pub bytea NOT NULL,
- balance_val bigint NOT NULL,
- balance_frac integer NOT NULL,
- drained_val bigint NOT NULL,
- drained_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_predicted_result; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_predicted_result IS 'Table with the sum of the ledger, auditor_historic_revenue and the auditor_reserve_balance and the drained profits. This is the final amount that the exchange should have in its bank account right now (and the total amount drained as profits to non-escrow accounts).';
-
-
---
--- Name: auditor_progress_aggregation; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_aggregation (
- master_pub bytea NOT NULL,
- last_wire_out_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_aggregation; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_aggregation 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: auditor_progress_coin; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_coin (
- master_pub bytea NOT NULL,
- last_withdraw_serial_id bigint DEFAULT 0 NOT NULL,
- last_deposit_serial_id bigint DEFAULT 0 NOT NULL,
- 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_purse_deposits_serial_id bigint DEFAULT 0 NOT NULL,
- last_purse_refunds_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_coin; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_coin 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: auditor_progress_deposit_confirmation; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_deposit_confirmation (
- master_pub bytea NOT NULL,
- last_deposit_confirmation_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_deposit_confirmation; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_deposit_confirmation 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: auditor_progress_reserve; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_reserve (
- master_pub bytea NOT NULL,
- 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_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
-);
-
-
---
--- Name: TABLE auditor_progress_reserve; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_reserve 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: auditor_reserve_balance; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_reserve_balance (
- master_pub bytea NOT NULL,
- 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,
- 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
-);
-
-
---
--- Name: TABLE auditor_reserve_balance; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_reserve_balance IS 'sum of the balances of all customer reserves (by exchange master public key)';
-
-
---
--- Name: auditor_reserves; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_reserves (
- reserve_pub bytea NOT NULL,
- master_pub bytea NOT NULL,
- 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,
- expiration_date bigint NOT NULL,
- auditor_reserves_rowid bigint NOT NULL,
- origin_account text,
- CONSTRAINT auditor_reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
-);
-
-
---
--- Name: TABLE auditor_reserves; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_reserves IS 'all of the customer reserves and their respective balances that the auditor is aware of';
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE; Schema: auditor; Owner: -
---
-
-CREATE SEQUENCE auditor.auditor_reserves_auditor_reserves_rowid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE OWNED BY; Schema: auditor; Owner: -
---
-
-ALTER SEQUENCE auditor.auditor_reserves_auditor_reserves_rowid_seq OWNED BY auditor.auditor_reserves.auditor_reserves_rowid;
-
-
---
--- Name: auditor_wire_fee_balance; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_wire_fee_balance (
- master_pub bytea NOT NULL,
- wire_fee_balance_val bigint NOT NULL,
- wire_fee_balance_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_wire_fee_balance; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_wire_fee_balance IS 'sum of the balances of all wire fees (by exchange master public key)';
-
-
---
--- Name: deposit_confirmations; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.deposit_confirmations (
- master_pub bytea NOT NULL,
- serial_id bigint NOT NULL,
- h_contract_terms bytea NOT NULL,
- h_extensions bytea NOT NULL,
- h_wire bytea NOT NULL,
- exchange_timestamp bigint NOT NULL,
- refund_deadline bigint NOT NULL,
- wire_deadline bigint NOT NULL,
- amount_without_fee_val bigint NOT NULL,
- amount_without_fee_frac integer NOT NULL,
- coin_pub bytea NOT NULL,
- merchant_pub bytea NOT NULL,
- exchange_sig bytea NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT deposit_confirmations_coin_pub_check CHECK ((length(coin_pub) = 32)),
- CONSTRAINT deposit_confirmations_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT deposit_confirmations_exchange_sig_check CHECK ((length(exchange_sig) = 64)),
- CONSTRAINT deposit_confirmations_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
- CONSTRAINT deposit_confirmations_h_contract_terms_check1 CHECK ((length(h_contract_terms) = 64)),
- CONSTRAINT deposit_confirmations_h_wire_check CHECK ((length(h_wire) = 64)),
- CONSTRAINT deposit_confirmations_master_sig_check CHECK ((length(master_sig) = 64)),
- CONSTRAINT deposit_confirmations_merchant_pub_check CHECK ((length(merchant_pub) = 32))
-);
-
-
---
--- Name: TABLE deposit_confirmations; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.deposit_confirmations IS 'deposit confirmation sent to us by merchants; we must check that the exchange reported these properly.';
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE; Schema: auditor; Owner: -
---
-
-CREATE SEQUENCE auditor.deposit_confirmations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: auditor; Owner: -
---
-
-ALTER SEQUENCE auditor.deposit_confirmations_serial_id_seq OWNED BY auditor.deposit_confirmations.serial_id;
-
-
---
--- Name: wire_auditor_account_progress; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.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: TABLE wire_auditor_account_progress; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.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: wire_auditor_progress; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.wire_auditor_progress (
- master_pub bytea NOT NULL,
- last_timestamp bigint NOT NULL,
- last_reserve_close_uuid bigint NOT NULL
-);
-
-
---
--- Name: account_merges; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- wallet_h_payto 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)),
- CONSTRAINT account_merges_wallet_h_payto_check CHECK ((length(wallet_h_payto) = 32))
-)
-PARTITION BY HASH (purse_pub);
-
-
---
--- Name: TABLE account_merges; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.account_merges.reserve_pub IS 'public key of the target reserve';
-
-
---
--- Name: COLUMN account_merges.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.account_merges.purse_pub IS 'public key of the purse';
-
-
---
--- Name: account_merges_account_merge_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.account_merges ALTER COLUMN account_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- wallet_h_payto 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)),
- CONSTRAINT account_merges_wallet_h_payto_check CHECK ((length(wallet_h_payto) = 32))
-);
-ALTER TABLE ONLY exchange.account_merges ATTACH PARTITION exchange.account_merges_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: aggregation_tracking; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_tracking (
- aggregation_serial_id bigint NOT NULL,
- deposit_serial_id bigint NOT NULL,
- wtid_raw bytea NOT NULL
-)
-PARTITION BY HASH (deposit_serial_id);
-
-
---
--- Name: TABLE aggregation_tracking; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.aggregation_tracking IS 'mapping from wire transfer identifiers (WTID) to deposits (and back)';
-
-
---
--- Name: COLUMN aggregation_tracking.wtid_raw; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_tracking.wtid_raw IS 'identifier of the wire transfer';
-
-
---
--- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.aggregation_tracking ALTER COLUMN aggregation_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.aggregation_tracking_aggregation_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: aggregation_tracking_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_tracking_default (
- aggregation_serial_id bigint NOT NULL,
- deposit_serial_id bigint NOT NULL,
- wtid_raw bytea NOT NULL
-);
-ALTER TABLE ONLY exchange.aggregation_tracking ATTACH PARTITION exchange.aggregation_tracking_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: aggregation_transient; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_transient (
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- wire_target_h_payto bytea,
- merchant_pub bytea,
- exchange_account_section text NOT NULL,
- wtid_raw bytea NOT NULL,
- CONSTRAINT aggregation_transient_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
- 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: TABLE aggregation_transient; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_transient.amount_val IS 'Sum of all of the aggregated deposits (without deposit fees)';
-
-
---
--- Name: COLUMN aggregation_transient.wtid_raw; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_transient.wtid_raw IS 'identifier of the wire transfer';
-
-
---
--- Name: aggregation_transient_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_transient_default (
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- wire_target_h_payto bytea,
- merchant_pub bytea,
- exchange_account_section text NOT NULL,
- wtid_raw bytea NOT NULL,
- CONSTRAINT aggregation_transient_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
- 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 exchange.aggregation_transient ATTACH PARTITION exchange.aggregation_transient_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: auditor_denom_sigs; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.auditor_denom_sigs (
- auditor_denom_serial bigint NOT NULL,
- auditor_uuid bigint NOT NULL,
- denominations_serial bigint NOT NULL,
- auditor_sig bytea,
- CONSTRAINT auditor_denom_sigs_auditor_sig_check CHECK ((length(auditor_sig) = 64))
-);
-
-
---
--- Name: TABLE auditor_denom_sigs; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.auditor_denom_sigs IS 'Table with auditor signatures on exchange denomination keys.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.auditor_uuid; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.auditor_uuid IS 'Identifies the auditor.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.denominations_serial IS 'Denomination the signature is for.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.auditor_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.auditor_sig IS 'Signature of the auditor, of purpose TALER_SIGNATURE_AUDITOR_EXCHANGE_KEYS.';
-
-
---
--- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.auditor_denom_sigs ALTER COLUMN auditor_denom_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.auditor_denom_sigs_auditor_denom_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: auditors; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.auditors (
- auditor_uuid bigint NOT NULL,
- auditor_pub bytea NOT NULL,
- auditor_name character varying NOT NULL,
- auditor_url character varying NOT NULL,
- is_active boolean NOT NULL,
- last_change bigint NOT NULL,
- CONSTRAINT auditors_auditor_pub_check CHECK ((length(auditor_pub) = 32))
-);
-
-
---
--- Name: TABLE auditors; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.auditors IS 'Table with auditors the exchange uses or has used in the past. Entries never expire as we need to remember the last_change column indefinitely.';
-
-
---
--- Name: COLUMN auditors.auditor_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.auditor_pub IS 'Public key of the auditor.';
-
-
---
--- Name: COLUMN auditors.auditor_url; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.auditor_url IS 'The base URL of the auditor.';
-
-
---
--- Name: COLUMN auditors.is_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.is_active IS 'true if we are currently supporting the use of this auditor.';
-
-
---
--- Name: COLUMN auditors.last_change; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
-
-
---
--- Name: auditors_auditor_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.auditors ALTER COLUMN auditor_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.auditors_auditor_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: close_requests; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.close_requests IS 'Explicit requests by a reserve owner to close a reserve immediately';
-
-
---
--- Name: COLUMN close_requests.close_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.close_requests.close_timestamp IS 'When the request was created by the client';
-
-
---
--- Name: COLUMN close_requests.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.close_requests.reserve_sig IS 'Signature affirming that the reserve is to be closed';
-
-
---
--- Name: COLUMN close_requests.close_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.close_requests ALTER COLUMN close_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.close_requests ATTACH PARTITION exchange.close_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: contracts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.contracts IS 'encrypted contracts associated with purses';
-
-
---
--- Name: COLUMN contracts.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.purse_pub IS 'public key of the purse that the contract is associated with';
-
-
---
--- Name: COLUMN contracts.pub_ckey; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.contract_sig IS 'signature over the encrypted contract by the purse contract key';
-
-
---
--- Name: COLUMN contracts.e_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.e_contract IS 'AES-GCM encrypted contract terms (contains gzip compressed JSON after decryption)';
-
-
---
--- Name: contracts_contract_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.contracts ALTER COLUMN contract_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.contracts_contract_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: contracts_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.contracts ATTACH PARTITION exchange.contracts_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: cs_nonce_locks; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.cs_nonce_locks.nonce IS 'actual nonce submitted by the client';
-
-
---
--- Name: COLUMN cs_nonce_locks.op_hash; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.cs_nonce_locks ALTER COLUMN cs_nonce_lock_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.cs_nonce_locks ATTACH PARTITION exchange.cs_nonce_locks_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: denomination_revocations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.denomination_revocations (
- denom_revocations_serial_id bigint NOT NULL,
- denominations_serial bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT denomination_revocations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE denomination_revocations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.denomination_revocations IS 'remembering which denomination keys have been revoked';
-
-
---
--- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.denomination_revocations ALTER COLUMN denom_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.denomination_revocations_denom_revocations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: denominations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.denominations (
- denominations_serial bigint NOT NULL,
- denom_pub_hash bytea NOT NULL,
- denom_type integer DEFAULT 1 NOT NULL,
- age_mask integer DEFAULT 0 NOT NULL,
- denom_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- valid_from bigint NOT NULL,
- expire_withdraw bigint NOT NULL,
- expire_deposit bigint NOT NULL,
- expire_legal bigint NOT NULL,
- coin_val bigint NOT NULL,
- coin_frac integer NOT NULL,
- fee_withdraw_val bigint NOT NULL,
- fee_withdraw_frac integer NOT NULL,
- fee_deposit_val bigint NOT NULL,
- fee_deposit_frac integer NOT NULL,
- fee_refresh_val bigint NOT NULL,
- fee_refresh_frac integer NOT NULL,
- fee_refund_val bigint NOT NULL,
- fee_refund_frac integer NOT NULL,
- CONSTRAINT denominations_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64)),
- CONSTRAINT denominations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE denominations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.denominations IS 'Main denominations table. All the valid denominations the exchange knows about.';
-
-
---
--- Name: COLUMN denominations.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.denominations.denominations_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN denominations.denom_type; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.denominations.denom_type IS 'determines cipher type for blind signatures used with this denomination; 0 is for RSA';
-
-
---
--- Name: COLUMN denominations.age_mask; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.denominations ALTER COLUMN denominations_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.denominations_denominations_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: deposits; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE deposits; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits IS 'Deposits we have received and for which we need to make (aggregate) wire transfers (and manage refunds).';
-
-
---
--- Name: COLUMN deposits.shard; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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.known_coin_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.known_coin_id IS 'Used for garbage collection';
-
-
---
--- Name: COLUMN deposits.wire_salt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.wire_salt IS 'Salt used when hashing the payto://-URI to get the h_wire';
-
-
---
--- Name: COLUMN deposits.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.wire_target_h_payto IS 'Identifies the target bank account and KYC status';
-
-
---
--- Name: COLUMN deposits.done; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.done IS 'Set to TRUE once we have included this deposit in some aggregate wire transfer to the merchant';
-
-
---
--- Name: COLUMN deposits.extension_blocked; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.extension_blocked IS 'True if the aggregation of the deposit is currently blocked by some extension mechanism. Used to filter out deposits that must not be processed by the canonical deposit logic.';
-
-
---
--- Name: COLUMN deposits.extension_details_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.extension_details_serial_id IS 'References extensions table, NULL if extensions are not used';
-
-
---
--- Name: deposits_by_ready; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits_by_ready IS 'Enables fast lookups for deposits_get_ready, auto-populated via TRIGGER below';
-
-
---
--- Name: deposits_by_ready_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits_by_ready ATTACH PARTITION exchange.deposits_by_ready_default DEFAULT;
-
-
---
--- Name: deposits_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits ATTACH PARTITION exchange.deposits_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.deposits ALTER COLUMN deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.deposits_deposit_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: deposits_for_matching; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits_for_matching IS 'Enables fast lookups for deposits_iterate_matching, auto-populated via TRIGGER below';
-
-
---
--- Name: deposits_for_matching_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits_for_matching ATTACH PARTITION exchange.deposits_for_matching_default DEFAULT;
-
-
---
--- Name: exchange_sign_keys; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.exchange_sign_keys (
- esk_serial bigint NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- valid_from bigint NOT NULL,
- expire_sign bigint NOT NULL,
- expire_legal bigint NOT NULL,
- CONSTRAINT exchange_sign_keys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT exchange_sign_keys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE exchange_sign_keys; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.exchange_sign_keys IS 'Table with master public key signatures on exchange online signing keys.';
-
-
---
--- Name: COLUMN exchange_sign_keys.exchange_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.exchange_pub IS 'Public online signing key of the exchange.';
-
-
---
--- Name: COLUMN exchange_sign_keys.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.master_sig IS 'Signature affirming the validity of the signing key of purpose TALER_SIGNATURE_MASTER_SIGNING_KEY_VALIDITY.';
-
-
---
--- Name: COLUMN exchange_sign_keys.valid_from; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.valid_from IS 'Time when this online signing key will first be used to sign messages.';
-
-
---
--- Name: COLUMN exchange_sign_keys.expire_sign; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.expire_sign IS 'Time when this online signing key will no longer be used to sign.';
-
-
---
--- Name: COLUMN exchange_sign_keys.expire_legal; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.expire_legal IS 'Time when this online signing key legally expires.';
-
-
---
--- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.exchange_sign_keys ALTER COLUMN esk_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.exchange_sign_keys_esk_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: extension_details; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extension_details (
- extension_details_serial_id bigint NOT NULL,
- extension_options character varying
-)
-PARTITION BY HASH (extension_details_serial_id);
-
-
---
--- Name: TABLE extension_details; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.extension_details IS 'Extensions that were provided with deposits (not yet used).';
-
-
---
--- Name: COLUMN extension_details.extension_options; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extension_details.extension_options IS 'JSON object with options set that the exchange needs to consider when executing a deposit. Supported details depend on the extensions supported by the exchange.';
-
-
---
--- Name: extension_details_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extension_details_default (
- extension_details_serial_id bigint NOT NULL,
- extension_options character varying
-);
-ALTER TABLE ONLY exchange.extension_details ATTACH PARTITION exchange.extension_details_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.extension_details ALTER COLUMN extension_details_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.extension_details_extension_details_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: extensions; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extensions (
- extension_id bigint NOT NULL,
- name character varying NOT NULL,
- config bytea
-);
-
-
---
--- Name: TABLE extensions; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.extensions IS 'Configurations of the activated extensions';
-
-
---
--- Name: COLUMN extensions.name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extensions.name IS 'Name of the extension';
-
-
---
--- Name: COLUMN extensions.config; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extensions.config IS 'Configuration of the extension as JSON-blob, maybe NULL';
-
-
---
--- Name: extensions_extension_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.extensions ALTER COLUMN extension_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.extensions_extension_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: global_fee; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.global_fee IS 'list of the global fees of this exchange, by date';
-
-
---
--- Name: COLUMN global_fee.global_fee_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.global_fee.global_fee_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: global_fee_global_fee_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.global_fee ALTER COLUMN global_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.global_fee_global_fee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: history_requests; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.history_requests IS 'Paid history requests issued by a client against a reserve';
-
-
---
--- Name: COLUMN history_requests.request_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.request_timestamp IS 'When was the history request made';
-
-
---
--- Name: COLUMN history_requests.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.reserve_sig IS 'Signature approving payment for the history request';
-
-
---
--- Name: COLUMN history_requests.history_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.history_fee_val IS 'History fee approved by the signature';
-
-
---
--- Name: history_requests_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.history_requests ATTACH PARTITION exchange.history_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: history_requests_history_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.history_requests ALTER COLUMN history_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.history_requests_history_request_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: known_coins; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.known_coins (
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE known_coins; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.known_coins IS 'information about coins and their signatures, so we do not have to store the signatures more than once if a coin is involved in multiple operations';
-
-
---
--- Name: COLUMN known_coins.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.coin_pub IS 'EdDSA public key of the coin';
-
-
---
--- Name: COLUMN known_coins.age_commitment_hash; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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)';
-
-
---
--- Name: COLUMN known_coins.denom_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.denom_sig IS 'This is the signature of the exchange that affirms that the coin is a valid coin. The specific signature type depends on denom_type of the denomination.';
-
-
---
--- Name: COLUMN known_coins.remaining_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.remaining_val IS 'Value of the coin that remains to be spent';
-
-
---
--- Name: known_coins_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.known_coins ATTACH PARTITION exchange.known_coins_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.known_coins ALTER COLUMN known_coin_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.known_coins_known_coin_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: kyc_alerts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.kyc_alerts (
- h_payto bytea NOT NULL,
- trigger_type integer NOT NULL,
- CONSTRAINT kyc_alerts_h_payto_check CHECK ((length(h_payto) = 32))
-);
-
-
---
--- Name: TABLE kyc_alerts; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.kyc_alerts IS 'alerts about completed KYC events reliably notifying other components (even if they are not running)';
-
-
---
--- Name: COLUMN kyc_alerts.h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.kyc_alerts.h_payto IS 'hash of the payto://-URI for which the KYC status changed';
-
-
---
--- Name: COLUMN kyc_alerts.trigger_type; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.kyc_alerts.trigger_type IS 'identifies the receiver of the alert, as the same h_payto may require multiple components to be notified';
-
-
---
--- Name: legitimizations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.legitimizations (
- legitimization_serial_id bigint NOT NULL,
- h_payto bytea NOT NULL,
- expiration_time bigint DEFAULT 0 NOT NULL,
- provider_section character varying NOT NULL,
- provider_user_id character varying,
- provider_legitimization_id character varying,
- CONSTRAINT legitimizations_h_payto_check CHECK ((length(h_payto) = 32))
-)
-PARTITION BY HASH (h_payto);
-
-
---
--- Name: TABLE legitimizations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.legitimizations IS 'List of legitimizations (required and completed) by account and provider';
-
-
---
--- Name: COLUMN legitimizations.legitimization_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.legitimization_serial_id IS 'unique ID for this legitimization process at the exchange';
-
-
---
--- Name: COLUMN legitimizations.h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.h_payto IS 'foreign key linking the entry to the wire_targets table, NOT a primary key (multiple legitimizations are possible per wire target)';
-
-
---
--- Name: COLUMN legitimizations.expiration_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.expiration_time IS 'in the future if the respective KYC check was passed successfully';
-
-
---
--- Name: COLUMN legitimizations.provider_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_section IS 'Configuration file section with details about this provider';
-
-
---
--- Name: COLUMN legitimizations.provider_user_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_user_id IS 'Identifier for the user at the provider that was used for the legitimization. NULL if provider is unaware.';
-
-
---
--- Name: COLUMN legitimizations.provider_legitimization_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_legitimization_id IS 'Identifier for the specific legitimization process at the provider. NULL if legitimization was not started.';
-
-
---
--- Name: legitimizations_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.legitimizations_default (
- legitimization_serial_id bigint NOT NULL,
- h_payto bytea NOT NULL,
- expiration_time bigint DEFAULT 0 NOT NULL,
- provider_section character varying NOT NULL,
- provider_user_id character varying,
- provider_legitimization_id character varying,
- CONSTRAINT legitimizations_h_payto_check CHECK ((length(h_payto) = 32))
-);
-ALTER TABLE ONLY exchange.legitimizations ATTACH PARTITION exchange.legitimizations_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: legitimizations_legitimization_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.legitimizations ALTER COLUMN legitimization_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.legitimizations_legitimization_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: partner_accounts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.partners IS 'exchanges we do wad transfers to';
-
-
---
--- Name: COLUMN partners.partner_master_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.partner_master_pub IS 'offline master public key of the partner';
-
-
---
--- Name: COLUMN partners.start_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.start_date IS 'starting date of the partnership';
-
-
---
--- Name: COLUMN partners.end_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.end_date IS 'end date of the partnership';
-
-
---
--- Name: COLUMN partners.next_wad; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.wad_frequency IS 'how often do we promise to do wad transfers';
-
-
---
--- Name: COLUMN partners.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.partner_base_url IS 'base URL of the REST API for this partner';
-
-
---
--- Name: partners_partner_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.partners ALTER COLUMN partner_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.partners_partner_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: prewire; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.prewire (
- 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
-)
-PARTITION BY HASH (prewire_uuid);
-
-
---
--- Name: TABLE prewire; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.prewire IS 'pre-commit data for wire transfers we are about to execute';
-
-
---
--- Name: COLUMN prewire.finished; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.finished IS 'set to TRUE once bank confirmed receiving the wire transfer request';
-
-
---
--- Name: COLUMN prewire.failed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.failed IS 'set to TRUE if the bank responded with a non-transient failure to our transfer request';
-
-
---
--- Name: COLUMN prewire.buf; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.buf IS 'serialized data to send to the bank to execute the wire transfer';
-
-
---
--- Name: prewire_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.prewire ATTACH PARTITION exchange.prewire_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: prewire_prewire_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.prewire ALTER COLUMN prewire_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.prewire_prewire_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: profit_drains; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.profit_drains (
- profit_drain_serial_id bigint NOT NULL,
- wtid bytea NOT NULL,
- account_section character varying NOT NULL,
- payto_uri character varying NOT NULL,
- trigger_date bigint NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac bigint NOT NULL,
- master_sig bytea NOT NULL,
- executed boolean DEFAULT false NOT NULL,
- CONSTRAINT profit_drains_master_sig_check CHECK ((length(master_sig) = 64)),
- CONSTRAINT profit_drains_wtid_check CHECK ((length(wtid) = 32))
-);
-
-
---
--- Name: TABLE profit_drains; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.profit_drains IS 'transactions to be performed to move profits from the escrow account of the exchange to a regular account';
-
-
---
--- Name: COLUMN profit_drains.wtid; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.wtid IS 'randomly chosen nonce, unique to prevent double-submission';
-
-
---
--- Name: COLUMN profit_drains.account_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.account_section IS 'specifies the configuration section in the taler-exchange-drain configuration with the wire account to drain';
-
-
---
--- Name: COLUMN profit_drains.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.payto_uri IS 'specifies the account to be credited';
-
-
---
--- Name: COLUMN profit_drains.trigger_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.trigger_date IS 'set by taler-exchange-offline at the time of making the signature; not necessarily the exact date of execution of the wire transfer, just for orientation';
-
-
---
--- Name: COLUMN profit_drains.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.amount_val IS 'amount to be transferred';
-
-
---
--- Name: COLUMN profit_drains.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.master_sig IS 'EdDSA signature of type TALER_SIGNATURE_MASTER_DRAIN_PROFIT';
-
-
---
--- Name: COLUMN profit_drains.executed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.executed IS 'set to TRUE by taler-exchange-drain on execution of the transaction, not replicated to auditor';
-
-
---
--- Name: profit_drains_profit_drain_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.profit_drains ALTER COLUMN profit_drain_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.profit_drains_profit_drain_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: purse_actions; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE purse_actions; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_actions IS 'purses awaiting some action by the router';
-
-
---
--- Name: COLUMN purse_actions.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_actions.purse_pub IS 'public (contract) key of the purse';
-
-
---
--- Name: COLUMN purse_actions.action_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_actions.action_date IS 'when is the purse ready for action';
-
-
---
--- Name: COLUMN purse_actions.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_deposits IS 'Requests depositing coins into a purse';
-
-
---
--- Name: COLUMN purse_deposits.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN purse_deposits.coin_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.coin_pub IS 'Public key of the coin being deposited';
-
-
---
--- Name: COLUMN purse_deposits.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.amount_with_fee_val IS 'Total amount being deposited';
-
-
---
--- Name: COLUMN purse_deposits.coin_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_deposits ATTACH PARTITION exchange.purse_deposits_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_deposits_purse_deposit_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_deposits ALTER COLUMN purse_deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.reserve_pub IS 'public key of the target reserve';
-
-
---
--- Name: COLUMN purse_merges.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.purse_pub IS 'public key of the purse';
-
-
---
--- Name: COLUMN purse_merges.merge_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.merge_timestamp IS 'when was the merge message signed';
-
-
---
--- Name: purse_merges_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_merges ATTACH PARTITION exchange.purse_merges_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_merges_purse_merge_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_merges ALTER COLUMN purse_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_refunds IS 'Purses that were refunded due to expiration';
-
-
---
--- Name: COLUMN purse_refunds.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_refunds.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: purse_refunds_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_refunds ATTACH PARTITION exchange.purse_refunds_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_refunds_purse_refunds_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_refunds ALTER COLUMN purse_refunds_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN purse_requests.purse_creation; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.purse_expiration IS 'When the purse is set to expire';
-
-
---
--- Name: COLUMN purse_requests.h_contract_terms; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.h_contract_terms IS 'Hash of the contract the parties are to agree to';
-
-
---
--- Name: COLUMN purse_requests.flags; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.flags IS 'see the enum TALER_WalletAccountMergeFlags';
-
-
---
--- Name: COLUMN purse_requests.refunded; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.balance_val IS 'Total amount actually in the purse';
-
-
---
--- Name: COLUMN purse_requests.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_requests ATTACH PARTITION exchange.purse_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_requests_purse_requests_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_requests ALTER COLUMN purse_requests_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.purse_requests_purse_requests_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: recoup; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.recoup (
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE recoup; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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.coin_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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_by_reserve; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup_by_reserve ATTACH PARTITION exchange.recoup_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup ATTACH PARTITION exchange.recoup_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.recoup ALTER COLUMN recoup_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.recoup_recoup_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: recoup_refresh; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- 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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup_refresh ATTACH PARTITION exchange.recoup_refresh_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.recoup_refresh ALTER COLUMN recoup_refresh_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.recoup_refresh_recoup_refresh_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_commitments; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_commitments (
- 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))
-)
-PARTITION BY HASH (rc);
-
-
---
--- Name: TABLE refresh_commitments; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_commitments IS 'Commitments made when melting coins and the gamma value chosen by the exchange.';
-
-
---
--- Name: COLUMN refresh_commitments.rc; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_commitments.old_coin_pub IS 'Coin being melted in the refresh process.';
-
-
---
--- Name: COLUMN refresh_commitments.noreveal_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_commitments ATTACH PARTITION exchange.refresh_commitments_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_commitments ALTER COLUMN melt_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_commitments_melt_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_revealed_coins; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_revealed_coins (
- 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))
-)
-PARTITION BY HASH (melt_serial_id);
-
-
---
--- Name: TABLE refresh_revealed_coins; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_revealed_coins IS 'Revelations about the new coins that are to be created during a melting session.';
-
-
---
--- Name: COLUMN refresh_revealed_coins.rrc_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.rrc_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN refresh_revealed_coins.melt_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.melt_serial_id IS 'Identifies the refresh commitment (rc) of the melt operation.';
-
-
---
--- Name: COLUMN refresh_revealed_coins.freshcoin_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.freshcoin_index IS 'index of the fresh coin being created (one melt operation may result in multiple fresh coins)';
-
-
---
--- Name: COLUMN refresh_revealed_coins.coin_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.coin_ev IS 'envelope of the new coin to be signed';
-
-
---
--- Name: COLUMN refresh_revealed_coins.h_coin_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.h_coin_ev IS 'hash of the envelope of the new coin to be signed (for lookups)';
-
-
---
--- Name: COLUMN refresh_revealed_coins.ev_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.ev_sig IS 'exchange signature over the envelope';
-
-
---
--- Name: COLUMN refresh_revealed_coins.ewv; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.ewv IS 'exchange contributed values in the creation of the fresh coin (see /csr)';
-
-
---
--- Name: refresh_revealed_coins_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_revealed_coins ATTACH PARTITION exchange.refresh_revealed_coins_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_revealed_coins ALTER COLUMN rrc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_revealed_coins_rrc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_transfer_keys; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_transfer_keys (
- 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))
-)
-PARTITION BY HASH (melt_serial_id);
-
-
---
--- Name: TABLE refresh_transfer_keys; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_transfer_keys IS 'Transfer keys of a refresh operation (the data revealed to the exchange).';
-
-
---
--- Name: COLUMN refresh_transfer_keys.rtc_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.rtc_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN refresh_transfer_keys.melt_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.melt_serial_id IS 'Identifies the refresh commitment (rc) of the operation.';
-
-
---
--- Name: COLUMN refresh_transfer_keys.transfer_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.transfer_pub IS 'transfer public key for the gamma index';
-
-
---
--- Name: COLUMN refresh_transfer_keys.transfer_privs; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.transfer_privs IS 'array of TALER_CNC_KAPPA - 1 transfer private keys that have been revealed, with the gamma entry being skipped';
-
-
---
--- Name: refresh_transfer_keys_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_transfer_keys ATTACH PARTITION exchange.refresh_transfer_keys_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_transfer_keys ALTER COLUMN rtc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_transfer_keys_rtc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refunds; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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);
-
-
---
--- Name: TABLE refunds; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refunds IS 'Data on coins that were refunded. Technically, refunds always apply against specific deposit operations involving a coin. The combination of coin_pub, merchant_pub, h_contract_terms and rtransaction_id MUST be unique, and we usually select by coin_pub so that one goes first.';
-
-
---
--- Name: COLUMN refunds.deposit_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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.';
-
-
---
--- Name: COLUMN refunds.rtransaction_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refunds.rtransaction_id IS 'used by the merchant to make refunds unique in case the same coin for the same deposit gets a subsequent (higher) refund';
-
-
---
--- Name: refunds_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refunds ATTACH PARTITION exchange.refunds_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refunds ALTER COLUMN refund_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refunds_refund_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves IS 'Summarizes the balance of a reserve. Updated when new funds are added or withdrawn.';
-
-
---
--- Name: COLUMN reserves.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.current_balance_val IS 'Current balance remaining with the reserve.';
-
-
---
--- Name: COLUMN reserves.purses_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.expiration_date IS 'Used to trigger closing of reserves that have not been drained after some time';
-
-
---
--- Name: COLUMN reserves.gc_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.gc_date IS 'Used to forget all information about a reserve during garbage collection';
-
-
---
--- Name: reserves_close; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_close (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves_close; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_close IS 'wire transfers executed by the reserve to close reserves';
-
-
---
--- Name: COLUMN reserves_close.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_close ALTER COLUMN close_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_close_close_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_close_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_close ATTACH PARTITION exchange.reserves_close_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves ATTACH PARTITION exchange.reserves_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_in; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_in (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves_in; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_in IS 'list of transfers of funds into the reserves, one per incoming wire transfer';
-
-
---
--- Name: COLUMN reserves_in.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.reserve_pub IS 'Public key of the reserve. Private key signifies ownership of the remaining balance.';
-
-
---
--- Name: COLUMN reserves_in.credit_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.credit_val IS 'Amount that was transferred into the reserve';
-
-
---
--- Name: COLUMN reserves_in.wire_source_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.wire_source_h_payto IS 'Identifies the debited bank account and KYC status';
-
-
---
--- Name: reserves_in_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_in ATTACH PARTITION exchange.reserves_in_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_in ALTER COLUMN reserve_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_in_reserve_in_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_out (
- 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))
-)
-PARTITION BY HASH (h_blind_ev);
-
-
---
--- Name: TABLE reserves_out; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_out IS 'Withdraw operations performed on reserves.';
-
-
---
--- Name: COLUMN reserves_out.h_blind_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_out.h_blind_ev IS 'Hash of the blinded coin, used as primary key here so that broken clients that use a non-random coin or blinding factor fail to withdraw (otherwise they would fail on deposit when the coin is not unique there).';
-
-
---
--- Name: COLUMN reserves_out.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_out.denominations_serial IS 'We do not CASCADE ON DELETE here, we may keep the denomination data alive';
-
-
---
--- Name: reserves_out_by_reserve; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE reserves_out_by_reserve; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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_out_by_reserve_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_out_by_reserve ATTACH PARTITION exchange.reserves_out_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_out ATTACH PARTITION exchange.reserves_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_out ALTER COLUMN reserve_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_out_reserve_out_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves ALTER COLUMN reserve_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_reserve_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: revolving_work_shards; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE UNLOGGED TABLE exchange.revolving_work_shards (
- shard_serial_id bigint NOT NULL,
- last_attempt bigint NOT NULL,
- start_row integer NOT NULL,
- end_row integer NOT NULL,
- active boolean DEFAULT false NOT NULL,
- job_name character varying NOT NULL
-);
-
-
---
--- Name: TABLE revolving_work_shards; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.revolving_work_shards IS 'coordinates work between multiple processes working on the same job with partitions that need to be repeatedly processed; unlogged because on system crashes the locks represented by this table will have to be cleared anyway, typically using "taler-exchange-dbinit -s"';
-
-
---
--- Name: COLUMN revolving_work_shards.shard_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.shard_serial_id IS 'unique serial number identifying the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.last_attempt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.start_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.start_row IS 'row at which the shard scope starts, inclusive';
-
-
---
--- Name: COLUMN revolving_work_shards.end_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.end_row IS 'row at which the shard scope ends, exclusive';
-
-
---
--- Name: COLUMN revolving_work_shards.active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.active IS 'set to TRUE when a worker is active on the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.job_name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
-
-
---
--- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.revolving_work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.revolving_work_shards_shard_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: signkey_revocations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.signkey_revocations (
- signkey_revocations_serial_id bigint NOT NULL,
- esk_serial bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT signkey_revocations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE signkey_revocations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.signkey_revocations IS 'Table storing which online signing keys have been revoked';
-
-
---
--- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.signkey_revocations ALTER COLUMN signkey_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.signkey_revocations_signkey_revocations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wad_in_entries; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wad_in_entries; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wad_in_entries IS 'list of purses aggregated in a wad according to the sending exchange';
-
-
---
--- Name: COLUMN wad_in_entries.wad_in_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.wad_in_serial_id IS 'wad for which the given purse was included in the aggregation';
-
-
---
--- Name: COLUMN wad_in_entries.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.reserve_pub IS 'target account of the purse (must be at the local exchange)';
-
-
---
--- Name: COLUMN wad_in_entries.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_pub IS 'public key of the purse that was merged';
-
-
---
--- Name: COLUMN wad_in_entries.h_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.h_contract IS 'hash of the contract terms of the purse';
-
-
---
--- Name: COLUMN wad_in_entries.purse_expiration; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_expiration IS 'Time when the purse was set to expire';
-
-
---
--- Name: COLUMN wad_in_entries.merge_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.merge_timestamp IS 'Time when the merge was approved';
-
-
---
--- Name: COLUMN wad_in_entries.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.amount_with_fee_val IS 'Total amount in the purse';
-
-
---
--- Name: COLUMN wad_in_entries.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.wad_fee_val IS 'Total wad fees paid by the purse';
-
-
---
--- Name: COLUMN wad_in_entries.deposit_fees_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.deposit_fees_val IS 'Total deposit fees paid when depositing coins into the purse';
-
-
---
--- Name: COLUMN wad_in_entries.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
-
-
---
--- Name: COLUMN wad_in_entries.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
-
-
---
--- Name: wad_in_entries_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wad_in_entries ATTACH PARTITION exchange.wad_in_entries_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wad_in_entries_wad_in_entry_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wad_in_entries ALTER COLUMN wad_in_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wad_in_entries_wad_in_entry_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wad_out_entries; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wad_out_entries; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wad_out_entries IS 'Purses combined into a wad';
-
-
---
--- Name: COLUMN wad_out_entries.wad_out_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.wad_out_serial_id IS 'Wad the purse was part of';
-
-
---
--- Name: COLUMN wad_out_entries.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.reserve_pub IS 'Target reserve for the purse';
-
-
---
--- Name: COLUMN wad_out_entries.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN wad_out_entries.h_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.h_contract IS 'Hash of the contract associated with the purse';
-
-
---
--- Name: COLUMN wad_out_entries.purse_expiration; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_expiration IS 'Time when the purse expires';
-
-
---
--- Name: COLUMN wad_out_entries.merge_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.merge_timestamp IS 'Time when the merge was approved';
-
-
---
--- Name: COLUMN wad_out_entries.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.amount_with_fee_val IS 'Total amount in the purse';
-
-
---
--- Name: COLUMN wad_out_entries.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.wad_fee_val IS 'Wat fee charged to the purse';
-
-
---
--- Name: COLUMN wad_out_entries.deposit_fees_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.deposit_fees_val IS 'Total deposit fees charged to the purse';
-
-
---
--- Name: COLUMN wad_out_entries.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
-
-
---
--- Name: COLUMN wad_out_entries.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
-
-
---
--- Name: wad_out_entries_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wad_out_entries ATTACH PARTITION exchange.wad_out_entries_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wad_out_entries_wad_out_entry_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wad_out_entries ALTER COLUMN wad_out_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wad_out_entries_wad_out_entry_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wads_in; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wads_in; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wads_in IS 'Incoming exchange-to-exchange wad wire transfers';
-
-
---
--- Name: COLUMN wads_in.wad_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_in.origin_exchange_url; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.origin_exchange_url IS 'Base URL of the originating URL, also part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_in.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.amount_val IS 'Actual amount that was received by our exchange';
-
-
---
--- Name: COLUMN wads_in.arrival_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.arrival_time IS 'Time when the wad was received';
-
-
---
--- Name: wads_in_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wads_in ATTACH PARTITION exchange.wads_in_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wads_in_wad_in_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wads_in ALTER COLUMN wad_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wads_in_wad_in_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wads_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wads_out; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wads_out IS 'Wire transfers made to another exchange to transfer purse funds';
-
-
---
--- Name: COLUMN wads_out.wad_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_out.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.partner_serial_id IS 'target exchange of the wad';
-
-
---
--- Name: COLUMN wads_out.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.amount_val IS 'Amount that was wired';
-
-
---
--- Name: COLUMN wads_out.execution_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.execution_time IS 'Time when the wire transfer was scheduled';
-
-
---
--- Name: wads_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wads_out ATTACH PARTITION exchange.wads_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wads_out_wad_out_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wads_out ALTER COLUMN wad_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wads_out_wad_out_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_accounts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_accounts; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: COLUMN wire_accounts.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.payto_uri IS 'payto URI (RFC 8905) with the bank account of the exchange.';
-
-
---
--- Name: COLUMN wire_accounts.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.master_sig IS 'Signature of purpose TALER_SIGNATURE_MASTER_WIRE_DETAILS';
-
-
---
--- Name: COLUMN wire_accounts.is_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.is_active IS 'true if we are currently supporting the use of this account.';
-
-
---
--- Name: COLUMN wire_accounts.last_change; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
-
-
---
--- Name: wire_fee; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_fee; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_fee IS 'list of the wire fees of this exchange, by date';
-
-
---
--- Name: COLUMN wire_fee.wire_fee_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_fee.wire_fee_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_fee ALTER COLUMN wire_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_fee_wire_fee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_out IS 'wire transfers the exchange has executed';
-
-
---
--- Name: COLUMN wire_out.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_out.wire_target_h_payto IS 'Identifies the credited bank account and KYC status';
-
-
---
--- Name: COLUMN wire_out.exchange_account_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_out.exchange_account_section IS 'identifies the configuration section with the debit account of this payment';
-
-
---
--- Name: wire_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wire_out ATTACH PARTITION exchange.wire_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_out ALTER COLUMN wireout_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_out_wireout_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_targets; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_targets; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_targets IS 'All senders and recipients of money via the exchange';
-
-
---
--- Name: COLUMN wire_targets.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.wire_target_h_payto IS 'Unsalted hash of payto_uri';
-
-
---
--- Name: COLUMN wire_targets.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.payto_uri IS 'Can be a regular bank account, or also be a URI identifying a reserve-account (for P2P payments)';
-
-
---
--- Name: COLUMN wire_targets.kyc_ok; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.kyc_ok IS 'true if the KYC check was passed successfully';
-
-
---
--- Name: COLUMN wire_targets.external_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.external_id IS 'Name of the user that was used for OAuth 2.0-based legitimization';
-
-
---
--- Name: wire_targets_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wire_targets ATTACH PARTITION exchange.wire_targets_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_targets ALTER COLUMN wire_target_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_targets_wire_target_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: work_shards; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE work_shards; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.work_shards IS 'coordinates work between multiple processes working on the same job';
-
-
---
--- Name: COLUMN work_shards.shard_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.shard_serial_id IS 'unique serial number identifying the shard';
-
-
---
--- Name: COLUMN work_shards.last_attempt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
-
-
---
--- Name: COLUMN work_shards.start_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.start_row IS 'row at which the shard scope starts, inclusive';
-
-
---
--- Name: COLUMN work_shards.end_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.end_row IS 'row at which the shard scope ends, exclusive';
-
-
---
--- Name: COLUMN work_shards.completed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.completed IS 'set to TRUE once the shard is finished by a worker';
-
-
---
--- Name: COLUMN work_shards.job_name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
-
-
---
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.work_shards_shard_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_accounts; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_accounts (
- account_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- h_wire bytea NOT NULL,
- salt bytea NOT NULL,
- payto_uri character varying NOT NULL,
- active boolean NOT NULL,
- CONSTRAINT merchant_accounts_h_wire_check CHECK ((length(h_wire) = 64)),
- CONSTRAINT merchant_accounts_salt_check CHECK ((length(salt) = 16))
-);
-
-
---
--- Name: TABLE merchant_accounts; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_accounts IS 'bank accounts of the instances';
-
-
---
--- Name: COLUMN merchant_accounts.h_wire; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.h_wire IS 'salted hash of payto_uri';
-
-
---
--- Name: COLUMN merchant_accounts.salt; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.salt IS 'salt used when hashing payto_uri into h_wire';
-
-
---
--- Name: COLUMN merchant_accounts.payto_uri; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.payto_uri IS 'payto URI of a merchant bank account';
-
-
---
--- Name: COLUMN merchant_accounts.active; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.active IS 'true if we actively use this bank account, false if it is just kept around for older contracts to refer to';
-
-
---
--- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_accounts ALTER COLUMN account_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_accounts_account_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_contract_terms; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_contract_terms (
- order_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- order_id character varying NOT NULL,
- contract_terms bytea NOT NULL,
- h_contract_terms bytea NOT NULL,
- creation_time bigint NOT NULL,
- pay_deadline bigint NOT NULL,
- refund_deadline bigint NOT NULL,
- paid boolean DEFAULT false NOT NULL,
- wired boolean DEFAULT false NOT NULL,
- fulfillment_url character varying,
- session_id character varying DEFAULT ''::character varying NOT NULL,
- claim_token bytea NOT NULL,
- CONSTRAINT merchant_contract_terms_claim_token_check CHECK ((length(claim_token) = 16)),
- CONSTRAINT merchant_contract_terms_h_contract_terms_check CHECK ((length(h_contract_terms) = 64))
-);
-
-
---
--- Name: TABLE merchant_contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_contract_terms IS 'Contracts are orders that have been claimed by a wallet';
-
-
---
--- Name: COLUMN merchant_contract_terms.merchant_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.merchant_serial IS 'Identifies the instance offering the contract';
-
-
---
--- Name: COLUMN merchant_contract_terms.order_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.order_id IS 'Not a foreign key into merchant_orders because paid contracts persist after expiration';
-
-
---
--- Name: COLUMN merchant_contract_terms.contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.contract_terms IS 'These contract terms include the wallet nonce';
-
-
---
--- Name: COLUMN merchant_contract_terms.h_contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.h_contract_terms IS 'Hash over contract_terms';
-
-
---
--- Name: COLUMN merchant_contract_terms.pay_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.pay_deadline IS 'How long is the offer valid. After this time, the order can be garbage collected';
-
-
---
--- Name: COLUMN merchant_contract_terms.refund_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.refund_deadline IS 'By what times do refunds have to be approved (useful to reject refund requests)';
-
-
---
--- Name: COLUMN merchant_contract_terms.paid; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.paid IS 'true implies the customer paid for this contract; order should be DELETEd from merchant_orders once paid is set to release merchant_order_locks; paid remains true even if the payment was later refunded';
-
-
---
--- Name: COLUMN merchant_contract_terms.wired; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.wired IS 'true implies the exchange wired us the full amount for all non-refunded payments under this contract';
-
-
---
--- Name: COLUMN merchant_contract_terms.fulfillment_url; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.fulfillment_url IS 'also included in contract_terms, but we need it here to SELECT on it during repurchase detection; can be NULL if the contract has no fulfillment URL';
-
-
---
--- Name: COLUMN merchant_contract_terms.session_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.session_id IS 'last session_id from we confirmed the paying client to use, empty string for none';
-
-
---
--- Name: COLUMN merchant_contract_terms.claim_token; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.claim_token IS 'Token optionally used to access the status of the order. All zeros (not NULL) if not used';
-
-
---
--- Name: merchant_deposit_to_transfer; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_deposit_to_transfer (
- deposit_serial bigint NOT NULL,
- coin_contribution_value_val bigint NOT NULL,
- coin_contribution_value_frac integer NOT NULL,
- credit_serial bigint NOT NULL,
- execution_time bigint NOT NULL,
- signkey_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- CONSTRAINT merchant_deposit_to_transfer_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_deposit_to_transfer; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_deposit_to_transfer IS 'Mapping of deposits to (possibly unconfirmed) wire transfers; NOTE: not used yet';
-
-
---
--- Name: COLUMN merchant_deposit_to_transfer.execution_time; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposit_to_transfer.execution_time IS 'Execution time as claimed by the exchange, roughly matches time seen by merchant';
-
-
---
--- Name: merchant_deposits; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_deposits (
- deposit_serial bigint NOT NULL,
- order_serial bigint,
- deposit_timestamp bigint NOT NULL,
- coin_pub bytea NOT NULL,
- exchange_url character varying NOT NULL,
- amount_with_fee_val bigint NOT NULL,
- amount_with_fee_frac integer NOT NULL,
- deposit_fee_val bigint NOT NULL,
- deposit_fee_frac integer NOT NULL,
- refund_fee_val bigint NOT NULL,
- refund_fee_frac integer NOT NULL,
- wire_fee_val bigint NOT NULL,
- wire_fee_frac integer NOT NULL,
- signkey_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- account_serial bigint NOT NULL,
- CONSTRAINT merchant_deposits_coin_pub_check CHECK ((length(coin_pub) = 32)),
- CONSTRAINT merchant_deposits_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_deposits; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_deposits IS 'Refunds approved by the merchant (backoffice) logic, excludes abort refunds';
-
-
---
--- Name: COLUMN merchant_deposits.deposit_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.deposit_timestamp IS 'Time when the exchange generated the deposit confirmation';
-
-
---
--- Name: COLUMN merchant_deposits.wire_fee_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.wire_fee_val IS 'We MAY want to see if we should try to get this via merchant_exchange_wire_fees (not sure, may be too complicated with the date range, etc.)';
-
-
---
--- Name: COLUMN merchant_deposits.signkey_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.signkey_serial IS 'Online signing key of the exchange on the deposit confirmation';
-
-
---
--- Name: COLUMN merchant_deposits.exchange_sig; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.exchange_sig IS 'Signature of the exchange over the deposit confirmation';
-
-
---
--- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_deposits ALTER COLUMN deposit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_deposits_deposit_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_exchange_signing_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_exchange_signing_keys (
- signkey_serial bigint NOT NULL,
- master_pub bytea NOT NULL,
- exchange_pub bytea NOT NULL,
- start_date bigint NOT NULL,
- expire_date bigint NOT NULL,
- end_date bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT merchant_exchange_signing_keys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT merchant_exchange_signing_keys_master_pub_check CHECK ((length(master_pub) = 32)),
- CONSTRAINT merchant_exchange_signing_keys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_exchange_signing_keys; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_exchange_signing_keys IS 'Here we store proofs of the exchange online signing keys being signed by the exchange master key';
-
-
---
--- Name: COLUMN merchant_exchange_signing_keys.master_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_exchange_signing_keys.master_pub IS 'Master public key of the exchange with these online signing keys';
-
-
---
--- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_exchange_signing_keys ALTER COLUMN signkey_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_exchange_signing_keys_signkey_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_exchange_wire_fees; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_exchange_wire_fees (
- wirefee_serial bigint NOT NULL,
- master_pub bytea NOT NULL,
- h_wire_method bytea 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 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)),
- CONSTRAINT merchant_exchange_wire_fees_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_exchange_wire_fees; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_exchange_wire_fees IS 'Here we store proofs of the wire fee structure of the various exchanges';
-
-
---
--- Name: COLUMN merchant_exchange_wire_fees.master_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_exchange_wire_fees.master_pub IS 'Master public key of the exchange with these wire fees';
-
-
---
--- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_exchange_wire_fees ALTER COLUMN wirefee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_exchange_wire_fees_wirefee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_instances; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.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,
- jurisdiction bytea NOT NULL,
- default_max_deposit_fee_val bigint NOT NULL,
- default_max_deposit_fee_frac integer NOT NULL,
- default_max_wire_fee_val bigint NOT NULL,
- default_max_wire_fee_frac integer NOT NULL,
- default_wire_fee_amortization integer NOT NULL,
- default_wire_transfer_delay bigint NOT NULL,
- default_pay_delay bigint NOT NULL,
- 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))
-);
-
-
---
--- Name: TABLE merchant_instances; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_instances IS 'all the instances supported by this backend';
-
-
---
--- Name: COLUMN merchant_instances.auth_hash; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.merchant_id IS 'identifier of the merchant as used in the base URL (required)';
-
-
---
--- Name: COLUMN merchant_instances.merchant_name; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.merchant_name IS 'legal name of the merchant as a simple string (required)';
-
-
---
--- Name: COLUMN merchant_instances.address; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.address IS 'physical address of the merchant as a Location in JSON format (required)';
-
-
---
--- Name: COLUMN merchant_instances.jurisdiction; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.jurisdiction IS 'jurisdiction of the merchant as a Location in JSON format (required)';
-
-
---
--- Name: COLUMN merchant_instances.website; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.website IS 'merchant site URL';
-
-
---
--- Name: COLUMN merchant_instances.email; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.email IS 'email';
-
-
---
--- Name: COLUMN merchant_instances.logo; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.logo IS 'data image url';
-
-
---
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_instances ALTER COLUMN merchant_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_instances_merchant_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_inventory; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_inventory (
- product_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- product_id character varying NOT NULL,
- description character varying NOT NULL,
- description_i18n bytea NOT NULL,
- unit character varying NOT NULL,
- image bytea NOT NULL,
- taxes bytea NOT NULL,
- price_val bigint NOT NULL,
- price_frac integer NOT NULL,
- total_stock bigint NOT NULL,
- total_sold bigint DEFAULT 0 NOT NULL,
- total_lost bigint DEFAULT 0 NOT NULL,
- address bytea NOT NULL,
- next_restock bigint NOT NULL,
- minimum_age integer DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE merchant_inventory; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_inventory IS 'products offered by the merchant (may be incomplete, frontend can override)';
-
-
---
--- Name: COLUMN merchant_inventory.description; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.description IS 'Human-readable product description';
-
-
---
--- Name: COLUMN merchant_inventory.description_i18n; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.description_i18n IS 'JSON map from IETF BCP 47 language tags to localized descriptions';
-
-
---
--- Name: COLUMN merchant_inventory.unit; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.unit IS 'Unit of sale for the product (liters, kilograms, packages)';
-
-
---
--- Name: COLUMN merchant_inventory.image; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.image IS 'NOT NULL, but can be 0 bytes; must contain an ImageDataUrl';
-
-
---
--- Name: COLUMN merchant_inventory.taxes; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.taxes IS 'JSON array containing taxes the merchant pays, must be JSON, but can be just "[]"';
-
-
---
--- Name: COLUMN merchant_inventory.price_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.price_val IS 'Current price of one unit of the product';
-
-
---
--- Name: COLUMN merchant_inventory.total_stock; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_stock IS 'A value of -1 is used for unlimited (electronic good), may never be lowered';
-
-
---
--- Name: COLUMN merchant_inventory.total_sold; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_sold IS 'Number of products sold, must be below total_stock, non-negative, may never be lowered';
-
-
---
--- Name: COLUMN merchant_inventory.total_lost; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_lost IS 'Number of products that used to be in stock but were lost (spoiled, damaged), may never be lowered; total_stock >= total_sold + total_lost must always hold';
-
-
---
--- Name: COLUMN merchant_inventory.address; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.address IS 'JSON formatted Location of where the product is stocked';
-
-
---
--- Name: COLUMN merchant_inventory.next_restock; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.next_restock IS 'GNUnet absolute time indicating when the next restock is expected. 0 for unknown.';
-
-
---
--- Name: COLUMN merchant_inventory.minimum_age; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_inventory_locks (
- product_serial bigint NOT NULL,
- lock_uuid bytea NOT NULL,
- total_locked bigint NOT NULL,
- expiration bigint NOT NULL,
- CONSTRAINT merchant_inventory_locks_lock_uuid_check CHECK ((length(lock_uuid) = 16))
-);
-
-
---
--- Name: TABLE merchant_inventory_locks; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_inventory_locks IS 'locks on inventory helt by shopping carts; note that locks MAY not be honored if merchants increase total_lost for inventory';
-
-
---
--- Name: COLUMN merchant_inventory_locks.total_locked; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory_locks.total_locked IS 'how many units of the product does this lock reserve';
-
-
---
--- Name: COLUMN merchant_inventory_locks.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory_locks.expiration IS 'when does this lock automatically expire (if no order is created)';
-
-
---
--- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_inventory ALTER COLUMN product_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_inventory_product_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_keys (
- merchant_priv bytea NOT NULL,
- merchant_serial bigint NOT NULL,
- CONSTRAINT merchant_keys_merchant_priv_check CHECK ((length(merchant_priv) = 32))
-);
-
-
---
--- Name: TABLE merchant_keys; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_keys IS 'private keys of instances that have not been deleted';
-
-
---
--- Name: merchant_kyc; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_kyc (
- kyc_serial_id bigint NOT NULL,
- kyc_timestamp bigint NOT NULL,
- kyc_ok boolean DEFAULT false NOT NULL,
- exchange_sig bytea,
- exchange_pub bytea,
- exchange_kyc_serial bigint DEFAULT 0 NOT NULL,
- account_serial bigint NOT NULL,
- exchange_url character varying NOT NULL,
- CONSTRAINT merchant_kyc_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT merchant_kyc_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_kyc; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_kyc IS 'Status of the KYC process of a merchant account at an exchange';
-
-
---
--- Name: COLUMN merchant_kyc.kyc_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.kyc_timestamp IS 'Last time we checked our KYC status at the exchange. Useful to re-check if the status is very stale. Also the timestamp used for the exchange signature (if present).';
-
-
---
--- Name: COLUMN merchant_kyc.kyc_ok; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.kyc_ok IS 'true if the KYC check was passed successfully';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_sig; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_sig IS 'signature of the exchange affirming the KYC passed (or NULL if exchange does not require KYC or not kyc_ok)';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_pub IS 'public key used with exchange_sig (or NULL if exchange_sig is NULL)';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_kyc_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_kyc_serial IS 'Number to use in the KYC-endpoints of the exchange to check the KYC status or begin the KYC process. 0 if we do not know it yet.';
-
-
---
--- Name: COLUMN merchant_kyc.account_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.account_serial IS 'Which bank account of the merchant is the KYC status for';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_url; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_url IS 'Which exchange base URL is this KYC status valid for';
-
-
---
--- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_kyc ALTER COLUMN kyc_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_kyc_kyc_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_order_locks; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_order_locks (
- product_serial bigint NOT NULL,
- total_locked bigint NOT NULL,
- order_serial bigint NOT NULL
-);
-
-
---
--- Name: TABLE merchant_order_locks; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_order_locks IS 'locks on orders awaiting claim and payment; note that locks MAY not be honored if merchants increase total_lost for inventory';
-
-
---
--- Name: COLUMN merchant_order_locks.total_locked; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_order_locks.total_locked IS 'how many units of the product does this lock reserve';
-
-
---
--- Name: merchant_orders; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_orders (
- order_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- order_id character varying NOT NULL,
- claim_token bytea NOT NULL,
- h_post_data bytea NOT NULL,
- pay_deadline bigint NOT NULL,
- creation_time bigint NOT NULL,
- contract_terms bytea NOT NULL,
- CONSTRAINT merchant_orders_claim_token_check CHECK ((length(claim_token) = 16)),
- CONSTRAINT merchant_orders_h_post_data_check CHECK ((length(h_post_data) = 64))
-);
-
-
---
--- Name: TABLE merchant_orders; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_orders IS 'Orders we offered to a customer, but that have not yet been claimed';
-
-
---
--- Name: COLUMN merchant_orders.merchant_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.merchant_serial IS 'Identifies the instance offering the contract';
-
-
---
--- Name: COLUMN merchant_orders.claim_token; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.claim_token IS 'Token optionally used to authorize the wallet to claim the order. All zeros (not NULL) if not used';
-
-
---
--- Name: COLUMN merchant_orders.h_post_data; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.h_post_data IS 'Hash of the POST request that created this order, for idempotency checks';
-
-
---
--- Name: COLUMN merchant_orders.pay_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.pay_deadline IS 'How long is the offer valid. After this time, the order can be garbage collected';
-
-
---
--- Name: COLUMN merchant_orders.contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.contract_terms IS 'Claiming changes the contract_terms, hence we have no hash of the terms in this table';
-
-
---
--- Name: merchant_orders_order_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_orders ALTER COLUMN order_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_orders_order_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_refund_proofs; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_refund_proofs (
- refund_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- signkey_serial bigint NOT NULL,
- CONSTRAINT merchant_refund_proofs_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_refund_proofs; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_refund_proofs IS 'Refunds confirmed by the exchange (not all approved refunds are grabbed by the wallet)';
-
-
---
--- Name: merchant_refunds; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_refunds (
- refund_serial bigint NOT NULL,
- order_serial bigint NOT NULL,
- rtransaction_id bigint NOT NULL,
- refund_timestamp bigint NOT NULL,
- coin_pub bytea NOT NULL,
- reason character varying NOT NULL,
- refund_amount_val bigint NOT NULL,
- refund_amount_frac integer NOT NULL
-);
-
-
---
--- Name: COLUMN merchant_refunds.rtransaction_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_refunds.rtransaction_id IS 'Needed for uniqueness in case a refund is increased for the same order';
-
-
---
--- Name: COLUMN merchant_refunds.refund_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_refunds.refund_timestamp IS 'Needed for grouping of refunds in the wallet UI; has no semantics in the protocol (only for UX), but should be from the time when the merchant internally approved the refund';
-
-
---
--- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_refunds ALTER COLUMN refund_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_refunds_refund_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tip_pickup_signatures; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_pickup_signatures (
- pickup_serial bigint NOT NULL,
- coin_offset integer NOT NULL,
- blind_sig bytea NOT NULL
-);
-
-
---
--- Name: TABLE merchant_tip_pickup_signatures; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_pickup_signatures IS 'blind signatures we got from the exchange during the tip pickup';
-
-
---
--- Name: merchant_tip_pickups; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_pickups (
- pickup_serial bigint NOT NULL,
- tip_serial bigint NOT NULL,
- pickup_id bytea NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- CONSTRAINT merchant_tip_pickups_pickup_id_check CHECK ((length(pickup_id) = 64))
-);
-
-
---
--- Name: TABLE merchant_tip_pickups; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_pickups IS 'tips that have been picked up';
-
-
---
--- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tip_pickups ALTER COLUMN pickup_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tip_pickups_pickup_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tip_reserve_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_reserve_keys (
- reserve_serial bigint NOT NULL,
- reserve_priv bytea NOT NULL,
- exchange_url character varying NOT NULL,
- payto_uri character varying,
- CONSTRAINT merchant_tip_reserve_keys_reserve_priv_check CHECK ((length(reserve_priv) = 32))
-);
-
-
---
--- Name: COLUMN merchant_tip_reserve_keys.payto_uri; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserve_keys.payto_uri IS 'payto:// URI used to fund the reserve, may be NULL once reserve is funded';
-
-
---
--- Name: merchant_tip_reserves; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_reserves (
- reserve_serial bigint NOT NULL,
- reserve_pub bytea NOT NULL,
- merchant_serial bigint NOT NULL,
- creation_time bigint NOT NULL,
- expiration bigint NOT NULL,
- merchant_initial_balance_val bigint NOT NULL,
- merchant_initial_balance_frac integer NOT NULL,
- exchange_initial_balance_val bigint DEFAULT 0 NOT NULL,
- exchange_initial_balance_frac integer DEFAULT 0 NOT NULL,
- tips_committed_val bigint DEFAULT 0 NOT NULL,
- tips_committed_frac integer DEFAULT 0 NOT NULL,
- tips_picked_up_val bigint DEFAULT 0 NOT NULL,
- tips_picked_up_frac integer DEFAULT 0 NOT NULL,
- CONSTRAINT merchant_tip_reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
-);
-
-
---
--- Name: TABLE merchant_tip_reserves; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_reserves IS 'private keys of reserves that have not been deleted';
-
-
---
--- Name: COLUMN merchant_tip_reserves.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.expiration IS 'FIXME: EXCHANGE API needs to tell us when reserves close if we are to compute this';
-
-
---
--- Name: COLUMN merchant_tip_reserves.merchant_initial_balance_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.merchant_initial_balance_val IS 'Set to the initial balance the merchant told us when creating the reserve';
-
-
---
--- Name: COLUMN merchant_tip_reserves.exchange_initial_balance_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.exchange_initial_balance_val IS 'Set to the initial balance the exchange told us when we queried the reserve status';
-
-
---
--- Name: COLUMN merchant_tip_reserves.tips_committed_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.tips_committed_val IS 'Amount of outstanding approved tips that have not been picked up';
-
-
---
--- Name: COLUMN merchant_tip_reserves.tips_picked_up_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.tips_picked_up_val IS 'Total amount tips that have been picked up from this reserve';
-
-
---
--- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tip_reserves ALTER COLUMN reserve_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tip_reserves_reserve_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tips; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tips (
- tip_serial bigint NOT NULL,
- reserve_serial bigint NOT NULL,
- tip_id bytea NOT NULL,
- justification character varying NOT NULL,
- next_url character varying NOT NULL,
- expiration bigint NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- picked_up_val bigint DEFAULT 0 NOT NULL,
- picked_up_frac integer DEFAULT 0 NOT NULL,
- was_picked_up boolean DEFAULT false NOT NULL,
- CONSTRAINT merchant_tips_tip_id_check CHECK ((length(tip_id) = 64))
-);
-
-
---
--- Name: TABLE merchant_tips; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tips IS 'tips that have been authorized';
-
-
---
--- Name: COLUMN merchant_tips.reserve_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.reserve_serial IS 'Reserve from which this tip is funded';
-
-
---
--- Name: COLUMN merchant_tips.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.expiration IS 'by when does the client have to pick up the tip';
-
-
---
--- Name: COLUMN merchant_tips.amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.amount_val IS 'total transaction cost for all coins including withdraw fees';
-
-
---
--- Name: COLUMN merchant_tips.picked_up_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.picked_up_val IS 'Tip amount left to be picked up';
-
-
---
--- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tips ALTER COLUMN tip_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tips_tip_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_transfer_signatures; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfer_signatures (
- credit_serial bigint NOT NULL,
- signkey_serial bigint NOT NULL,
- wire_fee_val bigint NOT NULL,
- wire_fee_frac integer 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))
-);
-
-
---
--- Name: TABLE merchant_transfer_signatures; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfer_signatures IS 'table represents the main information returned from the /transfer request to the exchange.';
-
-
---
--- Name: COLUMN merchant_transfer_signatures.credit_amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_signatures.execution_time IS 'Execution time as claimed by the exchange, roughly matches time seen by merchant';
-
-
---
--- Name: merchant_transfer_to_coin; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfer_to_coin (
- deposit_serial bigint NOT NULL,
- credit_serial bigint NOT NULL,
- offset_in_exchange_list bigint NOT NULL,
- exchange_deposit_value_val bigint NOT NULL,
- exchange_deposit_value_frac integer NOT NULL,
- exchange_deposit_fee_val bigint NOT NULL,
- exchange_deposit_fee_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE merchant_transfer_to_coin; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfer_to_coin IS 'Mapping of (credit) transfers to (deposited) coins';
-
-
---
--- Name: COLUMN merchant_transfer_to_coin.exchange_deposit_value_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_to_coin.exchange_deposit_value_val IS 'Deposit value as claimed by the exchange, should match our values in merchant_deposits minus refunds';
-
-
---
--- Name: COLUMN merchant_transfer_to_coin.exchange_deposit_fee_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_to_coin.exchange_deposit_fee_val IS 'Deposit value as claimed by the exchange, should match our values in merchant_deposits';
-
-
---
--- Name: merchant_transfers; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfers (
- credit_serial bigint NOT NULL,
- exchange_url character varying NOT NULL,
- wtid bytea,
- credit_amount_val bigint NOT NULL,
- credit_amount_frac integer NOT NULL,
- account_serial bigint NOT NULL,
- verified boolean DEFAULT false NOT NULL,
- confirmed boolean DEFAULT false NOT NULL,
- CONSTRAINT merchant_transfers_wtid_check CHECK ((length(wtid) = 32))
-);
-
-
---
--- Name: TABLE merchant_transfers; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfers IS 'table represents the information provided by the (trusted) merchant about incoming wire transfers';
-
-
---
--- Name: COLUMN merchant_transfers.credit_amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.credit_amount_val IS 'actual value of the (aggregated) wire transfer, excluding the wire fee, according to the merchant';
-
-
---
--- Name: COLUMN merchant_transfers.verified; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.verified IS 'true once we got an acceptable response from the exchange for this transfer';
-
-
---
--- Name: COLUMN merchant_transfers.confirmed; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.confirmed IS 'true once the merchant confirmed that this transfer was received';
-
-
---
--- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_transfers ALTER COLUMN credit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_transfers_credit_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: auditor_reserves auditor_reserves_rowid; Type: DEFAULT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves ALTER COLUMN auditor_reserves_rowid SET DEFAULT nextval('auditor.auditor_reserves_auditor_reserves_rowid_seq'::regclass);
-
-
---
--- Name: deposit_confirmations serial_id; Type: DEFAULT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations ALTER COLUMN serial_id SET DEFAULT nextval('auditor.deposit_confirmations_serial_id_seq'::regclass);
-
-
---
--- Data for Name: patches; Type: TABLE DATA; Schema: _v; Owner: -
---
-
-COPY _v.patches (patch_name, applied_tsz, applied_by, requires, conflicts) FROM stdin;
-exchange-0001 2022-08-11 23:02:26.210551+02 grothoff {} {}
-merchant-0001 2022-08-11 23:02:27.235168+02 grothoff {} {}
-merchant-0002 2022-08-11 23:02:27.650659+02 grothoff {} {}
-auditor-0001 2022-08-11 23:02:27.799589+02 grothoff {} {}
-\.
-
-
---
--- Data for Name: auditor_balance_summary; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_balance_summary (master_pub, denom_balance_val, denom_balance_frac, deposit_fee_balance_val, deposit_fee_balance_frac, melt_fee_balance_val, melt_fee_balance_frac, refund_fee_balance_val, refund_fee_balance_frac, risk_val, risk_frac, loss_val, loss_frac, irregular_recoup_val, irregular_recoup_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_denomination_pending; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_denomination_pending (denom_pub_hash, denom_balance_val, denom_balance_frac, denom_loss_val, denom_loss_frac, num_issued, denom_risk_val, denom_risk_frac, recoup_loss_val, recoup_loss_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_exchange_signkeys; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchange_signkeys (master_pub, ep_start, ep_expire, ep_end, exchange_pub, master_sig) FROM stdin;
-\\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba 1660251761000000 1667509361000000 1669928561000000 \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b \\x3a1198bc48724c589ce73c4bcf89635166d15d08ec037466bbb1be2aa7e92163babae1e7619803508996c5d089a2479dc2e6651dc89afafb138be4492722660f
-\.
-
-
---
--- Data for Name: auditor_exchanges; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchanges (master_pub, exchange_url) FROM stdin;
-\\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba http://localhost:8081/
-\.
-
-
---
--- Data for Name: auditor_historic_denomination_revenue; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_historic_denomination_revenue (master_pub, denom_pub_hash, revenue_timestamp, revenue_balance_val, revenue_balance_frac, loss_balance_val, loss_balance_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_historic_reserve_summary; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_historic_reserve_summary (master_pub, start_date, end_date, reserve_profits_val, reserve_profits_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_predicted_result; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_predicted_result (master_pub, balance_val, balance_frac, drained_val, drained_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_aggregation; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_progress_aggregation (master_pub, last_wire_out_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_coin; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_progress_deposit_confirmation; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_progress_deposit_confirmation (master_pub, last_deposit_confirmation_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_reserve; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_reserve_balance; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_reserves; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_reserves (reserve_pub, master_pub, reserve_balance_val, reserve_balance_frac, withdraw_fee_balance_val, withdraw_fee_balance_frac, expiration_date, auditor_reserves_rowid, origin_account) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_wire_fee_balance; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_wire_fee_balance (master_pub, wire_fee_balance_val, wire_fee_balance_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: deposit_confirmations; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.deposit_confirmations (master_pub, serial_id, h_contract_terms, h_extensions, h_wire, exchange_timestamp, refund_deadline, wire_deadline, amount_without_fee_val, amount_without_fee_frac, coin_pub, merchant_pub, exchange_sig, exchange_pub, master_sig) FROM stdin;
-\\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba 1 \\x3055636e89f269e560df6e787197f475d0ee80ec7fde580d98ebd494c66a2c7f603d2e8cf3f4b5d7f0119fe35707df4a27e45cd2c32a58aa6f66f7f926b14989 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x6000b5d64505986e5fcfd8ae2bac7d726fd1a3232a8746b5501a157876034075f66926a7f9b25ca85cfee7ebb5e5aa0b94b82adda8d0225ae924cfaa9e3f6f7f 1660251778000000 1660252676000000 1660252676000000 3 98000000 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x2cb1edb394a66583a8eeb50b600c85f4770e9611c8e56db24a7555f34f526af3c6083083c25c7141ec47734fa2a08c6d79b2132b64c0203650c693354b6a4603 \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b \\xd001b1acfe7f00001d290dd04c5600007d1975d14c560000da1875d14c560000c01875d14c560000c41875d14c560000109d74d14c5600000000000000000000
-\\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba 2 \\xa5e69e1a65ec203aafa4dec8d8f3670ac54e97dbed5e3a274440d57e5432c1c99191006515c26b11279394f71ce416ee9b1c5ad881411fe0ee84a14ae61bbba3 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x6000b5d64505986e5fcfd8ae2bac7d726fd1a3232a8746b5501a157876034075f66926a7f9b25ca85cfee7ebb5e5aa0b94b82adda8d0225ae924cfaa9e3f6f7f 1660251787000000 1660252684000000 1660252684000000 6 99000000 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\xcea9b3a91bf1c73acde5f85eae2af246671add2e146105849c5a0ddba7c6d036381edd6aed5a47a9da945d24878c22c45c78306825b59587b0c2c290d61aeb0f \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b \\xd001b1acfe7f00001d290dd04c5600009dd975d14c560000fad875d14c560000e0d875d14c560000e4d875d14c56000040fe74d14c5600000000000000000000
-\\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba 3 \\xb44b55b0bcfabdb7ad1c10955b62d7f2674bff99c58610e73f34f1d12ad2379ee7b9051c2f1706b23e1b94c93afd812c407f969b6c09a28f8ad82125697db1d8 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x6000b5d64505986e5fcfd8ae2bac7d726fd1a3232a8746b5501a157876034075f66926a7f9b25ca85cfee7ebb5e5aa0b94b82adda8d0225ae924cfaa9e3f6f7f 1660251793000000 1660252690000000 1660252690000000 2 99000000 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x2a68da4393ce25bc6b7608fb5b6e7bf7f855926cb39366a84f19e31b3c98824fff8c0c777ca34f1aab7b224ca01871c33e271b853ac163c86ebb633c60da930f \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b \\xd001b1acfe7f00001d290dd04c5600007d1975d14c560000da1875d14c560000c01875d14c560000c41875d14c560000200775d14c5600000000000000000000
-\.
-
-
---
--- Data for Name: wire_auditor_account_progress; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.wire_auditor_account_progress (master_pub, account_name, last_wire_reserve_in_serial_id, last_wire_wire_out_serial_id, wire_in_off, wire_out_off) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_auditor_progress; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.wire_auditor_progress (master_pub, last_timestamp, last_reserve_close_uuid) FROM stdin;
-\.
-
-
---
--- Data for Name: account_merges_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.account_merges_default (account_merge_request_serial_id, reserve_pub, reserve_sig, purse_pub, wallet_h_payto) FROM stdin;
-\.
-
-
---
--- Data for Name: aggregation_tracking_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.aggregation_tracking_default (aggregation_serial_id, deposit_serial_id, wtid_raw) FROM stdin;
-\.
-
-
---
--- Data for Name: aggregation_transient_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.aggregation_transient_default (amount_val, amount_frac, wire_target_h_payto, merchant_pub, exchange_account_section, wtid_raw) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_denom_sigs; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.auditor_denom_sigs (auditor_denom_serial, auditor_uuid, denominations_serial, auditor_sig) FROM stdin;
-1 1 37 \\xb5f5e626896c77b94828e978cf01ca0256a4c68049c61b28a01726226a39f71bec8252ae6e5c590f21b3e07bd724d54dc4401590e45e661dfa6bbe101e82280f
-2 1 184 \\xb1231e32f6e8d57a2383a40cd00c02a7d79a64e92965939605beacd893a12c5941e97eb14d2e4c4e193edc555849f31f26e0713e2938dbf6bf5245ba35391102
-3 1 317 \\x2c836c2bcffbde42929baf50ed668afcdd9a4856ec215b01aad54a431606fd1b8b9021e72fa4a8784f6e845074d7dbe054f9b82d4f16c488e186a000b283850c
-4 1 348 \\xb38b5a0708be914fc8d2ef7b1d1c813519f777f93cbeed941604685fc9b8ff024bbdd8efac7a02f7a4991e62f59cc0c5778f3ffb90523e4881d54f4dd563550e
-5 1 44 \\xf46ca847792446ce29ce8c9f92b6a3e7297f597241598668ee65a4466123947372db0dda991e71f1480b3cf89014a466b9b46c02f63103620928f66acf72c405
-6 1 246 \\xacbc6500a1101c9c0e34f1846aabbc580cb328f7e66444621abdc511922bd3913ae9ad49923e181d4fbee531a6908f13c42711997487fef92f01c848b2fd6e0e
-7 1 188 \\x86efd395f2b93bdce39d0bd4fb672b75a6219c8641be9f4135dc0d6684aa16641e0eea6ffcb2a3904c56816805b407fdf9573b65a673a1ee42572db2b16cb709
-8 1 306 \\xf797918aff8e8624053dd57fd8213baf38a5f162137b6d37336db59b37d429cd9fb78b5a47e50cbdea68a0ef030e6a968562a8ed88721d163751affba8a62603
-9 1 286 \\x65924981c500f3e45c666471059a72e1c80a186de61abcafd1e2db5b5fd6366f66ff7f698daad833c87ce6334b0fdee924c398fe382449693aae0b7148d3c100
-10 1 55 \\x04bdc3501602c7a796505d89be66df1d575fbc6432c07dd787bd2ee2dcc28e546001e6f75a8be2a94099e11d2033af0910a00e663d70ecd38e21cd2d789d3807
-11 1 215 \\x97d707e37e4668f03dd693b620b8fc016334e79bb3eeff6a5a994f1d6691fb4891d3a282a6aac078a56e44b586e8e0e0eb61b831942d5de94513ff1142846b07
-12 1 384 \\xde7b32e65c27c169269d0a095febf8f748b984be1d0f242226ab9f6a60a25179f9fdee23928a42ad65a3bafde23d15d18a5ab2e605d30f3c102ed7d9ba05e70b
-13 1 313 \\xa7d960c382da0720e5cb31561d3281b7150abc7e60461406ee46b8b1c75c22bbe664f2093dba38ec4065fd89ee1458f55c17bbd6df9a2ae2828bd2c24de20a0d
-14 1 366 \\xefaceeb89916c50c5fe8a8c3a5b9f71d9601567e10e35db1267f6f4b3688e21a2844841a8821c52ef2c8df07fa826c27038d8de1c37287d54138787dcc277402
-15 1 312 \\xb76f10f1bbd063f8e388d32c1efdb141dbb68e9de3b7067c41ab6350f2ac731f177563ab2fe9aa552eb39eb539a108fc983ce5d290c5b18c897af654f3b2270a
-16 1 336 \\x49d4db6a64a3a31935c9bcd83c425d9caf684f0ecd2fa4c0878435a36147b68ca465d16226d5be30859d5f87f2837a74d7e97968e0f51a7aa9a422c74d815b03
-17 1 65 \\xdc7ec58b720b82b0aec11ac6cef06433da441249774a56eba669836b604441d67ae848779cb54f065fc297da77fbfb0e54a0dfa714449b45c6f9fd0a500cb70d
-18 1 216 \\xeac160061be7d3fb123c76ac6af8f1e9f44a18210f0a13a1c5ff3f2170af8b46e29f542ae8d1f93a88ca95f720a1e76f5f0eb6edd0e955cf95b3d18455742f0e
-19 1 417 \\x91184928fa9fd1dac0c9c306aa040faa02f9d09a311a9dbf2a653928dad3dcfb5eea87943ffbd3356066ebfb48393de6de49a8b9eaba0d800fc78be6d82aee0d
-20 1 156 \\x795cd9d9d911f53c71da1be26d840aae6f90cd3c839d9a7c71fee2df67ea02c76bd17d38fad842bd03f0684204fd28d93c6b408ea1124044869fd565f60aae02
-21 1 406 \\x425a899b43f2b1eef88a32c18eef9d631763b140f50d415df39e9594ab9f1c94284ddab666b8f45ad541bd91b353e9fdfccd75afb4bf339fe09c6da3d152540f
-22 1 33 \\xafb8c19b192875e47fd368af7c84bcd248b10bcf141dc737cb7ca017bd7609c4e224135a2cb86c6e6f63f4cf45b47e6870ece696af57261714332b62719dec03
-23 1 167 \\xc5a4d06346568b607cc8a710f857bfce2d0f93d1af8ddd21bcd877a061f60171d528677eca3ac9a03a822b6f806bdf58121b51f99eb5ac04675a43e4de58b500
-24 1 262 \\xe4fd094681a24528d93497876e9576bfd095a9471b407f3d332f7136a61eceef70786d633b79cc8a1ed2fdc33129f275f384a4d98b5b869b4d703bd4743d8a08
-25 1 70 \\x69bd376e2303463f52ad1e49e39ddd05845101f2036207203c6c8b29b7f80c8567467ba8534db189465126f0db75cdeab94678921316ab5ae79512b89f89250e
-26 1 106 \\x6d0e7830607550aa7b123f8081a99d3c83485f2141c40e88469423d0d24b1e61b3002af59ecd214358439c46010453bd4ac523181971eb5a6bd209d01bc73e0c
-27 1 222 \\xf4f7291971df39073016a6dae74aa7096e80acbd82c9d9a5adb77d4a6fc57826bbac3822c776a649eabfd621c56758ac0f16cabf204bcbd7b81405ed74e53706
-28 1 367 \\x7229d0c6eadb3b9b567a42e8ca9331c4747d91d40475e59973d488061294c5f0646d785a5c980178fe94b566f2d0b581608006e1a4ce1c87297020bd06500405
-29 1 380 \\x717160a8c9edc83fa64f327d2ee3c7973194f9dd4c5f136fc6d19700b52810a52a70fce0cd9fa3af7e73489f2730cc9d011923b33e5c30ce2876f35d29e94607
-30 1 28 \\xc57929f969fa407b50feae76e59e7d4b6d26f23f3b35108dfeb2947f9bd80b0619bf588e6bfd9134f255476c21ec465ca1958b2cc1f19cc2f96d084ea9bd9707
-31 1 49 \\x14c11b0d14260f9f502ed76febc176f34d93b182b108f226e2b966b4c8efc75a4633f746f37cdef07122f6cf0061d1a67ff54ddf20dc102e6b99c44774f74304
-32 1 126 \\x14aad1b015af5726c9ec94fa52ca5bc8e2e7b09c820d86181bd7e83c113db677e96dc09f1739bc104eba8663af1ee6a3a0ca43325f830db0a6a94c53f1c9000a
-33 1 80 \\x1a51a17c00f1b8db1e4cb8159c7bc969043f676468a6d74d53d417b3d96c41de7d1284ea2bfeb0c7da6ae241e71c04420a9984d89f4b980fab94a6cefe24060f
-34 1 121 \\x8631fd112f11506a6eb11229d03c3aafcaadd1a27d15b00ffa66b23d7714baaccc0f5134adbbf51c3639712adea6f25a8acc3eefad331ccb6995d2f607b66802
-35 1 265 \\xd5962937d89d971833a32654f84e0409e1df7ce2aa905c3d0d17935eaf387858d11f912b7d9610b0c4da0d3c259aa5c01cf2cb8fae4b5515a33d269f754d820e
-36 1 53 \\x3756608a8c62819abc293004138a3626efeb806bc8cf5bc4661ae8e63f61a08216a3828a82b4dee8e99a5a2cf8599b653390acb984e546f72f25313aa4a9be0d
-37 1 361 \\x6ddd1dbda75db92b24b1fc201b32d990bc63c52f350400f16da7f057dbd943b79155f7f1afd6591e3e03e8d241832136c644d89222c141202f3b6d486b24040d
-38 1 185 \\x7f03fee57fbae089836538548a5a041588baf50a1d12f389e148a0973307bfe79a7017ffdd164eb657330b1028e82895db8e2b3354fb0e6d654a6570fe639505
-39 1 201 \\x0bdefe34bc53f8f5237ffdd7b8061ad097da31c30dc0bbfeb71dedcbd6220727728c7d9bd0be2413bf4ebd08a071f06443158c5b9b4ffd714b9150eed49c5c0f
-40 1 205 \\x8855a0ad19b2cba9e29c44983b0c66a7e85df6e988f45b5be923de2b52e60aacfd5611f865a26a28e0a829367fb5e595b0039cc68558dc5f4b0b6f921fa6f80d
-41 1 78 \\xe6979020946baccbbb8baec426e72ed6e0c34c297e6cd32d7d79b415a9329eac375dad4971156c59290ee46867aa5911ea8454559e6e5cd1ad12ca36ccc62f05
-42 1 118 \\xd537d53a4388d50aac05529f1e296fea34626cbff9dc826c41baa8946818e3a4aa9ac974633cd36a2b5b45cd725b67e4a69dde3c21e1efec429b10c812e0dc00
-43 1 100 \\x0b42242e3a71ffe0378cbd6b1e5e6bdcb128801a84263f7b7e0e9520ca3364db65e9a82c7bfa52d1094734676ebd47d6e682a0421ba92f2ec4a7bd3013f1860a
-44 1 132 \\x5961e882074829c559f7c05fc26ff3f617c9cee2af0637ee53551deb8069cc33d6ce04699b623ad298031340db8082e59e0d22d37734aea855dffdb30c481000
-45 1 278 \\xf5f93e9e545629f31f618a207bd7c949100dd8b4c603a15e5948660e183e5ad8fdd94679ada44c500d6a6d4421d83bcbd88043cbbc7880e52191274c8d121d0b
-46 1 162 \\x677ab8d91257eefd66b66a485aa121a04f632974abb620d22c20fb706ed42923fa538988bbd7ec901ebd5cc9ce9037f0b3c213f531a27c4e187d37fd3526d707
-47 1 217 \\x11fe268d605113da424927b929018a0f7909e1097d44da03df0f2ad7d12f5b6b72b4cc01b885a9eaa6766f1e26a69f12d5725730de24ad7537173e8b6341a501
-48 1 231 \\x59080361ad40619a512db7e69f66e27633a09df5dfe604db237786cce365ae94821a997ae2a751ff11da8c656aec1619e9ac8fd00eda3b4e7fb29d236c584303
-49 1 270 \\xd0e6e75ac26bfcad9e81386895697ee0a76af2a4644ceec919c92adbec964f0c21a5f02123242244a99417a5aedc1521e9df2029815523d73c0a843199a3ae02
-50 1 186 \\xcdf899fab7e7dfd43ddae6a353d14b5afb2258afe89fd8b5f5bdb2f61fdd6fa7d07943f9298870a4ac616e2582bffbc4bc0cacf03423305d06633f71a378d00e
-51 1 263 \\x5380cd2b3713f3255482e29bc8c14bf01e397936ff44025e8ad35d42ea91c860a16a442cf456e5399a17941c4f5a71d8fd50d830c07b21090ddd07c5b6091f06
-52 1 363 \\xf25cd72ea201a887db167d094d84214462f9b9753dd961796d06194baa64aaa5676dd07848efdcded52ed4d0179a310059012a0924a28a253d6e578f3ba7cc09
-53 1 352 \\xc59ebd572e0ebeda9841a06109ccc0c7b7fb29ed07508ef87045dabb2bd877f87fc5ac5f3775e120b2820e13135ce3820a4ea3559040a97624a0a27b56211104
-54 1 193 \\x417612712d9c8b64a557462e83c3472d6e2e7dc33ee71952a5ce661ffcdbbc2f348bd11cc9ae48eedbdb274fdbe9a008ded42d719c97f7a263d8d2d2bd949c00
-55 1 254 \\x5afdf19086b58f58d1e1422d33bdf33ff3ae50c5d9069a8e5a83a7a1bb440fa75e9b389f192f53782d43b707a8c3499010ea108d8774daa591bf57095a18230a
-56 1 264 \\x36e9a5064aadff5dcd4357d3e6b81643bcfb8f68ea2033b4140a112404426d2ba3019cdbe224e50698a738efaae66ee8e430650c13445bc1197fa26edad4ac0a
-57 1 213 \\x670457edfb4b9f21c56a9bd0b5a38d5d305fa859a9125d0a3a83e7d4dee0b855757598c93497a9bb5750b352c20f3de1d960a58720d620747d27502187bf8208
-58 1 142 \\x10c5ea666039f9bdfb3c920eae1a97bed8d37b2cdfdf7e28ce8e7030057fc8ef88ac6fa3c5fc45dda4bcf1f9ca8a802798773687ff6d387c51a7cfadeb803c0c
-59 1 400 \\xa10de5cc9e294dffd7f7aab5256f440c2916356e4ec10d0b9b29a75b1e13b3160697a56e70d513679e1cb96c014ad3793a753f0bfdc9a9fc0c2c67f5e527500b
-60 1 299 \\x58455a701b09def84b2eb7635a2d4bc566411efcbc496b05fda409b4d300de46626e5e9f20547510071cdd1ccd5fa9c9d972122ea408ae08045838a71ac5020d
-61 1 335 \\x335b18b9f0947363c68b46f3e169dea8e541fc25fa4eb1c7e0e9142e6d0c7eef930b76192778d70a78547260b3276a093045db73199278056cfef7a86694e107
-62 1 407 \\xc1fe3e3bf4da3c46ed1469005ecde4ef122d8f35f88551f25ac5a31ee2e842a9d8e0a79f4083b23e058285e2dd5c9c1ef09d73b86b427b3922d5251ffb083109
-63 1 81 \\x1c80752e7d564f8b89df1f19376c5c50e2fccf35947b3fee07858f30c741353d29d3dc16e0f57178a3ab67f593350aa802432a384545285c5f8e1a836718ed08
-64 1 26 \\x8be90abd4310ebbc374f2643dea3bd0e6021ea1afa5960293844b377f6bcdb5d2a30ea916344476686d5983de265f16c4487326583d47c1a09789624a1f7340a
-65 1 388 \\xa3066b7c84abfc218fc26b95352277ea9390415fe13886882c8c0dae44182d6044486e33d774fc12b6f278b73aab75e481fc0c867162fe41d296a50fcbf36d08
-66 1 422 \\x1661b1bc85f10872370d596657e2c09d9364e4d982e914f7d7e6e411d9e2f86221a64e537e43757ab54fe5d528ef7ef724a4aeaf6365c583ffdf32e9e167660a
-67 1 376 \\x09fdf33a15b9967fcf426c5d9811304986efce31c797d15e5326fec9b9cec1dfa04505b75ca81579838902650d0d9581d4d8fa489012d50d1c415156c4386d0d
-68 1 258 \\xe951e7724c82739c9fa624795f5a54e2546ccce2d016aba996dc024933552bd701244dd99ec5abc85d10e4c36611ff76ad83f9aa6394ce2601e294713cb58602
-69 1 379 \\x238caecc2e54a95b57789258db8d8cff5d6ab6811bdeded69f8310e04cae8017e9498d3bc3d2cdb98228fcd94d72242dd211ab2c96217e5f272c1e61954b4305
-70 1 69 \\xa52589d1ee3d8c7c3393a355fecf93b31ec8c111ac79c3dc266e4e3fa6d12424f5cc7dbba4298e2513f3315e53e4818085249eca3e5c3ff57ae3a5a73d6ffa05
-71 1 331 \\xb304236f99bb9fedeef18f718b6d5c40ac5a2ed0fca0f3839c31e14ed83745a75686382b5b5fd411c705f84abfe1404310064c25c55ae1b648385b34e3f43d09
-72 1 338 \\xc954333f43e7663cfb3adee12627acdd290e74bb839cc7d834ee358ac84c06310272d60ebc7287d4393783570f00f04c560582c59bdab537c3cc2911bc9bfe0b
-73 1 110 \\xee87f19edf0a1909ef6f2e28c8d66bd8c417fbba20e57b0a52b0ebf0b2110da0623780c47fa3755c96fb3591bdd48e6f6473897208c38e534c904e3e5cf4120b
-74 1 309 \\xfddd9f5a15786ea2de5e29f3606a98fa779a218d7fdf8391ec67315508304e73bd5911e7b6a09df34966bb82f851067404420514bf52354bb6e9bae57b8e740c
-75 1 34 \\x70a390d4e4e8ed27ae730dc65fdfcf9160adda6b2af6193abd318ee5a346d0f5b891437d250151154dfb7714c688826b73c33d9fecf62f70e41408a55891490a
-76 1 296 \\x5787023ad5e5e5a4419657b5474a45f7ef1619a4dc1e64a81d7865e5d7588957e48546cc903e64bc25f13abe0d94fc4adeae74fce81dc7289785517c4d0c9a0c
-77 1 332 \\x5d904cd46edea2885b72839160674963604a8bb88e4e457bd4c45cdeb9923b527413add3c7678b253a50fc6bff4f538da997f3bb2c75d0ee4afef6434f716304
-78 1 74 \\xbca97ebe6ffeabce2d506b2b657d3e7a01a781a703c4a4c514500bac5ea287db1f7fb11ef1433066a512874d305d28030a654f0aef050dc10a1f432bd2ffe403
-79 1 229 \\xcd977a2a32fd42b37b9cd0633c1eb0e4e4e0cd629a826d15e212d892f65ae24dcc09068df156fdffe1f16dfe438a61cd4e0003b78aaa3c9ddccd5c586a8fe201
-80 1 389 \\x888bdb8bd4c710a0241b41a47698b28e723e10a86ea1eb4d4d38e2040eb372948e5fdaf15ad2d36fc39446dd5c364b9c3419cd99323170b9ec2843b90e3ee204
-81 1 89 \\xbe3ad0c151bb1a4ebb2c331ae904a196d4987924c3f6217db886f9b39aa59ff319a6393636492d910eddc7dc10490b2a6a62820139b47fd5d2d98ffb91284b0f
-82 1 61 \\x4df1ec69d951a6a7e07dd186097240fb858a1b1148d96dee31797242b1fed8554f554e08fe8dbd0041d218e928ea1b9205d7d29fbb13d8f805461ebdfd642008
-83 1 220 \\x92cb2b04296b61b1ad785b433fccf53f9ed73c8cdbe99dbc2c22dc8e888bfead268af688479d00a0427942439bf2b619631957f0153dedc9d3668ba6b1a9910c
-84 1 103 \\xae61bdd9474e0dbd9ee0cccdcf012c121ce9468cf98ff879a346db9423e22c4cc2fbac3a6a85d5f3068e234bae1333ef09d1c66d525a6f6215efd6c9b8a26a01
-85 1 8 \\x57b58e6d40bc275a3306cbbaa719d9a8eac662f72181df087cb25fb1792137cc91557fc03de9a8edf9cd638c04403f112093994f52cdca5af4b1199be573b501
-86 1 87 \\x228c39aafdff74824c7be6f72f9709a6a17f27a01d2b0a14b1a5e1a0adbfbc6214b580fe7303d1f8bd7f8acfd5919d2297fc92d45725c01ec3213f4ddbb0db09
-87 1 401 \\xf028d8b556217d4f2f80a67da61b8c3819f448091f86131d5b6c547654bcb3339dbfc012014e2ce87442f1cb5577aebeafb300cde1a02eb11d2fd1988900ae01
-88 1 47 \\x3f0b7ff369ef96cca8dc3515e21b9b42b5857f6fa576609ec5786e84ccd8d581883b0c20c4debd20615376e5d75b3bb0e2035a909ad72bd8b485525a06d4a005
-89 1 40 \\x4d08784d844cddc000d20a12002d906ef4d07a1ec8125953d6c9948ce04519ef55da3fa271df8aff190353fda6d3604cb50aabc330b68fa349330d2d13e5820e
-90 1 1 \\x78fe3d1b828b51dc50ab85c32a703d629566536877b26309353eeaa5e65f4499a9e1c6161aa27fea7a215518c578ecb759c33c1f857f7fec24bf28368b157b03
-91 1 189 \\x0258bda79aa814045249fdcd878ca3c567a7dd2cc0f82e03688e1ac6f8fd2fd0cce91dabdb1741c8ead88cee1e755649abfae4f11ae0703cc1080096af97ac01
-92 1 365 \\x801ca23f5439f9f8825b4956c95bb40d875b88a1907bcfe686b3cdc6d21f1b1a4de347207f923efafb1c41f1984300641c9911dd4eef442c9baeb6d108b69606
-93 1 145 \\xd09112e94cbfe4b5fd517f49ae2fb785641cb5359299d6e3a8afe2cf27484f4eed5fc9e65a5fd3eb38024fdf7f2b96939450341ff998d2f65ef84bba01930d00
-94 1 198 \\x88bd290d3df750364d00cf387831b4f103ff3ae6e1a56b67c23518b7ba984b9d7d5a9f65431d45f07d55d780c17562f668c50569081ed99093c7d50ffb456406
-95 1 197 \\x7dccf4f32e288ec5d236aa3975ded996472a35e816cb31d4f0e08bf74019d231157db397fbf34aad345be48204f8ad03a7a2a78236ac3be76a50e8627c6d0201
-96 1 199 \\x22056dd5b549ee691aacc5c6f1c0389b69ee44514361b7fdd3f1a96a9ea0a0a22663e15b8e10b3e8e98695c8ac85dfc028a1254ae9b8e0662232ab187960eb02
-97 1 277 \\xf664b49e9b991e4e2c2443d22dc5b1d196cc727c60f50534c6002c4c25350076b551f8c9a91afdbca718ececf19f4e1bdd8634180ea5cf0ea28e47ff8875b00f
-98 1 307 \\xdd98dc13ad27587e3d6dfb06f75c7298c165922f28e08246a7bca7a46849445ac01e1a4959d421bb22b5b70fa8d96c574893b0dec7bc8a73ad4577f9a31b4a00
-99 1 303 \\x7895b251da6ad7d7cba105ec59a9003e8ac2ee84431198d5c266ce4c97f4505ac04d5138267d6f38ccda153c7c0f156a634b5fedcf4a9656124676e00ac20209
-100 1 5 \\x7b34168e31485c6a202abb73a8aaf46ec97e18d5b32480f9bc35687048a17ab03932adbc92e2501fcb48da7e179a545992c6d6c369e8fbe352c9f0a5c62f910b
-101 1 20 \\x0d4efae63a0caf0f7ebd059c5ae946b14dc4eefbcefa8e0d259f2888509a62ff84529e535a13274d130a1e94511af8e35962270228cf9cda8c075023890d6c0a
-102 1 228 \\x29896f73912aaebe1900007691bc479e11c38427bef5b70db4b2c20ec7413a537ae5de19bbc75daffe63f06beeb9df47e71e6cd931c7a3b75963654169971f03
-103 1 412 \\xcbcad7f45f29118914329708b226d30a269434c0ec32e272f3e849ab6a3eb4a830cd2768e3902e7c0be4d00d79cc0f858a57c84c25d8c0892eaae78c7e6c9301
-104 1 202 \\xc8ebd960f50f630242b19a66744fddda88ab6b4ee75f4a3393f28fbe99cce30f825e399e2dc2ec1ac8cb87af984723d1ba6f372b564aa955cdd28fa28988770f
-105 1 301 \\x227871d101f8b2d94e0a6cfd601f0738f8ccf5e5b5a3affd559d17d082df2c4be017ce8365b9f7646eb5d47beda9be5efbe19cb5843c966d59b03fe0f1d2700e
-106 1 285 \\xc2961a00b679ac26813ca80a0fca49119452a8d5c3cc445ebe31b6304a8eac6fcf87b1fd576235a4acb00eacfc42182d93a8413cb6aca6b1df16c962648ddb06
-107 1 409 \\xc4da330b0ac5ed97b56d914dccfebe6ce4e6dffedb23a01578433cdd075a5946c131237400b7bd9bd34929424172049c3d02bd2008c630a8a130c242cf447f00
-108 1 39 \\xe7ae978e5eb8d4bcb51851c55afcd15ca7f102737bbe0ad8f2a2e5877e4c415c928812ed4ab204419d5cf4ba53cd6fd6cdb3b873cde88be8f4937668b0848409
-109 1 244 \\x9d7d4d053c17fc154ac0ee428efff1f157961a384420096624cba5fd2b8eaf142aeb986cfcfcf197c0a4e01cf722133b9cd037b52a684a7fddf673e3908b5c01
-110 1 95 \\xf2c3aa1057c10a49269263ee6b86307cea2f36ca9439bfcd4ec7ebdb409a4b76dfafd1486d27437a5aa0035e33e65f68b3dabc803fd5d3e0071d6cbe88cd1100
-111 1 115 \\xc8fdd145b7631492a58ba94131a2d9804c1cdc419579cd26deb2e66442c48639e9fb4a816bf233f56bfa6c1d78cc5cb916e5888513a09ddc80f25139053aa50c
-112 1 21 \\x689a47f303b2a5d866d23ae01ddd88b8403c57e2252bde54f22bf5dcdbfc6d388b3d9fa32cc50a9dc1e43d928398ba62c67352f091c7b00cb2a94ae321c2960e
-113 1 42 \\xbf22ec1da69bc4b19996a629bb0f84298bb21c365c0d078cdea5e89761aa664e616420846456b3af1ae99d55f5f668c2f0367d307e748420bf7b151459e8f206
-114 1 38 \\xf8261a945dae328d70c4d73fab5351cd3e7f10d66dd69512e748b961ea19c1dd2f504b7e0374e446cd2bc76b0ec4e822e708be88718855fd04b4eb0aff74d506
-115 1 157 \\xf8b5c26802faa989b70b954906a12e2eab0c50a7bb363e87ee0bc928ef9054b8fda12a65b982d4f7ee234d26491061795caa9485e8e28923dd8b4e4c8f880300
-116 1 411 \\xe1d703719d5d9e064b6a913530d39a5df24407bc5ce4b56ccd6dc17aa055cf0640b37952664224a5ccfbb77614ba4ea70b760519daea774e965303b612224106
-117 1 98 \\xf015754ac03353ec8941de77259e2ad4d5a297f675e2f826d7e6e276b52e3b21c0eb02da6e74f343692dd7eff8924d17716ec9bd2314c3a4a9cbc55b3c14fd02
-118 1 405 \\x59421547c84dfed4e748a55c7754a2f9277ef04f742cb4e739c7630d7f454e039cd488e447ffe8e32268ab638393ba13c98b8ef1e5be848a029366fb44d04d03
-119 1 261 \\x53c7b2dac2b45eccfb014e1817f9a8b4adfe302f7e52dfb1915d4846eee4fc4220dfaa35e02bec7a0ebca791f26112f877e412a278b81fc6b12f4d597065b10e
-120 1 208 \\x99da69737b53b8bbbeeea7c56f1baee58fdf17531c2abe761b713babbaa28264d9c756ddcae2a53fd343223135d0cd32d6199efb73ba900190c86970d998dc08
-121 1 330 \\xf416fd28d88d6e95f32656cff71d53a9590cf56122a18c36929d0d9e7b00777b069f781a51109e11577f858e9ccddc9485807e5e7e354d4e025d6b222ea28906
-122 1 155 \\x92a8fe904f60178fb547fbb6952874490dd938cec6572d37852196e5adcc6a44ed49ce96d4e75a4b5eae88024eecf26b3279e9866f98092838ce77fdcfb9ff06
-123 1 75 \\x9d6fd4d742db0aa9a5a8c42a910453f5d40d39f411dffcd8ac25183ed2e56bccaac97724d4dac7b1b5c9a44bbe0b7a7258a486f96912a3ba5ce87007160e8c09
-124 1 111 \\x7938c2bef3a6abb720a5703a61482e8a6b6a9d6c68c35e1330ac5df9996fbc32c34822af1fdcc11e014359facf2e41e235e6684ed720a887c1a8d89f1a2c3009
-125 1 7 \\xd5b585a7929460691bd282363644e05b468b0d69a5aa7148e02e898c4ddda16ea19f68b3173ede6098a3276fcc71cc728d91c2ace2d1c6b7a6fba0f54f2fd907
-126 1 85 \\xd2595fc7b2bd9a8a8dad176c518d3e3f446c3eecea9dcbab766c4766124d75b1be2c5b7b090203b1467b8fdf505e2da8aa246dc1352fc484464c79116ce11909
-127 1 27 \\x66b388067d21c51e422ef29ad81b09c4c94e50a0aee98a14fb95d427af67f470019f7f3e0e6add934d2a42543e88c52ce31549f9f4b0fb81aa9b1e5e3c9e0702
-128 1 180 \\x145e8ce67a6d6744041cb9f811bb83f5a85f5c190a098fc11cc010a2e587c447d69933af3bb2993873a111a27877128c3b3c12e04296e4e6ee55116174a18d0d
-129 1 320 \\x3f5ac54b441586a9b406fca08a07746a98c19b1c9682f3c45eae4de5cbb4f20595f63f6df26fd3ef32a8dee161b98bcb2c600e4fab32e18ed035dd907361c50f
-130 1 31 \\xe5fa8065d275b41cd808bcdbfbd078c7c6222b1eded735e96e22e5e9886c6463747530c8927162f1cff977983192f0858b6a7e26b5cdaadd9c64e653b27f490d
-131 1 41 \\x6de5dac317f03784ef8ef7c61e4d7a3489e7d4b1e7b21e6c70d82b91ad0f274b8c8588dad81d81d735d3b734acf91b89dd934d32231116fdb7193f54c4d14806
-132 1 62 \\x31de2bc92134f3ea5fde499e088889eb269499cb163b19b81034f6faa0ce4d1578f29120482d30b4feda0ab2f3bb8561edd21df0f9c3f4898847221d70ee3b06
-133 1 10 \\x10bd8eda726c2fa56f62c47427b0722c1e6b6c71d9766549b7d580789fcf2ab4d8bddce4913b83b99c5bc7ac89216da911dbf19168e3477c59ca9d567bb02605
-134 1 349 \\xfddc813ddf094636f6cb89a1a630383a867f48986f178afeb5606935e40078b685845039dad20b43bade6afa45c65040f13737d89e8479d444b6320f3a6efb03
-135 1 137 \\x5054aa991a9a674a9b9a5a8d10d38d985e608b0e08f114cfe1ff76158ecd6deab657004914707dfabfdb9b28afe4d50b1196a7ebe83b3dcd4e05a811c0204802
-136 1 249 \\x0f2d904fd6042b0430bf35006469872f63533c272c78c804cde2d06920158fceaccd2acdf0d59cb69125a0f3eb69ef46d104a84e3770f8899015adb661714f07
-137 1 29 \\x3b508950859f12b81ad86796b8a21707699d9211f27fdbc21d5aa3219f488c2ca9fa0faf989a427be492795c44b64ded2b4d7488e5bb6fa010ae3e97c6c27102
-138 1 339 \\x0628fb8abea3d42114a1326bd6e5b1283c94c873611148a2258095e0984d494bae7b3378c2bbea128303879448a8a007fb5e2da4c055e9b2188e42ac2357790a
-139 1 289 \\x99807f22da48db2c8d3c2aa64964dea5a4cb6810a3eeb6b88c9b3ce636cd0d51510203bb8c343ba72bcc71d31041da10a045bafea3e8b2109871da8e7d319301
-140 1 345 \\xad65d6110faeb9dde3f358e3534509f29f56ce4b50be090c953a1e087cef3f8a9e3a6f6ab13673964a3e71e9fba70776d55cdb479614de4c31b6ba85a09b9b02
-141 1 164 \\xbe2d23a18d273831c8396cab895a20aefcd0666128404883ae9e26ea7f6560b0d80546ebd75be283b9c848b24ebc29b29afdf3a478e2b972a108d8426e594a06
-142 1 18 \\xcc593b75f51a90e13e2b923d3783e14238b6bebc20cebbe8a9d7c0896bf2e0d18b1144d5c30d7ea0f8a055b785cb791ed432d9dc443e8dad25ec8b2663a47b07
-143 1 396 \\x8f1eeacf86fa1e2366c3e4902bf700dbb21e261f258f7a7bc91d9a443315cd094a553f6539351fbf62373e3dd38586677251c44300ab34335feaeb111308f109
-144 1 120 \\xbb6f6f8e950522079afc08c07cc12fd7cae03e58388876b152abe0de4b24c8d78b6fd0ec6d3737d410cc98064dcd96c97b8539469ca0e0c11e0b15040375cf02
-145 1 14 \\x1174cf0c6f911d4c19f04527760767baad97d4c612634bd90b81d64445ddf9fb87bbb0a2a6065b164925414e7a02e6ca97b474d7b8f44637974e609bbafc9405
-146 1 284 \\x0143415e70d1c842f3168574b24433bb976cc98bee50598b54d407a043537715271f8ecf46cb415a726cfb9553763de4c6e88a27a0a8f4cb5a0506cd28754704
-147 1 102 \\xf6f4f7031d687d8ed0f7eb67bc2889ff3f2c0520b38a7c59bbc71c9ef77db2ed994fc2a32075635770f8a4f06d3f20d7a78468e4b9618c27f386cff54febf803
-148 1 154 \\x8e652ce396331e2643b11c785c324529cd49e0ef0521051b85bfa2249fcd9169dc22e1c318586218f259cb00fe4a4d7a93df8d5d9f5ca3fc12a58fe05900bb09
-149 1 71 \\xd8e48cc69128807de9e6f0a78679b664d482b8825ab516d03d0b6cf8aa454479fc1faf487b62c9a3ff15553b610d9159c3e5065a329fd02058579aa7ee66f80e
-150 1 294 \\x2952ae4af27ca75f7aa5038d112f2344dc81f65c609981608adf9ab7e304ccb03f64f1eb0e40bf9ab1161e63b1b08edbdf1dd1bbfc67fdab4eb200b5a485410c
-151 1 105 \\x893430b17ab4aa8ecd3cdbc232f713bc9d4a87867c3da27002eda3f7fdf974baf81c21eb73331e2759f7ae94f0538a75db8e803dd9f889f1036ee039317e4807
-152 1 370 \\x3f993b7b4d979d7dd1ed33ae6c8c4cebbd07228e0a072d33a50431fc481f1826500421ea4e5d258088cab4926b92f41b2092034b35696800b9edfb332190170f
-153 1 304 \\xa5d5065608209a7d17a2ba09cd38ba0bb323dc2aca2437312cec545dbb82a48b6ec6cd8eb89e21c42ac7869c5b8398eb9ced5cc69b9fbaf2c17a481950c49808
-154 1 314 \\x63ed5c9445ece5b00b39221a9069a415e43c74139c5d3c67091130a3b99942c0a12855a3597dd69a882fd0b575b4971b91b82e10201ad731e4fe662f3117ee01
-155 1 291 \\x43a40cf318980c236bcf44f2adcd7c24a0ff73c987c459d5f4f562da2f9dc66cd47ae621cf2c5d3fe62380935578cf8c3596ead28209f6c0d4ef7e7bb79a3c09
-156 1 168 \\x521f3d0553db70bcb9ed0683909d900268b062a465a07463772d66ab33ff301bbfb5278eb1bdf88ed521bd9d971960ba2220b6ad184a785896e3cefc80ffac04
-157 1 371 \\x4aa3ca0b42763684b566d4e8330b30b3ddde678310ac8a8441b1d6ed29b00b806fd45a6cd6f44ef9ef0a8c5bc2854dc30cc1d18c706bdb5d2429774f641fe309
-158 1 172 \\x9a9aaf97f75f2ed789366c528873adda765727c34acde5ff0cf1d2ce8a63f4d9a405d7ad6a4a522686eedbf19c19cf44e62f0ef1d33f5fd03bbe9a07c29b260c
-159 1 269 \\xfb974bc9bddee6d73f1c6580a0f849d01b2bc3adcd6e5ce9654dbe989ef718756ddff8777cdb3430dd62a9539c9b02eb78bac03c3afcfaaab9dd054e22888603
-160 1 255 \\x01dd15086bcdfc9ebf7efc9207f165e068b8b2c3f311c86dadf194202ffaa55f708148c365af424e5f9487115fa9d527bbf9b5406b465e258d93e0bd1540d50c
-161 1 266 \\x3c0f00cee3d91db84828676f92cb292c5d16e296c7af9396d5ad9b012f56166c71df4c2c989a980d3389ebaeaab546c240a17db8fc7eb9aac676be617e41020d
-162 1 6 \\x06af65c61691248aa99c0765a182e8875a8562c5b830178412a8382575879c790d5c19c6f203877bd8cd2f55830891b45fbbf0a76af5b0c0519c0f2efe8bba0a
-163 1 36 \\x7f62921749670fe71eb230f421d00d27a25434a57dfbc19b4f561db902f91b7162f90df8af1df4a02cdfc712136368a3399681c22fbf485592eb889bdc89ca07
-164 1 397 \\xc6fabc2f5852bfc09a65226b1f03b82d6600440ad7af5a2dd032ba4b80f0851fdf9997c1446fc81dcdcee4282ee0ac3196ea6041c235ad17f2c32b1495046d00
-165 1 300 \\x4d51a940233c972e267c50d753abad13bfec10b92fa173a01ce251c6bb16f7e4d0ca0813bb7142a3ddbbd2b616a69aecc75f37b79362bcf578ed8205094c3509
-166 1 13 \\x7c6b634b623d8aa5508bc599287e6326c7ee608edbc849df2db9dd0eeaf1be98f2d7624302de41cdd27ecd93ac3407083c03445a0c89c3aae89f9ee823dad50b
-167 1 91 \\xafd55677578ca7ebc5ab454c2bc379927f28f43ba69ec18ab603cb0eb745df1ace2845356a7392923514c325f90d339a295238bb59b77090c061628df9063903
-168 1 237 \\x1a74293b5691ec9eaf43c3c056ac699aa469637f6b0a6799769c34bc949ad19258d087a1d07edd6f5878a05e54b2c3a8aa37e4ceb73ef9f1b2317cc141637101
-169 1 67 \\x0405478661461760076d9ee4a0181f4cc6c8d4b408249b426ae0c05e6b42a956a2a6a60b6490429d24ecc40f900d8a352ab9a8758e8a66c9f9077569c839620e
-170 1 64 \\xa9f208676710a81987a0ecdf23788e76c1c10428713efb4ebb6b7855532e2600e23e5357b65f3e5835a603044b1cd6ed58ffa957c99de9d0fd3a49904b221106
-171 1 93 \\x19f7e4096782ea065cec168e028dec11dbc20e95767fe5881bd9cd4b396dd292f79c63690f4b42dcf22eb9c434a78ed728e2ff1d6ca4f26b0d05ef0c33b8520b
-172 1 377 \\xb2706690e1a1a6e8e9866aa3461fb1e6ffdaf507104b369a0d1dddd1c121fbd1a85b7b40a69260276e8cf7e082265b5a5ab2f3c45109b0dbd71aba27af64e602
-173 1 2 \\xece6c9a3199e19c48697db28c6962082eb64fab4e83783dc5246d32badc5c5b2162b6b5d60b8e39ffa236a824b7bd4d1acb9d095bd1406c18b7a4d6217f68b02
-174 1 16 \\x9933e914a0289b1578a1968fe1080017391fa7aff0faa8f6dd60e7514100173279ad8562bb69c2da2daa405fbf59582a3ff58ee926c792669f21debc0f86d008
-175 1 88 \\x0547ec813d43da6662dc0a8a6feaab700d45edd1cd8990a3c0b5576630dca0d62a43bde0d7dbbb2fa0ad8b3f71c0f5fde08bf0656dee64db296b1aedbc783c05
-176 1 333 \\xfaf6a4fb486d4f87bcac1cd4195b7afd2a9c47a6cc5aac6b5851e1c4ff4cacd5c78df45cf6930f87ad7d86ce239aaf3eb74ed82d46a74a17be8875edf8566209
-177 1 256 \\xb0e622a9bc369068174adb277fe293287ebcab857d4443727bcd65086dd47ff32c82d8f16b4b8b7c0d60be06221ea288b7acea8e06c2b6db7702842c3b852c06
-178 1 143 \\xb4fd610ea8f8bc54bf04fc571d940ad77e0df2b2371bb7ad47033965bdcaa250074dd508addd7b348465b1551fc3fb771612faee30b3bbedef7b86fcde0ad705
-179 1 373 \\xa97074d664248fad673ba00bda5a58febbf9d505f11d5254b04112d044448d58008065eb33ff0c305a8df45b9267d7f6aa5d0731c7be54641012e1ee5097960f
-180 1 310 \\x5b35f1759094ea195abb7cbff4b89f731882cd2ad6cd19b2ee9a4389ae8347ce4af39b464301b68d3b749ea079d4c854928d53f0d5f0e8b2534f97be82568b0a
-181 1 3 \\xee32b92c8701cdadb54cb27debe46c8287444e7b5bf420255bbca9447944f65e29848834a046aa35140e06ce1d1503e4efe342eb241755d2a0bdb2e4e082e80e
-182 1 293 \\x2aec61da15151d484f4f8f20d6d9d9a21ea81d480ef8bda52ccaa478e11d08109dc0fbc078990bd3a970d67e2f73cacb62a08ef942915cd8cfb050d342dfa70e
-183 1 358 \\x0a77400fbb45dd033bff13e63834efe900690cb409ba30312deac06191d2fe4317387f9a3cd8fdbdc9124f8c6342b952d033d9dc261744de6865be8ccb09b401
-184 1 272 \\xb8e012561f4338adaac20c4d6c453fd31faa58ec163b780ba43f9c69b03ecd2e57905a56fb9c09cbcabdc64f36a5477eb42788becded02bfeb7674b058cc5405
-185 1 233 \\xe27c894cbae35166fefd8c7e99c8dc2cf74fc88378aa7d339f43a5526e4b569c95baecbd4f8a21620118a278503d6a7ccfe7901deeb18c8ca5ae581fd9526800
-186 1 178 \\xaa550d7eb03375c4842f120a3bad0573319f8eb92cfdec53fce8022a7862d3a18b5afd591f2b9a5bfd9029291025463f64a88be797c826788c7c77dffff9c20f
-187 1 420 \\x984ae4dbb6b318bf923a3b91ca141d09955c5f7d09c5bfaf2c0bd52e2b790e2cbe637526d2a5dd37fc5134b5c655ddef5afc72dfc59ff43f12ead587f710160d
-188 1 350 \\xd9f0d8b7fff794e43133165646d60d0f00f80d00b9953dcffaf97a8e42acd945f7c73f47ded84b259a4a9063bf181e86e760f23311b5863ec68a1b87e907b005
-189 1 221 \\x03cf2945e4e92ddd62278348afe67c71d73d1b6d3264302b1bb6c715a39c844dc05d4bb4939623811fc17582225d0dd9525c5f297c085df5448dafe8d8747a09
-190 1 305 \\x835beb6ca5492c6c17e34758b14b574d333d7cc0296b6e2a37bf3888f3d512675fb2ff28edc82735974fd561fd1df68e310d3574026527d329781a1b3330a709
-191 1 279 \\x4da299bed62984659aa3311afd663db546473be1f03ae888b6389ff3453d5671b4d614d7407da5eb53437b08d098ce2396ef65aa223db05c1e0e52a01ec7990f
-192 1 209 \\xd3217c18f4ac85caecb806be186863f02324b9b414ec008108d90f659f22ec960b8a06f50ad2f3e06b2a30491a657c7eabcd00b076c6677faa72dba3c466e008
-193 1 101 \\x9665890be2f49153c5efa8825b88e9c00979d9f0f36dcf64299c720cff8155d7ff24615ea4c46dd2c37ca67a1b15da31c92b2378815bce841412ad7dc1d20205
-194 1 298 \\x7d4ddf4a3ede21128ff611c9e8ea110c16e43eab3b061d7c94c71de4ea0b985e8b13684b6882cddb0630edd13807305df2bab316e44f695684327ecf0572a201
-195 1 149 \\xe926ac1584e9bccf0d0d19107ec166adbd2889a4da031b2a722f0dd0806915b0f0cfe6aad71d5c550d1d8c11c57fe1965ec32f871f5544ee1ed2e73ba552790a
-196 1 45 \\xe7ff50332ef1beb1adccaa71bbd689a16b05c99c92488570e69a86a1d199d685823aee259b766e8da66fb3a70a00a65f7dd25a1e4ef0fe90d213831d747c5b0e
-197 1 204 \\x833a75129e4653ec40d194d788b4e206ba7d49e544b206a177eb61298af0a8f5d80fdbcee1996be6e108712a60043ac6dc20180d959219defe8605ff9bf9e90a
-198 1 15 \\x2f6781ec26a7c32b5fe9cc9e366caf4096322663f1ba2f1c1c7040c6986c2661eaa328b0b4299adca77c99fa791f9f672042b3caf07ece5b32b5ef9bb126c800
-199 1 176 \\xa7d401e12d9bac31fd892a94783c8b28f425d6ea0bb0aeaa626f1ba7c73739025e5861043af5b2766cddc2b8759c90225f3788238d0d28d6b54f349c2575a305
-200 1 368 \\x7ea778b7623973ffafbd6e1b5294dd3269060af63dfeed31dcd8743d16222eea4ebb7838729b753894c761e9f5b0a44cb1a66ff3ae181435b1c5c1f1057cb603
-201 1 316 \\xc83b578d2ae7b1ce8c98077970a42fdc6592222591628c9dd694c71e6791d67d37351ec476edf483d882e6aa89632c68b89616628cbfd105cefe3652bc66b405
-202 1 353 \\xb23d2cdc6924173ac622b3b11dfbdb062e7a5b114b8b3e2adc144bc3b808320aee03dfe1dbf8ee5ec59c5ae582d6ced502e028d0feb6d9f70464178262b1780f
-203 1 214 \\xacd6bf6fcaf19571155c5b3f232c1c01ef65d145d5085fec29596e4c29942817e5f63191a3fe23825a5ca137a52abfcb36a53c49a4c60fd3539f7567eadc9e09
-204 1 418 \\x92963d0e4a27ddae9b96579fa6afb7547b5e84a245cabe0e88cb4d1039ba04a1c55fa06bfaa12927150cf3577a1d01c24bd9f05c128d427a3fa36e7b5d33ee01
-205 1 311 \\x8a8f55d4b6bf4321a60ff4604b76be64770a74dde10102fce4d7ce6fb2c2872c4457c2b506e3f54166f53f1db97971a64f3587431a65c6ebfc920ab01dea7007
-206 1 150 \\xab88a6264c4c7db0ceb1f2cdafc5a284acfb87130702e9e2abcfed6d07a2818d2757a8e096d4f1ead532cc85b808df8d4d538b7a98088bc09df154a4339dee06
-207 1 19 \\x29114154944e90358c0fc84da33c0751faf4f1026c4ad1420c089099b8c6f7f76da10cbbcbf1b1190a0dc57b10d20403588941f16d529fa0fe08e07f350b2e0b
-208 1 247 \\xd12d061b59aba88426e0ac1d81fd9cb7fd9c29451e9a77db85b4c1cf43a49beb76233c9eef77ef65cb5a8c4ce121024676892880dce28ff13fd407b86823e308
-209 1 192 \\x8c4b266e4a0060a611e3a2ecd4f3c36ae735ad882bed478044da889d7a72be0ebd650394fe7179ba822b76c5f3ca710c8f0106a6742ab2aeae9a58e19de9a70e
-210 1 334 \\x1399f9700f405313851b9da21ae8f0906b8648def76fcd067a164ce82c16ca7b56cf4844fa7075f97b54c0c6030f04088f87270a33fd7d83446e507bbdc5980f
-211 1 224 \\x2787d013d7866dcf73dad4ee7b305b17d90351146932047533e75c74de060d9930bdfda2588e8dbc981aba2a5ff8f2096e31905fc687c1beb51dca0db1846d00
-212 1 163 \\x3583918287e3dd1dc0d2211a5876eaf73ea1b93e9559755f752167e0771cc8d7def0c2a3d9bbea6322b717411b87aa1d57273d34d3b7848808277d2f34e93503
-213 1 210 \\xb99e077e411571cee971d84c465d0acb72438d9bfc706af18fba3e270fe93d1a44e3f456f0a213bb1595833aac162f4b789e07d28de9d3f71b7f8ff8bd414702
-214 1 323 \\x354494acb272c570def055aedb416c256224e9543fe2314449facf259876d43a88ec487e05623a2879ccc5088a6a25ac34a014608d41f2539a1e7b8745780407
-215 1 239 \\x97c8f6eb7ba1e3d938d723d6b21763448ec8d9630d5be36b6816b813b2fbd9a852ceb47e287450710ab87d1bf77b060d20cae2eb605ba91ec306cccbdd4c490d
-216 1 414 \\x6f5ffc0b11819f62262cf7cf926e2d029d1939ed25af9e585e08bc55f9b057bba32cebf8467530949b1918fbe32975a2f7acec66e3326b655ffe841d96c2180f
-217 1 54 \\xb1c5c2434fe63792af2045bd341e7d7cbd4da7c0118f7c392c890414c17e41e7309576a45c92a426738886dc765ad74a040a29f5b8cf431650cfd0c30faee700
-218 1 223 \\x24d8cd381f5ed8dda537d0cdd413c0918a86d5fa6dcaeabd0e7c53fd16ff0e1943aeac90264b64cd8060f10ea2e6c651b18e890c6f53920a8916553856b71a04
-219 1 153 \\xffa31c867d58b51c37a9b5e4cad0230e78faef68ef0fa8edc00372af81c93b29148385f4e9f46ded85257f8e3459b520b06d95c0e0f1ce1719a1e312fcbf0307
-220 1 387 \\x9eb81e2043ff8cbdb895a51a65eae90f3f1dde562865a07dd03f798628313f88690828062333e53c5a3be9c8d91090db23098a670853ee21a45c55e7de81080c
-221 1 114 \\xe69572ed80b56f1364fbde5c47a5661c7e1c1b463fdb0cb0c8ccd4d431d5005a357e71d14979209771522b21a051f2d25728362fd414059f667c62e7422cff03
-222 1 159 \\x5efbe8d4d90f0c58dfece54f74d18f1e21c8f2484b855751df52de7d638b7d619753bc5a0572c36c0da3c54dbba5ed8e2db6c56a6fc4f07d51affd4eee0a7f04
-223 1 360 \\xd1aa487a99bee3d51b5749f2e2db3047be60067249d6eb8a426fad72514e06873e2652f137ca41690e240f551d0c03f755afb8c51cba3cb9a104c4610b66200f
-224 1 416 \\x53cf566b1bcb99ac41c19c93b691fce0e780a8329882ab33efffbb1f136b5a603b1b268b78d50c1a066e6073b438b8807f5cf8b7df6a4a5197586d2499571e01
-225 1 136 \\x6f7a897c70ee841e9bc4d76770abe4a8a143c17abd5fdc0a486f8976043497b33ea814bc739150e573843f0059214c3b302f694a85aa23f61a3eca12c76ec704
-226 1 73 \\xe70aee60d22c5b84d7014a92b5ece36fad2aac1c9f6386433d381b82a47d16a0d94b4f9372a5faf02ecd046f7c3b7e6c94deeb40ee1c51e382a0e827344b4b04
-227 1 58 \\x4a8ddd36ab3b59dff4d1634ef44902e5b3508f140172a8159a2f58a59fecc578b9dc160f3b2e65e94f7e383fca808f2b46f645d65943bb7c886b1ee95daa090f
-228 1 177 \\x5ca28146c91f6bfedfc2a1ab64463bb62c017e842303cb6f469d7cde57aac3a77b510f2c6f552b90a1227cea82835085daa8dbd0c35e888de6bad8a04b900f0d
-229 1 236 \\x5a43cdb8abca70e874e6805af0991ff1f9a85c630cfa0597e69a03cb3bd2fbe7cfe124ee151d1a112cc40cf77503f035780875a5ad4bfc4b7f1d6970482ee90e
-230 1 267 \\x1dc7cd6cb97a1d455e7c28eb542a1ea5a65455c8df317cf676cd76211222f8461d3999e35f3c399ef973aef9fb04cd59305c014db3f2e8a9b402e75d9f10140c
-231 1 225 \\x889711f408b2d8e13aa0ecae72ec8941e1527499ed970d41afe5f7012f3e79419c9cefac8f21506c0c3f66ad7c720089596a93097b3494e0240bddacd92e920b
-232 1 97 \\x40454c94442e3477de88e9689d3c118e9f41eb1054a73fc16df2bb407d7d60b3922d2046757eb9777c5ceb6a4fae17dac33a8ab7121e3d7b78d2fd51f1a49909
-233 1 290 \\x7c0ffaa020f588bc2863331c788254bb97d4b111229ae6dcf47829cbbaf43c2147816f657ab0a0fff67844df3f32fae0eb459eed8f7f9d12250ee34bdfe9de00
-234 1 395 \\x19e580e2bddc50a42c00d62996717ce839639e0bddc5f1506abf9861c73d687e07efad66dbafec1317e055aa2ebcfaa61f9a801e02faa994e0fe902ea8705503
-235 1 415 \\x14d1aedee58a42fcb2af38d7f6571541a16f13385d6bdcc78804e224b235860ae9ce4ff346dbca9ea5eaec7018bbe7153bcdd375fd2a68a54d2b5f27ae370802
-236 1 119 \\xc2deff336c97f04cf139b605ccf45b5c69dc7c76547e10eb1b804c18a5a0556a3fad8c4eda223f12b3f08991cf143c7f56987b7dac80dfc10c775ad25dc75c0e
-237 1 24 \\xbfee76e167429c2e8bf3633250c7151376e70988cada9ad86ca435b3103008490c4b149ca25b636c1cce01e4d2c635e1426232ca82c35f33693488fef10f3409
-238 1 413 \\x67928aefd05812707adc6a1b6c767ffacd140fa4ee6d8d999b7cc44ed3585b6011c33bc1c5d40a8774440a117e2af24182035b6e9c109e9e91a39435cdf2080f
-239 1 211 \\x8883e37e25f717556e0e2c71d68dc1425f4149335214b03cf64120e255035b8bf6807025fbe71142b2b316cc426ddd18c023b385f7b7f23462e8e6dc45962904
-240 1 337 \\xa54ecf5d31ba312cadee2483bca58c86887da735d9485080be9904fff8804b0a666c5dc0077096301bf859686ff4f60a1a532e9b50c18a5a16f07f203e07090c
-241 1 72 \\xcdd848ab37dbd21e88a298bc37814d09c9bed5707f0921d8d0877d93d2858352b33a4a553e26185e86a4c700e6928449ebdedf4fc170dd752ae91a52b0068c00
-242 1 99 \\x331cd29d1f865e49d85f6b26cb09a49bec4628d2e00833a425c35fb54e8cd90171060c67658292fd9a67acbd5b5d31c3e560d8e9795391c67587343d663f580f
-243 1 383 \\xeba4dcb86dfadf7c439e6631ad720928418928a98313b0ccd876274bb47738e4e58f543d7f0bab0d3109d96cbf0da706683e319e681e06ac288bb9df3129310e
-244 1 46 \\xee8298d3b45aa964798eb847c00a5f2bc2acf3659894d6c79b95ccf72a6247c44d97fb3d8a24844633d2fdea64f5ade53d6ac47ac303f82431104d3235f24009
-245 1 404 \\xc1ee4a341597f02cffd5eb7908f1de287ac0df53d9f6f3ca769ee0d49323456e892aa5ac2709b2eaf09db2c38db219f6e0f0e5e6fed7d7e5f121f01ca1d02f00
-246 1 171 \\x3950f611729a84def29a0563ab87bf0b472160959ed89eea7289e20a2a7e3cd4ca6661436326256e69b453ba763328874ae1405efbf2833472cf537f5c5e1c02
-247 1 83 \\x75efab82de6c141208ec3f3a37e56410a3fa770ffc56556faeba2b2dffe2d90b8ee03903b593445224ac3cd6b208af975d427701965e993e96830cf5f584ff0f
-248 1 242 \\x0adbfd2e226e45b5aebd32afcde1faf23ff52b1894fb5eb4029706a370fd848614af9a364709fac408466bd0c80480a300c216ec9e100c29b928f780a6384204
-249 1 169 \\xa7c1c01ce4c3768a60aa4458eeedef2a4806b059babb04cd130d2653d1605560f3269c07a6ff022e19061d08cfe43c95321dbf64b9e3b678c49712205da6560c
-250 1 11 \\xbf540a1ef13915ae165bb6c48b76bf20c44a2697ba844ee66e37bbe511ad7f646778eb37edae291b53021a6e250e77b7d1c0f5dd3f36169b52a65e4513b85e09
-251 1 238 \\xbacbfe981e97d608dd59b67587dd2a07275898a94cf686f93d80a545d2eda353590b567e64203f0d3877ab3c4e5083b0542f3dce3f67109ebaf722650b99c603
-252 1 182 \\xf0f373eb9d905852238d553a6cb3f0fb02db998e1e217195ce8a913815a5d09be8a2057f2396aab3f5d3dff7b6c60a113ebd3e7684ce3b2f41ef450f3bc9ae06
-253 1 191 \\x1774625677b5ce0a3dabbe27dbaca16ad35550c6923491919f7cbac9ab5eed3171b89bb21d7029cd719b11cbe174ab4c6d6c21ce391761f3576bfe3edf5bd505
-254 1 50 \\x0a9150b74d2a7d9ee15d43dd6ea9f013f8a3d3ed17169fbd43b8a7691479980c480d19e4810d90dcafb9bf334d24701c084571f986abd3e225bfd6f3f088550c
-255 1 165 \\xa7bb573b4bca0ca3fd1b0d8f6ea53772e39b41b46d11570ddfdb7392e506a826d2950e19254dcfc0815e7fdc8faa3bef97ebf7a118cdf72c4cb03ebe8f571504
-256 1 113 \\x69beac3c530a5f44f9be4a453d8d54a4a92e9e5186b1bfa64774a34f111bc60ccf93650ef16e7dbbd65928d9ec201fdc3e4ff7fc8800382890af95bc4323070c
-257 1 347 \\x0efdb32db9e9c2d621922b68cc01d2d2b5e54d8788ba874246fbfd190b145878ba69c094850b2b963ddf18333ca549493855bccffa25633614fce84eac2fcc09
-258 1 109 \\xa06054b0cfa79f4cdd88e3923391ef81ea0176f65ee8c740b56c793b157a05cee55ae37593dd6480f9065ceb55699c680a6466c15b29557cf05e98601082bb0e
-259 1 68 \\xd262e2608615b18181461f80882ad3e7ad6d1967c6e98371d9426104862210596faaea606f50da54a771821cb6131a10fd53cb89a1365d97faee82b9a3e6f400
-260 1 362 \\xdd3f4181de8687f167d2cd2b3b7a7f1e8dac00546c8c38a7e2b5bac65826c7b05bcdbf4e8d12dc138a26fbf83b1168a4fe49857aeaaf6dc0c22f10ad1c95d206
-261 1 200 \\xcdee15f3cacf00c7a62dc71faa61c1d6a5af194c45c9be72226d5f2ed0f6aee4bd8a82780dfd880dd160a85f798b10aab98bdd7b5bb6e68eb58d1e5b87957003
-262 1 410 \\x63d1f41e949e70e6c10bd5b708d49707596b118bf7c307b94d402358bff904c6170e296571855d4374f932a6a603abe74dcb0ebc80c4acf3822abceb8f619f07
-263 1 183 \\x4f8e095141aa4841981077189124bc3387b89178884db595f6ea040a6f5d3b9fa05d6dc0d9c50c0a463fdb129ef4480138d5317d4d14193e569d44647dac7904
-264 1 116 \\x16941d75ff4c790ea2ba38d78db183e03347e2b1655e69836304f0f998d45d2ac19ffe6ced4f0436cb88acf34006311e485f846bf3b19f85e9ae24d22358920a
-265 1 124 \\x555001a8eeb55d2e3c44570fd40ce3ff45bedf595620d469ac2edf164388d5476c13337687958b86ccce3d9f9ec3e5be1bd84640fdab007625430f221d57e70d
-266 1 252 \\x5cdb6de2bb74edf5bd83c5cd0a443ae9a4a81829961860c948265210cebd3123627e1590d9bf8f9a53a809f62f941b4507db69c6619b6c800ca6609ca280db02
-267 1 219 \\xd1a41925f182418a350bd7eedda7c42da0710cad62817ecd6220ee13f97b3950c214bbc57914d54028873289f86d9570572636cf0d8e633426d83dee18d65306
-268 1 424 \\x6e9fd473983d6a2e2c5eebaa92adef868ca8bcea05156ed89efd85103d58b315c18191c7cf93489907ce58b176a2af9fe8ca17043e5dd203fc8610d78148c404
-269 1 79 \\x428eb9f4f33cffe3ce112469090a2cb36516e297985e9c49527c968e33942a071be7272a6c5c0c9728a9e59df0f3a86bf9f1ba2ba67b0b4dc755e9576601a10a
-270 1 324 \\x06152008cd81d891c0ce400315475eb20ab9c732bbaf6a8b58225e7af0518a6d719e12fd1b1284a9edd3a4059aef0fb355f2d31d1830ecddd6a2316c708a8d0c
-271 1 288 \\xad4320027eb0a6ec4d3e904155016b98ffc6f3d7cef7242c43206d32c3b5295a7dd8d1b447cae20105bcef200ae13a37ecc2a654bfeed0539f5def5aee42f80f
-272 1 218 \\x069710f95dda1544ebc04cd92e013d32d16e2b7b73b4f586add4281334eb286f54cc1480a6a5d28001c9726c50fbe2bbe2e8359f3e91a33155f26c1b55a54203
-273 1 259 \\xd3416808de035fc7a69f5fd8706917429021598a5905b31ed85002c66141434cca4327f65a9354d62f808e7bef232716158f97c7aba064399b118e8bd3ff4906
-274 1 52 \\x9325757fb0452099d4806417f3285f1e9b1db7f590383ee2ad916a6d151544e65143b2de03bec42fbed4c05b11bab9e77b209c993cc9403462667e0fcd54b300
-275 1 86 \\xf5af9079002425237bea8e4169a08ab9ce4075118f90e03cded159f63e30c1936dd5e3b532cf8d5cbe3b33e52c490cd2a124bc30c891c56af2917b20c8d6c50e
-276 1 107 \\xe31ea9b0488f9fc309da3c788030ca48e2fc1a090211fa341978e800d1d2e5ed093ad876b866cdb78ec79630aff0490ebe0ff44cff63f8331cb35387e2bc3e07
-277 1 342 \\x8b88ee51653b6c8f86decf4d85278f6e5e6e7f3ceafb454faf5eae5866a77bbcf2587986c7fc33eea8d995fb020bbf2f64c4c14d337fa67012e94a665058e804
-278 1 227 \\x2304c7aa26f8dd1a46b7d770a1b6c9d4eaebf7875bc9fbf612f066c715864ddc08da4ba57e457fd1861afd710700c5a058ca85e64b337a241ef1a7563694960f
-279 1 226 \\x87ae529612a9be7c8bad87381f603b47b7c03d3e3521867306e1a6bb8555c95e1ded80ae30e3f5fc0cc7faa94197dd97ce5470776a5ce392c4b154331a5ac403
-280 1 355 \\x4a803dff1462df03e753378236341f3de307a7b059f06e1587d8947107735f93df2a716397e785dac5688d5eb43e9bc85d495faf951aa41bd92e8922efdb3905
-281 1 283 \\xed7ea85b48dea9a0c590e7d048626d13e61d661c8ea1f753f7d533b90d3cc729aeb1733cc9b8438dddd886078b42cf91af8c196e32538627330b29bc76c73c0b
-282 1 77 \\xfab28ffcbed40c1e15f15923c5ce2ce8c2df97d6ae1a578009782e50f1ace7e6bb29634f463f0a76fa334379b5a04999a5fb50c163d7b9cabf655838fdb27606
-283 1 207 \\x151743205fc01a14fa4e81cdf22f5f3e57d4112df9fd0528e8785e0aa3ae5d2b366d929a7a090c72dfb358ec310b3c6ae9051631f57701c9c8357bfff9209d00
-284 1 419 \\x4e67f22ce4eec18d588872c4e7106317176755e606e063c46d50d4c09f2ee68ab96fc1231e8b4581604427208f8704cd65d8367c4b1fcd42984770ae1e2a7701
-285 1 9 \\x89237844e060b5fdbbf03fed373e5c11ad0c8d0d446cd175e01b4837cb48248e978776e2cf9e16e1c54477cce515134d55896f315c35e3bc0375274f356aa109
-286 1 297 \\xc092b4b7b13df0640459f8b0752eb2330430077b2ad043e3838fea59a7f4627266afb6b84193daa2577ff4b2c0785e2e5c0d909f4dd8af6df747579d392ebc0c
-287 1 399 \\x59c4bfaa36bc321c871c72eb9eccf95157324f5222d65c0b4fc333107b94f607b328e34acd947cc0a0c98701ae35577457dcaf72219930e6a851c8932e6e7503
-288 1 381 \\x2fc5973db8e9932d10234b07f266bbc54673d0d45c2420f02985ca24404a1d1966a494edb5677b4c3b34cd2a59aef4e833c4121efe27432d0fa30ba0fed2b30e
-289 1 391 \\xa344558cf1fe0ae5c5b5981cdf3ff8bd3c21f23e22ee689d6c738240f25c2a2810f7e9a89387c8467bc7657e6c83f4158494a6a033df0fee766621c5b579c506
-290 1 63 \\xdbaa05c27f4b12df40753b56ffda5d24c2e4f7bb765da11e23114f14ec42f3951e5b77c1c2e34a783a79c4865ff29289002576aadcf64f485c0e3701ab6d7e0f
-291 1 128 \\x8f5c0b5dc479c379ea0b78cd77c7a21ab71c341df241b33a0d3a2883380895ba72f21d85e5352111671dac62ba35b96f8ef9b9415294ac3fdf6d37ccf80fb302
-292 1 174 \\xa70ee7d0efe5a8a300f8c58a7efaf453f33c52031f9276c1b0ad52d1bfe2de8530b2136f342ca2328ac53b5f04626d244421efaa5fbd7b89d5aa3c1e1a3c6a05
-293 1 356 \\x22ee48b4c9f27e39aeaa850d431861b6b0a9a430503c8d4505fb8ff5795137658cf2326dd41f8181732004101207083dce25b7dcc963364fa078f07bb4d17c0b
-294 1 234 \\x860e027a14edbcf715ba4024bf7ac738f414f45304af652f09ae9857b48fd688265e7d12944943c823bcdc41c15c7e73711b84028ba93cb5e9c3b8fda1fc4b0e
-295 1 390 \\x6d74f597d4a54a2fd8e93c07951e0942930eb97356a46b92505ea468a90ee9e422cc6d1852da28ac1fd14590c3ac5a0e787b799744aca0d0d2ac7c6d993c0803
-296 1 274 \\x2b5dbe8631acb73fe73a73084a98799c19c480249064d5a0e5ad41026b075764b72f794363f42015d004b6230db9266aed682d3cb64942bbf87d8a82ea5d4b0c
-297 1 374 \\x7f6760abb321508db8c68df526347d93b9cee02f36d8b3cbf38ddc3fe124a2ce8db50ff3cf8b7ee919845624aa54313c158cf904adb5be6a15831d7994fc0107
-298 1 179 \\x90076fa3cf12a4110402b7e18e457b4a692feca5495b25c900168ba4498b0777d01e75889c57a66d498ee3eda2cfb29a79a9e3df6817798c0d365911190d0f0a
-299 1 394 \\x4a8990f1af4bcd79900f1abf35911b9026f909d4e47076cbae0b6c6b06385184f4633f4ca47260855a89a8307cdf58e852312b81bb11d2628f8d44b0bd1f710b
-300 1 235 \\x354cf15965f23dd2a2c57e6215263054680734f748726af1665054e5148363e062f04948e656054268eace0d77b61d6ef0c175e8963029572976d01e0345090a
-301 1 357 \\xd609d72526aa9bb754f67db5b30eea6fb982236067df77f72cb87d4d1cb706843480fc139d163a90e44cf70c322b22ff0c716a8f3ff86793be129aec63f0d602
-302 1 230 \\x7460c6311f68c9f3df248cfe41e2f912e2ac69db4e41e30a10b41d2371dc974531fff4cbdcad773abecd156396b63e3c86b55c1b8f46f7f5aaac476914c3010a
-303 1 59 \\x84ce4ee3e61db4d110b75ce30f8222de8b922d6cdc799349917351ae5489124a4acab301cd1e483fa078dc0a5534e665eb08bf4e745738519b5ee49c78fb3501
-304 1 281 \\xefb939e7fb7cad5e7199fda77557f07713afeb54b72367eabf18e26bcbc9a4dc730965013fb656ce7cfd57399c2c657a232d96bf668fe5c5577f2df65019f507
-305 1 315 \\x8eb234cd05d2ba48e38206795e29119b59e538722216be33390402c64452cfe97db1632c0da4519073eb01ae00b3091beffdc3f6caf46b4534b7e64397f22902
-306 1 66 \\x66c8500ec494a3b19422b5f2e32b6617518a9e587ace9900d64b5249d1428a7c07488822b6d285a948db833a3f07ed08bbbcd3f6da3e737588be6d67af193406
-307 1 141 \\x1d796d06e6713ad2c3216f7f4991efde551c0dd3bb46c018312a43300d7ef6b3f6b24bb381c4c313dd0265e77911cc487ce5069a3e0697295f4f446e51a89f0c
-308 1 173 \\xcb4b46364d5ea975eaa240861233bbf6dd1727755159d048b936202c4cd988ac06d67af7fe99bc82d8d9c9bf0cf619141f4725220c87796b2061f8c03cc39b01
-309 1 378 \\x88a1f0e52050c2c2013d698226a15579516a860129093e3a6d68d7bbf62cd552d8643bcd9ce62f7465b09d4664d70f0bb54deac749ba87283bced031862a410f
-310 1 133 \\xcb22470f9c658a2eef5374d3948542bf1b18a21b8317425f23b77689e8c871aa53bc642c96d663464f0dcd8d013c6a977027500b8a9aa92c0581f52e3d4a3f08
-311 1 421 \\xbd2ae9a1b3b3764bcc818d265c74e140332f9f799f92fe5500c9c544e7e87cf4c1ceb6f6cfa187b36dde1fb359c9b642f0da742b22e02e76dfea2e989e001b0d
-312 1 122 \\x37c1aff86d4db7ddfe3a58236458f11e11bb3655e571cf1967533a7eb5e29876e8a96d6791f47dd5bc10988ca57ab834d4a8f1119795ac4a1ba68884772acf00
-313 1 90 \\xd93a59268a7c1511da9c849967603e412bcdfaf2ec4d14bcdbd61be34992795a1c2563ce48b5476f11b7313ed952929376e6a82cb72ffa630a661b08e9621f07
-314 1 343 \\x4eb8e1b012bffa455fed3dd9b370bedcd5aed08636a4de759473db14a942d384c3a03b4f2afadef2b390a52973d4d2d3deaf91264f1a59e03b9d4faaa1c49206
-315 1 140 \\xe0b2bbe48a4d406a436349b977708bee5c0d548f560b1e5dc230bd28ef87c4563335de74200f01a3eacf23bdfc9965088c6fbb1ac6586d6b8ba517bfba313b03
-316 1 94 \\x47db17bbe6cacf605e84b2c6c92ea65bb516ee3abdd53500aa39a7803e7ca648b1c8f22a0e560ea1aa50dfcdd7befb130ba02bbb795b612622d7758679186807
-317 1 328 \\x7df7d4c513eedba5ab3dc3e23c8ed423bbbd679ae95c375f5616e2430f554d8a62c0291dd542b03896c5cc223109e8a8321973ba6f0c7a0df501f51bcb52b70b
-318 1 144 \\x73954af7675d0afd15ef779aa2e48f3bb384e8fdefa3964e0e7446b9fb981976ba00d53e6a62fa2eda7dbdf9d988df6d5157ca73aec484d3b1e139cf4a75ec03
-319 1 403 \\x750115ba3b011bad063e3235e3c1d50fbc107067d80c410f324844b65ee40e8212632db7c865e4fbe8e85de78c7853250576bbfe46666966eede86bd21350201
-320 1 212 \\x5242ee40ea63b1b0299875d2f50de7269681cf40c7d9dddbbd4e4b8321aee6acae091e53fdcf1d3d36ee1e9b5bc29e7b0ea1dc994d7331541dbee3ddbc1f650a
-321 1 308 \\x978731e0b95330ed6fa018031249099d3a48e9f6e041ebbf548f4a29c2f63437b2cd2bd2210eadfbed51d20d50f720bdc72583653911a37b1dc0ebe1f2986509
-322 1 4 \\x87080365539346cd85b2fd662440d5635ddc191458baa293d2b4da09e282c2c9ab5a4d29f97f1733540956464aab401b6c11a54362a6d1b409f34ffb2f33ca0a
-323 1 271 \\x33cc6c1e487080755d49a8bba2e20e5ebfbe685f37b79516a21fc11c424b3a007ec63559e7374aeb9ff197bb061bd0ca3b5a18912ce9f2a05608c8127987ee09
-324 1 329 \\x9c5cb8c71ec2da3680d8594a7bd664ce16789ac7dc8beac960698f26f6e51160bc870c2233f0aed40b689e62ed307b8816c0d47dfbdfb830dc3566bff1a7930e
-325 1 130 \\xc642e42bb33e980a9851b21c45ae4fb9f739d6893455167165b1c34b864ca537e2ee624a015a3c27652fcf7f8aa2806c7ebb0fc47956380c62dc26563e51ad0d
-326 1 146 \\x814e7db6b706bc15d7d348e30fdf8c7e99f753d7c2579b80a2352588c2afefdc501c2188efcd867469b319ff9aaae0e3ec6b5861ac636518c6f2e0aa5399f20f
-327 1 60 \\x93a5502764e7a6910665d87c9f9c6eecbd90eca5df3d13433a3e4e0579cbd7f3349c54d29342acfbcc2f80a701e398fa9100612bc89df7a79a3181181dc26c07
-328 1 134 \\x1b64eeb5b93b4ffa308bf24378d4193f978c47c4da2910344ae106233c6adf16dd12a783a4a8658f5c68eae9ee20e0187072292f218571f785ccfd3e5d9cd608
-329 1 206 \\x5114f46768f8e7f106dd5f368f66f690f58e0b1e3120cadc2f02fb528393d7a2abf04e0c7d112d64c07afd84002211f0e9f43f19a67693f4446c900788acff03
-330 1 161 \\xde1533e422c26a83ef0c15a75bb6f0bc3387b2ce375addbccc8c3065c4e26836d7f211930adeafa4663df253099614a9c01aef933acb634c6aacbe64a4150a06
-331 1 295 \\x7c6e2f23629e48569d1efd905074fa4ba6449895ee23b29299e71b58bba18c6859ca7f122d3558adcce6189fcee7ce823a7c478242bbe369a0fb0fd56203f70d
-332 1 96 \\xe5bf0656dcaa2c51b991c441d0f85f5f3c5714ceb4bb6ba1c6190ca07191224aea4879764cca87b7258a5a458f18676d7ec43d72c110d31e386a67279443f700
-333 1 170 \\x5c6ca0c259345351c59342b6f3a5c76913ceb8226a6d0de33b8abee345bbffdd1f4e23593f59f4bf8bf0c8db0ef22dcb70cb9ec7af522e0cf8cc825683b00408
-334 1 166 \\x5f51471cf419108646af035767c35346ca53775e6029c3988747142efbbfd28f38da3de233dbea9c1616a55da27e26cb884aaab5e3511781526659039f180b0f
-335 1 57 \\x583bed414c9e38a939388da1c115077045ca1c662250bd14767e32fd61efb792f11216850adf4aae4d2a5ad62ff48c4ed6ed6f382fedf7197b343523231dca08
-336 1 273 \\xfe157a9d2dc6be8661f6ba3c91ac0ee8c9e6b5018d47d1f39add0dbf0c50266d36d619dd2a60b837a07e5ceb94a1f03f72fee7c908d79d52c13da7fe6e55860c
-337 1 51 \\xb58c5a0a97891474fea34b56982dc31a17d4fb79bedd2d8b420e1073fcfd67bbc6e5c90a9132fc1f6d43a089141b2ba836c314793903d52380225f06a434d60b
-338 1 108 \\xd2340e57969f24b909e2c03d0e0f07ee19f8c5e72fb2e95008d071c21129360f81fa60c38f5c485d6575fdc8a4948b7d6bd7459311c51359393c9b53ad49d40d
-339 1 287 \\x5f125655986be5e8e73f0026dd4237c4f93186614468b1a5284c32b51b99a630c2ce500c485689ff9f070ec6f78997dc3a1df6cd097af820237828f3914ef701
-340 1 260 \\xe1df89480c337fa22863697bffe7192518a6480c3839aa3578e2dc0178e0f4b992350f43f04723f1a3af15ba67eb97f93c3913f98fe9b409c55c3fa2edb1e40d
-341 1 382 \\x0938efe18fdda0a31b6ce1cb1bb10ac07eca007c8afe072ea012fc6a463e36a69120af4749a2a60ba1326eb2fb18f95d57cb320c890ddc1894d8d5aaff3f2b07
-342 1 158 \\xac79bc5f09b062517b0c3e1a157f9d8a672c74bff7d0d90d2da33d4ae6aeca2af7e8c1c920dfc1e31dfe2b64b35b7607a1ecf8c7e7d247e6911f2c964e774804
-343 1 243 \\x573228ca9bd1d2f8871f6a57156f6dbf0aa55b1425a9a04a36c7e4e762f34504359dcfaaf038dc5d75b3d8909788bb2f84b57edf56ed4451deb841406dd8c505
-344 1 17 \\xca151af0ef34ddaf5e1917fd3a967c7f1cc5801b2a63bcc01fd3b8ee889af7c5ac142384a22c9456887c17b629e68c9ce858f484e97c11d1b6c202d5bd12210c
-345 1 194 \\x7fdab148b8b1476c92ab30d261979a9d16d6daab60dabf679c6cdee73710edd742474432a88961ac47037b93095eaad584af0e69d8783f51ee361eb2c1cf2800
-346 1 139 \\xb824ae3599f7b894477c1662d8344be94c3778525fb3ec0f1a3ad2c0cee4b0e3670d766bfd80d6d11dd15e2d43e449e35a12dae6c3b243a3c3c2244163650c02
-347 1 48 \\x5a82e35019b5fbeba8d050c1cf141c7e666c2cb9fd4a0968198b081daea4fb35a9159d92411e37153a6ea2b6d0b81ecac276f019bd8aad52adf26063a24dd606
-348 1 129 \\x51c6b7c194b9bd0fd630a55648f24d356f9ded2559d43a32b90c3f2f4973f85475b5ced63e2505086dae72c8f01f15b2153506bce8bb4d4163a68c14ce4b8401
-349 1 76 \\x4b1d9ef0721478277d16c5df954fb68a2bf5200e659f8532cbb07b293a307d848d4e2feea3b5651147a2a49e39a2ce85d46c44b3c9c4f64ac9083cf9848e930b
-350 1 22 \\x4dd44a4cffeff08eeba0f903d6f84c9b160f9ddd66ae34e5adc40d537bcc20cf53c88d64be314964569a440f587222f77489c2bc467d82839be4d17f7bd81806
-351 1 280 \\xf60e0dc93c8d94506f8d8e7dc4fbba1a1d9233a3231852d2d9f388f229d27709d38a33c8d2476ed5bafef18586f140a9b950a74c223a8f18a6520bb707279809
-352 1 251 \\x7e26fb9f2655e02366dd68c41e762b8e19821e74bc1d4cc92d651361f06a560f36d3400de9841e2b53f07147d978b6405c77bf4a486e06611ae90843a488ac0b
-353 1 241 \\xcd642d3c9b86e0c294c3c1d26a4df8f3d5e401122fcda67dae3fb0f2db2d5190ecff01ba8284d2592dd7ce239ad260f807b63a47096e5596a3b2b1467c7c2004
-354 1 35 \\xd17cd3b16f29a0570e01484d13bf0e9dd7a00a8c0fce9ae75cacde8c8cd8b3628d5ee3c5b037f465d9072823953b61e998c5061dfc22744ac5cbf74c18d80907
-355 1 364 \\xb00d8dc2bc741fada45593fcd48364f6b9c9e45bf11bd9ce631b9b07061825deafc8b4aedc94159f8ffef98b0cbb3bb77ff5b34018017b97186f277643f8b906
-356 1 318 \\xa701222a15a5df00c129d8e7203d97bb89f2379775633217600a6492ce653930507c158a1e11074ea6cf5c88c1fff4cc6501792b6002f8f123bb2d72012ba703
-357 1 321 \\x86174203a1c659328c4e92baefb6b29af3dc1cfdc1dd85e08d359be7756a47e12fe5ed4db1dd2bdb322e5faf1b6694ffc3a9ba4bf58ac06cf48f9cb3ab8d7307
-358 1 196 \\x4ede51decb245bd0d4e2a575193a530764dd7530d33cabc299108e6c298258512814d12022b55d58c276ee98da4819dd378061f6004c0c1c5d261a1f4c6a3f03
-359 1 92 \\xf2babc3a02cfbdcdb097e89e6da9f2c7126af0f7865e26c8ef8ef755b92b5a864dac8cc17f07678a6683b8e604e3764506d201f31467be6b921834287357c10f
-360 1 43 \\xdf596ca66b5df21a75afe017993a8e74fc149514bacccfee97ab61091cc8ad2c501103ca63476db6658706a8a6b5d0a79e07dc7944a761b05a66dbadf2181c0b
-361 1 319 \\xc89f90ce4360fb00517fbeaf0148f2438d7e7266f474a448e73d513b9b6a4599a735c352de26ff00e537a30dff1562875915d4581702f855d0b00e40e63d1309
-362 1 152 \\x69cf8c51df8d2c5451e84cc784ad25137c301ca44c3cbc02c39b42ac451cb82281f80227c45237bd454c72ca3d3292377af41a7fee7595589723f22b2e7a6506
-363 1 257 \\x4f17e55b24c18eb9380eb6393a6fbcf2d478d7e992ec7f9f9e72753fa19e5c9caa448d13e9c90321aed09960a020dbf1c69b7e1ad65be6b32c3f9c71cc24ae09
-364 1 393 \\x12a9848d024a9f5fb17025e1acde421d6566809175d6ced76fb76a2f6257209bc78d4fa74e104776b3660f509263889ac69ca059f5ca0694d17b172461e0160f
-365 1 341 \\x5cf9c142afb68a0ae6382781f75d6ee1c4739dba63e3bee37f0fc5ddf8a4c19662640818fb48c75839781113cdf979f7e95e386692c7cf0a84ef092da2f00403
-366 1 123 \\x83ebfb1a9d5895161732c062ec1c65eb2199ffa02cfff9ff8585844c443de8f4003694811922d14a762a2b455c9dee417013058c40c4eba1fdb45ab7e952ee04
-367 1 302 \\x3113c29efd21a8fe3777d204955b72193a231afab1df9fbda8c9ffe22d1b8796671ffa5dd958860e99bac617e170938a61c9486ab2d0880df5b2f02623ac2f0d
-368 1 203 \\x5640276ef3a72955507465c9296229382dddd3e35b9b539842f13e3a032fca1cfd348c227df059ae7c2e26d9ee0a94856b63cba88254a64fb727bb40d96d0c08
-369 1 372 \\xa9fe50a573db4ed7700bc8641d7e80e96dead02c0819a9ad4233a853bb6a7ddaabb446ae42889005062608170d900c9bb5159e1bc28f39887fdd002956958a0d
-370 1 187 \\x03bdaf37d27769836bf490a0517a570a01ddec9443815d8f3895ae6431aacb9244384f9b2033ee3e10b84aed478bdefafd6065fda280c7adca37c7ec7b5fb60b
-371 1 276 \\x6168a07b40aae6e1eeb4d108158a8c9ee85b394715a05a64c2292a6b800bd9f8f1d39a14f45c8f1433768e0c38fdb715c0e3d297920786c4b7dd87dc39670b0e
-372 1 248 \\xc54c9ffc4937601be9dd8014c3342827edbde97b2461a298eea2f9138bc9e27be9eb3fcb9d80af45d544d2eb73281c75a72d9a258ba6ebcf1664e011643f4d02
-373 1 340 \\xc41d832da13a5860d2b19093022a67e6f4b97597ff877bc9c1458ca0c1226218ff090f3d0e3eb0a8335144faf6a9b55df9781b65d238e13724d75e5594b85308
-374 1 112 \\x0536c1970c388ec24d4bda09f63ad83b156563b54a25f9d0d7a11641ec303edb680b4368fff59608f4916369de9d18e70a3f5dc00f1420fc2d769afca3cfed0d
-375 1 245 \\x445b73bf4ed65a76ac3bf89e7d935d850845850773c0932005782834f2506fe4122310b3799baf0db9379eb5153d330d8548caf6bbda6a260e20b49382cc4c0d
-376 1 135 \\xa916272f4c88f5d0f54467dfca8f5715174abcd0117e1264377e6b9aef72650cb8eef63ae0a8599bc0bf7b1a9f0752d8ca9bbaed4b0e9215601ba7733169f302
-377 1 398 \\xbd88a6e842ede43a0008e96571372372d716090380108a7fd1a9596c1159bb9c4b93879f4f48b5a3da68d7a4e947035d40e4a7ad63a7c4b264cd8e9d9a978d0f
-378 1 30 \\x3c0ba580d0b875c3c65827f87056ee616cd7172ab4abecb315d7a5c72cc6ab2b4244165cdd5374d8b35c049d893aea9598c707b2a0729662798b812f17a34a01
-379 1 325 \\xaba39c4aa676722ff05fa63946b40f5eca64612a5dbb6e13d3847187a95a663d8a978094f112c03ca5441f01fc47354e3c526938e5377e3830fa4741a4bd3f0c
-380 1 151 \\x3510ca496254151768dbf35b215653e586b35707123348a43183325b1e9e45a5b5bbfb0d7d3547533ad006cbd5b14c9fe3f2dbb156e5a8eebbfcb44ef73ceb05
-381 1 82 \\xf34281fa64e5c317cc80fc1de85e5a1af2840cf6b05b036c078b0f1125a4d162b2cdb1fd2bcff1831b0481a667977f23637c4a27c869d85acfa67e33f0215e06
-382 1 359 \\x069af8ee060540518ba5b3d53abe37194bece1733cb3d22000906c906382ca41d280675d0d289c778b32aec8d2a66054ac07488ec55d4390c6b4ff6c85774801
-383 1 148 \\xbfbd3ba0875b8eeb5fc7e4620515d1dac1eb4bdae7ca7899653154774b34df9866949d883e648167647bf3cb51aac57dd51969497f1c6294ad6629dd1660e901
-384 1 344 \\xdc4f27d3d2efe0684f7d1bca206d951b22081d687291433d17ef1ede65b33fd5bfdcc5ddb57a6da9c47a662bc42d7bba52e4b3bc0abb7283c8315461ffe34c0e
-385 1 160 \\x1fc711ee86aed686e380e7ae73d5f37a5385ef9b01ed0237e7a690f9baa7106e96c26fbae3a053ed6dc53350ea1f490f3bdfda0267f0175fe230fdba404eaf0b
-386 1 275 \\x8e72bed9dc3d21d08adc8de4a0ad7ae83999623c07a3246857c18e79a50dff0db7d80974feb49fb6c3d0be4ab11efff081eb2cc684303ff72f6fc0823e850607
-387 1 392 \\x9dd4b6f34b336e94f5ff20888c93ef772deb70b15867ccac3607cfba256e8525b25b62a553caf2a50f03e6fb756a866ca2aadf92d996190b47dbb1eb0b5c6104
-388 1 408 \\x28e1490346845e30ddba21327bad061f7b95671350d5fcf9367b5dfd9ad4a0123dd284102f2f667bc3536cd05f5d26b016a951c2867df88a85f858fd51423d07
-389 1 402 \\xb55119be26a68558683162744a131fbb3052c24d3e8cb52d072459473221c85234dc7e28851abe155383584bebc08a2cd709266108a61be5e2b5a61485d96805
-390 1 117 \\xe0667af9e955dc8b71f2ce88a9a468cfe49e6ff54a600c693301e93916396ab7a01244cce1fc49e532f3cfde96b22b506471d4895dd809986cc5441a99968b0c
-391 1 385 \\x8478fb6463ba5fe08d9c7f99f7806bfae98050dd3c816ba2b01ada79334d575bb875eb1c637ba6050b71ae073e88d7be231623a60dc6cdaf252a2fa731ac8302
-392 1 327 \\x1f293ec453f4da85d7ab0153e8ae17926021b42c83844aa440dac9267c9a027886f790457a84bd70a022d97fdc55e3481ab520c5491f23b3fececc38ab746d05
-393 1 104 \\x3121c8558a1457748721b3ff401f9249c48b504f979d352e73ce4a5b9c6aae069708a993e7c08a25f3e50a4cea8bd5e1c1d3def3d979dddb4e6d475445114401
-394 1 125 \\xc6231ffd2693eba1455cdebdd7d7ad8640aa34e6199c3993b11ff0441ffef6f535dca75ea3bd4b531fd64eacb8fe0544387ccddaf9d1d886943f3f55f170c004
-395 1 354 \\x5a600f84f638eb1c91f9ca183fbadbfe9c3247e5b4928ce92f3dd64e0cdbac4d8c6dc39936e9e52450e98589c50839cd89b7bb6b13df2083417edfbb27be5202
-396 1 386 \\xd42189095a5458b6ccd99581b3d653eb76fba87c88e560e98bbe2e1c047f64e3472b7aca353e137f4ccbb397f5fa39e82e605ba126407158e3b25112d270460d
-397 1 322 \\x27ed4ef5f0b2a3547b1e26b049f9a75a00e2a450dd67b644a8aee56dda51143aab45430814050a0ada4aca295a78b892fceef9bcd9d541f66478ef50b2258505
-398 1 423 \\x2342c858dd0a2a95ff45e8b01739ac182196fa8b1f4d0575a5dbec619c889d41d89a23a14bfff570d5892b792952a07eeda7735f55ed9de2bf3388ab39ba5b05
-399 1 131 \\x3d50c0d4ecba3bb57c8433214aea9e250787e2c39ed40246de92a2c07e98b52566e724dd08c3328f16592cf800d09f8a0b85b66304f30bfa303d0dffc6bbc309
-400 1 346 \\x7228ac227a98bcef4fd8855183f8e45a0f6c1b6f83ce5c5c7bbe830ba0ba7776fa02141e094f54d63672ffc1bcf8e21450ca65e1f4f44362ba59b98c11c3d301
-401 1 175 \\x5a557f0f1796fdc564122f479aa6ad320ced84f47b4a5eb49b1e217f3190bf459274f9a71725a8b3b5f0c3ee6c750d55a6c17c29c31a793d68d7b93ddb9d190c
-402 1 12 \\x3a973eaf80b01d3758fb22f1857cafe5eb40ebe44da9da298bc66eff5ed2076d3bf08a9c6861b2778d0688bfff49d1e22576b57c6faf2cb0d43f20b144ce150a
-403 1 351 \\x27a5a05904df5547356046a10bf9fbfdaec59e54c6fd339c8488389fcedada79a563b6e6758be4f8f823cd3486b1a6a6b7a47b92ddf727a6e6c54e7f5743930e
-404 1 326 \\xa34a7c776e6b46ddc26a6f31eea7d02cc4671358d862bdb6402520cf7885b14871f59e5b6fecb41987c721c6b52ee76ff2e18c44891c9411497a517d93e2df0e
-405 1 32 \\xa0742b8da28fb344fac59a5ff21fd0ecc2307d778037a489aae519d0dc997a80a2ee7631ba33c7bb4e426f9a218e102f5726177283124c92d54073d3a7a10c03
-406 1 147 \\x7bbac975ee330fb7b7393e40a44705e5ecdd5e56f44487e7f69091972104f806f4f7d68239823f37e75f22f783d4256a57814e1e961fa2ea136185749683060f
-407 1 232 \\xf7fc7039f091c1b8e5b4488892ec1f9fdbfd1f80d69c878ce285b4583fa4cb75c3e57bc84a438957de203deff8d321893d47b4aeea3dbb13780f4c31d0b9ba0d
-408 1 268 \\xbe9fbe7d9659356db4e7f7e0412422c67dbbfe97a5d2bb72b3950142ec383f8b75b63fb8e28e577b266dce090cbff4fab90f6905283417b5ee362a8543bca606
-409 1 375 \\x0de423e0f4d7f07a238101ae7d072ea6e663e5ba2a3d99b710d7d6a315f4cf3605d8598c4c3311d52161a6ec12e69c1bd693ec9c75b39d5006fd9a9bbad5ed06
-410 1 23 \\x66c6f0a226660f7edc587bd1494829b668c89a00ee471ebdf7389bb011232ae1a66d574f1d5b4cf79a984dcfc2330db85c174fe4bd09989ae4f4fb51c7d6da04
-411 1 282 \\x6cf296e24b181aca58c920efc24779f2a6ba956f90208ac33f965d1df54cf71f345ca9b69f103ecf6325fc4760a65081de2df810560c3a6f887823f9c364900b
-412 1 84 \\xbc6a0fecbd67774275922e087049aa858b1ec90923bd06d0bf9ce0068d953408596bd6348a00e345a16d1c6783942ec286a16fe89d73c74c52e665efeeee4b05
-413 1 127 \\xa78eb81f8be2f82def65dfaca6a16284d9d0cee8344a744b8f9aca80b745207547fda9859a32abc33a3d240104e7b156f9743466dd1d789b57f6a8891c614d03
-414 1 25 \\x951a5976dfb47768e9c0753ed2ca0fbf34ce82f6c1b9dd3039f4ef775e9ef5e9bc883862647c45e6712a14d3fdf67875cbfda71ead3a2fed5523cc3061cdaa0b
-415 1 181 \\x11f50743d6c77d4627298e7f8d962de63a71a0ea0c7b962958792e0690e920bd0e1a38c08d4e55919546890b67a3d9e6e578e1b956df3dc828eeb6f61b77c70e
-416 1 138 \\x3e11f23e1795178a08fb825568c6a63b1726f006e636e354f5622ca7c1851e553ac2916ee2f3ffc608ab5c6b565b85e2b89e8c2d82c4f7a9b974820af461c70b
-417 1 56 \\x9052f0a0b70e896ad8699272b672a351a742dbc25f5f8d5f3c1a26af277d4a927c594915386321f1f22f52c2b653d79e17cabd7b2f91a7aa78f469845bdb9705
-418 1 369 \\x22f2b6880cbed770d4c93096667eeed4c9b291f4e036ccd49473919b196a40a0f611dd2176029d4d7953e1c2ffbb6bfeb802b78da009742c8c41675340ff8f02
-419 1 190 \\xed152088596b8df4d3861a8c8d2c04c588245efc6d5e9b2d5ef36824db5a30547571513ca0cd9f40d633f86e015017b3709102438294d195d6da45b12d3b9e05
-420 1 292 \\xd61f01fa3bc82fb3f2f586c8a22456f20a89a75206af3ce6e21670520f5dd1c631a65e94ffaa8b3cf475cb7b6fbb57ed849137b73119a888297f5b6c07240402
-421 1 253 \\xbe8128397fd99b594cf670f35163b5791a48bb50b97801882d1276554a5f28bfc1a1f995d47fdca995f5f41e9969bc6181e676affb0f0d116007219290b44e0c
-422 1 195 \\x7baf85eff1fd11a4b20f0783db90e96854f69cab9b5eca77b9e86b500064b6f2f1ce50fbfd8ccecb05429a7167ef525d2a24a813463ea3c589b9819fdf3b9802
-423 1 240 \\x6885565ece2e23a3986b890b8983f109efd99ed2214df44579d9c13d687acf15dc70bff985f9112a4fe6781f0aa2cddd64cfc484b8394f299ea04da375483e05
-424 1 250 \\x439e7ddd88e99799d61156ace6b3c4df60db67be573aa298390c457b7ffe4911efcdc03f19fae4af9aaa5d2367e5ef6fa773755471466a58d9072b73c08e380f
-\.
-
-
---
--- Data for Name: auditors; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.auditors (auditor_uuid, auditor_pub, auditor_name, auditor_url, is_active, last_change) FROM stdin;
-1 \\x97fd67147ef0874b823ad6c6df470a5f098a1b32c87c08bc51a65d675b1239f9 TESTKUDOS Auditor http://localhost:8083/ t 1660251767000000
-\.
-
-
---
--- Data for Name: close_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.denomination_revocations (denom_revocations_serial_id, denominations_serial, master_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: denominations; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.denominations (denominations_serial, denom_pub_hash, denom_type, age_mask, 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 \\x00f83320a310bda5919bd82a343bb93f08ec5d2a88f3efdd5092439c1dcde4296a782a83da567b64009cf8d60ce82b301744d3d0fc2f2422a108500d277a0e99 1 0 \\x000000010000000000800003cd7eff47e81b024588a6b6bef7d8274c8c6cb0e3c830be26eb0bf93817e6bf13346036a85b7570249b4f6f44182c4b940862c509bde1177b3ee37a457b4038db88dae111f80101ff45a8d12253151a829794f03f16a0cd62109573638e0f8f509184a186f8ce688fe7648260df4020932529f9015eecd369104754e19b24102b010001 \\xc99c83cfe72e8cf1744ac750fdb6f3a853d2a0175bdc06bac86803e1607378d6b20cb6a9ef8240e80d6217290875d6925d5d553c64d2fb9ef67b502e53169909 1685036261000000 1685641061000000 1748713061000000 1843321061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-2 \\x03e4508a152cc349dc2d4c7829befc4d157a5daa5ba3207159ee1291c372cc177a4303e1eb7010669547529a8d15ba6c9276685e529f9eb19ec92545c15757ec 1 0 \\x000000010000000000800003d8e156915bdd885503ca9a80413ce231ee48311be170946daf9e10873a171dca89f7e77d046054d2d48ebbbcec3a9cac5c3ce787ba13633c6134d98e7a3e5dba269d49780336554d424c2b5a84e314ed91c63c9bfde9902a34b0532ebd48f64891c1a32b5d873061380314bcd2c5bed6efb83fb052d7397abdfb37cf66298cab010001 \\x170eba3f62cb0912afd02c32d856946bedc3acd14e80f79f595108247f7732b08e64fdb939ddb6305ed61ff66c9b19c464dfd403e09c28fb47109cc09144820a 1678991261000000 1679596061000000 1742668061000000 1837276061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-3 \\x063092e047658d9d4ac5d0b35a2b2c4e1b7dd2e6244b9bd19ff2a95bb8db1fd21a5f4dae3e14eab632830ada43216c653aef3b8b28858d0e911d1f8a1f29701a 1 0 \\x000000010000000000800003d5e94ca187dab40b7cce602bc83b99c88051aac505ebadc4aaa02253c79858fbb084842b42936bb46b3feb736630cd6eb9174829f44d3adbe6601fd516faf5a78ee744a43f15267c90b5d96f4f78037c2a4a39cdd6c0a99cd1dd41e00446dff0e2b250058e14a81bf5e8628038116ad709bb97ed799ff4cc55d8fd83aa60920b010001 \\x2ead994a3518c4b54ebd4b5c52ac507465904be866d5f85d24ca748544f92db31d57d6b4ad6adcd78052a6db0d9e1642a671a0979473d7a111b5bf2e4c164e0f 1678386761000000 1678991561000000 1742063561000000 1836671561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-4 \\x0720e6531868e7a376a2564738b4e1db7616b466ebff56bacf78c2bd86ab72193c5fe270898e94716859ee58eac116d614350e47add2e43cdf6ca034b1837b3c 1 0 \\x000000010000000000800003bc29d710fe64b48f2e4b26a81634e9c16d1d0c8e78a6166d576ca67500abcc1a55e7d080f18f97b8c788649a6309c399178239e71ba640cbc1ceaed8a681d131d012cf1a169659b5f43e3311d8fc7cc860886f4bc082c7abea5fae04271f8e9846da11bd1c892f695f93ea57c625ca0814b58bc604309f85d377b2a6d0c4a073010001 \\x057a70c943758bfc72b6d8e41e737c1d7a4a572c520a2a138dbc53d0959f8d5a090c2bdb3fe3ef24e46125ea8633422b734edecccaefa682215edfa6edcee504 1667505761000000 1668110561000000 1731182561000000 1825790561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-5 \\x0cb438c17fdd61baa7d5e7497331e7be66171b84ac2147b1522f7a02f95359e0f89805956aa284e43bc27bb8da700d2cd3a7e29dbaec03dfe19745d0e79fdb04 1 0 \\x000000010000000000800003ad070e7b17a1c0eadb03b7ad7459d035e73f41ba618f2ee98a54aa31630a5fea24ccba0349c8b46653889e8ec59de027c5c030581fbe0045576ec3b4df0440d1091fb3e38447924ad14a8e60be4af72b8b93b7d849f32bad73b30f0b705aa1390a50ce10d13eaa665f5db441aa129a25b483849d174e60548b1806f316d72899010001 \\x3b717b17213c91267b752e360bc82be3e3f9b140d023b3fed9b136e31f0845114f28056179faf0e5f5c985f0d035f3b0863289312f7d097ab5879418af6a4d03 1684431761000000 1685036561000000 1748108561000000 1842716561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-6 \\x12483e5b2d959ffd90c652e8711e64bd349c9e85daa6a7dc2235d8ab8e3f9d5ab32fab7300eba63b978a9bca14f79222c6cce2a5ee47c6c5084e2fb8e45f2e47 1 0 \\x000000010000000000800003a905a4845158cf8682404f51583898f417b7502d094bdde7041b754668a3f787a893c8aa28d428b0a7d260909123310b8caa91708f4a8387727e784d0e2f15b82206f274024d332a520774b6dfb6b9894e9dc4c0d3727f9f68531f05772808483e37fc6ae8fce6b23f986e1271eb7224935ec12b16f609da3eaf7f82dccba3e1010001 \\x03420aeb39d208cde772da18ae441bcc983fc40a2229f6cc1f6b39d1834e11043d39ae759a8e8fbcbf10cc674777ca6a82d3983f15063d878257651c9489b100 1679595761000000 1680200561000000 1743272561000000 1837880561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-7 \\x14f4442f64afda64ba5a9cdf9b1d6f43c938831c63700d00fe8c85b577bb92e290029fd3b6066154bcb156d0395ecc7a7ec521a6c4d384d830b44aa2618981f1 1 0 \\x000000010000000000800003ca6e62551167beaa16ba7fcd0a7811b5028faf33f6efac586489ed7c2df8a3c047e60e95681c60cff56dc6c1ff876c29f5fd0db886ed0af720affc66048ec4c1e4910d79f150cd5a4fc94d0150fccaa8f52ad3e65875543a5457a550a33529721d2a338e5a5e09aff91864c1d66b5a24778a7b056abae485b30d3af849a79acf010001 \\x68971cb1b0b8431065bf08e8203e41d8eaee320a8eed7f64837391aca3da58edb6bb223a7ba756137b48138f6e69f41a782a9b2097026882d1565284a5027b08 1682618261000000 1683223061000000 1746295061000000 1840903061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-8 \\x2018490448eb449c3dcd3dfb2e532711e1e0a4e6e9acf59489aba53af281b950fff83b98ec2b76a653c906a63bb98d0e66f223ae72b4746dd73897ac8f2d59fb 1 0 \\x000000010000000000800003e6f7c00925462a37371d47da6ccbdadafc024aeb455ad9db3d73645b70b59c357ee163525377b9beaad0d6c51cc6a4b08cb72c144d1e8778d0c1251598a41f5bfd4b749afebc14466b902b0ecb2952a63306d5714b29c05ae6b994856667fd5c137437a9080f4da615c7eab965379b343c93f4c8243c596e6978e12f263e5ad5010001 \\x38c03483c3fb9b6c7aa5f93d362640ab7814fe8a8a75b01154da2e7ce0c6b9755e5f10d567307f530ca43582c4d62c181951ec94443ce42d754cf581c6c65d04 1685640761000000 1686245561000000 1749317561000000 1843925561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-9 \\x206c3119de02d04137b81c226b7cfe5bf488abf92c9cc927367bf47f4caa2b16121ae19efbb30ebfcb7f826068cd4c79150bc1bd0bdb48c481edbe21192c7d38 1 0 \\x000000010000000000800003c3aab36e540930ff0c05c8fafec4520db48f5135a6f01a7bf4cb2c825f89e41ec9ec1f091c2d7c568f3253753f8356d525c1d460ca886939858f9a2992d24b369573cf8197118258b96aa5ebffc166935a14ec6859fc2fc17f9e9a65a6e53ea825314695a529898dd0cd65434087a3387468134d87cba26bb85a11b71bfc7b01010001 \\xff55ce6e8391b39e2d6f276bb2504d8b8cc33a0cd7530007911fd866504cbff40f08ff4eb31151816d0b4b1887ec6bed475984aea767bc3dae466e172a666f07 1670528261000000 1671133061000000 1734205061000000 1828813061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-10 \\x2494b34d0975544d791193aca423f8fff3c33075f11747c6e4586c361ac9eab7fc0dc609d0ab2b2ffa03045339605ca62b06784dad094ac4b36467be0145e0ff 1 0 \\x000000010000000000800003dcdb2b3a343f547c66eeb107ece75adb7e2b848804a398d2967862f57b6846ca98ab548c858e196373e9a4e6606e34d5a64a097e658d87a05e177ccbd045bccfc1d29f19ad98779f80075536af7b6bc64199cbd7c7fe6c02e9f5baaee1f1019a2557eb84ed2b7e24b1b6c2f410c12dfbc3bd00530b934c1452cffc0dc0514bd3010001 \\xafd97cc5afacc22590280c7fcd80223afc65ae34c08a236d4e4d95759ec91c28a7f245e874903e83e98988bfb006ac863b638e26da61bef3b766dfd2412bdb07 1682013761000000 1682618561000000 1745690561000000 1840298561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-11 \\x2b708d76c58288e13fb19bfb264a3279174066ae45755041fd1d6261dfdb77092ce683e7eb5100178956d1147667454640afbe5434e571b34d78f30d1c4d6ab6 1 0 \\x00000001000000000080000397d112144c6b0b58fd1de441feb98d2460294115e05ab09a7f790353baa8f99f9de859a2be007e9b398308ba02ddbd0c22acd2cca2196ade6c3a0be808c8c91f114dd7d447f492486d83df0f46d5961247f40f1f869f40d38c3d5e014abfba29743ab6d5e2480df16e9bf0cc83feac9cf224c5de3b66724341f7f77e57dbb3b3010001 \\xc8d63e0ee78c09c8fd91d81e5251d61dcb573a59fa6e83cb8c57f7dae42185fcee52f96eb97b84f4fb665fe10c17c8a0c15b0a0e2ab8ba6538fcd238db750e06 1672946261000000 1673551061000000 1736623061000000 1831231061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-12 \\x2c68866d9f232f507ff4ec6dd33cf85e050eca721c409f8550bc8605232c32c5e415c62ae005cde7953770c54a5e3ccbc51fc6b0243782d27807f5a2e040b166 1 0 \\x000000010000000000800003e2f61213463ed1b2144c9d378cdbb11513398cd6c1b7cdc58fdead71bc1d2e1bffccf914b345198f81754447feb051127689c3e590082e25fd3f6bb8aa6883540fec89e11ed7c3458b49ea330f6d065c36042298180d84e83a5fceb67bc59e58bad9fde8c5af2eaa07b43e006c7ee24bff8fe738f010acd3db98bbb4be52016f010001 \\x603abcaba57cf1bfa653c9ccffad28456de094fd74dfba5cda41fb3b8d493690bd92eceb2db897843f490def10bc477097bf1ec6c63171b2eeea511f9a37e20e 1661460761000000 1662065561000000 1725137561000000 1819745561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-13 \\x3014bcf08f3ce969b1448914a0438ba922f9af72064a110a98f066fd237b99c0d552ae0dd66e68d1ff7544a9464c185fb032c78d5744e70af9857f92280d098a 1 0 \\x000000010000000000800003f51f956a17901453aacbf82cbc3330a2e757de16d837c9ef4fc2f0c26636e48958c4c655f71270644283ac7265fbb3eeab33d84192930b7e497257d182b785c595da75dfa085727155274b5f23abd6321d11dcf8167137b26aedcc50f2cff13ee0093536effd74bba961cbea0af8a2519a64d9d8641f7924668132011dd3172d010001 \\x0910d7c781a43b1d43ecedcfd949ea3555a973fe86305e59e2dc56d01fb95cd7e970bd285d552195420eb1baa577ee790873719cc18ddd0f21da6f087609eb02 1679595761000000 1680200561000000 1743272561000000 1837880561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-14 \\x3234e2bdc4464031df819ab3269cfface20677bdf64d789ba04320f0829386715292330ef7cbc39e8895c48f1a63197604006690de4963e485eed9442d6f184d 1 0 \\x000000010000000000800003d955f4850b1a1c0816f9c6f3a511e4cabeb1485b431d5b8d1c7661f05778510da16a606967a1d58288ceae2289adcba8191f0a7a95ef37428f4d26eda3abc179b55a25ccbc2d9c9e534da0caa32fc096a8fafe3a462ff06d4de8ecc7c33552eb84e34a8c9098bc05cf297b3455aeeed04e1bee508b9b62e9c9ab4319737a3451010001 \\xe0fa4290a3fce3a1607519cf73c5eb0164e76c966627f0d398d3e805a47c5585d60e7f65b13dcef87e652e61bcc71f814fee8f50cbf75942bab9aea0c56e1604 1680804761000000 1681409561000000 1744481561000000 1839089561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-15 \\x3454d1f5c48e58263433087ad96848ded0514bbe1820de63396d0f0f643052ef9280254dc84d2d7ab6d345cc88a605f5c3139fed414b1542080cbcf49fed6995 1 0 \\x000000010000000000800003ba2f0843544a6d9e593a5f31561ecb66a605c80988acde14ea61d8d0b7589fe92c8143e3b3b74b89db90c1a8e7132ed09951305d073213347ae67562642901a4ba8741803e173fd3e24ea2ada915492a7b12bee83b92fc6f54952e8ac49ffd015df9aa05e6b070ae01aed8bb0967def53f1af2e7385d8e58386df1eb29a7dfc5010001 \\xa705776dcfffc0a393519d14b0a17f44bbb4ebaa53b78c2aca5861ffce61c15386d8486fc41975c5790353e896adf25fcd0cd6378eebc2048c6f9ccd0a21e40e 1677177761000000 1677782561000000 1740854561000000 1835462561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-16 \\x3960956a9e533e594a6a7e6fbdcb924dbe86b519ce4868e103282268a0cbda598c2b420b42c32b549804f2f37b6784bf70d62e2c1c290b30574b435c90357e74 1 0 \\x000000010000000000800003b0bc51db3177d1f16d97a2dc4a605a552a0032a646034b347f08488b0281436b0ef2c5afb58501289093717adeac4bb23fbd0f4ce6dfd03cc64b93e22a57e729348219399cc777a12b22a5fc0ba363d31771009f3e9c211f6826f997c70b418db043014a96b9016c699abb7211853e370fcb1209a528e70a8a1ffb90d7bf6b99010001 \\x02371792b22ff2e478fde3c4f38892b7cf5302aa5303d5957f25fe281a05cb897a45511c6bff9112a51ce81fc800bd0bd7c7a0e51fa202988e4592c0f3dd640d 1678991261000000 1679596061000000 1742668061000000 1837276061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-17 \\x39f83c1e9a8d1989d8c8b1c8eaf16233d504dd5db4d483ed5aa71a2bf2b8cb2d11a1ee60dde54fff0fdfeb72e5a7aea07dcb55c4c73a42ee65f3d36054d00972 1 0 \\x000000010000000000800003e0fdbbaa95a890e6978eaafc52364ee9fbbe0eff46f488e811b9528a55303c3768b22614aff38df6f56447c24dd7372201b9c260c09a4e21336fb103f65dd4e7efb28b25c150c292d124ed739d77befc73f14b0af84e20e45f746739415ef5725426d1d152480c1c24d04fc0928f2431996494be7a8445cc70f8b44fb5849463010001 \\x674d7a2cf4b547351a58bfccf095e87c79d710ecee3c6216b66a4655d031642d69b4b13e17f1bd00cd4ff63f82610975eefa57c6c5fb78ab8ff2abe61d025a0d 1666296761000000 1666901561000000 1729973561000000 1824581561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-18 \\x3c04e4a747a592d05e3974b7ff19222decdeafae452585288def3960a595c4254a2bffd0fb32ed3c17455c71770a3eb4d74824f491d015142790852b57808c9a 1 0 \\x000000010000000000800003d9ce0984afd6ff93925c2ecb2874d46f230094414b42bf472e1045e363ca637a372d324d867e46f0ab87c0f9ee5b6b5058d1a1856dc1304b4b491a41031ad0fb6f70e12dc789afd5ec8eaa9b35c089c73cdd61dd94632ecfdf5cdaee20b7351dfb2f7df8712f92a254a3fd4b988218df14f85630f798d1b31dfd911b48eaa4f9010001 \\xc326733ffa6929f40be4b1d8c04d0df24b53e4033e68409589e55fd244a5dff09bff0e1fbaff9cb245a172ea5b071a159480d587c606fca745e35446fa5a2f0e 1681409261000000 1682014061000000 1745086061000000 1839694061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-19 \\x3f9872155b3759ee2f810feb3cebefc141ace05addd018e0ec4f2d5257228c25ac7adb958e900f800c96de8cf58982fef001c81b4994587fbefa75d8bd5090ba 1 0 \\x000000010000000000800003c1cdc6a649586b4facec1a8025149cafe7590207dd2b23a814faed6d0c8ecc645e0d852620f77dd929790eb2b71d61942a2d603643e43a6ea1e8a886a4a569fd7658bbd5f372bfcab36c1b9d9db26cd2a7444dc7f459adc2b2d377fa45ee1659a4f78c85d880b52992f1496481eb6f540819b430ddea5f8f2474b50cac3ad25d010001 \\xaeed99e28d2ab0b785439f806bd27371e37d845ea6029e2db4ab0c95eeb72174ac6ff8fc3beddc61db621c8584da4463b27be8554aaf642eca7e2f61bbfd780e 1676573261000000 1677178061000000 1740250061000000 1834858061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-20 \\x40d4930e772aa7db75a22dbd41d0e2ffb6ef428e3db274385b44c7d1423c6415e357297bd1dd784abaadbc47546ad518a48570549257a641fa4ac6bc6ad40631 1 0 \\x000000010000000000800003aecdf47e7f5873af07e7234beb225172cbaef562c7c106fe273c424738b017d5dd8c641fb859e70103e497bc564ad818f5a7a70de2530a7ad61b6ec53b2d404d9f97a7d20b0f96e5b952f70f3e10ef74171f978b4ba04dff3803e58f4fe3fd57629d4791e2f9b3184a66bdffdc92dc13b426f7d2d0ad2b920f857439a8164e89010001 \\xfdf17e945a2ad03336c5402d5d08d512a89150a7ca596d6c8474a10df400758db19760126ea03df362e4844ff986b959fc56f755491679de87c1b3360baf480a 1684431761000000 1685036561000000 1748108561000000 1842716561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-21 \\x47f06352cafd25790b91b9c4aae6d8aaa5a6ac5c7ec3f49c8d0d9f1971c334be6e75a8ef87f564216ae742b937d09e8bae5e94c7f84c4bcd77ad473f4f7480d1 1 0 \\x000000010000000000800003c4f1d2c768292ede84b9ad2180339166615b30c64d9b6b1908c8144a1f85ff386d8bee6246ed970c41e642070f34d69080d65499ffa5ee914a511daf8d03e6d27e73f205a345c35cccafa05753cc74e51a90024562623a60bc07b00d7a39bbdbf09ff73d7c9033202149176342b0226c77a8a40170321d1dc1e2bf363604e41f010001 \\xcbe81fa812c6ec2a6ac1676ece48176f9edd7a1b5e4fb80fcf9d63ea38bb7d53b4c841b5f26c73405c7496a9d8f6b1d98cefca68ced39a9a855f3af38c11d909 1683827261000000 1684432061000000 1747504061000000 1842112061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-22 \\x4b4863b602dbb5776ba10cb6bf1a9c1ca6b9e7ae6ecd669cda9dbdb617f2d72b64a3445382039958a4be5a95d1fd8a775fa7fe4cf36bbdfa66c59960e7179baf 1 0 \\x000000010000000000800003cd5ef6af8113004625f740f9811966808376dee444f9eb77176d0c1880e6999af72ece2b6db8bb1cf7c8b1ab6893dd4c40febd02217fa1976024976db4b01d5685e3459d031d757928d77c19df06a6cadc0e9b1f7e076793857d6428f2d087615aaab1ce14356e3820b168de1d0f732c60f4f3e052559e53901762889a50a331010001 \\x368cc626cbd881acf3548b3ecb13a82a84c381413bcca2f990c3fa2045071d4c2a118d1087e01d603ecc62db4f1d4c2d8a25e5669d778792fcdfdd425517800a 1665692261000000 1666297061000000 1729369061000000 1823977061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-23 \\x4b7097b0db328da30f011a1e73ab9d97ab1a894b80deb5f158efdea454a76bb7acbdc8e60f4296e123c982995cd250e7fc9a8f56731beb464048f1d805ab8b43 1 0 \\x000000010000000000800003bddfcf4cac1112cbb96209c53b0ffb4b183003abf8b6dcfb354380c240a6e3ef27545cc7a7eb5d886760b3f4933b5b5ffbe754749ddbe2c986ced78e799cf5992e9c373d26699cc96c67abdd94043825419c7e95703fe7c667a9074f1faf52b616da37a3b00a340f86aa878e5a10a3a17e4ca3bcfa0259efe6be10ccc4221199010001 \\xc0cacc5dfc225e4d32456778ab7d584f07aff18134fcbd09b59b04ae8c168cf8c937ce3d43a54e0780225151960bdb1de28c968a75a3aef87d2fa3b5829cac01 1660856261000000 1661461061000000 1724533061000000 1819141061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-24 \\x4cf4a5e819ac738420c58e7dc98a373767a0347b44f473f3152a02bc641afea1a994c8d5fca43245551855ef4c3d4475fc53b9c9401ca2a8a76d6ddc013d1d21 1 0 \\x000000010000000000800003d4415b93ae5e6ed3ce13f85602411f6ebc03861783fc227c1a7ade785fac81f6f40d87de874448ee78bf7594e866738166ea9ea2403548cc2630c9211254273535df1dbe139bacf418aba0b144f84905ae6f318c20b0228e8608dc3d6c82bae992c274ce37d4a765ba01a3f2da73757d7aa005b94a7b193423d0a2a1ae2905b9010001 \\xea6e6e79dd511962f55ee06a5c9888db655861af81ae745b0e1e252fc8679eefb7862667a7421837fad388eb4483915bf8aca3cd311a970370d0e9b445628406 1674155261000000 1674760061000000 1737832061000000 1832440061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-25 \\x4d04f97b4689643a2d6d8fbec496558f86a2ff5952edb6a5cfb85bea4f0c34ef075d2fa6133b3c7c41c2e107b4eac8389e5afa354fb982ac380f4928738f7581 1 0 \\x000000010000000000800003b70fdce3573edd77d76ef6fb012642aea1fb7a27905532252b34fb025ceee4ef6908128a9a2828d15e6376f37137a0dd46bcb9ba577c53529b867b3fa0911ab55141be550822e8b3617b099e50b61b618f87ea42b32063d0c6d12e7fee09bb900c96410293a757d5416463e1f7b18356cb0de66b837a73d1f7dac219fe3deb55010001 \\xdffbf7b3889cfb49af4e21f9c4839eded1359f68dee2f2dffd426689e74aae73161d9b13150db7e2bbaedc15ab9894f73645a335ebac029063ca02716603860a 1660856261000000 1661461061000000 1724533061000000 1819141061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-26 \\x50987659d6d21be3123fcba28922a181702b39229a3ebe0b52ebc027c30a0ea76f082faa559c8d3ae8368c03696b917b31ad8eced80591c372d2ffd1fa5cca68 1 0 \\x000000010000000000800003c4f5489da6965e9386a0b7165085d659914d0f4fb79dcb0d0f1055959e6daaef90cdda3827253820ce815e19b12d18047f40815146c70ac1cfbdaaff4804f0d5a05d4aae69c71043a3ca8acb907a4c7cda62ffaf8f4b1f60cf1283091db679da0e5609cc42e8ccea84367efec8d6c34676a4575c12c8f9b39628efb0e9330293010001 \\x211193742a40417d9fd2e509bff2bffbe6153da237f1c5e364a3d54da43dc015a0a2688de948caee6cb9d948ea0d4dcd62efc2fc7b27847dae9de2a8da54130c 1687454261000000 1688059061000000 1751131061000000 1845739061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-27 \\x51300072e26d4d71e973e9c1118833d00a274271a882f008e5f6892d998e3906024011bad16c69ce00afaeb92552ea765f3f8c0b2e3c6cbe94fd4230c4f4105e 1 0 \\x000000010000000000800003befdb2a8bb5d49d8bf62d1aae13946ab1c9ca229dff6cb3860ad2298aedb926412e4323b7efd71889c01ea32dded6c5e7ab604ba4c48be7b44b208e11f7ddd49692b5c2cc2c60b1e3a6b1321fbd5615db92d23ba5c85ee578121696c611e89d1b9998a3be1bef09b101a27bc0ab480b0ceea6f58f38253998ced2c5e0275394f010001 \\x370f6f42b1eab697f429f5229cc85622fdd27a376bb054bc5e2d3b36484958e12bdf10247aaf18d15abb37b89415a6f6564a99cbbad7d3e1fb5194919b1a4b0c 1682618261000000 1683223061000000 1746295061000000 1840903061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-28 \\x52846834b4b0539e826327386f33c5db8cca4ef081e12fb042e9d3d1a59700d187a368f1fae0f35d2a21e6dd8a098cf4ee2609e6a8f86f86a153d0b40bac29a8 1 0 \\x000000010000000000800003d4c2acce4ae6906fead7cb3f85a7e6fc3da494492d1ba0a1e50f3d17dd051b2bb4551c2cd3743629f395d0f2f7635630dfd5d2cf2c8f2480d543fe6da937926f383022124b2b1e95c4d1668ab0fe886758d756abe2943fa514323d14b4261ba763ded4ee0dc98803dde39f48add55f248356aac667451da7aa420df5977177b1010001 \\x0ac73cd574662679741904e4e9788af4644438dc1bc4b73da7c2d5c48054e6e554efdc7be83c851988a9d204fcabffd7e0cd2059fd6870460403f3a0523cf00a 1689872261000000 1690477061000000 1753549061000000 1848157061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-29 \\x54ecfd070436bf8a042eadb01b14655c408f2b9de12e38ef0b194b276096ef057ab6dc268e3f1c8d9cdea047df198210c7d63a1c8e6ce4c75a10e64db514ce30 1 0 \\x000000010000000000800003d107240dce81584ff8e947912a725b233c7e49b07fe873977ca364e4c79d8db317f5118bf78f22f92e98cca753136b927408cc93d9c4240303d8f6455f60187173c85af04d6c830b1e91350a11a23681510edad82eaa526b3e3efc684d898c98fb7b73d2a85715ac5113ea33856d84823cb46cde51ba97e8e186ecdfaabece0f010001 \\x58d9238746ffc35758f4a1685bbc654c94b54392a10a00a009b2700c4c94e17d9d58b66ba96f61172ecd8977d4b0b6759a72d028d7cef4b3dfb50888e787b903 1681409261000000 1682014061000000 1745086061000000 1839694061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-30 \\x5a3061ad0fa9ecac2b44fff3bc7f4ccf02caa4d7455558928d1a5600b766f40a3356cf1be59aebf683101ea79c276766b4e0e004e157d7f85c6210a3be4766d4 1 0 \\x000000010000000000800003b12940b415af18486452f75a6aca5544869913a6612989240a59d2b54ea9c21ba96cdaa114b46f460f5ad49b38995f4ad58f8eb56099825fd6d6b9760c81c5299cc56cf52954bca69b23732f373f748ff11af6afb0785305eeab89a453b550e010d5a9014d8bf600c39180edb74f8b1f3d6319438114310beb56c1e9f15260bd010001 \\x4c4bf7d3a034184d52f1c15beda1dfdcb7498939d801024176e5bece5fffeae62ca96d2a97e482a2d3f2bb5384c1374bd270e4cf48deca9014dcb66320da3300 1663274261000000 1663879061000000 1726951061000000 1821559061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-31 \\x5b54e4a97fffa7aea7dbb522be7265c7a5836f07bca6261f08ce70b2eb7575d09ae567caf583aad4dcf59b58dab8004cdc33e2085ff37bb1ac00fae573b4d2d2 1 0 \\x000000010000000000800003a83d73c2b371b33204175aa3cb3b485e7471704097c3e5baf0b5b4572400fe7f280d4a2e56d9eb432475446b2d5c869974185cf3131daba71a6697db97409fe6e753828e89847847aca5573a10177090ba313c41644eb730b8d23e77810f4048b627bfe214344235e29f5461d38d2f74410595f4652ecfdabd92bc9ca1b4b06b010001 \\xee394ed4520ab37fe8cf998ea525022aa68466a6c41701cbddc330a3e78891e1cf53fe84c756974541e09720c4d9842c133a497b6ff9be08eb9c38481a1a5504 1682013761000000 1682618561000000 1745690561000000 1840298561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-32 \\x5ce4343e27892ee8cf8fc514ac5dbb0c2197edc40cc98e70c3a2864f56b0e944f39a1e133a37c21b921ac95ee8fa2b30dd24d7e6cc8afc4a55c7345765222014 1 0 \\x000000010000000000800003bc2b0ae564e53ee606b54e02809f36460900e6ad59134e0e855831f5bf10fbe65905ec37da927b6a2a8044dba20e0a3494f003d44c03ceaace7f7184d513f1fe3d38495f057c153a868edf341baa79d3c7ea03af5e4643f9abec10b1e72ea9591bda484e083aea314a43a84473282577b4a6029d6e18853b7920d51d0d8f790f010001 \\x1672f4e96fb9c8df213869c8291772fade5cc802ceb04c98b23be0e3f8cef6bc2cecf72e04b485a39dad8ddad98ea4f0dc7fe157ab4f13c6f5b9aa31bb447f0f 1661460761000000 1662065561000000 1725137561000000 1819745561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-33 \\x5e54a23c6e7ebbabac4a8c20de2700e708cf17a92a3aec6925ea65e1c33efccdf3a9f205e2322cc2f3e2ef7432c75edbf5f4ed3f8fc1cc125040d629bb404a1a 1 0 \\x000000010000000000800003db6ee807afa39473980b7913d0ee9f6cc748a6c1bf3f5018b53bc0bd91217f7807bfaf01e7dc19a4dfc430bc82c81002cdda9a2d604fd47daafcbf854201199f87f74c817f6a7e424cc1f53ea19e3661c5e9e2fc738909fcb3f684dbccf54e7ca4f9b64057c4e648f4f22bf7428d6d55c410855f44f08fa2879c388cf24b444f010001 \\x11ac8c6a6ac555f59dc24fad0c450ec6abdae589f40e7c6e54a6adbf3875b1a864bea7493f7cdf504d42d74ca35303c03aee3867f0b944ad98a3e10c29482800 1690476761000000 1691081561000000 1754153561000000 1848761561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-34 \\x6320f7990a9337b9d8b687c6990ec217efe6d0a1beb06906b6579badb2c9d09ed13d5b0ea503c8fc8820cea55d55106ebdfda6a0e722325b88c507ce6b53e0fc 1 0 \\x000000010000000000800003b49fb9f5db9e8feec912adf7cb4f914dd96f4e0590ecb72525c2478d2515fdda99730f80f062cb14457a981ba407c88a4a6085b21e19e1d0990ef1e20ecf357fe2c0de336d7ded72ec85ef74a044f81380d465b7b3954976765ba742e98345067ec41c8222ba10a4436375ab9891ed0a5bf19d888e1a4227164fcb1be4d4afbb010001 \\xba56d1442aa27950e164d001b4055c29331a8a5637491ead0638e3ca4b37dd195fcb6a323e00ad2800227b75324d845732739f6fd456d17da7482fac0ad65805 1686245261000000 1686850061000000 1749922061000000 1844530061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-35 \\x65ac7db601a7f400029a14fa20632f1ac877680786f662e3806779fbc07ccc2beb620ddccece5f55bec0ea4287253e5903b4a709e635138573ce0f3fb2f2b4aa 1 0 \\x000000010000000000800003c8bf7888dbaba469cdb3c926763dd0f772b1d81c98eb5f014a21c6e167d2c4beb8b260cee67cc7f63ad506bbccd85e332a7a1e1533abece945bb93c271762773204f44697057ad3dc11f7f9c297c4ca6625f42d60bfb8ea39cc068df20abff6017ab9f2e16aa1dba39389758c275ec43c4f7512bf7d959ade3edfa2b8c94455d010001 \\x523ab70b1d38228a3492fdca188fa54103b154ca7e5bdcd408b20ccc541536846e36abf5bb96f2481a30d103aae79e84ed8691bdf522c117a1c1ade1cce5a100 1665087761000000 1665692561000000 1728764561000000 1823372561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-36 \\x65c02b45e57e628156200ac533739401ee81c1eec76a433058417633ac55ccae0b90bb1a988edd53aa3bd678b4624dab9bac12e5aa1eeb4a7b626e32be402feb 1 0 \\x000000010000000000800003e61bab0c49c35d66eef4dcd8b6a7cfb97fe4cfd3853d01fbed10d578d1306f1a36ea6a966aee1320e48882091519bd3cab7a96b77ace17824e99a9e1d2adbe3f179f3e90addccff251c819906a511d10351c9c6018194944494355280746965a6998f182fabc7a7bc7867a5d1b996aeb2e325d15f8104a5c8cdecf41f6055b77010001 \\x547acb80c8fab9586bb50c48cd4748dab97c403cc3330b839393b46c3bcb4d6ebc7cd17e45925b9edaf4df270137c07bae03803f20b3faa49a9d9f0f6c676e01 1679595761000000 1680200561000000 1743272561000000 1837880561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-37 \\x6aa4df7460ec89c5d41018f116ffc0c5f91c4ad078ec1035ac71c48d287a5c0e759da6fcec837624ae189ba29f03acab4827ead0efb3fde24b80c8a748519c06 1 0 \\x000000010000000000800003ac774454009bf1ff29c5d03cc46f2ed146c8438ef1ce6f55a06c17dafad1c878739dcbee69fe3a03ec29506e48bdacb3e126a993d057a643da480c2686e5ec42a184b0dd6d26d38744e1e9c66423b91daf7acbe2c1ea1f864673b33c4785e218e20d0009df226ec7b39411a5119baab7be31138c88ba3cce893920d049a9f58b010001 \\x83da8fb8797e4db9b398b29f2b3170d7088141f90fece2a205c26e88916afaa481baf068f726bb4a7b519c1cf6fa8790e6e775f921cf7567163b1b95442a2b09 1691685761000000 1692290561000000 1755362561000000 1849970561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-38 \\x6a208fa941de3f67a5e5c52189997bb76884c19f5eb45566b5a68c97ba2cbb4a2ed8b1c723ef84ec4baf0e197ea278bc4ae191124dbdaceeea49f9212e9870f8 1 0 \\x000000010000000000800003cb96e1dd0ca518cf8ed659e005e56c88cb768f141cab6606fe5c449006c48ba0930b3b125b4680972ff81469fb8bc09bd30f0cfa4a471101ecf3f9cf67a1820657215135012456c1958228171936abbd4de17ff1a4ea394056b3597e97885b310c90e345a0d2f226600e142ad754c12d207229d268f76ebec72cafef41b0f2eb010001 \\x3310cd3e1f129388ee690a4ded0d3a97a18526d315c1966a7d0186110248d3496823bbe15b38d3c3ea58ee64b480ffe6797809a65ab3f607caacf15694a16c09 1683222761000000 1683827561000000 1746899561000000 1841507561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-39 \\x6a443fcc3d2ffa747ce9e0d201385b3cfa122ee1d1728482738a82797e52ef637961d58ad7fe7060918986d180cc0a3c0f4a6365aab77e0e57f88d76ffc0b7bb 1 0 \\x000000010000000000800003ce71bf30c90d4a562062e614fee2ec29965b2ce167a8f5c3a05e23a93d78938f548e504ad4e67202c371716314f80b9dc5a31c597f5bcd1b5c9030170b9745583371481ea187d60797ca43f6efe045a04f004e84b15acf7c75b6a0faf86a9d1baee7a8a500a2a7f56258af31408083defff56b57d1aa7e8571b7520add8bcc45010001 \\x279a380da00aee6b9d79cdefd74dee9c8dc108fe716ed19dbcc5a7973d4ad7d0a1874cf4e931974e51a553cb75a73991884f9ebd36aa86e25bb6435fe842e109 1683827261000000 1684432061000000 1747504061000000 1842112061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-40 \\x6f5c3fbda0fad616decef7cb157c30a29f7dc0d7e14ac10f03f939ddcddbee92a81304885fdd9268bcf31a72c738144ea1a8b60181a4b7b9b3444ec0fc61e5a9 1 0 \\x000000010000000000800003c1790972b6fd1f8e6817f5c7bb7eae99ff5fd36240dd4f39d8fb2416de1d6bc136a9a34bfe6da8f891116125d583485d00a3c94e19b9c58021761c7d3f4784b8d9533d682ef44f925e8dbec42150a695d1ee35737f5334cd0a41d9ef66ed89b2de22e65ffdee0d4fd4c794c60801c87be31309d3dc812da4f91c9aa01dd015b7010001 \\x919bc99d3a1551ed68aa96818758f72cad3a2c2b6beb63399a23fa657d83c60fafc298596bd6fab889e2b6c2c8a3d0247fdbbb5c1c7758f742e2a989bdeaa50f 1685036261000000 1685641061000000 1748713061000000 1843321061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-41 \\x739c37a1b34b4cb898d0fe11c7c71e3611251900ac9a7c980d07dd26b8b3f580064911945dc086b6ecb89f07815cb583d851fb1d3ed16d92de44e2e3f0f946f9 1 0 \\x000000010000000000800003ab808a218874b178dc882c2dd1800edad204185d10ed8f01c4a2c9518a45bc51ae5ae1aa8b1b26791e8eaa0e4afe81f105ba176f838c8aa99c4f5890dda39fd0ab4c5a7de23596152b83f57327e5eb413b32bc35fa034c5be7ea6e05c600056b3f846e54411a8986144a5268efa55c40adbaa58887be7397bc6f58042d2ac683010001 \\x2ffa24dbcbc8eb86cc0474499ee83ca4e93051a4243199952f033c0d9cd6657fc71e99f39b5dc09312c92aa6360ec0cb1d9961971063ba868f9bb9067889f00e 1682013761000000 1682618561000000 1745690561000000 1840298561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-42 \\x7428be110b5bcd1e88677ca065ce5726bac70bbb78fa31e4cfd092a9fff2b7374ce87e4d5a47704709d71507a19339eda2971858fc515909c24ed19cc29cab51 1 0 \\x000000010000000000800003a4ae259cec66f792b6711169fa236ef8840c09bc6178cc0b46fc5cc1ffce91596abe67669d90692870f7caf332300601e3431600717948895aa5f4d1152bd61b5b339ae29c5660a5821a5f824b1457a707f9c9c33fabd0c8e94407f25e115d8fdeb3f76b396e8623face0cd1393fad614358220db77f414c12466b00249f0243010001 \\xdeb651c3b178d628571a586484658c0849d4e7883603589c7988f6bc808a49941bab253bd442ede74cea9a2d68258c91021a44885049d28ddac9b85d77142a05 1683222761000000 1683827561000000 1746899561000000 1841507561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-43 \\x7ce8643421a1a9bcb82d31a47b46c9197338f735d19d926d6838173daf300f38f6f4267b361db29ea5c4bb4b8502a12abe5ff8f53ab43fc21de145143b0571fc 1 0 \\x000000010000000000800003b8f40a7ec467378b6abc13b75abbac08ff67fdedaeed1532dd94ef8bdd71909811b6c404081dcdacdfe6f94312d09206260adf78f42ce71bbbdabc18c484d4b292ad11fcf137c0e1fb3d7e76556b682946f472ba1014e66d0ff6dc67a8770272f9f0fb5d7290e39ab5aeff574c0bbacf27144bb9c8b66597e076e1550839bf7f010001 \\x8fa6bc8a4faa0d8694cfc68823a17e1ad3a05694d780afe4e24e740567c22074d59e9cead40cac39d92af1a2da313bfc0bb342f0075640e00d304b24aafd9f0a 1665087761000000 1665692561000000 1728764561000000 1823372561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-44 \\x7c0c29dc37742ad8a7088f616a5101f1dd9693f638a097203358c1ddb2760bc1f9af5b5489b2fdeb98c5ea8d30aa62f00d2c74e0f118458f7a5f0f9baecc3f1e 1 0 \\x000000010000000000800003c3d569062425d176a2408dd13d869205d8ab0a9cee088746a87aa262381c2015d25364152de528bc90c05e0341df6750b4e38bfe492d21cfd2498efeab7075f6fc77cf76ec88fcf61ac17eb05af8689d3f013cd94a2fccbcf29b8e631fb358ad4a65ad0fb537f0b5d6b272e4d30df77976d3815aaa3437f51f3ddeebfbf5787b010001 \\x8b50142dc8ef0a5bd8ecb4189ebd738a5e5f4265e89eb77c29f9d9e6e65d320b3e3bced337c668a2828ca7d100c9da5983a19719c4bae028f6e6f744336d1e02 1691685761000000 1692290561000000 1755362561000000 1849970561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-45 \\x7d4cb683e5afb1649e5d590f00c55f08b1fa47c23078754c5dd15a4d8791e4c8e9bd8d7fce674ed85be9450a9e4b3ccd50b2d59dc729b4dd69188f139fdc0c75 1 0 \\x000000010000000000800003a9c0e3c6aafe1655291138aa4a9eecae6cc2747ff2c54beb084e8c89ac3c3a77e507efdbe4e4cc8caccfffd2c07feaf69314ec7144a93fcaffabe972a79ae39b2ef9ba0212efbdde87880b6c935b6b3a7ba7b0fb6f863407014f2d826158977a16731954d3e848cfdf63e9f02516aa5510bf4d99f48a46d4294c3596d197825d010001 \\xd21adc1a358e10e5ae2096c9517c99933201f17fa673029fe55c25f3f55631943d2c28cc9c8eb36362beb4044e076ad0dc9ba62dcab2865130ff2580ad33c70e 1677177761000000 1677782561000000 1740854561000000 1835462561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-46 \\x812cdeb532229c66b2fa26f47a3284045e77db2da607c1ec5caca00d40f04754ab50896c83238cc8879b9f63ed385bd9b704409567866075582b191178065dfd 1 0 \\x000000010000000000800003d56a0fa5439cc3f76d6caa12625a47c85f2b82630b9b65dc09c112897d70fbe69e5cb51b827dd00d012e7e047aa982815d680ddc47a84dbdd2e324307bf1abb69f488741b1a08634548cbd079d2589669f697dd82cefa3f3f8cc89dcecc738edc0bb85397a8729b4e7bcb18fd1fea9082ff636d6ef75aba063e68e795087fa4d010001 \\x5f57d982b90b532a7494fbf5de5a8dabfbd6324d48c838ca0e1a035db84470c5904431653c660de631b331d9edd7dcf2ff8f05471362d342b2b023c3f49e6e02 1673550761000000 1674155561000000 1737227561000000 1831835561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-47 \\x85c456c0a0d92ddd935dd0e3cfa083dbd29c57e6d227f9b71fa739e94fcc8b64c9c0195f34566f77b79280ae94143cd0ecbddfe7c8a6af3abc47259c73de03e6 1 0 \\x000000010000000000800003be98152d8f8f48cf0c060ec7bc914afb0d8e5a8659b62f489be164cd8e44d023f5865abc70d953d7acc30a1a8fd7589661c038ec0d95ac3254a253e0ec3371bac10b47267ad4c7e291f9f8fc287e62577d9f23ebfbd7dc20e1497921d4c6aaf0de133016f3fad6475387eee5ed7f7cf171190919c305296f8236938e3ea6e733010001 \\xc4ae8281911099578612b06513c1780fda02e64cc268928def5a55c102170a492741f750c468c19f33c480bcb7b2aa9fc01ec95b1bfee39a48803eab203ad90c 1685640761000000 1686245561000000 1749317561000000 1843925561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-48 \\x85a49ed687e566a8b63e2bb5decd7cd9a8d64e6cd4314507347ba5766dc7848647ca4ffb0ac173f0244d88498ab19ee59d647b8e0f4b428ff8f0d72a1f36045b 1 0 \\x000000010000000000800003d2dbee03c6ffb017a51564d38588d584ea616c00d28edfb20147fc507cfb4000c2547eddd262be190fda8792c18f1b54d7fd64e4909322cf788e813cddf015ad7c42263ccdfc932c1da482aab3bb4d661cab076263db50b067437c4f19153d867091337b3f98e832b9b04875022c184d960b5eed04bb8c89af408505d94335a7010001 \\xe4160a16526419c15d9632516a130fc552b7d19dbc4aad616788ea29cc83e9b773b3a0788b94a7a449fcb9b16c7eeb568162f84042a5fc3c2bea43a98f99df03 1665692261000000 1666297061000000 1729369061000000 1823977061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-49 \\x8a38db1a6a6269ed54fed0aa70066c4dca02c6db05a792345c05297d845052b97f9f326319f2c1ad4625de8e66c4fc2f1aa93cf2b6e1b80a6eded1af688bd52c 1 0 \\x0000000100000000008000039a2cca59ff63792900c3c198907dafe4ad3a2016608b2d129aaa0eb49acaec77258c7b6c1766377ab95e460445f6ce4bfcd081b0912b6d42afeed7aaa9d31de2ca934cb698acb8bafe49bb5474ef2d307a636e7a763f9d7cf1d7673fcaed668beaec725a1c70a7eedb51bd2a47a83ab125e1cad043b169132e0ab0715435651b010001 \\x50079354b82f04e20ed9304d54b0bbd71906694d8651054612a648f6f164fd430ed7e9bc3f4d42e5d5219d362d4c53a00715aae72a33984b32590a80d7db7b05 1689872261000000 1690477061000000 1753549061000000 1848157061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-50 \\x8cb43618cccef1592e590ad1086a60ec2545522f7812f16add660d69449fb3c34cd6b1b13751287a8ae8295ab7278295a4dc10c38325297f891addcc4636bcfe 1 0 \\x000000010000000000800003c7be72df545bda12ec45b7db4075c18f5ffd94293e8ca3518a16a67a27a56d0693802c0f5ece64816e04a0f6ec6748c0e2c9b8d27d5470a7b584d15a9bad85f6251441bf8fca69742c29af0237a13e79e2f1bea1fc81379b3d72843ad2121a490e76c3bb753fe0afbb2b43c089faa6ccf136b3437c5a0ad890d1472f6cc8b64d010001 \\xd95be8a2521057ff9e3d3b79b54ed7c75baef99cdde00ca6902fd1cded2f2971aadef97e10d820c567936f1180b4e202ad1064b42aef977def447c22520a0106 1672946261000000 1673551061000000 1736623061000000 1831231061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-51 \\x8c1063ddca8ee81ec85ae5a5e1b0fcabfa0fa8d0534a231c7d9ee08d735242daede747e186538772f180af28305a80d65652a2899104c779fb98faec7f8f7996 1 0 \\x000000010000000000800003b9802741ea1cf80b854bc86c8e68944005bc0de971602bd296f03c81eabe4e86e9fa957ec1859e28e31588a8bba9e5a1016e88c68d5c74453fc320c5ec7a1211d0ca6a467503088cbe367cd9302d6bc3ff7ad22910b40d29b32ec563adc21b5a9aed408b6ea6d8731b5cdebcc8fbc6597e3edb66e85f0d1d9a5363b5be2dcacd010001 \\xfada817fde4156344ebc357b1a963c207152193d13cbb2da04e45c6ab07b25e93f138626f451a1809e8564bcabed2b86618465083a1d95429055f00200d1380b 1666296761000000 1666901561000000 1729973561000000 1824581561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-52 \\x97dc9e224170fab932483b3cb985a40502361ead5a42d361e8d6ee2da4b0dc4a96b24b88e5bc2e3b3d8521b41482db63b9bf7697f6831021a2235b220d8655f0 1 0 \\x000000010000000000800003d73c0b2f0cafcc985d65c4b7cadd8d15a220760433f936ec78b10aefa52acdce734a27e1d894356eb0b0e05c3e5f46edb5ceeb5cd5660b3313b57c75b6a14462825554c45ac30af006ef08cc592b766a5f4d6c98a0cc0850be68d960a46bb43f1caad92ba4af28349ace068f3a1bb07675dd5fd7abe7dd92529cbfa99f696a15010001 \\xb0b028f1c2dbb10b12e1020415ae2e476dbc07a2539c2d2f4b3607313ef0e74c352286ce730eae37f1d5f7e63061955a2e3c4e342fc8c9936d1bee98cffd7f03 1671132761000000 1671737561000000 1734809561000000 1829417561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-53 \\x9a6082c5f8f3900d92c0472513bff53fefb679cc13b22b046117f9bfb8603151a1e472b0ddc930523e1222c3c98893ff4f88fe679a8da6b78c6303be77cbf40b 1 0 \\x000000010000000000800003a739c9754dc4e1f4dc8c2aa7d91e2f29691d9bd481acd611789c985215a3202ff061608e38650c61bd1ef5f9d573bbd9bea3cb4028f2e6fa1a7881a008f5ee6316d4e95fdf1921fcfc231536b2267d8ee1ae5fdbf4bd64b4d6ccf5659a9690bbba9e367982d2483f392de8cfd2bf413eb825c9526d632a2b40b80c70967db189010001 \\x67cf87d1f995b1dd1e0232514a4ebbf4e257e3b54bd77a55483058f770bd9f11972cef52fe08e8a0e292f12325a4004dd3b50650c8669fe75105f51b4b342f0a 1689267761000000 1689872561000000 1752944561000000 1847552561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-54 \\x9b1ccc2ab65ed443ef0af0c1eb6e1af8f9c88b5a1f67a13953b068d231d415d8435dd2b5b536f607434e844d5aeacbdddd0f8d39f9034d8bac2e19be7bc85194 1 0 \\x000000010000000000800003b79a6ddb5aa44e36b5dbd2be069d5574bcaa15f0327dba3d7092d6cbdec67bffb7984a93a199c480207e906931065743596ef0214204bdd8abc59550a52a6eb2e3b991898512852ac5e90904ec636ee86dc1f1adbcc7b3245673eb6183f3ba70e2b0b02e7c813c8becc0fab1b7fe2353b813aa8e74f146502097b41fa0a4abff010001 \\x3edc02f712f512b0936e2da2ead9cf674fd46f1801e33a6bae87911895dcb7acb2fe4020d171d951be86c4c6a30b5e6e2157f2d0667607869e092f2fa90cce07 1675364261000000 1675969061000000 1739041061000000 1833649061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-55 \\x9d3079ef2d4649838c17b8ec6925a7032b2fdd489e242e75970f1d937d5c0b63bab1eddd0a1771c57a1af94da9325fb8ef659e2d6c65d59e47d007da2fe1dd18 1 0 \\x000000010000000000800003c304c138abdbc2ef1f6b6fe076a38a83b33f4f9f5cc2be303e14e7d8aec19006c09577fb60dce2c2685d7f092d33323440a827de950f225caa11bf6385432f03ed8fe7cdddf71892cc396b61966c3eae23027605772f48b5007f2841ee64182a363e72068b3efdddb6999a48d89961b44b7f23377b90c62c64b5fd9de91ff229010001 \\x403fbef4dcbd62b80f963f2a0af1fe5afa80df82cdd485abfcdd310f8a1d0cf8e4a8bf04cf3e94d7102f09d0df7dbd74d1eb9890d0f88502263028103d221202 1691081261000000 1691686061000000 1754758061000000 1849366061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-56 \\xa1683ae2358700e83b5796a601406e7d8d7f383bc0803dd1a6e58e6d0ca0a339acc86e34176b62e9b8334e7e49790c16c67fb0d4622c04314b0014488567e575 1 0 \\x000000010000000000800003f1a2aaf613967eb78bce3992c5247820e01f5438ab9b1e4c56472eda52f5279af568db9d023615ba5ad3eba714dd45971cf47585f966aa94f44e07734fa7dfdb1a45d7aaa7ed1f6b53fd1657f680cfa71b7ce2fffdc974330fae85e65744715515de735ffd5e67c34bec53900d752346349cc509bdbc0864eb614c87b9b391d1010001 \\x8bfb8a500dfaa4f48c24aa4c5ed053ee2a166d54a18aa5a3bcc4139f8db2f353b04e5479df4270f5e15825c75bab321d554b565b84431606b3d9ff888bf8a604 1660251761000000 1660856561000000 1723928561000000 1818536561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-57 \\xa314cbde221c479bdf85dc2a80441303201f098f34bcf75dfb258894b5666ddbbfa308035f3dd50d19091863925eb2a98e51f9be9da41cad548322f76f7e395c 1 0 \\x000000010000000000800003ad36f6ff0881342b63db435197e9566bc97926f0939ff8419f719cfdd9dea49aac9bdfa3ac34121a1509ddb14f2da3e0d7e2467e263a95ef12cd03276019527da80e8c03b2f85257e15aaf38795c195c34978ca59b2f57ead68acfccc18f17c7314b962aea5c66c3b903f0a9090d89b6215ffd104ae177eaf8f83680a5427ee7010001 \\xdcf189a68ea42c1f2268b2cbed6119c2ef7f788ebe582094a00abf8ae3358cfc05b6ae9f5b4e7570a52cb506a3c59f4c903ff8a118a97e29185504763fafd70f 1666901261000000 1667506061000000 1730578061000000 1825186061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-58 \\xa56063480879cc82cd2fece3dec1c9cc99d2b7424214efdeb574778b2507dc0c24f940b1245de131cb6a307638de372cbbb37a51e5daea9f161a04116304e531 1 0 \\x000000010000000000800003c048a1e554ebfb8a3f598f86de8d01d8d9a73ad24008ac43f9e9bc77315bea357be28efa09534e0838e0b58335b12fc2a87be3913e73cc51d69b03bc2d42bf62ff99e184c2bf5dd88baa95e56cc4f1d6dd847371b721d7ed48c599195b4977755592031340e8bb73abeb683e97b9daaff8555f2ff69af255b44ec524fc2a650b010001 \\x8acaba0f842a6c90f74c7b6e77ca62ccdaece5a87c8e93897af6be0e300812d0df851e7b8b715d06d29042aadd9e59923c906c69cbd63a66fbfcf61bce5a980c 1674759761000000 1675364561000000 1738436561000000 1833044561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-59 \\xa5587bc3c14e1172874307f8a8d795cf6134b4dfc358b46f9147833a696689ea02d710bdd02cb2f290e82ee068d0457d5eb09a8dd86599c40faa35a18ff7d3cf 1 0 \\x000000010000000000800003db59c3a5c4db924712d6a28ec4c8266c72f945b44f00638b1763d28b61009561a18ce6e9cc5329c49482c1265b68673f26e69a0525a79c01cdb62a34a0f68b12142f87bb7407f0659121e8d32f25b4105ccf1731fd628e8286e621a330504c336131d643b2251d553e88fa1b0f5ad1d09de5dace607b445d78d92da81996d5df010001 \\xd599834d7d532687baead73800a2d7c43e5f7e57734356295b683bea837a25d2bb654c89f3b6ae4ac79e8d2701779ee517bd493c1f573326193d04f55e2f660e 1669319261000000 1669924061000000 1732996061000000 1827604061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-60 \\xa6c40aae6ac02cbd5199c80ed9eb68cf741b42c8ded27e54dd6946ee5edde14b5050b366e9b611722fa7106b17ccc49cb37125cbefd832461b20b2ebf3af6ef3 1 0 \\x000000010000000000800003b1f917f9c7dc0d07f9f9282b9389967e8b99a59bc227b3252bce8592972b44e21a765940112db04aad1fbf5ceb38b043c998e8ba2f4331eb725594f1e93cac27450d9e723ac515873c64c8a6545d294a45622d762c2c676fa03f952a927ca934a573fd253f64b9d0ef87b4d3efb3bab1b2e433799f5fec13b9dded105167109d010001 \\xd41994d032f447077ce4be3319ecffd9a32f293be1466899b6833749fdada1b823083497e73f62436f05da2fd726c1110195c928d4e5e791f9e187b468915f05 1667505761000000 1668110561000000 1731182561000000 1825790561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-61 \\xab604c0fc7dda26c2985bb143cc2d598f522ef43078ec609ab8719381f6d6c422b87cad60f4efd189ded2bd9b7dabf5301b2d314fa33742e96ab0441e3509505 1 0 \\x000000010000000000800003beb82ceeecd798f587fbc62fafb81390b01b398714275fc361b79d2561f0b14d87c157f8fa71c7013fe7cd26ed5950b2db7b2da6eb5b896bc5bd6b0d32bc18b34ddff0c935db04c4d21e8ef1ddb2c831bff0f69bbaa20daa43f829d01e6990d04eb2a9e4b99a0b229ab3ccb82b242b33208c300e25387b354f3b00fd39e1587d010001 \\x64d2840a1cfc046c3e83d8cce4362a916214c056fbbe14a84009fef3e52849ec25c9302337958ca397c4323ac3111bdd1c28f6f06f4cec6dde227176f26e0000 1685640761000000 1686245561000000 1749317561000000 1843925561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-62 \\xacacdfb83388525cf854f729a430cf480abd96e09b1aff681de73db10d908e783be7e82b618019b96aface7639f9c2c893e57ce623bfbacd61d1b89ce7f673fc 1 0 \\x000000010000000000800003c35b442aedae379a704a220748d90629ed0ca33c8cdc4d037f9bda3814087b7e2f67edfedd7990dd72f30ca49525de0a23f1ac14883d797306ec820148ff93afc26986a58f61d5c09c1705a0d240b8e7e3f5b5a8f4355eafb7d6384505ffe0a66e3e12a42f54d665d1ff1af9a41b6c27204646e89d0630f7c8db1a06405d0fdd010001 \\xa3300532f5655393134be0e57332519d02b8b209857366e1cbc90f7ea680af9f94fb529352412684a16cd533c39e4edf9fc5c894de210d418da14374869df601 1682013761000000 1682618561000000 1745690561000000 1840298561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-63 \\xaf34f0dddcb4d3f2fc0c073443b496fff0ef6da5520cea9bf1f67e54bae92cfaa8cc87569a82dadfdaee37d57b7e2e5099eb8cf35e299daa5806c567f6f1f791 1 0 \\x000000010000000000800003bbf32ed6d2cdc94759859d00983f7027c30d8a0236398905d4432875065198139b71b8437e4f1992d71257767e90a596856780147fac2c05ab2236df2d12a390373f751255f06575c658c30082755ff4377bbe22bdc5dd6a3dfe92501c7221d08a0af9f21fa372dd300496213986fac7f88902e96a96186928b19e84cbcad211010001 \\xffc75476f8d6fc6b2ec11730498649e008a5e93475092971dcce73e9d911a2b4e27c1b4d376103690629eedb97936e8c5074e75940abe398249c334a4b5b1c0e 1669923761000000 1670528561000000 1733600561000000 1828208561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-64 \\xb5901b2368cb370252eb76860f38d3cc5d9075b35b3dd19911f873db87a9c82cb97c5a4866c5192ba869950a804240a30433a03d4c0397f56aca94f8b87b314b 1 0 \\x000000010000000000800003eb2e7568e4e3ccc5c54dd81503343f50f42786b7c97a4e81ca05c72ac095d9b9e0eecc0899fa27a6f38c1b1bcacb69cbb453cb153d6422e133e8a4ec048be0b8b1e08eb01cd8df70a00922cbbe657879132ecc7aff80140602b7d8e21884da072f8dbae45a9a4f129752c788a3c59b50314b62868304cd7ee56f5c9880a06665010001 \\xd03afd892d55bb25b6eb47e7523f7541ed20e2b1e29c2b5d4b9a977def256ea872165b56042f17acf9775a77cc53762d75114d64501af8c0cfd9195ef3260403 1678991261000000 1679596061000000 1742668061000000 1837276061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-65 \\xb758f902598f2ffd07150f5e681f781788cf21b59d39798792abe0ebe594a80a47b40dae1eaaed8319079179fa028a10e1482b09ffc2f1408bbc79cc4ebe4d13 1 0 \\x000000010000000000800003aec13007d9b80f74d7a5b59c1af70451c5aec62ad5ddee4cd23628a3fa12714e6070fc2af144543da027bd50d6fc16eef8094370f92ec80873e40aa2c47957e17d719fffd18d37a638162005902bf5e40c298aaf5ac7b2bb89cce2e149a9606b1c269a2c42408bc47ac950fb8da2b04683293112cd048ca47ca093fec983d511010001 \\xec613f6d2dba07fa3663730234f7058e1da1a969571f8c7cec4ba73a60b5ecf52cf42aebfb1045831b6490de934b0f41ae9294242c431ba59bf99885dd2b5803 1690476761000000 1691081561000000 1754153561000000 1848761561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-66 \\xb748f06490459a1c7ca74b558c645cc9a7d79bdcf37ec9d58b22eddebb0e6eebd61905ded44f5e343c6dcdf236e7e07c8fd745fb902750c1162f97f69e27c82d 1 0 \\x000000010000000000800003ad621d62034971b4c5431d2342ca32bd85e2beb7865fc9efce7bec39a82e1293138f9951cf25b928c58e08a592fe91716693e5034832ab77005c265ca0cd528e99aafdba0fd2a012b2c4efe6f90e1b2f3b6d18779f14ca9baaf0e5dd28569b3b8d853f93b886c8067a217d253b5557a361f4b64c24d960f218ebeb8d65583037010001 \\x6d57de13cb43b6a81d174fa5000a945fd6a111cc69c618d934c06676b805ca5ae49341ff531546bc33e3d569183e8b8ae16b06dc34df319596fd2518764ffe0d 1668714761000000 1669319561000000 1732391561000000 1826999561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-67 \\xb9ac6e4acb38ea0411d4ac1064de909b4e1ac7c62cce00de19dcdfcf61d809fc71ca590be6b713b5b72bad63167a0a3d81adcef6e4eea811feb6b66d1ddf3a01 1 0 \\x000000010000000000800003c5f5ee8c61b4d96a4a27c40c4606f26196aee6852777966ee59155412da99e0461c8a7c37d569b17da9f34f6c5e66553c1aca9db2751ce663da95f86c555ddb121dd76016550153049fba0749e27cb9658c8a30d8aa06bd9100555530e5dd540a80bd51368836ef52c942ab2fc1ea3a307541033ca0d3e060904a29a7aa169f5010001 \\x527911b5390a6f6331c1565e9a86f312953fc663968a33f0cae68f5125c77d9b1a07a02bb8caa8fabff97c524d8c04f625a2374459cc027f3e966be0e1ad360d 1678991261000000 1679596061000000 1742668061000000 1837276061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-68 \\xb9e8b3a38fa0786cfc82742219424c3bf7e79ac2e672d882ef0de07dd454d02ec31e43a1adacd9a3871ce2f84a8dabbc8bccc5843278845f4e15605684126b8b 1 0 \\x000000010000000000800003b55236c8df73122b432e147285ff27f0b9ba68e5b596789c3f38859df9ac08d854220f49f83497a4d8a27819c0fdbd30e4c7a9004ec8d7742cab348cfa74db8b2efddc606f4db4a404694e5f7887cd92ce21fbcb38a8c140a81b468647ef12dc2924b27ade211e6e2a00fcdc894a339fc3358d5ec75a054d0e94f68a3113cedb010001 \\x90bcd1a3e4a90c4b2bff62e931d2f4e8dbcf029d599168d265f0dfc0103ca95dc5848d0d72b4a95b5c81c080f472197e3be6db3714520d85ce2a11c29c7d7b0a 1672341761000000 1672946561000000 1736018561000000 1830626561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-69 \\xbbf40e02c2ad7ec039f6f3f09fffc196147962e93b29e452ea988488d61a55476360500967d63a5a3de5eed74e7b2c64407ee7924402bf5559850df8d8d1fca9 1 0 \\x000000010000000000800003cc73f118e9d59f1f2dbcf4250e511b95f5b9f1d9271fbbf64fd440cb7b11446d214a57c5a28c218eceb229721540544b2d03f9f0806df88778332531844d1f6ed45beffa822960c17bc5788f125165802d3e82e7935abcef86928084d999bf1a43af2f571e819ceb58fa61b6e24743eea548d8c4678455ad5414bc73b76dd2ff010001 \\x13d8b039a6eecd48ce29c657ece089874eb0268bb4f2be3a241c1c1d2386eab85d611fc2ef520232c0f573ef42850d88f6ec0c70f3baeddeb29c308bd9c71e08 1686849761000000 1687454561000000 1750526561000000 1845134561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-70 \\xbcf0de3664f6f8861304404fc3b21b84fc90cb531093e3aec75816066f2d9c073f5b3d1b5ef034d34ba21bf1d3f7d5508e8c76498852edccdecfcc080560d00b 1 0 \\x000000010000000000800003c46dd1a6b24724d9c9de5abe01a7e34929ac72f27bc1eb92cee7b61f76f1c975dbff536abc29f61a36308237e892c3c4a24357e0caaafa0cc81c7d91fabbc7db1d8cda5d70ad20ac78ba3c7e62484e27992015bc8e8886bbd1630a8e3dc8a14cfb072b826ad2992543a49b19a11633cb68bf1780815eac8615046f836034582f010001 \\x3eb415d979e7149339a93bd068643415eed0ff8bd07e301c3bec809a1855d29b9c63a98cbe48d2cf10f7c35b53f188895cc4304cc9b2acca3188ea04bea76409 1689872261000000 1690477061000000 1753549061000000 1848157061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-71 \\xbea8e66f839d48b0959f16ca3851a34186dc441787ad1ae9912febca9add132323d4a367b231e046b46ca5ca68e8fe41c3a5400be40de7e01613db47e9426bc1 1 0 \\x000000010000000000800003d2d76e1bef6ea2f7893274f4dab43e9b1c21b875fca7f2cdba636ff7321e2eacb93767329b5cc7a90da53721668bc937ccffd45ac0137ae748fd82b38fb4a808063488a6bb8960b9b7942367fc72a84a5b8f6cefd9b6a269e13e766b861be599571eae0c0b8b6dba36c4045faf47bd3241c476ca3d584f92c1d2789f92dccff1010001 \\x408688c0dfdd09dde31acb85d9ed1a591723d33beae7602bf7312a323d4edbb92fe4fb1bdc9fd8a7c50658f7c385a8c6dd2375aa67290cad80904800cfcf870d 1680804761000000 1681409561000000 1744481561000000 1839089561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-72 \\xc34043e553c0f71fe620ee113a090f573ebf7e4c59d59cdfb1ad82beb87907d8e3942f2d3db211fefff388319fe22530c318d67f98de0166f8886c760fa77f83 1 0 \\x000000010000000000800003e5dda4e3f69c9880d7345db4170dfaeb49cf8550e9bddb75b039502c402ce3bb5ded6b03eebd4fafdbfd09ee782b1c4216e7eacea4176907de68d7654042fade19191e3742a111ba48c68664b6ec40d7d3b0906db0c9aadd838a7ee1e0941b35a3cb8634668d6ba2d6577c4014f4b7172c2c44b5eafcd8f4288a935f98412211010001 \\xa9049dd303813c7a70db2f7afdcc008d762a76ffbb6a3bdcee7cfbec76b545478bd52a6d14e8abd95949a130c7d04663da935eb465344bfc3c91789709b6bd0b 1673550761000000 1674155561000000 1737227561000000 1831835561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-73 \\xc614d7c1bbb9d67c4b8d05a4831bd356e3c9d22d01b28c260e6949f95c7da05beea81db185c25d416e2e14fa368656f94692bca495f982a7e217c554ca266d26 1 0 \\x000000010000000000800003d42010d486546ec49967312ea128872245c42a4bd710570dda8e401081f02fd27f49b8a5c2bec44b186b93a920c7e1020257d37ec24c45cf63655c74c7d0ea70fb0e0765d7e5c70a33caa0f8b6035f796c9167108d789fa4b9c4414d5a6b34d417d908230908ef672144f5f17102f3b09ac8defc476efbe193ad0e5575bfe47d010001 \\x52d93e8ff120315051913d2cc55adeb5e45c2a7de5d392bbfc1dfdfce6492ff23966c1b2499a874cae168ba5442204e585e250bf7bf7dbddc158bf77e6b4c107 1674759761000000 1675364561000000 1738436561000000 1833044561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-74 \\xc7a475ebe8404291e3599cbc452bee3f20b79740d7d7438a26238496049684f5ee412f9dce09e2fd1711f78a1518df6af63298eeb0f454e7ee24622b82e780cc 1 0 \\x000000010000000000800003972f070c14da8a1680966f37d2d765effe65c135bf83d7c9b3761592a8aac925fda3ac1aa6c941e9b247b68e470bd7ea29a25068ef522d7b4b0e7fb99834a9da83158b1835d4b09385819de0a08fb649f65f4f45d41617af28f7d05e90204a0eb979e777303e858974c304260451d2446940ec95ddd4bd7c3cd9026b6146f75d010001 \\x9b01e8d76890241629e7bc4caf216350133b90f6bbf080b71693f94ee82c34f73835e61f8234b1040f4f97805f44c87acad65711eee57fda19e89235ceb2fb00 1686245261000000 1686850061000000 1749922061000000 1844530061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-75 \\xcec06ba9043e9e8e56a5060bdbb4d62ada634e8ae41a0acdeaeed764b9b854ab5e5d9ef59db6cba1961d4d709ae72e29c0ddbff2b64e00cb47e2da6023fa49d1 1 0 \\x000000010000000000800003a403bbb4aabfd21dd98a78025176a3aac0de3cb74f05f2fb1b7e79ac8d42f08fc15a7ea1ad98d303b28fd4cc1e52af4246f4eb460a7d5abe526c42aeda4ea1e741a1fb318b9530006a5129ef02e5e8b9437aad9fc4a751f62753466afd0831d714ff4c3bf3310439eb5d422c1c5935b46e3232e898d6624af302cf455c8f182b010001 \\x19f63359edca67bec8693bc0cfd0acaaeb951d6ebff02f7c1ae1cdd3293e737e03bd8f67c3a046a1ea2d4c831d6e676a98ea390ee02f1feada66a419d9c50e05 1682618261000000 1683223061000000 1746295061000000 1840903061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-76 \\xcee4352aa2f407b4855c25935fd1785d6bf1328f198a85202849368a48ef31d3b485bda57dcf10904c5f0e9e67e031733b846d1557ccb9b1b2f28837d861cb1e 1 0 \\x000000010000000000800003c06cbb8a64e18b9dacc539dd0ce0a8f40c034c2fcc816475493c1a3895a7e044526b17065c90b6556a5c8e64a52c600659344333fbe7e0121e10d75756cade510b121204c65d6b69c8213804bfbff342aab89601926fe9d5edcaaaa7300b178306e4b1893172902bf7e9311597bb775490322bb8e64e8aad831924473af7151d010001 \\x4d534cf3435d0acfd788454b9309d49ea4bf42e8a4bdf92410118d63fbc7cd33ccdeb825e28146e61866435ff31d5d9f00659a6c59a03c21e9a950dfb8255707 1665692261000000 1666297061000000 1729369061000000 1823977061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-77 \\xd0f0e467db8f06dff99740326ef3413c24dcd77a12e034ae1b928a426f5e128ae2e57c78c4a8b4a455a3d8650771a67fca47faec143b894e60b171aa4c3756a2 1 0 \\x000000010000000000800003b7909039dd1563388d07e5ac9bbb8f18a4130cf3fc74ff1651ce089be76b330f5dd557f56d5b1f3d33542d77f9d1c5785fff32e8caa95b40198aabbff577fe02094ee3c5ca32379492a598818ecff464cea25c73eff30cfa09b87ab580ae4f83d2c5c2ec5ec66ac0e55da6134202d07251abc2457349eb14893fb99d4ca9c9f3010001 \\x6336466fa37ce46a44b2ced4d96c5e6cf272212b83975057f5372362cad36d13b2ac90283145dc536bf489cd2d17eaee4257cb238ba3c4477bd174cf16379b03 1670528261000000 1671133061000000 1734205061000000 1828813061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-78 \\xd298be0402f402cc8ea9f648892b4424e8958718744e54fcaba08928e3882f7bfeac17bbb893b43e2297a6eab2fe8ae2aacb0503a53dfe07db4475915f6e353f 1 0 \\x000000010000000000800003a9db0ed7598e737f29732c4b694ca1a6f0417a1c476788d94f07b766fbe4ec17e7f0062fe63e119546b98706c0d2266697c0fe58da629b4d79ab337e41602a82da4f930ed72347ab718044b7ec7d34262f7149001b8ba4cc66eb31b2ef3ee15c89a08eb842dd3eb2964def920c761e51cd304e72b24afd524777f72f893a3fd3010001 \\x5147d7386933962bfe5f3d01a42d35783b4a1c5bfbe4324a06602addc1b3f1b82b1c6ffddb3ea8975fa422dfaf45604a4b7933e2191344ab0bddc71682c3990e 1688663261000000 1689268061000000 1752340061000000 1846948061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-79 \\xd72cc356298a3e7bdec94e1ec27d7f3bc62f3c85e13ff4f0f3941edae93da01c41fbcf83b31303964d9134b74cabdcba41740a5eff0e25290bc192d219624c19 1 0 \\x000000010000000000800003b502b66f0555add853059db52de45f7d9f75203a47c30bf5c2b1aee8549c0626faefe3a61fb50da774812a9fb0499e970d4d91342fbcf518d07d49e7dafb762badf3dbc5feec2cda9f0e3b9eb3215fbd736f5f560298c19d7b3289a6f3d46dad7ef680ad9104ea74bfa6180359006d890c325f93b8333320c910b7a0157779b1010001 \\x5ee97fb4db27f6b24585f5dca045e52be370c564b07d95f54e4b2a50888fc9a49eb28151d4b8f39797b469b4660af3c25c39989359d786a2cf519c72467bc302 1671737261000000 1672342061000000 1735414061000000 1830022061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-80 \\xd7d09dbc9bc062aae41646672c424d05300d2ba8cfb157c15e17bbe1e727fe52265ffd1c40b873e99e8d966600639b52cf095121f34da396e850e4d4f10405ab 1 0 \\x000000010000000000800003e251cc1ade30977e9fc5061e5ba7f59efd279d367869dd094f8213d3a3fee7b0b4bbe9c707dabc027988c4df29b699530eff4b079fd510bfc6d4eba093b0ad70366cef31686fcd7c04c6b0c7d0e50e871e2bb9714b79369e9745d33cd6549dc5a53e0bce2a1967612d2fc476c102a9bd5047c2d0252f5c15b712459947f78ca1010001 \\x1b88d4ffefef3c5077f4ba0995bfd99248eb74bd926aba2caecb10348a45a0c7d12eccfe8045706829bf776b09d93025e1c78982bbabe446b3c04a66efafe70b 1689267761000000 1689872561000000 1752944561000000 1847552561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-81 \\xd8f8887f30ab35f3c0c8c11a0371124604ab40440907070706c83afdb21e1ca3fd218a3ef353aa3e44ea8de5d792188fb84c58f36a365eb1b8e31281debb9fdc 1 0 \\x000000010000000000800003b5c207050d275b1a84eb126b073d83331391fd36c2d289de9dc38649c3d9955cee4cfe7d5794897e95ea959f2f389397f36bafe6ff2d7940fd22b72786e7233b1c2123ea410cd0105ac9ed3323bb1828ccfd632afd7ddb8bda8bba4046f30df354538ddef5c19a620168cb6710d0ac9f001130cded6ca97afff3ec440e5de399010001 \\x73cebbda25c93c60db8f6743e8405e561ce0856f7a36a0fab618641e5c228910ef3519de9091d3140e0f07fbbf612197df03bc7375a0378339f907db3a4ec60e 1687454261000000 1688059061000000 1751131061000000 1845739061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-82 \\xda744cb6db86754e456b44a99b3957688be325538afc84374acd02d3f68741e9df7eb96dc2c5a1a97a2a6684932264076ac5274aa66b18fed56113c0e5b629e4 1 0 \\x000000010000000000800003b11b29de0e27c8f1f71ac32b83e68c897a1bac0e8fcf26ac169945eb9c6a473b1b0f973a741854031cc4fa836a6435552516a12ef823da6a9f1d2f6161dcb82a196ec78966bfe98cfdf5c370df1ebea5febedcd75829724747ce705fd5bd61f1a738013f8277afb1858f3cbfeace76326ae0919ca0e113277e9928d6951022b5010001 \\x239431ed9343e303b0154669216be1c4ed70aac1801afdb0d42afc6b3682d1f447b724a0671d3a76eed0b2039d4536f551a03d63cf8ce9c09e29e42ec7c7c304 1663274261000000 1663879061000000 1726951061000000 1821559061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-83 \\xdc88216c1401bc32b97592e7a470c913c674ca48d69286fb6f2351751496a8688b1aa438f656d95dd7487b58b4ebbb3b37f9ff65a0cfd77a57738b65cfcb6041 1 0 \\x000000010000000000800003e20db346a594783b54a92c7dc73ca29858898b1593d413e196550fda729536b94bf5237fea8d44120c9e05c7d82d733583152d47d3221194eac268fc8fdae970011115bc02dcecbca8364f4abaa0b71d842757acbcd1587441b1c5090ca1891688548a6628ddfccb5c514fa6d10a7e6a3b02125a39b9fa191af05b15bf2cc65f010001 \\x3e5ec8d01061b38ca04c08cc38ae55f5fd2d527bf2e41aa77ede01435d8a4014f73078c47856bcc40c23d72d704067f06c3b96564860a10120e52165b263d908 1673550761000000 1674155561000000 1737227561000000 1831835561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-84 \\xddc4d1ea458151e6e732d92300fe9e0f5a98b3511f639852bc5233ef95e131176ee649af0a8446ebf114e21e7e532de4c03088df23db8fb5133a20cdfcbcab51 1 0 \\x000000010000000000800003d38c27c941e8478e1d399fbf13b6f9458cebe12125df8788a2dad8cd8a5b4d4f792184ac16f42b55659bd2729011a8ef033b0609e7f96ba41fd6be85eaf39252d1dd4739350b788fcf7cc4e160d0a19ab2f06127eb331f196bdf2635aefd3226d7e7a7d90d54242958277b010db11036b566dcd12ea4a2daf159674d6e9ab9bf010001 \\x1a2256669405ed6d0b9ffe000851cf4130efca3f820005cf6f87e8e868e8a4e35a5d5dd0efaf0885e96730070e3f4f3f7b6a40b873275342e5afe30601658f06 1660856261000000 1661461061000000 1724533061000000 1819141061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-85 \\xdee0404c976448c6e4edd137d7a0d7e5f0c139f484fe6c0c72eb04f23426dd779cc161e4cc805fe12c0d0ad044b4f636ddf6bf1ffbe0b523a323b64bc5613202 1 0 \\x000000010000000000800003c5b5e12aa207ae169fdc998b78072d81cb46148a45660ed1583dbdcc4ae8154be24b53b846e107783decb26a358a4270823c2d5f32490669762f3a6f8a650001f9ae0eb5c743837628aad13587d608ffa33e3f91fbc55e2cbfc524e04731069bdc424be6a05641cd37c62be7896270598c47b7d56a1daa89650fc939280ea249010001 \\x769e4a4dbd9ff89052bf80c660ca98ed8a2374eb93141d5243f7d1c5223b22dda3273eb3fb8c65a1859be582b6e22c4a4b018e88315df487953cece60523db0a 1682618261000000 1683223061000000 1746295061000000 1840903061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-86 \\xde6ce83d3a935b64b406df47407747f2c820459af5c032f52ce0a8a68f0e0d82a3365eecaf4c060262c3c5f203db403cfd09320856a57b84a203090fc11e086a 1 0 \\x000000010000000000800003c4366fd7978d10f994588e111117ebad8e7cd9910d3a980212cdafac21c3290e7d40f0bc583f26043a9b2c0e13f3deab185ba30352484eed3a9f94e52e394373439bd53ec874fc79307c6e610a7a8076f94b4b7ca3a2262ffc74f22b591e9b6c59186d64475b39d61e08c55bbabeca0864f09fc7c20bcdfad50db2a3be1b8185010001 \\x890bdf3202edf32285e9110717015f943f9142926923afdece1fdad8cbcd24a6ddced4c818c9841079c861c7d6c52b85ff832b4293d32cb4ac1573f6f6f81a0a 1671132761000000 1671737561000000 1734809561000000 1829417561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-87 \\xe0404a3c8e37a10a58f62db20912435c3183791d7b5d5873fbc53c20e92bda760533ee58edcfcf280539f4c8a70bdc42a8ed088e1f9d794441f536099321e2bf 1 0 \\x000000010000000000800003c56c132f57c49b1236044916268bb942aa301b9ec2dc71b1499dae6723df5e2470c3c22d4db5b0c20831cb7313e6c9b85a341d226dc2cef37bea3fa7572617b7771944630481ddfd040e064b11821f49e36b20fa877ae5bd0253c32b99b42d52e3d370ed12b44999958bf4cbb04e9375029bab4acce9e015458d78d2b8e96c5f010001 \\x2a416d3da7083071234935dbfc31b04da2b10c3825a73193247027b4601897d922ecf4066202e065621c273ed136991de076832d3995c912796568f613959f07 1685640761000000 1686245561000000 1749317561000000 1843925561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-88 \\xe19cc4ac9692e8465ff01000eb11027b92709c64d106d8087fa42198c1e8bfd87891aaba0abd902c55809817b88798792e9ece71fb8a14deb3e69dc6527e4118 1 0 \\x000000010000000000800003f383a38768ab8305a14e97e9801757813478e2d322e285ad4cab02f96c63ec489a744cedf08fe78b72062574390dc35e608ffc8600b5c6527cc01d357885a79559533402f472e95e2ac3cb644ef3a3c5fe6d2ad736e1d285d1dcfe5d2c38ef601a4dbf3a2f7774125eeb649778a0946415092585498fd865c714838e46b7b463010001 \\x507ac21ac428dfc860ae174dc07a051eefd29f749dd97dd4e68dca5752b261076db9f4e4e2ec7dc3069d43a87e352620f6a889aaad3517ff6dd4742087c2590b 1678991261000000 1679596061000000 1742668061000000 1837276061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-89 \\xe3207ff2cec3d46eaf2adb95925728b1b800acfd82cf71a8fcaea6c468113cc37f1815d233d05a10a656d5413f4e6dec46483020c304fa27af44f162ec1b9a88 1 0 \\x000000010000000000800003b5fa1e1b5eef8d67326993f80c6908d1484acccddd5f4f57b6af8221f7e1f287d232fb5bf591f2672ef0541bbd3ce06f030a78b689cadedaf0d86e3adc958ac3c3993c8f84608c52e8778bee7bf155ed4e660b52bf2c4d41067098df9da5cfc9d56fba3e1b64dcd28a3d978941da5e004a7537dbcbd92920f894ab94da2f10bf010001 \\xc110d77ff2c87b49a9d84ea528b67d8d61cbfd58b22bea26c1ab794e0b8d74ef02c76354de1fb7270fec79fb07f6d3238448e15c706bea72a1cfe00d62a89206 1685640761000000 1686245561000000 1749317561000000 1843925561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-90 \\xe498bc044ed1f596aec07655279990134eca39239e1e3ecabb75d3252b8f2190debd8d93e57f81a0a82c7a413997faf0c6863e7bcac9729785b516a8875771ab 1 0 \\x000000010000000000800003de26507a5a1b737d76c81e6c9ee9b1a7580383ea55928335a4727c9185493c5d0b36d314037650d1de68ca2b30e1a0c7577254ba7ad5c5250cf7d1ea8597478acea23e9fd447875120e36ab84507573454cdc1100cc2771261cf5ba64dcabe4d6e0ba3123c1426439f29ba2373deed7bcac34f664298ad987c7172c2c497d023010001 \\x0a2e8731e4604441e9f60073539752128925e0273e13f5cf29a43a37435ab7b791e5acc68ac7b5137fd2aeb4d903bb82e01fb0dd0bcca2ac8f3b95ae205ffc01 1668110261000000 1668715061000000 1731787061000000 1826395061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-91 \\xeb48b274bff1bce04f3ae78bd9954e85093a2862cad719e07b538fcab62f9e6cc94c4828b7377bfd5ff07872349ba76cfa35a74b691343ad362ad0ad596cd84f 1 0 \\x000000010000000000800003cc4e768381824c036a07d929bb534bc1e05b6eb59d57264fe90a025b4bac4dc456483ad2a84cc511c1dd47784050935d762ac3dc124ac3d6a0d1e31baefab6af1316c78738000c10f90d027b93d48e34ac964e979073e0fbedeffba424448cb48074ddb173da30769cebe5cc1db623f90ccccc319570f5f8a5558226662bbf93010001 \\x811ea0837883e5a8618a410a592dc455c1a90d09f618896c795c55078e50e93c5d7148270d21b0a19bf0031b3c6bb3372581735967cf68d5ec50e08e16b27f0e 1679595761000000 1680200561000000 1743272561000000 1837880561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-92 \\xeb6403345b0137ebc8672a024e77d287da857b493f45715c08401897572f57ff237d913d64b00abeaa58dbb59cd457caf9f8f82548086b5cc455f35c964ef83f 1 0 \\x000000010000000000800003ac6dd1891bf1db317c52450f484fd99e5453656d19d6d3ff67cd8fc074d9686988ef79edfce261d45efebd4c612d62f3cdcf70ba99ab8e770a669edb5a587bcc19e6c0eb73fa08c1b176aa6dbbc14d2182750165663e89b2a4d6970b721992d920341b4abc50397c33bc23672d37f73a3dcf0b983cf185f68cf555928741b68b010001 \\x04814d3dc5c29364be57d553286b4a85898b77f3eee29decf557ab5a74835f01aaba46d54ef576f974046b387919af011f392d1b98e420bfbe0f91d867cf830b 1665087761000000 1665692561000000 1728764561000000 1823372561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-93 \\xeef4faee3355c262e2e3ba1a1f5d08fa7a41fa0d3a10b0a353ab296daa936461117cca6bce08d8d4a1228706cbe9a86b6a7da11e2374f8e6520832eb304f2ccd 1 0 \\x000000010000000000800003d307037d8699303e9dd8ad9f993d4d87344b81c768a92b9b3f50429686c24459f6abe010105c4a80eea4a1dd0dce82024901dd59166f4d44123dadc0439cb58f0205e20298a6ab31613a2ed881c7c125e27df0d673238a9de13c55a32bd94e32a2eb838c2d3767db7a0f0edacf959b377aa4896091c3e008604ee86da90beac7010001 \\xfed151023aa553dca49f3a7bd6a8a36264223265e22e1f346f066b36a2fdd77a5e298727eb6fe162a01ffc98673836915ff94c9f322f2eb5cfedcc57a557d505 1678991261000000 1679596061000000 1742668061000000 1837276061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-94 \\xee1c426e7141440b1847106543e6b138be88c65e2fcc3ef7e458f1a8fa28af012e735783b40bd2322da5332d06d2269255b32d65755138c08f3fa9dbb2c2b2c8 1 0 \\x000000010000000000800003a8026a978e942311b01b781bc39c32e06c744eaf986fa29ed079026b24a5e114636ba2fa34312dac57d8dfccc425de30538e0612f273026717bbfaa24dc89b1f0ef7ddf6dabc54b8acb74b726adba3774fe6c0d529e2cd9c3639c202e163fc90d2da8c1eac07de2c656f91d3907ac7fdecaf6e8eacdf099a51045cc492668863010001 \\x1158636d8059969f307e56ef88c5183deed5b9cc0d7e8e2085a498228460c89bb3226a2e28f8478918a6887ae988111607d00dd45a1e8c2b617efdfc5d3e7f0a 1668110261000000 1668715061000000 1731787061000000 1826395061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-95 \\xeec0b42c14e76c7e860085ffa50f315b3d73f09d6ef464f4131b3813dc9c3c0fd502a4b175ac33a23d02f86d4b26d89c92ac93da00408c2610f75d13c2e73ef2 1 0 \\x000000010000000000800003a81057fb76eaeff3787cedb8f332c4ec66ddaca33c1040d5d84d34887a1a307a24068cc344ea8086f15a10694d5f70a8fa446d018ccf46c19af6a63d920aa827becd5371cf65a9bc2ea336a43e1059df22661cd186425b363a4a9c2d17cf00e84ca8a8e2c56b1c6c496cffb0992531307da85eaab5503c05d5b2b89be4a9a307010001 \\xff3e10d1b8edfc33372a2d5aba89914192583a046ad317ae92fa0bc3eeae0c025d15d8cd4462c4ad547c7547d4a948fcabca7fdf8ee51c4f9b7930253e12620d 1683827261000000 1684432061000000 1747504061000000 1842112061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-96 \\xf1086cebd0f5bc16c508f387e26fca3e8472052fa9f2d206873cf6ba1389ffff9ec1e69f896060ec42cb3a6341d164bc09875cd11ad7b53704dfdbe8d7a01b10 1 0 \\x000000010000000000800003e3418bed2b1386ec76e99c118c55b7850f96d2f03ce9b3eb81528c891b087c1327880b0ec7bf55709220732caab1a0eac3767f3d4ccafcb65e6019fa5b2262e9dc207ad17a8601d14ba434cebc2d673b73213af08a4e63bdb161b6057a349c5fd5520bd01384ecea38cd7b3827034b1b5d19f3e2b79c20724b05e93c1a208617010001 \\xa7c6869c6294df066eb04d65435a00d92e4f774f830bd573bc3fb240c7675e1aa9b0164d415e6d544b03a34d84dd749376fcc14e40067057d1740b01b4e0fc00 1666901261000000 1667506061000000 1730578061000000 1825186061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-97 \\xf3ec1384ae583482e03376eb29b4682bc05c026f26ed8b081c4b3c5faec24b8462dd41470d20ada5902952672be37781917e9e9f173a6c5bd05fa01c7545cc9a 1 0 \\x000000010000000000800003bcc5b96c4da88649abde8876ec2a94d457da8adca782031bdfe0160f1406a20d2b02e4bce06984db5d25de7d5c2fd17150734f2388a622d70c4c505417a598ccd03b4144a438bbdff679bcb0081887effad385c5527034e7a45c08a0dcb76300b47ec1b88908f866e44572e7dc4d019d06fdbaf79640973aa46838ece8160dc9010001 \\x6ac108e12b9f23f1ad481eb5edef596df6765aba06fb52c50676640ff1359d3cd87b9aef1638ba2f0a32a5e371e32b597a0c188eea5a7b052fc276d4ef01c600 1674759761000000 1675364561000000 1738436561000000 1833044561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-98 \\xf4e4c17a3b5527bd72c5deaaae076ac3fae987c19b0e1cc7e487df643e6dc4d19f3333a1c19834e68941ecc3dca9916fca3613e4ffad9a68bbefdcfedc88c762 1 0 \\x000000010000000000800003a76c55ed17fb4f054e508df6f175b72e4fc7bc66c7fb6183036e45363c8892b46fb60ebfcb7f71385c45365813219850bb22966f8c300a4d8908ba36f5fd83fb8bd0f1e915d1435a2ddb139218e1d2d292f2715babd10218494e4f22b450c7987fb8e8dd330f53fb54fd39d6d4dd1775d0dff5186965f36e02be18b993cf7d97010001 \\xc356ae0199462ea9da52281431e1bbf3463536d2f74ac4e2eb9ea6c8b02bf7fcd6e5a3d0a4053f4ec6d1898b3298cbd79033e281be18597124905a7e875d1f0a 1683222761000000 1683827561000000 1746899561000000 1841507561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-99 \\xf7f4a2604e1f02d77480dc4e626031f84a1aa0d170df7888c79092b436da7e52ea80d221c0ce6b99af4586675eea33038e8f7523a1e0240f96f6ceae4c657318 1 0 \\x000000010000000000800003cf932bd7b14b6dd5695f600043f530f5147c529686286696431db6043ae2b83f291f96c16130cf1cda30e9792a2c64da14cd92399a92c1592e2ac48288d3d8fc3ef602d31113333134626f2c3ee09bda8d16effd8516f36a1392d804c63b77c32811e9aa5cf10eff012652f2934825a485b24ba45c33c69e51c98b63754dda75010001 \\xe0b5c0becbe4ea97af8b26e4064a6200635b2677b7dac6380313822b45d0272e2310693b23c6ddd62c35a83eeae11529d99e5eabbefeb2e9d0fc69360069c00a 1673550761000000 1674155561000000 1737227561000000 1831835561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-100 \\xf8648ff1e5af38090b9059d2d09a1860753e0f986a5e159b41d957c2f53e76e97e7b3edda3e90938bf2c9519b9db860c202d9cde17a77931d6c741537c46207b 1 0 \\x0000000100000000008000039dc946a01149580ec34de4d4697684acb5155943831c0a1be45c82f82b9472d203a47335ae2c4e89f7765bc886da86fe00936817ab8263bfc98489b96f8619058e29544eee79023a8ab3d1ca1e7917509dadd3015e2231f258f4941be0830400f47a03ea563a6dcc32a2bb1acdbf0f7db8a49bba017170d53730643b6f571ff1010001 \\xb17297867d2ce7e4c6f01e9d02859e4dc555c0a96dc670475f6cf37b8800eb1722f41a7bc16b5cf677ad207af1c4027b9ad664de4ca5c98bb34426fe084ba305 1688663261000000 1689268061000000 1752340061000000 1846948061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-101 \\xfa2c9e6b74458c91918bf360ea7ae99d35044640f1b33c332e6d7424286bf6a6d197c8fb80ff18334ee145f79fb1d158ec253dbb0d6146fc283817065a049f1f 1 0 \\x000000010000000000800003c5479f34c7f78cc779d44752cfe1290703ade277bbe7cb88c37674c39a9142c4ed8a1c1b72eb5079847da7d7d3f3c4f7c977c1adbb5aef98fcebcc52603cd47919800e4f670b895c29532b064e9d2f3895bcd6c59dc587499d57802750c62b4d308f5bb42c58cb90655cf9d9f0cecb5fb1518f9fef0e59252ffbad05c78ede83010001 \\x52cd7f9378db721f1145a08b1f9d0e39a409d9c00b4aa82d345ed6831b033390363abb4b3be291f03d7152e7b0d54220698944ce672d7f6194d76b4336447708 1677177761000000 1677782561000000 1740854561000000 1835462561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-102 \\xfaec70f9f153e70f86fa101d8ecdc2b34781bbce29bfc8a4d41a401e7b07dd26b2862154dab456501ea79ee88d1b5c905ab65ffa87a7af1e0643bb0bc59117aa 1 0 \\x000000010000000000800003e2b58cc4d18b505ca4e90556eb40b71dea985eec891e597d99a1554ffd532ea42c8ead28027579b4bf6d9db1ffb5ed29cf537daa38ca6134a00478ff873b842df78c7e8f193af19ebfb79fcf940bf1fa4b6ebc3450014fc9ed43db9a10885456b0344affb4d01e2ff41bbb28021fe5022b521e72e9ba554677e536d72bdbe273010001 \\xa0c02d49dbbe7b4721c1efd044753e22cfd1e90af9357200841060ffbd2786b5cb66ce02dd86aa6d78ad6ef9ab95541076eaf5eb0290ffa2263718f25b5df70e 1680804761000000 1681409561000000 1744481561000000 1839089561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-103 \\x00b986d12d0868a5f88d71f8f4b8c09c4117de10c5ec06f078adcaa56ee0eb8773ca00dcd1353b60dbe4b23b89afbd700431f5d312afa0e08d5730a654cd7e6c 1 0 \\x000000010000000000800003a91f992885cef73145301818fb997d0d67803ebfdf6809d1eb2e3961b221e23e9c8b780c59f671ddf036b45bf741f63bbbed3f6d60fb16e16d10b1cd58d66b33d3b2d4ee46cf9b533738d3da7ab8574195ee1fba80b62fb62c2ca5e525a4dc37494eaaf38372e407cf321899e24ba634c6cb4b462dbea648b304f353638991d3010001 \\x5d4d9a176880dc9a01cac9f443aca66f66b07a56c1d74f41e6ec29a4aa34329b317934c2965364eee8177510bf7537a55402252d6bb94c8fdefda7a73411b203 1685640761000000 1686245561000000 1749317561000000 1843925561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-104 \\x01c9c7b8691c92f00cce472881a688c7078970d162aaee3a49439f07064cc9ffacc79b48ac776a5c07088042780ae1d240f35cbb3e1dd4ee8da7d6f561b94d14 1 0 \\x00000001000000000080000396b3d4ae1849b84ec4808db36e848107f2517fa2af40ee22ee6ef2caf8955590e68cf9baf617ce3971a8c949ba31b2a699044a0600ec099ec27b6fc2b0abe690904a0ec7b0d52014709df44b4d2a6db4991091f736073479976e7ce9381183f7a424540281c920a65b1899fd328c2076f15fcffb02be1b716a7264dabbf7526f010001 \\xdb5ea3771f2181c51d33ed741fdea538e7edc9158a0b8d83b55149e102a5fa135021f1b0fedfe674b22413ef7f1046ff34515d1d4b3e4d35ba618694382b0805 1662065261000000 1662670061000000 1725742061000000 1820350061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-105 \\x02a51da0351186484fa96317eba3adf20d165a6cb36c5e04a264f5e1da82da279d36c933c3f185c3a3eaf38a59e8c0c86014df91a0019f0d58a83200ff4431ac 1 0 \\x000000010000000000800003b848e657ee721316a825963d54353831c6d1a556e123ddceb1091e746fb5d4ed57ebf276774b33a570f8a52f2af1e0a8bfe439d64d46d9b802cdd657abaa43abaff62252d4a54494c6cb4c921e5fc9ed510bd6ed0aec346dfbeac7f17e82b802d27a5bf2be42e0d1c8f9a7a05c9bc32d4bd62820ad0dc9877fe412ebf8f65713010001 \\xff4a642cc43ebce9753a303afd35f83bfc6cab2afaf54ae2f1e3f109816bf0869e9f17ad647e7b0f0b8b749a7e6f0c5793bc7fc557465d348ed482750f79480c 1680804761000000 1681409561000000 1744481561000000 1839089561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-106 \\x03edd5c3b724f9566430ce54c18c061da6567d48c00710bf2d1f7aec52d058b4f9ec3d0654ef5e21f785af42931192a9a25a023f9b93a8d504bc9a2e1746891d 1 0 \\x000000010000000000800003b3e0acd30ca08f0c3c758c7b207778d42ac6de82dca786b44fc0b7b5d19bca019e645a8fc55b1fc863a024a054ffc2b7da656f6facbf97ececa1510e4f1dfe4da4516c6a690d8b5db588f9c1bee37e806d93661484360e969132b80fafb0a7607e44ef42788883fb873e3be024d7bf472d9409cf02e67d4c4852c47ff7458be5010001 \\x7fc8e4ae879687c2ff1d46c8f07dcff7c30cf68518f6ce76a1f29948b0f3a26c16bc3f3dfff880c285290081eff5f9f029d9e01cd04ec6f28725d87aba21eb08 1689872261000000 1690477061000000 1753549061000000 1848157061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-107 \\x043985c8d7572b6a9b4562240322f02c8fb86f6fdf805dc9299453ce1f8249e02e218102d98e2b2d3b108d3aaa3879f2c4a76e07fe9af9fb52c6ed08f586d0a7 1 0 \\x000000010000000000800003b1e729770b51ff34ca06253bf957e05a78a78b635e3458457980fc5843b8079353726a0ac1b3b7f1247056cff409f6b803a194beba3775c54cd150ee94a1ce55e41b14f1ca78cc511d60fbca1324fb5a546da00b8fd138f2caeb445fbef8cd8cf4b61802c8023cc32e134604ccc16666e416b86098eaf7427f315d9e7a7a5553010001 \\x682bd3c3a5235afbee47cf917fbb18d70af3b27034e17255d814323b3689b229b7fb85ca9e5d2f1db2113428ce68822910942401a2be53882bdb6544458a170b 1671132761000000 1671737561000000 1734809561000000 1829417561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-108 \\x06dda984a6a4c010f7f352dd188955006190506f596c2984940e4ca7e9f8e816745595623ec9c9b64ceb4b4cbf513fc3ef4785ca5a9c45cbc66b2a3850de938a 1 0 \\x000000010000000000800003b792f0576739b1c23f30cbb98e460df98e42b865609995c505bfc2d3ef0402a1fe53e329e3ef99dea42d963e5b50772fceed637b5378d6cb61f7cf0982726125671dddb7dac49900f54d8a70ccb0d6791c45927a650cb9523da8cb0d2ef62fb460f934b25a8cc4430b3554fb4a145652808b848ac007bffcd6439cdae0ad59a7010001 \\x3babb5d9af35490813a8ced5058d10c004b0530e4f2ce323c9fb08ab684eb358ae410cd58b9d332da7e6c9b8ba3b1d2f8b43f8bbea1771dea42d9900306e8501 1666296761000000 1666901561000000 1729973561000000 1824581561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-109 \\x078951d717814ccf72840e8e9c2a53f5f1acbe8f913668ffcf502b27f5f0839daa22c5da7eb485787fee15f9ea7cd80b0399ce2bd1b9bdbb0017156192ecf9c8 1 0 \\x000000010000000000800003c8ec19ca257cdd0d202094168ecf0799b419bd1f1eb800c8ad903ddb8f325f38c68770619df5c694dc4a3c0a90a1fa3c0d5812a6aa67b086c9a8c131f22a4b78fedfd7f71cb7270158442fabe3cd98c7f3fc47b70b994947b083a0e4907b15eca9d89048a4094bc6f518ac6dc400d52587c39160484c6d17dd07b15046e3eb69010001 \\x44d63dfee2f8a020e0a39a2ded6e62c17ecf0f7b3a142cca0d6990a440c3da140675c3b2024953babe4969caf0f8caaa409e65e5b35ebf92832266912c163d0c 1672341761000000 1672946561000000 1736018561000000 1830626561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-110 \\x0b112debf74c6f4220418cbda7a411a0b8a2499e8450f499f5b14101b99e2fcb783338062c312924c4aae7261aa4fcfdbe88d85daca9a73c83419f755ad53ea9 1 0 \\x000000010000000000800003e67b462bf106abae8e458b8802cc93cc059de12c2ec803ff4abc760e1f52c29a68e47da126552bcf326a1e2df22439ca738bc8d5b492ce226a41102b1ae7265d2e418ba24a67619de9ddce07c7f7bf6e68612f01d0b8ea5626541d8781b0b4c9142d80f9845aacd64dc5f6577954c1ece7d705438e06c17f9016472ee17a9fa5010001 \\x2104e605bc54faa8cd21bfd1e32c3716face327f149d09301722a3af77f00b56b80c81c8fe48dbf2efd8ba5372494bf9e87eae0b37e7219740cbceb5370e7b05 1686245261000000 1686850061000000 1749922061000000 1844530061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-111 \\x0c456be94606e0518c363a59d642df62ebe217f0b78601748a28896930a825c804820b6ef969ab07436da60b9f03dc22a2ed781d4fbf4b274e1669d97ae96009 1 0 \\x000000010000000000800003ccc7fb760355773af4fb657620efebd0622ba1ee3989919fdc9121dbc9e174b21e54efff2f5b63e96216db14fb8a3600d54c633469395166e4a2300f70076f2457f86c1bd24d0d5b8a9a3da0f0ab901df337d9b06c919f8429bcb3d6975bf4dd3a07ba22dd6913cf7befee549c4d43584a3f2d8bb2a3f6b098d940cd76fbe3db010001 \\xdee5a29f496e30658c3f129eb6b973f4e0c449abc44fb20ea164c08fcdf05cbeda6ad5f5592c75ddf09f115f1af3fcb0c3bf6243f824b85a5c017a34cc2cd507 1682618261000000 1683223061000000 1746295061000000 1840903061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-112 \\x11d5cdce382bc114eefdca1a74812c40fb179441c35b93f9c7ded4b48b1015fd2706d6a5ff0441f69c94bead0f564f0b07a1d0f61b5bb3bf512ff7fe34bce97c 1 0 \\x000000010000000000800003bb8ab2e16d1a31ef3b187aa7c14b24ed0fe927103a4143721014d95065a9948b93bc064e47ad6a11155b1dcd5eea3022fc8b7a3b8db4569fa6f9ab03de9fa83cc22cb7b20414e2053dbd401e40024c99551bc4c5d2b093f33f4a3c803ad77a09d2723bdd868ce902739462d5e4bdab29fe594201647b663bafb6c7eca342117f010001 \\x49751483e8a50783705a757c18e011b9ff52f8124abfea92214b0d079566ac7e0497863ac0b87fb00492c0f76b947cdce9edc0bfca45bdd7ad02abd0c3381508 1663878761000000 1664483561000000 1727555561000000 1822163561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-113 \\x12851a660e2961d41cd6340af24224aa406865746f625c2c7965e3b08b7d48684f4262f42fdb121a7d9ef3ce2dc0c9d0fc2c62b19eae9967e86465e4ec0a0270 1 0 \\x000000010000000000800003a7ca66076c1b11946338990db7634048585b4b5547531963628c0ef8122ed85dccb383f5991eb493d692b8438f0924c9be720ded2fef1270494badaecbb55e9a093c115ff16027f9199dd400de5ef5f2daf6ed1004dc480e2ab3db574b8fd0af987adbe63b1c3aa16025252a8e14f28d50206f538a5c6784096ae7adc54ee393010001 \\x41a1e58d573fd2cac36834d303fb10420eeae6efd427f704f09351cc99b447958731ccfd3f8fd962f8c259220de0a68f50abf22b01265a16f1993a7ea5f71b05 1672946261000000 1673551061000000 1736623061000000 1831231061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-114 \\x13d91b1b70159c3a889e97501ddbb8500b3af451f2ac3cf1e56b3ed0231c4f391a90a259328793690cae12cadaa83ca83c73f38735f8b9aa358ded96b7c35214 1 0 \\x000000010000000000800003b9aeab77bf2d0949938a67366385a5d8ad1c4dfb7a96d2d86b39181c9460ef5ea485b400e4403e7d82f4d6b905316443007d986725aca478e3f31c1256b2c50c043dacfe35283a082aa1f339510dd7d6678c59688eca75a66ffa265cd64486b42a395c6f70e9b0004f70a9ccc2dcc34d5d598019a67ca2e4300647205395c223010001 \\xee3c4700a18264f35c8e281dff3a2b96b77c9a41ee18293ecf16b5f8a176af8a08b2a609fe23d41b6806776e70a4868b0a548daf6f666cc7160729a84c03bc0e 1675364261000000 1675969061000000 1739041061000000 1833649061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-115 \\x13d9ff5feb8eb739f71877a176ee4a263308e1e60010cb5a6e52333b41d157f241b57ca44cd0c73fab1ab6de48cdb865df8ede8a8c1db33422a397faba13993e 1 0 \\x000000010000000000800003a73f0fe255d46264e09f7033008ed5015acfbf98d11b48c74dc2d8a8053fcaa05dd428c418450c649f9fc743a6ea3a6d20645d15002fa642a515d865aea3d04addfc6915bb5d196c5113b978e2803aa4ff2a06fbe2e6f53f4a6c960b2ffad9baffa62f7e2dded5d70f5370fbf12b1d6b75c20a61759f70456b2e5cb29e1256f3010001 \\x49200d37a6af063ca9032a89b5a73a68b777f2f03eb31424290ac1c822fd968e82fce59c4c961f44f2513ef2088d7ba22dff5e06f100362c12827aaec7492101 1683827261000000 1684432061000000 1747504061000000 1842112061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-116 \\x14adedaaa6cd0a3a1c80a455da26ac63795a9cf8472a4186c3acdf7ea04c5fe727e60ea5e9757501107d8459688dae8315c2e7cb5dde562742505d98fcbbe43f 1 0 \\x000000010000000000800003d2f50741e511f30b6ad3a9380ca4d061ef455ad9b012e5dfd00b46d439d8cc0abcdade08ff022939db3ce25c422565809c3e60d82004e62cc73f4392bae531abd0faf3e8c324a7c05a3db21af4eceec90659b0f3fa5c4f7353ad114997d90d9e4a71f78d23f2b473437f21fe4d58553d02e2e32815bc7cbc5a5d2772d3d7e2ef010001 \\x97e54341ae4714216bf719863655f207915688e4516c5ef0af0567f855430c1acc2eefac8737eb5f04efda2bb9d17210ea31ea1734766bbcf7dbca959663d70e 1672341761000000 1672946561000000 1736018561000000 1830626561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-117 \\x1551ae5c74705a6e355ceeac045997eabf2a10ba3df1045d01bac62151cbfe2e3581ceebe16aa933606f81e21a4714ca0317b66ff4a33582231586887345e261 1 0 \\x000000010000000000800003b91b1db793d0ad0a2a5096da7200f65d9db8d5c0b72cf860443a7dfbe92e36022c5e15c3e900afee1cd6f1ff08e35c515edf29a7d4c996d2b2d7bfdb09e28615f410a4e90693da9c1d3350fd4a72a576a0efbba45a34fd79cc5439e457f853461e4cc5350620960a7cefed8b8f1bc955c0a2543ce329611bebb3c2c2027c55af010001 \\x097fe9c5e1c025975e4009198fc03909fa88ad472e1a2167008f966f329e86c6a684288c0edb298986b34a133d23490af6783c4f5b3c6f2d36f89fe654987e04 1662669761000000 1663274561000000 1726346561000000 1820954561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-118 \\x16898e0244e7567d88e6d5a05f47f37d833bdd40aaf35081363609469be88fff064b0bc9d18dd6dd40c7905dddbd9ab8f9aed08adb836034d4328f9436fb3fde 1 0 \\x000000010000000000800003d8e963c917e89389bbc3ab46827db59eb8a9a61a8ada667026b0c7cc8ee1bc5e2fe36b11167ef84998146cc8e3ce7e7d7527381f6d212716e522ecc84b150c052a109f264b4aa4327d9605f54033894574fadc66ac5c88eb3ffb8a7eb22a46cdfcb4b1f4444350fc684d5d078fefac510f691da8cac83cff1a8f1685a56faef5010001 \\x79cb6a1f50aef5bfbf35d173bd10694ff183130bc6379da08176cd48230902e4d60074aaa6b0fa65822e5642620d603bf931c537898c81a8080ac9abfd64960d 1688663261000000 1689268061000000 1752340061000000 1846948061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-119 \\x191dfc0d914c3d8983ffc76856026054db8ac417b61c1de403f995b077574bf09b01baf9d2e4f0ec604599d983f2fbe89a0fa51e7594d7d9184a430dc6b801b6 1 0 \\x000000010000000000800003bb7593d093ea3b5a08dbc817b58aa092c7739d934539732f9c51944c5fe0b0c0b34a772e4a64650829f50ee947c3cc45659f5edcbf7cb3fd7a1a1ef28c4bec7e1fcb450bec4851d2f1fc8e450bfaa880513f82480e64594ea92d791984ffee8f5334c54675a0bdb42ad067166f9c3668238073918598f9eaacf3458c5b2020a5010001 \\x46f0d117613669e33e93d0536e705cdec950c6357a325f57a19b3adef98e17268c837de6e5df197f64269fcf964c68fd952b3d9c289b073ccfba8b55af785a02 1674155261000000 1674760061000000 1737832061000000 1832440061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-120 \\x1afdbd3f61c55cfde9f07ece0688bc24572da6d313e9aadea59681fb5f62ea01d033689951bc6e2edfa2d17d763d1e7c130464648024704c27f429c441bd9184 1 0 \\x000000010000000000800003e90140ce9f0a2c92e71bc0a1da6b3ea3f6745868aa8625ebabbdb0bed35e21910a8e0983b6e54512a171485e28a66efaed7004fc2351bd902725b700ea244bd53390dda89c85a7f83c3d8c1e073e370373e7c742e08df60199e54365f7e4526666cb96f58f11ab2024c87b963798c781eecbbbc0d68a4cf11dcc8d1585af8bb5010001 \\xa2f28889f0a7fd70e6198cc63a5003494d646547ce51487b05ca59b69454b83be4c85ecfa283a09a38ad5154facfab7865be607743ebdf198cf6ca67aedb270a 1681409261000000 1682014061000000 1745086061000000 1839694061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-121 \\x1ec5e25974229e9c823381087629fcbdb3fe226986474634fdf2749f98f07e657401b682c427009a935bf9708e17b28e42d56ef9a84b30b87f9dbe3f265e45b0 1 0 \\x000000010000000000800003a6e257b2d084250b772d777c04381924d683ac3623a42d4bda5b6f4a64ce1186dca631572c4a3562c73c74f9aeef231ead5261d2e3364a9c797ea44af9e9771e7fe3d7a387e0a4750b4e28e273eac2ebd7ce3d3ee171b6064d3a0a1c608ec509894441d8c257a09b74571d60955dcc25094139d73de8f7e3755c302a6a4ac50d010001 \\x87fa559df44dc9adf85fe7cd83c118acff62eb62e4c1291483502b77e494de2b0bb07495337307237ad9d78e1bc5c413ffb1768299a2fb1daaa33ed125b2680b 1689267761000000 1689872561000000 1752944561000000 1847552561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-122 \\x24756fbb5c13b1c717f6098c3f201fcf87505a10aeed79be71d3d6dddc3aaa8f256d2bc7d45f3dba8c3ebdbcaec94bdc27dd1133049d5a5b7ba7629fada6d37c 1 0 \\x000000010000000000800003cb59c4eabc8d9788301e9737ed56fd6a22ea76ba8b41af6181cf5cb7d274df96bbac6d42c9ab778882a0dee354bf022f4e75614089c573e93eabd1c0a21eae2f9361115dbd1e51fd14644432726c5d931b87818cd85e261ac8c3528d9a7234c757bf162b54760ebbd8fbc57d5182880e11ecbe5b6f319ff8f2db0ab1a9bac4cd010001 \\xa91fb8084996e6e62f9a69f97cc389849e440f19917785e29dcd697696ff5b7a1eb05396eb9215f809d841a87fffd354cf0d20a3eedeb652f06411624eb9dc09 1668714761000000 1669319561000000 1732391561000000 1826999561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-123 \\x25c1d11986698c324c052baf80e662caf1b2131d09b316a6d5cc99007cb25917a6ca26dc462c34587446175e91e83830b8fc111c9a12f15bd9519b6081a3c5a7 1 0 \\x000000010000000000800003ad981bee631d8cf79020367e55858c91f47495ea6af16fdc4780e388d16bb5fb6a227c2698ebb0ab71fdbf3e0fd33bd25b3228f927d5badc596291ccb486f572ca6a058a2ee5f93fb794dc851775ba63b1c4bdbbd38ffec394dc6e05cef73e2f4fcc24f599a8eb27d59bf0a28f1f2129d7d6f4e045e1e8d7dd404cb53af29ee9010001 \\xb98194447885775ff5fae78cae2a961baefc5061abd22849447d4be596c5b4a8c8e0f556cab933dbaf561de8cbd2d759f86200548bf112daf246115858259909 1664483261000000 1665088061000000 1728160061000000 1822768061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-124 \\x273d31f3d8e0b488c275cbf23412441ba41484f875dfbde96299a7e60c6c2ec395617f34c2ab389b860b1428bc7e5c1386678192f2d72d37bb779f2cabd0003e 1 0 \\x000000010000000000800003ca54a577e393a3fa11521180782418611070ee715f2ee852d76625d2daf60df7bceb7befb80479cca552b23ec3cd57fb57553ea5b431e25d9874c69e2fca866c9159ffc37684858513fbff195a50e53ee39bf479cdecf4c0e177f235db01ec5c8be43b00525872bdb16f2c8623c9ddf469a8082c707f2f91988dc2976809287b010001 \\x5541a0fe5b6587a5f986c29955fa62e02f0bfef063e6ea9692eed89c2e7d7a37c599c722514dde2075548620e12188137be9bebf94f02ecfa11179ec6c0de801 1671737261000000 1672342061000000 1735414061000000 1830022061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-125 \\x27d9f31fba7d8fb0867ec1a3003a53fab96fbde2f62e77f7eef41fd6ab80cf1e3d804114a0fcdadb25e443a79dd2ea61e6c950321cea6dfa41918b210fb15d04 1 0 \\x000000010000000000800003ae60b0b57f774b7b3ee3690f02bff53704861480f710d60701feb1becad59feba4b564756c07099d1538ebe488a40d42e5f0ef2c821522b44486c0433efef81b88248c7bae6442ae05d1f8601994bec7b3904579f7ccc4fb305bed7f91c2671d87bbb521e62d28ee79900c8d86d8b962cffef168b48dcb3aff4e5bd06bb0712b010001 \\xd90f125bf8e18226f924c892633eb525c2543cb28cd9b7ac9722d28400da3773154ba90beec7af5bfd2ab8d70e7a3bf1e347005f859786ce799cbef9f4558206 1662065261000000 1662670061000000 1725742061000000 1820350061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-126 \\x31f58e06c4e00add279a7412aa980166cb37a675d5d91d457350c6dec056ed7b35af0dc88c973b470ed8e6c86fc69f6182ae6edbd82ac11fdb0862ab2f37a0aa 1 0 \\x000000010000000000800003f47ad640088c4726567105f360bd57385bf247c81aecef208647d7e553beb17ed0e04ef20e3da1a23660e96d3eff332693b2ceaf04cef38a331a687f6e2dfbf14ef01f502fe2c734c21b8d7c305cd67d5cb58d0652de9c28d10f8b70fffc0ae734deb16b19e179cc3c4212cd154b28c685b0869050ca12ddf741e9e92b6a8777010001 \\x3ed58b21570233e1c77b738a669c38218aab5284092018bfe4024ec868684718ff0dffbb00b5ed4a9a4696d81e64152cf7bb10c05510d29ecc7540c276bbc802 1689872261000000 1690477061000000 1753549061000000 1848157061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-127 \\x318164cd1f7b13f57a9a047448607a2d0fba0f10cf511ac1ce5dd6d51b553ccbfee261e07a897a65447f0f189f04e52f05c65f6fb356ef17d39c1a9267b0a9af 1 0 \\x000000010000000000800003cba726437ad4c6fa6427cdba62a86db2c59c9c4191b5de03cd4486212ccc1f6fb2512981cb78fa07fab82a14fe318f08e57392ce64404b215fa23e94048f36d53c23b901cbeb59912255e8615fc952c6f2139f4648b9c059c8ae4b9713001d2f3b1541eae9217d4da3d6724ed628bcb753dbcb52b4f9ada81d10b7275020d7d9010001 \\xc220e86615faeb80e266f61d8f462a52444d10b25f5ad2775b24ae7ac9af3a7dfd5fb38f2d28fe9a44abe0195e0853a34a51e150150606627410d3a00fb9400a 1660856261000000 1661461061000000 1724533061000000 1819141061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-128 \\x3185155eabaf26deadd9de32809b3265741e74ad1e2b265977b0b3f2028009e7c56d7f4478f1d6101607a5d46952401cdb648d7dab4f263158b03a905b16e218 1 0 \\x000000010000000000800003ce4b6cbac419f3f71e13c4ae5d4138583d340a02f6a14d73ae7a1d89a461b9ee9fd6b12ca9a0dc325f787ff85487897ce222677613c923caa7125d048cc430b517aff814d07c692c7465d77614e6326ec4ec1c6cb93bd5a62f7bb6342041d0471cd31dcdf8fd70d5d131beb06192b6908c717177b0ea45e247cd4d0a070270c1010001 \\xe280b3c0a1e8f9f15f1c0ee35d779f62dbf5238e47928f6c729e45451f87fb859c042f4aeb2097c929f97cadd130179145034a8fe38c589aa34b4d20af674609 1669923761000000 1670528561000000 1733600561000000 1828208561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-129 \\x391576c5c169015b2df718c3a5a99f06d9e431510b1863f07294f9c97079025626206abf104b1b51b011dc2dbcfde049afd3d066cec87c11bf75cf0530ccf552 1 0 \\x000000010000000000800003bccf2af0ff0891d4d57498ac5a6450cfc50907657615264290db699c64ec34cf257d975998739a613bcdfbe97b0fb87fdde8f07285e96e9ad1d932f420546f4a52be8f513a2c1d873097f544b084352037eb606cc40830344581a21913f359de259ae36a09526dc512531a6440d9a8e3163e6f1960b88be225d8ad44643132b5010001 \\x8a10f9cb94e2297b7f21f86072dd5a1b7ecb57b21604d650b5abb1f2947e113ce612f3a83a2e2df63703a50b753c120bd0e1e67e5d9ca8fdfa15e03828788103 1665692261000000 1666297061000000 1729369061000000 1823977061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-130 \\x39f98a0047b0b8574be951fe859a3d9d5bd807b274fba4cefeda6339767c04ae66e5ecdbf377ac9497639a45b2e34949721d86f0cd666008f73c3dd72be15f7e 1 0 \\x000000010000000000800003c8d3aa7763f451143560e638e819f86e11fcb76886f519565cb9f85c1832ef81437acb764c5e6e1be403979281240d153f7987d39365ade5251a5a126b7c61a43170c21a2cfad4bec63206dd5573102949c5334ce56fc614284bed016010bb7955cb651c8486d2758ead50be8e2884901964341a0c2db60c68d1cb27fa4d89bb010001 \\x3369aa604e620aadb5e28e932b3263fd97f83781aa4f1cd81f999a35d6bdcf6444f941aa8d56c0a3d38a67ff7b59e7b9f5075c0a9c312cb7a02cf44c8421c90d 1667505761000000 1668110561000000 1731182561000000 1825790561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-131 \\x3e719179a316ee1306efd3507e3f69e948d03890a2f69212ca010308a0d1ba9195c9c3000d33d3623215b2207020bd5801c8bf7a5573c87314024a5569d9e845 1 0 \\x000000010000000000800003bd5cf8ef339325ba26ff9f5aa0095d69cc40dfb395fd7f4caedbccad1e5dfc36386cd9b48fda359783d2f152a573cf462013f622bc4a0c2acea66e6f3d0909423deaab4398132b526f457e9271b1bf6705aeccf6de2efad1a2ff5b9c44f27cc51952397dac8412c582cef171ee388d5d662f9d09810c06285c954ffdb24f34bf010001 \\x91322b5bf027eca5de5f6e1dbb33d4554b5a09dee575e07addf72716083d3a7293ce9977e6701d04fc6b48a5c93027b036d6713dba2b098ef60d8cfaeced5c0e 1662065261000000 1662670061000000 1725742061000000 1820350061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-132 \\x45fd0dbf6c10f2e6af0962090a8ea484286fe31bad4ebaccdda75553102b583beba6f054a841da651332f9b4a08f088e8db5e28532ac65984da385b1dfa33078 1 0 \\x000000010000000000800003c59715e2165bce0cff74a3b454a8a99cc358aafd2b8c671391a15559e59a3d1a1a544ede2f30ff78968555b268b54f8520eb982305e523c8673b7ac3e05f27c0ad0df6203e8b2e00a5f5294a93eaa1fdf443727cd81935c9f4b127966957e099452003c29c03d293bb815c35eec86b82d13b36498e36bf7ae229c430ac6fe235010001 \\x136503f9d0b8127e4d0fa777a8d2a7b27b0b7a78442d36fdb1a5d02937dbd315ceed288ce84a9eefc3270a2dc9ffc6a05132af5f82560fb608f6307323bda70c 1688663261000000 1689268061000000 1752340061000000 1846948061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-133 \\x45e160300b3b55b3b739ae938bd9504a9c43f335d83e390f6c9cba8394a4c3faa0dae463fa45dafc790b577756c5cd47f3867f49991fc8275107a5bf9091c5b9 1 0 \\x000000010000000000800003b13777665f18dbe91f809c3163673c00d837e9522e66b8b41a08ff51d0b3fea06e39f3395383ed517161ae4e84eefc4286dbbf7ea76c82c5482a424607a05cc3791542dc3379b3dccf0fbe3c70e4b729e9389d4c6f47a5fb2eba6ca418bb1f7a2fe282c150dadc05f1583c3f99e843709204b26bafbda0a936f8391c3b7f251f010001 \\xd5e6953a23ac320ac83fb8572a7891f0061277349ff4e2851c1d6b0afb718b098e78b18cfe5a3ca87af3ca71685390432342b17d4a5d57196ec27ee1a68fb903 1668714761000000 1669319561000000 1732391561000000 1826999561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-134 \\x48c17d56f2beb2b6f84d389f38eae446d7a2ee2b57783f83f9055106706fe0031e39bc26e582cdda7dbcbb0db6704d8b4f3102f95dfb96653de318a6c0e8a66a 1 0 \\x000000010000000000800003aa678f081993da44c09976b661bd031279b6a02bbec4ae0d8e6e5a7b7be7a225f29bef9c0cb3f9215b1ee4cc56963a5f0eb46af4f27e670d45096404903124cd5a41ecaabdca590621fd728581e33600593ed7aab60fa802fbf17c3b65564ffd239412bf4d3ebf95d2c22593637d3c5bdb9a9ef246370c7878b2f8c05e3badff010001 \\x3be08f280c4c159dde6a7092eca9b151eeb84340508e9e166156496b7cc35b9225a46ce5c9174b6e05ce456dba8862a85cb2a5d8303e62d95013441da524df08 1667505761000000 1668110561000000 1731182561000000 1825790561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-135 \\x49cd151d0bddd5512f0fd1059d638297b53514aea5e6adbd04d71622ba0380b55102a7632184a5a83c34b421a42380f729b50bd6ccb9c28c52202bab232b530a 1 0 \\x000000010000000000800003c3c534d117fcf0b8482b668a13fc50129b562bf763c9f5bcb9dad5baeac6dfb57814a1bd69d92f21587c5c25584682157faa20d92a8862cdad80287543e608bfb19c05e57e03a1546f9e13cf25e4638f15b74ce010ba2382d8654f95ef8ea9293d5071bd7aa7e409a6eb6dac0bd12c2322794023a3114bc5fce8ee9cf3748371010001 \\xda435cfd9481dcf321136cdd52332149b3d098b0e67775298a4ff13de84a8be7689ebef5bdd89c9821de7d2163d51229a7b2e0193fbb2cf32effdbcfb502ce09 1663878761000000 1664483561000000 1727555561000000 1822163561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-136 \\x4a8582b1b3dce57f1b2350b29f8e12f0648d43037a4eb0ed102fa8f111d4d85b4a71b192251ffb4035ddb5ace683674eb21674c6ab92452822033e5629f5d869 1 0 \\x000000010000000000800003cbddd5ddf070d90f35a82c3d923f16814a7ede8de032c7283cb8473b3f37dc236d440cbc429036630c95db4461f18df12ff7ec7fbff78b116abefbc1807614d4b8feb8e2da1c63f145b6671dd1d0ad46b627cb12b8456dd2b62d9076dde1c8e6637b12710277003b43267f584090c2638d49a3bf9e946d910aa6a23066413a6b010001 \\xb5eb482ad31ad54de2e63f8737192eadb4324d461ba127d80dfe057e2f7ca20d1b80ac5d6e4227bb6ad5f93226d8b13b2aa6a272b597c057a343b13e38ec670b 1674759761000000 1675364561000000 1738436561000000 1833044561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-137 \\x4f818827c85491e6618a1b3945c89dc46cd533c94b759b04d8947c16163e8cb9b26e35e02804ef21822b3125f68ca8ec3dd33a2ee10a70c28696795215032632 1 0 \\x000000010000000000800003cf7a63851551ef065855e587fb984b8208126d30c8f7f80d8a2f2dbecde0e26a24fdf84162451889f9c1a24aa4d4c45c6a7c90ca97d46b75a172164ab9f49f03a1ed6323591a2d7d0bcbc38af8d763b75e53a3704fd2788e4760355c52d0daeed74deff1de678fa4dea769a6f496fabcdef6c947eda16fa39084a5d5a23db171010001 \\x95a47a3f1507e105a8fe2e4a92afb65cff27da409bcde9427a978e4b4529c3fc2647705bdf49badc3e44fdb27254d8e268282045ac913d101edaf05c83b4b503 1682013761000000 1682618561000000 1745690561000000 1840298561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-138 \\x5331460fccf5f064b22d9327aa32f30cfb841c5554043b6c669d74e0524deffc5ddb75ca70e4e47f2c41e67cca712783721d2c984679876e601d714c2362298d 1 0 \\x000000010000000000800003a2ec47a43207aa26a62e9a8fe4951cc85799a7cc32db562e2ad11c22f6cce8af5452a25111cdc36a25302c0712a3d7290e4302acf16818aa9770a2d10be9d06dbaf880ae9fcef92c30cb752f14d073a9c2ba4ad2bc74bcfcc04a9ce0c9375573e19a5080025910842a0fbb1eaeed16b1b640de6237cadb0c746f71df9ba0f1ff010001 \\x515037472b816c610c3c165b4426a1cbd89c6d15e20107c8aab34e322d794503a78aa00c45d6a4c0fd84ae18033c58dc3f57d793b00de0500c102e035cc49208 1660856261000000 1661461061000000 1724533061000000 1819141061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-139 \\x5611b12cf1d45c77f0f697118768901f7ff5f44a10a7598f4163e87c3b1ccf9cd8dca236a63e7ed74b3baeb98efcf6a5c66f22f18cca50069954666290710a65 1 0 \\x000000010000000000800003b8f6e28c3da68bc10ecb44dd1f1a25bebb54befc6d58c6093657051a5c146614fdaaa9864d2d58c3083051633fd83296e5fc44d608af1e5a0b226152c096188e26d469d8c440c5cb956b6a1ea4a43d5e83c909d945e31c185b7086942dfb9e2656e335b69746ab499935f277585289b01ce0966214a4470ebd0a9c3667b1aed7010001 \\x7b429265ff4155497d0ac9cd8ce9bf42b3c5421e6081606f963123e4197d21601a78cb992e37f28926813f1c1b2b907cc21f2cb4a043bc9ea9bc9c0dbddeca0d 1665692261000000 1666297061000000 1729369061000000 1823977061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-140 \\x606d4bf35e3c73fb2152575797287fd0c435b47d00200992fff34375b9ec8b3027a46fb235e1183fd38ab0696e82435b0570001ab02ba6878fdcef83e09c9bba 1 0 \\x000000010000000000800003b1a0d99a23cebe4b8d543a5211e235279f76d2215164f94927fd99abfbfd92f91d4cd1d190492d3b855ee45d8d4b99ae7e0cce5ac666f1852b68f899dbe3da2c480b2272fb5fec39d35bdaab735d6ac85107bdf5fc9455ad8ea61759368c2e493c30adc59b5bdd22096926415307e272f88a244b4f6ff042d9cd1f05f29bcbf1010001 \\xf2fa604be9c968a8777503a17a807bd74710788f223877010cf340b9ba07a7b23f43a434c63c73d34c4fc7917fe40872d5df688522ab6c090ee823975dc8f304 1668110261000000 1668715061000000 1731787061000000 1826395061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-141 \\x6415fb0dfa6e26189d98d5127c87f3505feee21d9486a0089d7901db2cd230ebc29925ce314e9358d9e0f5c77679a4df7d55f30b7feaf1379e2e0347707d15bb 1 0 \\x000000010000000000800003bc7c55191cf1147a382aba224ec61caed9051bea5c31976efb1ed28fba5cf890d303b87dd20f80104973a585cdc495c7e9b174b3b0453657740396ae6f39c5da84a8e7363c48d586d88904349177896d07af6858514a43f2c484f22da4ae6751f809ed8e7380ad63649743903c6236e20bbd7a2698288d496746a5396196aec3010001 \\x2057c0e75a071dcd20f065e742741745818dba773267fb5e1f59c46a1a8f565880b79e4c04d7456cd5af85e9a8e70925b745868b2d35c7bcfd62898dcde8e309 1668714761000000 1669319561000000 1732391561000000 1826999561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-142 \\x6bd1423bea10c54f50b36cf1b927ceb0a9a42daec86cf39f7f6bdade9bd93a080dc4bdba925a90d01879c0bd4421b405fbe6a05ef46b5de669e02329c2df2bd0 1 0 \\x000000010000000000800003c25ab64727fd085701d5d1ef92ceb1ccd9c48000c675e95b37653fa724cfe798f9dbea1871400fc656bb2e5fb3141bcc1ec08237975cc8281badf707fa6d731f3ce0139bfe17d657c17d12968ad6d9b45313e9ae481e5d1ba0fd0fa6b5e097246f2966e31d5e9c0d459e863839cea56098c56af07c47bc29ba7b0083c08ad20d010001 \\xad55f569fd978f7609543827bdfceb4a1c887c27c345f6bec77ff2dfddf23e612e305716deb65ee6af660c1bd413e2b5a68c413db373b0aa393bcc7506c1d708 1687454261000000 1688059061000000 1751131061000000 1845739061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-143 \\x6dd17494163be16cf315af46965af8ef7348720036e4ef241e034919cb48d68dc46da46a1fcbf5e26a442fc88de2a4f40205322b1d532d85722544e1cee06419 1 0 \\x000000010000000000800003d18a3e7b1886722e9e11c38cb1fcd48c0b14a684faef41b56751b057bc585fa8a9eff59c2d8e314d7f6521dbdce6dcb7017c9b6e62a3feb7f9060416ef2881b3265d51043e9ba6df560298e43613599fa3a4994278263f8bbfa01cc43cfa258890538b09b9eaac6546563c22d760810c4004f2a1a7f21a26c1472814de91255f010001 \\x4d24090f27a9cb237194338119846211555d5ade6ebd91549df4943789f3a2fffe699b102faaf5d711a09144ebd5d66f2431cc2910532f11e90bb560f37d8f07 1678386761000000 1678991561000000 1742063561000000 1836671561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-144 \\x6e99979ee4f7b3c670d2cc67d0096bc677f26d9409b2ec3cd0a93a1272fa49e7ad3da5d7d24323119918ae535ae26ba19c39ed008f44c375374780eea9bf51f6 1 0 \\x0000000100000000008000039371ebdaff9c9c84b30b5dc8176789e503f5b6449dbcae7f3661fb39f41f1e6b554bd148245f23fa9a5922186fbf2b1b1a99fade03c5ef0dc793c9a625de575944898c608a20cbd2b482915eaecc524f99ca25a90eb061f5a674063719e631f1d16e2d60067407ec45cc100c2d98ee9e0c0f9c2e90b9e7fd1296db232c2dc1d3010001 \\x11615c93782a9e936badd9766cb4b3a7c3281f4fd124095d4088e3eb732e70914542568078f4ad01f10f957ae5aa601883a05992615d2dfa6297e514217a2603 1668110261000000 1668715061000000 1731787061000000 1826395061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-145 \\x7171fb0b68d339fa51147945ff8fc8981745cfe3810257172a5884e45217089d2ae76681fa85c3093b160fcb4d4f8283a35be30e55fa0d66f72c7fe7a6daba6a 1 0 \\x000000010000000000800003daa12d6edc705b4fb4b2c1431a569c1e9da4e09d3300bd3d3c3a7e12445af44cfbb7527edacf3be50743b6f172e8d62cdec31f72d7729bd2f11ec9d49b84f21e740b36a7abdfa9535174eaef08fd7d6d071eca6898aed3fb67af121bda633882021140675a210dacfd2ad67bdf2bc93b4853f0265ac28443af6282083d77553f010001 \\x4156a63da181405fcb9f920499727612751bdd18ccf4e97c371d443d7612d4ed9e87b0ecb3455f7afb071cde476e9d8a009acebc2026d3ef4ebc4b91b826e406 1685036261000000 1685641061000000 1748713061000000 1843321061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-146 \\x719941ff09a8154de91d7ed0d22b0c12a69fd902ff6c2945f661fd882dae515018aa115dc9aba3c5ba43c0b459e7fb3ba9a1ec42ec20ff73811fb99e8a365acb 1 0 \\x000000010000000000800003b3345ab0ced9700a704c4bc15f3c045b99a15208f340f24428dde4592baab8ee5661ac4c1e91096dc34ed7539b7c28e74ef60561b61aaff594f464ca502e1b955d8fc5ca607372f5b58d91f3d134771217360cb368da38695abc50340fc24514fbbb852b8126437116ef21a0e948a01faae00d6f4aa2a2fbe4ade3ee0bfccfc7010001 \\x7e256ba53a4218f520ce4cb67717c1694fd5afa002732586e0afd8c870d915d5f8e7721f191dcf873f1033e8cb9598676c88b48cba915e85626ecc6511814d07 1667505761000000 1668110561000000 1731182561000000 1825790561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-147 \\x72395d17c7c3c88ae7b04be05e01665d29894b437a178789a0df4e4305aa8ade31a2ff0bc53c5c4155b25ac03f137cfa756baa6fbf02fd1ca668d2dce91ee78d 1 0 \\x000000010000000000800003ac18380bbc778b6cfaba3bed05e5dffdec961a93c8fcc811f110921faa79fceccc87355fe4898e1908982474c078f0f3222456dfca5f5cff15f715cc93f798ab224ba64c69da453bba8b0f0eb438e076f8157bfecbf513186e08a1c2f5ab1411f175fbceb2770cdedcb844e7641310ab36b0bce7775ad4724ae707fe6c882999010001 \\x06d5754332806aebd42bafa785b3b74820369d7cf9c5b28f0b12d35672d1dbd2c2808103eb4b743f572eaa0b058fb05391a8a9bdb09aa68738e110deb0553a09 1661460761000000 1662065561000000 1725137561000000 1819745561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-148 \\x75d9eb683e3401b4bd33b6e9c7be211426d5f19518a2d43aed0f92578909f50b4cd64014e551d9d8310718219a58f0494cde69339814bc8d10b652ace400cd03 1 0 \\x000000010000000000800003d1ca1fcbd2ec74fd5a0ce2ecfdc8bdedefd8d2c4a46c156ccc75ba69a7de06fff768b0a384bd63a1e4eeab547259e36cde12af608d8364816588d8d988d71fab0f67247abb3cc24435b8e3b72e0b1e6688ae3d2ed031ed4ace21d85a39c56d27a3f2f684d24ebd973eead8d891c8167a8aa6b243727d5ad245af078902e16e11010001 \\x6c52619d2675505e36bfd69f92f02847e7aa8b7e186a762c3da161dcb4102dcba70b1c67cc74d877cb7a358bfb7a4d40872224b05b47cf03d02e17d0146af105 1663274261000000 1663879061000000 1726951061000000 1821559061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-149 \\x7ab1001b7a8eb066876476182b2c8d28c2c3174a4c2e4dc5483fab64fc102697a665d4f9e090bfc647f0dcc3808f4e6c48b7db1fb6eeb2cc89f7b0d3c2bb7940 1 0 \\x000000010000000000800003a67e25ad75cf6175a2d22bc67154aa7ec53a38a09387e66090b4b93f6b14cbd5e1ee68344e3c245f89d525175a4b206fb16b366d036c3510d5df9430b0208887e5cc6691f57b8ebcecc93e31a5401fa38f8e8e5cfaebd5eca50763c9ed8fb263722fb8821d47f99895f67b410a556d1010b83896e49311fc825e7c0825613199010001 \\xb1b7269a1946d0c99bc3ffa3b027bba9a45952bd675b7759b49cbdb25cd95683c99db72b836f915dd0690c5f8f087c837bb12e86fb73508a8a78805e9f7b9600 1677177761000000 1677782561000000 1740854561000000 1835462561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-150 \\x7b2121ec5da4a020e1da7d4175d153aad9398e7968cd5f177d5a86d6f1c69febb0be02c935809888aca568ae13654decd785526249693ff71ffc0f6378128c0e 1 0 \\x000000010000000000800003e8a60894abd6180c8be790278762176460be4d81a80985b13cdfdef1898ce8e74ad297b9638c4a5a143bc17869cc510fbba5cfa543faf50965ee8a251eb382a017086e86ffb9d83fcbc438309254dd978965b3039568e5ec8c51ff64b27406d3055c052baa0a9ae1011956becf9d5971032cc7d3e7e3801f5f2fe187c74ac4e9010001 \\x402a7b0c11a840652ea356e4290ebd07c24306c3b9df445a95c8eef1c74053eefc22ed7bd603c0a8ea3024a36b16f3c1abbe4b64ca31538fb480fc2a96d6bd05 1676573261000000 1677178061000000 1740250061000000 1834858061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-151 \\x7b15c46fc0af1b784238bc71d7055e5edbde4882aa6a293c9e6f29eb6b26e6f6e0e5bb6523ac79148144444fa7b725293d31ee0c39f1a6f5b9c0a29ae7f6b51a 1 0 \\x000000010000000000800003b6884e8733d93e5d1777a6cc2ec74c0fcdc375596d620f16bde62afd9e6f51077477db3c4ebd84c86b9b4a0cb91230e0f79a567e9c45a35370288d1e6933fc13d12c0c77f20a90803c6745948c8ca050a90b294158e7d34b76597f64388fffdaec749f1f042952bd7cfad4b3781549dff0408fd44ab04a86c73e81ff77fdcec3010001 \\xc669c90d23cf92518c3aa0d40e1bc5a63777032cdf8d92d544113bc996a3a4d64b2c14e67dde595477009d9bac3196ace06c05ca806bade506a640a246ed2d0a 1663274261000000 1663879061000000 1726951061000000 1821559061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-152 \\x7bbd138663928cf3684489f98bfbde9707239238e3d3ce1bb2f29076db05aa96d346cd0c3516742e7a5bed21b5ed74ec8e8a391310a09277213124e2e55772c4 1 0 \\x000000010000000000800003aed17c241abf4b690891a682d72e1835b4a4d1dcb0c6e5cfae87d2290890392b6becba3f9eabd61b8f3f9131616d4f29455ac31ffa21d4b7867d4b521483ff591a19baeea1da2b4884aeddf51fb701b116191c2e8329e33bbfdd22b70957e359f92bdc937d1ad946e8e15ed17acc438c1443dd460785e85260823d3b4f555cfd010001 \\xed71603efa27e875ff96faf7b074bad7c4f88547b67e5eb89d4f0a008d6e4e313e89144c81361a86b8d25c5b15c75e1f1739ba9b14cf788b4260d835059d1c0b 1664483261000000 1665088061000000 1728160061000000 1822768061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-153 \\x8039ea40fca0abe4b6a9e4c20bd49689fea4742a30838020ef33e73456bb445172019e69682de00a2336be979ea831373d4c564d5805f14022bc93503ce22412 1 0 \\x000000010000000000800003b123a895eb7d993a6ff1d3f546717fff724d82d83a379153a8fd860064e701d43907c4779679ee2eb04ce2efa85fad6f713e7d465ed0e0fd88cfb2ba3063f2984ae6a4cc6b26b912e2ca9d0ae21a61a3e08cff9d33ccb593761539e75fb0eb190c65faddece443e06faa3a564ff37b95815a5ad0061837330a93a84c3c3f3de9010001 \\x8311c55d3a491d437fbfb9e389260b1edecc275407b7723da0dd008e55da427f293ea9c357359314925ac15d72cc2d6561307add22af03dbe50b834789605103 1675364261000000 1675969061000000 1739041061000000 1833649061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-154 \\x83656d7fce1e00609358c1fb8ee565a4dd833d1f9119aaf9ed4649de57a9e46f4f34d53c8493ffbc19285d8aff55c810aa138186c340522cbe72f8c1c225d27e 1 0 \\x000000010000000000800003e126640cd69c03fa5ee8d42cf418d9afa12a3c2ba003f4bd78488cb6359760a6fdf9dc06e4fee4c6a58c684bcad18c06401f332e464b0f0b68e3580de8f180902880fa053d0564a2f6d0463888872102b6a185a8d540e6a3eb0c2142364a9d1c40f1bd90e8d0d5563515b12930203f393b73d96a1b44de13f28fc32a70e1469f010001 \\x09a58aac2cffa0247e38f08d8504c10eb6a618da0f09c1820e49833bbb86d0fa0b446e4c014f4b78d10fd903ee25accfe8c2d284d7ced8939b17deee076dc902 1680804761000000 1681409561000000 1744481561000000 1839089561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-155 \\x84bd9a1d7189008e101ffa9ed5d4c89f3dd0bf0209f7702ec8fd36ae118bad2c9e103818700be8ede242826ddeabe0d0273725fb8d73bd980e482bbcffb6cd0c 1 0 \\x000000010000000000800003d3674ca8a675690cfe2f7e659ef203194c0c3b01ac52871455cf1265d6ae691992add2f9625087e778dda35bdd7356720170d26a5ff8667d81c23a1df1f683e251343528f0fb80bbc720f196b3956fa9e573d4497425fd0ea717391bc481e42337271f119f454c877e490ffba935ec9ef7dcbf410383fee431a9de8c0ea3df3d010001 \\x3b2781a6a1a626fb498d684af9b03fcd023e8acc2a2c780135dba86a0b1ea738f5ed6185db6d18f226bec97eefc561621d0106aa995e2a008f4972b04443c60b 1682618261000000 1683223061000000 1746295061000000 1840903061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-156 \\x857d4b0708ec86b7c313982ec2f51af622d655a4318bcd2a533ac0a6ea37d9145070e586451ef231bc6215caba30bf8caa2c8d7005a15652cdbb1172a0f87f7b 1 0 \\x000000010000000000800003be55ac36630e8e8650d149ba00c9b75f8fc0df5e60627945c1ca55214afe1027c54295d046dc4a7acc3bee429e0769c879a650516c7466fe8e1b41542b077a25abf8e79982b8741bb2c4ffe2759f8c2f05586cb73841902e709f8403a50e36c855b9c160103df0f7d1a3fbb25763886ed316589cb25b5ca6f914414e7abb52f1010001 \\xcdaffde005afae8b1d8a14a8486e82506b20cffdaf288cdde4ffad8c4a387fa529ba4d2df7defea95f7b753019ebb3d0191fa039fb20b9898fe583d23e3ded04 1690476761000000 1691081561000000 1754153561000000 1848761561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-157 \\x874171d7c1c0c4d0e3d4cbe3a79e19eea238018eb395d6506b87f6dabd15f4b88f92d263e74014756ca8670ebf1167e144185facf453796175be9a0ddd47786b 1 0 \\x000000010000000000800003e1a3bc7d27f9c0cc2dccca51cf3373e599294fb3e526ee5022e84cc78ab7af309fd9a384c60179fa52a4dde70dac454b1aca5cb48b59253e87f50b65d3353fe282eb13240d05af2beef2c2127a2811158e842cc687b16211d0a4beea54e36bb0432a32bdf99723a2205e5ba32583f8b54185bf88c918c111d359e8364d4721e9010001 \\x3f4f90723dc2518a21da5a9732c7add4dfb0500a2294c0887794d9f4c2eb16ceaf80dae4137b0be9a1eacd2f194e32b71ec7daa1885e2a8dc2f3ecb701cf990c 1683222761000000 1683827561000000 1746899561000000 1841507561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-158 \\x8961ba3ef929016598aa27b3bad8116d5683b2e679b73a10f6dbbf52a45f914c2add270f63689b05855797c4743102f823a57c9ff6b974861883d049f37860e0 1 0 \\x000000010000000000800003c49a7787eda860e4f621407476226c71b43237b8a5fcb7ac0f59b6d52f7400856e10f489d57ee8b17cf8579e19cdb1eb7b8f2e2517272e463b55a04fdfd824fef6ffdc067493af1fe8ee552879fcd85588d014a3e6db755836754af13727c841495e9ae5bf711d687116222da540f382db9dacb20b5aaa28432608180853005d010001 \\xa818a9ee755014b3b6174148aae0b491f22dceafdf8dac513596f78182725450fc9e29731c953130cd2b88dc475eed53abe3b98e5629cb124a66724acb1d9e0e 1666296761000000 1666901561000000 1729973561000000 1824581561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-159 \\x8905fd396fb072f9ceaa9ce790915feb0d01560c2407d010f7ed980f692e2b0b9312688d1ea1dd52a8283ecdcdbdb2b02f9f6615f06944551024ff72963ac243 1 0 \\x000000010000000000800003ceea18fdabcb48815188e9695005d697db499c56cd4b1cbf44610ab0acdf880ae41273de0ffaf1763f3c95905dff51f0bbf91ec4f40d42068cafd4bdff87084eee94bcc1bf46caa6dae716af7f949efa335855246014b714a28272e6b2f6b5472784537854b9f6a26c9a16f6f4e7c7cc9ab93b529eee9b29321ab8791a492f0f010001 \\xe7e688ef5ff7eb3282f85cac5f98e3279612f8ac1a382f32964d47c2606a7318ccf363166ec172c1e6a351aff52d7c6c69ba8a9c6cec3e13eeff1e9bb3169300 1675364261000000 1675969061000000 1739041061000000 1833649061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-160 \\x896d6c0d57aaff5f7289fdca2dca9983e7a5acf58f4f2804aef9f302b70ebe9926cd4902096c2798462131383c173c31f3bcabf779644524d2cbeeb0ed10d27c 1 0 \\x000000010000000000800003d78b32423ec7a92683ef5dff8a745b9a63f6eda193c554b3574caaf91a36879edc2a5f617627dd1bccca66c8689ae24b323548733832bb100f998a0f950fda2e6e359f5a6508022a2b66e594d5c456c687d3acbabb4ad722ef5c77d6bfeccac3aa9572a9429f165c43e50f08845aa4cd4319d211449fd1943f0fffb456321973010001 \\x3f0acf773135e24eca81660890b20edb73fbf347d50d15d678d8ed966dce9e02fb0e065e6c0360e27b46f276fbf13dbd8dd5da69d3e47f7bdb75488526556901 1662669761000000 1663274561000000 1726346561000000 1820954561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-161 \\x8a6951364431cc64e0e2363c306f517de14e04794637654bf78accceec6c24d102bbe532c03df7ab585c39bf5a94cbaeb48683428e7a1422a491f52e03cd746e 1 0 \\x000000010000000000800003b14b95e4a30aba31cca5d880823798c6cfd0b241a4377db4351372b7f4da0fa35c440a11eed6b91de5214d8bb25db3328af02a249d797ef6f56c22f9dc4fbf5aba6c67d9bda9d2ab3570fa890496f6b38c683bbd925a3eebd42cb64864f69643c797be246b0f871128ce6f86df9410166e81f79c83f80ad0d4d6ffa93aa5616b010001 \\x1af6926d0ec9008fc75dd9b63c46667d6cdc8bed9c9ff942e985d2e8836481d5a5c1cbd6c7e3e9d100384984c9f15e5ea0c4bfacfad3ac2019e664e9ae1a9700 1666901261000000 1667506061000000 1730578061000000 1825186061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-162 \\x8f5d30df3c5b6ed84c75845a1974b81fcb52c600e66092da5ebb96edaf964aaac62fa030392c84f7fa20ce6a562451b227f2160f1c78b21bc1baed2133adcf2e 1 0 \\x000000010000000000800003ac5e5b18a791375e51e4a116668dea9d746c195f188013a34799f80d0b1b62af5961bded47a07d0f40eaa2fea1c1e6bf2550013431b849c97eae04fb562ceb2bda8cc7167ec052e6cbf956056e6cacb26a45e04622a70b9e5f3488407858f349ec0d0da04bf4854978b59c8d70f28e2c11f7748b155373730e4b31cc0dce4491010001 \\xb8421c60326605eada32f5102eed9d0acc816502a1111a8a78f792bedc92ffd09881d66ba617dfa23864264a07d476293fa334da78d0b8c6fca6d0e06cf62209 1688663261000000 1689268061000000 1752340061000000 1846948061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-163 \\x93f5381b17e674a9688f882856f661bf84b815a616d73605bc381c827774c8559afb965ca22ff1c953463551905897a2c1e8f5ccd4845ea23b28a21a26e8e4c4 1 0 \\x000000010000000000800003b819aa667705d9135971481f8fc71f693c2937624afe40d5818156f0d09a501da044404426bf479c41c62005c551afce7bab6e87cce59633d455500dd39acfa0f5e77d96e643b644567dfd71493de851e4c9f306991017b75c32578281d1dc7eb274237ca19130cc3153cfcfe43155bd927393f051c2ee890b048f59931ff7f7010001 \\x137d0e968825da309698148f89ead14e3274c5f2f9993e10774d52bc69472f48641d0569a019537b7bd7ae97ab82f54b2e28f5c579236bc3d1c870a6c0ccb309 1675968761000000 1676573561000000 1739645561000000 1834253561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-164 \\x936558470510e6113a048bc3addbffaf2a376410e15cd4996fcfd0f367c65dec60ab0a6a50cac3ac0784d870fcd0914df89bc6ea2f61351412a5653eaafbac42 1 0 \\x000000010000000000800003bde367d7db5086997a2301fffe54d15e4a2fb59a14d58087a7f16b038ea6a58d696110cd70762aa95fde68c04d9082eb6b524532963a1ea4749dce6ef99e505e420866d079922b36d160f032142b50be5e8efdd69be3730139f2b0072ea9495cd7b756622e276d0a621b348c60782ec5a75d4374675a11fa87fd4f1d998ae6c3010001 \\x79f746622cc491091cc376619027b190eab941cffc74b1e81ee6d285e1ab32ca04c409530b76497c18f36c0ef851379faa7daef708ddedb1642245418d0f4805 1681409261000000 1682014061000000 1745086061000000 1839694061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-165 \\x9389e00cdc08b8c617ceb458460520c142600809f26570e602bc6871364c2a5b88d8949ad226ddcfdea345112f9335cb41a2724aeb48006eb2258732778379fc 1 0 \\x000000010000000000800003ad3a9194981ce0f80b73a9be1a8458b50f0a39ad00abfbcf211cc7788a308e61e13fb32ae40f6360ec71cf7de160c229c977703f5d218ed78564112a0ef451507bafa0d14ec0242f379d9c74616c283bbe6ceac61f06bc9da20eafd92a930c6a76eb6a58a43deafcea97e7201c9f19b375455c3ec050b2bf2444dc7cfcbc01c7010001 \\x04ea3125c5f03fbe86209481a0d194f6e9eeca3331616fc3967e132ef55f24b7162d6ed44377f686551eb22cc9ad8f8bc76d74f2ab1b62a49a735baf8963a304 1672946261000000 1673551061000000 1736623061000000 1831231061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-166 \\x94c5d5d8718531d58df0f88c862ba471375a837d58c43b580482d1a875577abfb37e32524f79ab7e33bcb0d37521f11141d792e25fc0aa9f3e54c77d1521c514 1 0 \\x000000010000000000800003ab1461a607a2c6cd5a002f43d66809dadb95855a6a765384f409ed1c963184f4a6e890e21668649b726e4714365e99f1b1eba84289fd4e0556331a40bbda099a6e51d13f8dc3b77790c56be29f15510374945edef8a6ac54b01f2fde6bd41867cb93a112b506f39cf6694f30f7f40595513576b148db84018e6322ce7175de53010001 \\x1bd8bac6e1acde4be6d6dbfa395f6e439e369029ddbb3087ff4d29bf359562f93a3858912195333e5131cc6093a7f132e319bc8843d9a9a28d329cd1bd713907 1666901261000000 1667506061000000 1730578061000000 1825186061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-167 \\x9565901980ee23fa49da46f8cd82b74eae8715097827045f2a291337da69e4d90ee2ed823ddbf36d8ae6fe692650e91197a4ba950ef862da5694e403f7626a9c 1 0 \\x000000010000000000800003edaee21cf4c0601b9f5cec95c2d65dace601ee043dfb4d7dffb5f924160309e1db3afbd5290cdd9ebc917edecd112861a0ebf628cc03a17b9e693274cc3e2adbf503783ed820009ece99f5c96d088529eb8562f7ba35e867cc91b779e6b462179a21d9c4c50e88e8986f978b14611aa8fba9eef20cb64e350742a563c08c8e6d010001 \\xee6437254e94152832a062ad53301c544f9500143113ff35868ff40e2c0bf9a604deaf2763fe8aab3df2181d65b060ce02cdda2dba43d7704411ec2bcfec0901 1690476761000000 1691081561000000 1754153561000000 1848761561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-168 \\x98d11f3eb56be89a934d84d87d0a0eadb8abde5a5b441cd851e3f82b14c76a34acd7d62ebbe1ced4a47bb44a2df357b5daf40ae403478aff290482ad0fa61d09 1 0 \\x000000010000000000800003e1dfcc3f8c2fa152bbdccce0bc75daf45196a40070cebee03b5c537713d05dffe0ba35ec90b260242397045b6c24580937e4062cfb077efa07188c9093cb1b80057b926ccda0749e30d01ff1c43bac899f9f4394895769adcda285f1d900cce380f6bd11c74c5178defbfd7ed697eb8a4c4f24d4c94defb5ada4fce432b7ba5f010001 \\xa13e073a0911325838e71206f2641d53a4b7f185a4923e9875d010affce919c1c2a77719d469e1f724ca2676c5c15fb8e13cade710240fd0bfb241554efced0b 1680200261000000 1680805061000000 1743877061000000 1838485061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-169 \\x99114b92c5da27059d1575ef20e2646004c9f1d90fb35399ccd2a43ddf4e921581312dd8c190a003f16f6c93a74e68240730f7e854185f330f888a20f8ba5653 1 0 \\x000000010000000000800003b7d081d8aff4a2d6f8177557edde406522a93667b28b5709818e67f7401f6d78eff63b65d927d58a6ad304bd39aa87e75e3c35ced1dbcf4e88ffcac8a79169920e08fcb4ae2cdb717a864e1c7050184eca87340b73bc4619ce4514b242764c6d8d441166e3fed3777eb063a7d410a6118c2e73376adec73a1d4df3dc77c53b1d010001 \\xaae1204b33a52451e17e22259b30d1391760046e4beb2efeb09345f14ebec49af579fd0b770ef2ed4e601a134380fdd99986038503e63b9997f27a5b5951f708 1672946261000000 1673551061000000 1736623061000000 1831231061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-170 \\x9e6dcf4b64597faf7e318f8588b824db7a18132b2c39078073da6c59ee52e8d1a01ed16a6e64a472194d2342314007c455a6a50498055d67011ab5b3594dc320 1 0 \\x000000010000000000800003b5ecfc7cf8ea9bc52d5745ac678e11b84fe3270e3bd7b6a636c2a80c551c5e92e8a311728ca042c1c3fd21d256367e2f3f8108ff0048a5dd3aa66b0b3af63ab908eabb3030c49dd6aba54b53fed734d4b3edc2d13e3379690e2fa9ac87440bad61c6f1a49165fd3f1137d5cbb7c686a3a06624128e7f28a2c8be5237100fff67010001 \\x68569d7a6512c7ca85d96bd7651671446485f33a9bddb745b894df77c6af1b8b99f818607b01cf2cf4863930f258f41833aae7b909466a7c4be374c0ef9d3c07 1666901261000000 1667506061000000 1730578061000000 1825186061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-171 \\x9f15767224242e0ec08146387cab266d49c6a2a789c0767c4645a0ed59522d13b19c031d9ae1b25d879545c54eeadb0c2d8b939b03a1fd327e5f296a5bae1af3 1 0 \\x000000010000000000800003c66c0c9dc675450111df199ca6325ab0ddf503fbe071f2af4b5746653695e79e71797fabda1d5af5f2a245f5694731a14060370acb262ea01d7646482b375845251b84d5a8df39cb7e987ae0995edc46b64fffd53e1b79ada8b12791f183c5f4b29d44e28beee40bfef6d7d9d867510338716d6e6a9fc0199ece86e2fc0ddb2b010001 \\x96494a997ca98e67723fe3e398185a37921fe11d8e787e13310bdb54e33f4aeca2551bec289f746e03211c2e26756e0a998380ab8f2df762242c01803fcb4502 1673550761000000 1674155561000000 1737227561000000 1831835561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-172 \\xa49dfc1f2b2dab6fa821f1e99d5a4f6707520a3528d15fbb315b4bf4dc8e4b35c663464e83862ab6d23fc6c55cf2b534b3ccfe56e1cd1ea07c7dfca65a1498e2 1 0 \\x000000010000000000800003bfd7f803fb7ee85008a73bac0faa497028a69ec9d86d1713582b60922aaa013dd5abb65b8ed9040cc8aaef53cafabe31542e87ba1e8cb83d3eaf8f97cf7507ff603fc7ac299017d56c99ef2b1bdda8c29b300186b7ed005cf2e0260e9d32782135d70229386febd4f167fe28d911c31b6b14ba645a47534b631b03fbfb9b4187010001 \\xfba536a7d477b67ceba137af5935bdf393d4b73ad305739981a0594b49f0820e7c9c0d7a480b30511017005ef8f43219e55c95743c78975aa29c0667150f1705 1680200261000000 1680805061000000 1743877061000000 1838485061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-173 \\xa5c169121c04114714ec953166dc6c53ce0733b82696cb85f1d048cc31cf5200c4b25712607bdf16e5d252791822a0847fc597de880df690f34e12fef72204a8 1 0 \\x000000010000000000800003d81740477a22a48431b4d94b68722b07865d05587a0c06c027008f5b94188c5fd953fbed76ad1977e15fb9e6086ae5487bc3f0e7a1858654388ee1a7de1082d8a01465d57b6d4027bfd655781f9441e5ce1fc8186cfe8b1677747409a2eaf93e372fe450d8eb9d52f62e8e5cabe5575725e6d579d03392bb12ccecdb5b7fe8fd010001 \\x7a48881730e90c9f397b0232f51c67b9c9c4c96074d0a02f70bdfbc1b4d2688231e651c19369e8feac9d18ab74c7c143bebafa07e7b78ddc0372e0ed74d6e705 1668714761000000 1669319561000000 1732391561000000 1826999561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-174 \\xa86d7f7b2f7df305c5a81a349b64fce57a3e1807beff4a7bfc0c85db5aa4b5fb624cd5d443aff209136d91b5ee814efe6ed579b56937b2f3e170289a479c4771 1 0 \\x000000010000000000800003cd203b2c0bf01c31059e08af7f09bf577c70cad1f642cff1eae4ad1e60971e23f5cdb98904f156a26e2868350d2e17940dfad5332be1989525160d0c96e917f0f90297d80ad90064844d99dcee11304621c9ed85a7189df530ff627556c0754a75eada35af4ed4bd0516344899b6a96fc49b03b24b8cee30d93e626988d784af010001 \\xab21f32736ebf3e42eee11dcf39271c0ba60cccaa23badf4ed2773636af02f4edbac626e982ea19835232177c1cb6b87796ba32944efb3bb83351d2249de6e02 1669923761000000 1670528561000000 1733600561000000 1828208561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-175 \\xabe1ac8215995f832c49964ebf857578ce68df4a5ffeb38a6619ac90d45cbd6bb98e76553c349d45d4b8716c5159ff93b37ff18f51d89ea04d8c42d8a3434957 1 0 \\x0000000100000000008000039565f90cd7a9a442027c7205f146ab0d52557f64faab085ef9438e62d0866a225934493aa39665f9589c01f1ec4c0e30b07e2a9f3d806764131b5a59e268a5f4a23da6cda489a249c8a580fc40f47aacdd1b9a7aec700501664334ab43d5b61c9898df3df54ba4fd81ca89aa9ae2f3c60ced25aea11f750a1f088e3087d6f767010001 \\x0d4e6d64a95d1bf8a380048266419e8fa63fcbc437c90b7c02c06afe8eaa4ee66f3d4209c8a8bde65aeb80d617c447997454f49b02bfa5375530408ec1ffc40a 1661460761000000 1662065561000000 1725137561000000 1819745561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-176 \\xacc9b31939f88eac07267c50b31b70d5c88d5cfc10b601b499888fca4dd12e682a236fd227293609903238c082d10f87a00f8e63a3a15e0abef8ee9a91a8a27f 1 0 \\x000000010000000000800003beb18e6008db32c1d5ce000f442e83ca16a46477b792e1b975cef33d51812d3121e2952f508458898556e6b00adde8504cb0de484cb219af2f535fc801a6e706f4a33a9bc933a1ee0d916e3f43b1f5175010337470b236711b10eed5a09eb7fc315392c1596f9d68bae681f176eee5a3e2ffc8827a97714f384dc34b3c953d9b010001 \\x161916346334eb6eb07b2169cbe9eb880dd75ed1ee22de044f82771a0e284ac51ef542fc7634d86701f5a1d1e2f0d41fd7b6248f64dfb6038513a4e6b79ccc07 1677177761000000 1677782561000000 1740854561000000 1835462561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-177 \\xadf18abc02c9537514611acffba8c9d6e24ab42d6cbfb4fd0b9b06a57f6b0e8ba26a4b221ff2415daa23d6afcfd365967f0ea934a7a982af93c098639bd57adf 1 0 \\x000000010000000000800003b9279c6be82a6d55bec7259aaef9d5c3c1f5534a92ea0dc9f699fc1c742048b34fbdae77a1de21db68190f162a6b306b90c0eefaf3cbdada42275c0ff15dd52c65376af288c2c2b4fd708f0a18b5eed98c95e9967fb248c3e5ba62196892d9e47bc1572168c6dc9b9ce0934f4bd5e1302e4b92c0929816275c6258ee9be74585010001 \\x6bb14fd9ae8804966e255fd62c773570e32945b033a2d9865abfb07871463ee469047d1cdcc2407609062e34615bb9672696e13df8c9a64523fb116cba19d40b 1674759761000000 1675364561000000 1738436561000000 1833044561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-178 \\xad39e7a189d3053193715ef6ba2b4f52292725a71e75e464ae9e75fa59bc822991e7b2d5ad7c248359c46d055427232ca7c90f00039c98bf1e765ccb45260b0c 1 0 \\x00000001000000000080000397122e64c7cd69c01bc1848dc6970e9a10ac0cc743122bb5963c1f3d4c969921979b157af209bd50e561b058548c2983d12ac8b7d3bd1d61d617d29a196b33771ac0238f869af8fbc652cd3f21ea045cb7a24134369f0b3a38897e8212c47a658d2f5f73090bd8f2dfd69071cd58278bfbd91844b02d20d2b0bced9b048ad617010001 \\x91bbacd08b26e6129e421bf9e54544e0d6040abbad74cd980a20825d16af5b3cec8949cfd3759438e038756a629379fbe8de3f6fa672b16ae750209bb406fd0e 1677782261000000 1678387061000000 1741459061000000 1836067061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-179 \\xaf059f298bfe80367466c6058a7672f96ec739469247bae89f19d489ede0c26f5c45cda9ee8c432a15ce40bbc931fbf7f94d0a59432358ca3d793d1e5670351a 1 0 \\x000000010000000000800003999ff4a277c668dbac2174cefbcfbd6a544902a0f85762cfb6156b134800336cd3482a1190ca07327345fa49925221d6be64bd4a40c312271bf38e56ce077bcd29af828e055708cf55af2454ebdbbf0c35735cf365e618a0f2c80c6b991cb890e722033314ca2ef0aba5f13ead0067fc6fb2cc69cb63fa8494ef99da6ab29aed010001 \\x4cd0b6079db860cbe8ed7b62b97f270c729f7f640af8aadf53c082b68009d03bf1eb37a8f0c4294011096a467bcd074b03de56bd299cf14f31e1e70e0d8b8b04 1669319261000000 1669924061000000 1732996061000000 1827604061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-180 \\xb111c416827d2f63d057ddbaaaa771aedd7f342ce533864b1ca5dd2e1cd414f9b3ac6d8e4b740fb436e2d8670173a9c4b075b9d8724e1f0db6eb743eed1d047b 1 0 \\x000000010000000000800003ceba20b5c78f8dc1fead81785cb2e7d50633e08ebecc522b4ce543b73d865e2549b8488dc3457670132f86b5bde1437cca28e0c8e5734ca0b4be7ced376ed8888d637130166b2eb599de9a9020338a32efd87e1a982e55a10d700f1d5c0d22b7e2b4f7df331fd3d27280fb1c075c3b55188e8559d0613a37088bbdb2af450797010001 \\xf901a30a7387e8b7632be0b64936347b5716c4b0caa6a0132ce8156f8613b5d31e03ec1f1953f6c64f27a5ec34e290825f78fd1236ed3ee8848de36227784f0f 1682618261000000 1683223061000000 1746295061000000 1840903061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-181 \\xb3d1054372909156e84f3733438091b85d9d9c1b0400b53f5794eb5c9d004344aa454a00866554a8c7edd7c7f2bbea21c3e8548f58ae0f1e9abb2af804b1c294 1 0 \\x000000010000000000800003acf0b79a09b22c66dd2886a0cbf046e89726c599960b579579c389bcb6d697524d9f4cb93a174f2883287c1c0b8faadf61ae2ee2489a3322de44b3f96953984d784c3978a7ced9960a595f43c7456a85346ff23990cfd0b4f2815eb1b48bf1791173252f3f468224378d0c3f34f1c38787bd0f7bf8676643e1efdc8f23c61873010001 \\x446d9c1ff0d7fe26b6f6aa0ddb15f7d6fb2c61e55745eb73750b627bbda51bcc7844ad0ed20a37b055285f60c50fc368bff5b774e33ad75c6d041edb52eaab00 1660856261000000 1661461061000000 1724533061000000 1819141061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-182 \\xb409554656791ac15e657f8066e125a7c093e6b34a2bfaaac7b53328d6966fd2dd0a0440e7c48708d12bafb9c79126b63d36ea4a54d3a712a7e84fb6983e4d64 1 0 \\x000000010000000000800003bc08e6c228c690dfb0208a14c030a57840f8620a3abfc4c70e88a12c7e0199fbdf10314f181980b24a45d3d18e432613cf1368d00fa2d1bdf951449b849a8ee5f43c497da069ecc55bb86c2d866ce16b4aff119607a87b16f1db5e57a2e8208a82f2c61fecc3b0fcb7ccf62fe02bf8264216aff65bea95d2338f3bb2ccb2bd39010001 \\x85e736325053c00a35b50bacb76ba1aa1ad46d358ef107980eea256b4a07a92584cbda973dae8e96486fc3122adc64ae70b226b328d2d87cff2b87ff55386e02 1672946261000000 1673551061000000 1736623061000000 1831231061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-183 \\xb6e1ba6f2698b9079cf84bfad0cc84c0f61362f6e706ebc325d2ff93433ce7e500969d2bc4c8905fd929c47525c297ae12576f58342c502cbeceaaa23bddef70 1 0 \\x000000010000000000800003d9927a28b796d6418643eb28fe24d8f546b380166fee4a9f5553473fe8e59d128d9f1106aaa05ba284a94f0afc83568d6e79ecfe37877ecbc07b5509a35f26bcb06fa8ae1bfd9a027803622f73718d4f860a6dcb908df4316827de3898b7706db97122b949295fbe614592b32b3704d7870409c6a674e0b4ee5ad1d0a3a2701d010001 \\xbff1b74efad52dd9acba00f28ee6e2f35ef2fde7d2d46ba4306996f4d9be91f02592f70f547eaa028440e23a429a1c019d43a2f6e69b3223ac8b91b3d1c38d0a 1672341761000000 1672946561000000 1736018561000000 1830626561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-184 \\xb6fda74785dd882ba83fc22db6f04cc668a938c36a124467a6d74126552ccbad9d46a6c4a0b2b2ec4fd102a07b744a1ab9891ae53dfcabc28faa77513adcd773 1 0 \\x000000010000000000800003c609f7c61ed9a5f74d8a3b83d3e7d86c693f9736502588339017dfe3744e2434283bbb9c8ffb40af87dcb712fc059fffc0dad1d4fa1b50caa676df395e5914a3d01450016f6d7bbaf01eaefe4fb4527c440ef483ebaebaf457ecdef5284485bd0968ae74075fdb209e38d540e39eb0d9e385004b1af0dd5eb524398e454c304b010001 \\xb140c90b44a5808ce7998a6ffee976dff15c41c250e7ff7f203987caa00673c0ed778228956be473078a72097d04c94d0e373a82160d957e9f5bc32c67f49907 1691685761000000 1692290561000000 1755362561000000 1849970561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-185 \\xb72d613d29fbb9a6e64e7989d769cadf11374da7c9edeefd66c3dcc563769f5cf5de175d6a482c34270e3da022c2139246fd5bf1c1b0ba9ca665dc6ad74cefb3 1 0 \\x000000010000000000800003e1ee1752d96be4cabadd11d9e2598129c35b4bda5b0477e2f2c9d56b0f113d92516987ab22e7b2b8a50d13f5fb156a77ba92edc8498cbcbce43409749b0ca42273249e6262bb158b696edf5d72d89b4d97df526820f415008c64fb339f0d82e448d21a5a053e6d2297318e185d282b469f837f14572877d304764a1088e374cd010001 \\xaca95c18814623d37a98d71a4a796bafcea850412fb7712433a5a854cc47129872e28332854996b5fddb069bafc0e9739b93eb5fe736806763aee62d8aad2907 1689267761000000 1689872561000000 1752944561000000 1847552561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-186 \\xb7b5cae0daf3085d7b38bd42f805e5fa64b1883d002bf1eff98828141f6bb52427938330b17969f28e1508759490bcdfd252391885f5294a18677fe2357a53be 1 0 \\x000000010000000000800003ecf324d9ddd465df5b3a97364d27688ccf8cd8435a7639a4abec6b0e486b0fb076b9f9adf7841faa4c26a4166206c26e29996888512b08afc456badad3be40eb0ec8feba352c532fc4c7ee949e25a32b9f921e8e155e6f1592466dd019787a5d899252049f46761d5278de834b1bd2757e3d0cba32bb4df55a6d6b397659fbeb010001 \\xde77f077025befd6a2d6eb92a050480e4ba34d9988c0c4d92216d1ee2657408266aff4456ec9d87862c8f378e8ea8934532af8bcab2ccc816184fbfc2c7e3c0c 1688058761000000 1688663561000000 1751735561000000 1846343561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-187 \\xb7a9a34550dbf37627ef1b1919ff0b0347a2dad3f42d4f1129b5ab983483e1c81ed7714dcd782bb1d3c28d16a067fa823fa8b0ea9555fa6b1613dcc8c8feca9e 1 0 \\x000000010000000000800003b1c427c295dfb7308749160173c30bce95d721603d78deb1373c1bcbf4559f707110336e79b109236ad077529a9c85e4289407cd28911f236b574c032566ac444e9d9e3f71f63cacb242f0cae57fbc543f5192259299c54dae2b56031f2dee67a3447bae5c8db03139c2999e3bd8e7f7fb57a5741da3dc25edc63629e033235f010001 \\xbaa5c2d21f1255a35f0b5cbff22e007cd25290176da32a94500226040e174f5de5cb9a048d1ea481d7279af71d8105315bd5682e048792f10f2312bc28361a09 1663878761000000 1664483561000000 1727555561000000 1822163561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-188 \\xb94598115dd30d991fd9a606aa03e2dae0c92cfd5460c272b7eb1be258adbb745178ec76cd06c16384a80c3f02ddbe690cdb201187e3c24a20fad2c1d552bc3b 1 0 \\x000000010000000000800003b92a6db0fcd91edcf504f948d56e3be7e67a1104fc57c975c8d9b3fae04c3a179007b06fd98aca933c3ae9635b090e206a81f960c49315d7c8e1601b17cab7ab32ed2506b751dc9a4d2ce8b58bf9dcdd3e85b5f9b82eeb3e1153d1d7f0c9ecdebba2d87249fd9fdf37e103de4d874d5b3ed71ea467f2d2247cd7fe3dab1376b3010001 \\xdfd3bb7492b03f654d4b7905b67a63e23d8605be8799e98cd05afe1dcb70c13cf83124dc4636deab0554f60557e5962611c72453ee1385f32d49d33e14eacd09 1691685761000000 1692290561000000 1755362561000000 1849970561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-189 \\xbaf5d11ebcf840ae84218cd913ba3782a82514b92594cd1a381b9ae012d505955487ced93adf201b5ecb748218d7fd8427c4bedd71d6f9189f95b5cbb7bd0043 1 0 \\x000000010000000000800003c28abe1f68afb25547c29605ac53cf82f9adccec1575654a9be8c79b7bef0703b696006c00bb6514e8eaccca9d67a7c31ac8975e0a3bcc63e72aabfa43e2cfea080c605c98bfa4a42250a1fbaa64c4ccbad642ded4d76f078d86850b674115da8e599aae342fc0aafaf23fc50b267c63ff0d29f198d5e11cd6d8366d538c5737010001 \\x5721228e39a2ac5dd88c416d28173c8f6f1fb141c48d53780af22b30e966caa45c6932bd04b435aa5814b7271c0be5e4e82348ef2d9dc7917b07b9329acf0207 1685036261000000 1685641061000000 1748713061000000 1843321061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-190 \\xbb7dd0e1c54f31e72b316a871d0b08b6181a0a680b788de21ad21907a22d515c69c70ade8d2324bf4e5f2374bcf1caaee7e4243746fc8f16b42f4ec6a5f37668 1 0 \\x000000010000000000800003def1c3bb4500af350a9c68ea98505132eb0a27f669c2f83da4b2ca9a70572350f6a407fd4662d475685140c0932967eaa2bd162aca56dc838f7ce5c7a6abce2c482542c0e3c711f61c8e3ddde9122c748ead9efe142498f4e51814f7c386dc188b705aaaad7d912d2104a517194b5af304e9243c709334d27b6c13dbb94c1461010001 \\xbf1ef4851d8d310b4b0084a5f22bbde58d0c4872f160cf60633b67ca0e7b037b737e4176932425b57ab9316693567f29074c5ba409fe6092ad0ff9beac4f620e 1660251761000000 1660856561000000 1723928561000000 1818536561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-191 \\xbe85bb887c4eb046a10e0a6f1096717244a55826123d09ca65cc926b3c0c79ed727af06dd4ea57448ff540fe05c2687c8aa55131cae413b0836c579ce9f83e99 1 0 \\x000000010000000000800003c831f9b8b9d84f832740ec54937675cfa1cb6c8cfa898c0140020f11d491e5b935b6474edb033acb2038bc0cf2ab7ad135a450a3ec2bf762e2385533a5ab4bc491b47322ab8045db0ec363157209ad27b856b0930b56ee3177be9f8d8862f7a45b358c269588338de8acebc6fff1352722e5066366be1cf071808438046b1dc5010001 \\x4313e24550241187e4ff0c888ae802d2669f81e60bcbe4f8e6f2ba49997d13ef5661d235ed8f08cf521c53d15319d176f48a54fbb31f5bb70c96c7ba496e6a00 1672946261000000 1673551061000000 1736623061000000 1831231061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-192 \\xc0411922827485d38f067396d9238bd6172c0fa7dbb1f5eae9442359ce19af9930ec67ec50484cafc5d1841908400e54ee34d79908569f186ac8ea115b437ba4 1 0 \\x000000010000000000800003c59cd304635d56fcc0fcad156375b010022f3d8943a04236794e8100fada2ee52e79e2b4ffd6544332106435416ba283ff91fbdaa45682d277abaad8d65815daa226d83aa8d1f80895a9d52bb725259b8b10786cbbed62026712be222aea72ad9c89fb92ddfaa40aa97ec09db545f1fb9f33b75831052f8f09894051f6d54cef010001 \\xbec7baac0bee2a990b4880b4d5a69613685e1b05685223463121681c3a04bbd8410ce5d707127d2e2d4461316edefa2ac5f5879f7b57b0be8a6427f76dd8a807 1675968761000000 1676573561000000 1739645561000000 1834253561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-193 \\xc23528cb3ba8ecad9ffd8f9974868f37cbceba730ee21ccf4206da31cf4acc4eca8f2e2442e95b2dd09132aea091e5acc3925040de95631915f023967b922d64 1 0 \\x000000010000000000800003bce657328eabd2d44767a4498159bd00f246ac871d1a585a19342c53f284db6fe0bd13746065a06b615d18d4978de06d2386233ddb7aaf42bdbd36e58a31ac437d76f87784cd2a0a21cd16c57efa29e22b1437928eaef3b1363ceceea4d6840dcd3d6e0b8205066603cd4047f4024706345227b50de69a20a7d06c16f005f7f7010001 \\x2aedbb9603946a5a3b72f8d6fc9cab5ebe49ba81115400098e26249b9a431388e348cf93404f9bef365e24b6f109aedb39d385cab170e8a287952de527b39e01 1688058761000000 1688663561000000 1751735561000000 1846343561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-194 \\xc6692ef70a54db93b9023c07331dcd6ad450e1847f78af088ab11bd6b268e1d1ae25492e4a67ad437cbc3388a6a384e4496572ed145cd8105e252c67a3c4c2df 1 0 \\x000000010000000000800003b9dbfebf86997f8b9709095c3503d7cb5dd3a91cd21c054a2a81b3e877f47ca77823ade5531ba2731a97d39e76a0ccc248ea4b0ec1728012a85228d1fcc9488f536ec44ca7079ea7815e7cb73f72a028526203ffc9b4a7fd3beb5ec26559886dedeb0d44d29caa3dbbf07bdce3485f4001ca77efc0c3426515aac922efd70ce5010001 \\x98214b4b131a853104cc70a94a86de2e1e8d63b6abc5e1f3b49b76b12804563db8e276040638cd8f0c0798d37511b31dbbaa838511cdb86e09870ab11d5c9406 1665692261000000 1666297061000000 1729369061000000 1823977061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-195 \\xcbfdc5ac76b0aed052fe25c41270ad32025c1248522f00da7bdc59a9ebd400f6ac741d613c325d21ee94705bc1ad85c5613a342ef3dfc9f3b1111c5473a0dc28 1 0 \\x000000010000000000800003e05c1567b8f9156d948dc9bdf1d39dbf2ab49b296217f3f26e4e7647955bc6acea9454ce7061f9b1722a3e2b402d437c1b4a6e15a45333bcf8122089b7a3e29bcaac84d4864acabdf36aaca756045b75ee2c1a2259f639b6d43987db273112394e215c56812b70f8540d0c447117e1a62ebb429175988f0a98310bffa771498b010001 \\xba8f93606385f2f09a714bd59cb889c0953e6fa7d999fdf756db3f7563dc503e89e1dd34832eca4f23030c0c144cf795f01ea45e4d1bc92f092c15724d88fa0a 1660251761000000 1660856561000000 1723928561000000 1818536561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-196 \\xcc0105cda29bb6e8d75e482ba9557fb85a567ea713484e3b7285c2b45e29abdcaffb7cf1b658959564c2c32d98f660c0cb65dde38c46669a9db8feeb3b8aa0e1 1 0 \\x000000010000000000800003a0c804c2a033427307c15f384defcb64fcc1d3367c95c340d46ecce0713d3dbabb8fd154706088f36d707ba3d3b564d00ac86193ad3cf96f90aa6e029c69a8ad7b633e7681e443a82f2c3da22ead5de7352bab9da36c4500cac22526937efa7262f29129d98a8abe3bb23c765134eb83b02eea4c3804a34b5216c66d13fda4c9010001 \\x20708e8fffcf951e0aca355d70608eaa81169101c3ddd36d94ddae54ddd12ffcf342665760a97604ba6d90d0c752f6645d53338c8279d3a5cbc4c372996c940b 1665087761000000 1665692561000000 1728764561000000 1823372561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-197 \\xcd49a8d67142a12ab59bdf8cf2df3aa847dac1242138c2329e4e262aed00412b74e550e1c9d7068d4af2534021252f7eb039be98c9388888b6261adca26c914d 1 0 \\x000000010000000000800003c1145a5f4d8d227ad053290b59379b0cc8dce482bec446d98c127779adc7755d535276a8e9c49a6bfc43a83cebcb3b0681622641049c03a01d4e3ba18336ba067a36548e8191839e52df3bc78c11a86d58f7e4a51155a8ad3fec3c20f89bfe18174430d3956f3de2d1a2e28f8752738418be810a79c30a06faa41dcac2aac5d1010001 \\x203286fcee3722aa6251c574565a95891520179539344aa40fabefb35e8cb06e2d8edd9f7ec40398f27b794862ad2648264dd54ccac91d6a2d3379b26a12e303 1685036261000000 1685641061000000 1748713061000000 1843321061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-198 \\xcdb5b8c09b41618e6e696300d558302798ae2df76d1f6cc204729286cc759eb2336fa2a8b6db9a41d32dbc868dd721741184a6298e4b4f4657235cb333bb7c8d 1 0 \\x000000010000000000800003ce24cfe06d37f3506ad07137b103266daa3faf89775b76e94d141b98b1ee20894a0f6b999cdd643c56870d934da4163354f378fe52cce2354c390466c3200a03266ef4a45e8b4cd6051aab61deaab77f08f1797e1f1988c1b38b4145ca0690934f28fd285952148f2150997c1bdcf37db0548e6eb4b07d2f067baf8b7bd4cbf3010001 \\x6e4a3780645b39da7baef4c4d2f5a4d2ec555880a82a5ea15b9320022f55bbb3867e2212fc82e927dd40301b1070afabba9be86035c9f343800ba24c17d11e0e 1685036261000000 1685641061000000 1748713061000000 1843321061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-199 \\xd0214c7877ca818d165ddcefb22d03977bafc34dd2f866073e02f8343a51687eb4c26d89c88cdba40ddd32728fa0261878ef82d8c6bf744214e1900996e0f74b 1 0 \\x000000010000000000800003c20e884bea5d337f49f67102431c5bac7f19612ad4612b9ec1d1223c9bf5d7ecd61f8614f787469218e206eebb0b4966df14cce37c9608512de15b7e53153435574bfbd40c3f5a17c27b95b73cfbdae72872376ddd84ab1f78a5a0a667b43fb343c4fc93cefa60f1e9871c67595067e6c1a94380828e9a8c1dcb5de21439ed39010001 \\x8eb8dc9865e018e70e3d4425b3e5174e70ce08a5b806a1af750c3a4c5fcf6e2c1cf944094016f614e97815208bdf876e9c56b202c20a5583f1afcc5acfde3309 1685036261000000 1685641061000000 1748713061000000 1843321061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-200 \\xd03d74003366fbb8a048fdd6730af3abf1401550092d61c1c92072c4e7a3a3dfcf5ce14a8fb955ed408097eec20d4e5fdeb2f9abd57a2bc4b030fb0b492195f7 1 0 \\x000000010000000000800003c7b41320c6bbdc747486e7a5f99b54aa86d1d20fdbc084ecf43df2d542101e22cb6e47daea2b4be3ec689a70b2a3b44ac817381873142f40563d8e89f8cb1013f9e8f015c1b9ea467cc2e5d25eb6184970171c63cdb2e0fdf29a66ad6071b0056e32d73df82dca178ed91418433390044026303819ffcb12b29dde75231b9a09010001 \\xbbb93db0a98b82edf7d161caea744406c5d7661bcf6c05442997b413433d88128a721228afec9c728fcd2317eba4d6228b47b446445471b883d5fc69fd4d5f0a 1672341761000000 1672946561000000 1736018561000000 1830626561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-201 \\xd2ad6c8446654c74d2e2c46ea00a06bddfc254ead78f27eebf9f70bc4e4210e4c9057a2f519091827616ead8235b422a1602268b7af4a3450f92e2b735ccc176 1 0 \\x000000010000000000800003a5039e70b5f2b5d624f465491c77259f7244ed170680e137974bfcc57e19d02a38f00e84e0e3520825308eaa196d2dc3506ca3286da81be1b8383a7df06917d0b49b3e321788701c9345825b80dd883b86c663c578790eda21305f68b8098d5bc0d16d2b8e112f736df4ef690375de3f33ff662af638a1115dd32c93cf9e3669010001 \\xf5471344785c0fef411ae52705649c10a62737906751154c0cf94fc681781c97e76e68d76298a3c7520eda22b7b7b887f0361d8e6b0a4fcd93edbebaeb2a3f09 1689267761000000 1689872561000000 1752944561000000 1847552561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-202 \\xd8cd509393ee78f731b4382d984b36cfdd1458e7bd535cca6419e967c3578c09b783e9a1fbb88b0341e20085c112482b8fffcbb71d92279c6a26afac2b0eb15e 1 0 \\x000000010000000000800003aca2e997d363e6f9145df8cebaedcc338a507e3c701de346ad18b8a8f627ec780bf6b14f07534555ae067fbd304dbac8f28eb6dd072865b55513d3a49b8142b653a7232466a2f857e10cfd0b5b2a6f17e40ee5b81e42d30896838ed1183122382e4f4cd0af3bd49e7127b84e62b3fcdc8bf43e034b06a805e2d002861c035f2f010001 \\x5decb48f40a1c281b010589dc0ed4fc48590199e3459ea16bd66c1b7740593cb70121989e649e62433f39c3a04daeca927b23f3331be6ab1235ec0bf91ca2601 1684431761000000 1685036561000000 1748108561000000 1842716561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-203 \\xd8d9edfaeb6c8970979519f9e05d7da5578296e47e3b0a5b4f40781bd82527c2a01addb14dc6a1fbb567df2d7b164c8d93aa9e41567ad34bdddc4620d259ae8f 1 0 \\x000000010000000000800003a388169da476ebddbfb1c3493dd9fcb62576e8fe8993c7833694d55ca90fcef721ad43b139e2b7cedb7f3bcbd32c76c4915d0198c99a724d89e2542286668213bc490e06d109463ae4e810f1cc17aacbdf3f7816d12a22fe0aba7438ab334c90c59b31452de5e1593fa4bac35cad3a1bedca5d27a7e7c6db1c4f4f8ec04bd4f7010001 \\xe958fc08bb53414fb61ad220db0ceb2a003a35dd96296c91308d6763790bff36bc17ded09e7209afa9b85f9bb6c5f0f81fd815c0fd73c5ce6c02aeef6cace80e 1664483261000000 1665088061000000 1728160061000000 1822768061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-204 \\xd9598d574fc3205c06dfc5549450f79da1976dc02aaa4f76720763714264dc71f3e1d3e170afece8efc05ea9befa89f582c0e8e1b7ac1c4e7708fdc1eebd0a15 1 0 \\x000000010000000000800003e526c4206a8d83b795a3997e42b934f902665c312ff0aef4554e908122719585d414ade656df94944a330bcd710481251955d6814aa6e43a64e741dfb9cd22e177da10eb2439cb8e309bbbd657d0b0595a8d0ca5ec29a1eca24d6a6787fdba7d01bf8f0d1fd21d49371b82b61afe89e816de8b129f82862e9c7d03ea8814f25d010001 \\xca1c0a51f8c48a8614adc4340204d508649ce7a0dc180bb325b816e0c0ad51b740f9300716c1fdcd11f9c793bc91d3f28b3f1086ba64f9e4d9fe3271ea824201 1677177761000000 1677782561000000 1740854561000000 1835462561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-205 \\xdaf9658dc8b2755300c4f60c9f95961b475abf4295faeb0f99d4b5428660a4c9e877b62da650bbe9ba8c789a53afff13147ed119ba6058d46d531788d7797734 1 0 \\x000000010000000000800003e405d7afe1dc36dae4f3eade27bda6a3845d901f4c81a534e701071a49e8a3b395927e4dbecf7d2b30420b32fba6f8f209173b53ba7cec62a62c4ff9b34691dd2418e9d7fab9f6430e4694e784de27e0f7f041a18a9150da6b957a1d6e903b3ad3a3c858a76501dc90435091ad7812e2217dafaf63d5c6dc2086ff3c7dd6abcf010001 \\x88abd465884a7db133db653bdd5326e09c3cb84d43b774f330cfb5a78eda56676a8d063b98ce72b568bb95d38b42c721fd20908fcc168e48c265db9d7a68af09 1689267761000000 1689872561000000 1752944561000000 1847552561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-206 \\xdc15b9b9efb076d05103e3810afd4bb3a3d4ac13f299c7668e97ea8ee80ffbb7990ea7c78ec9f7472d1912ed688014c3d360a418ee73a1fb9e0999ff7569312e 1 0 \\x000000010000000000800003bef977c1e0b7e0cbf5208a49e40e03e27c6cc76c1ae086ac49bd3e5d25e76aac2740690ad6a1371994b3ed27481fdb59b30b7ad5f02307bd2915fcca2543fc6122547774d5eb925f8ba3a85cd0fd2652a5f7ff03fe85affecd19f41b053d8a233461c89b90406303fa6156548c65381ffa1a84f3e130ac6794b8f5c2763b25dd010001 \\x88b4e90601ec6cac570f4d92660cec8069fe2b2ded05dda15fda6e3ad0442878766381e790fb8ec9644ec216f2874eb23ba0b75aaee069d5631af3644ba4040a 1666901261000000 1667506061000000 1730578061000000 1825186061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-207 \\xdf857611b45d3aa7d0f1eee674badabda2d9b6abcad221a3aaef02107557d55183fdd6c412bdc22e66093da9ac1a23ab4e32074de76117e66e2deb6448581107 1 0 \\x000000010000000000800003b20568827376ff48f179958fd3f0103a622b30ac87b571d8a552a539960fe111833b8dc6a676adb0354ee5867c9169f8c05ec6968d17b7acabf525cb8ebdeb3133414733f64758798d3c1ea0a043c49a1d8670cd176ecc940e8fafa3c0f7437944b26f5c561d9e7227433cf484a955a8e09029dd0627984e456066d8962c5237010001 \\xf0006ae608eeee9427f16f9caf0dc0d4101cc425817b707ae4e434dd3097c8f0df1ff1cc7d57615f6934825f9b0afa2cf9b415c8ecbba09e8ac90a50f4d6410f 1670528261000000 1671133061000000 1734205061000000 1828813061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-208 \\xe16d5bd6c746e1a541d884197f59f5a8658a28baa32e98f32fb1c4bf467f903579810478bcad7a02037fa61851366f877b239e629d848bd1ff56aefabfb5256b 1 0 \\x000000010000000000800003c7d31625a67726f9f65433961bc967aba5e0586a482a93ed2828f8ad56f3662369c2631a16576f64957604c36a95a1a6419ba8b11dd03d37e93d4ca0626fbdb33185f28aae91f242ccdaaba787043c038aa3871fb9f105f1b68dbeb3117d4bcc0bbcbf20afddc61e9450dd30a437e6bffeb37806dcc8414b262221e9b429de8b010001 \\x774e9a8d822b3c9bd6937d90b5a7ea46f97d216e4d7fe82a6d3aee8ffcbd5c15fca736fe81e878bb4c232d01d6c2efa9aaa1795e36bc392bfd8c2068d552db09 1683222761000000 1683827561000000 1746899561000000 1841507561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-209 \\xe20db27939d2a3ff74cb224e2a866317cd63dbba989463e3070b8e2321feca3bcd6b67737b0237c5113209330b2fd9aad13d8814f4c7066f9f7a255c405e3d66 1 0 \\x000000010000000000800003bc94d00d36aab11b4b8ff9c13f9cb8ec07b55344f188688e234829b9caac88cc05205fd583759f9f5874f38a70246c33a11b6b231d63d37df64ae1001586b09946b082afb9e3caecab6eeb30fd32d8a322bbd77c5a4e4d670ff4bba7730e95410d6da8295f354690b3f2e83c5d35a26ca8344f13e13185f5c2b1b26a2aa6245f010001 \\xf82f64525ee66c643760b4b971c5c229dbc902044ed279fe1793c1993f82e37084375c39b23811772ecae5835a19c9c05da0fe17495337e080276ffe6ef3da07 1677782261000000 1678387061000000 1741459061000000 1836067061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-210 \\xe2913d7398a964bc56eac853b4dee06a4cf29abd7321fc87519a5e95c3a05891245b9f64771572bee28bb2e7ab5b06bc5d24c3da2ebe53eb5e73f93055060e18 1 0 \\x000000010000000000800003bf8d0122c74ae5cb7035667d23ffb5cafbcb016f7e1741f2261ea9179d757db2c89ab7790303f0794e27f63c9c706c17d51310f65fb769be210901dd167300e056b5b12497aa4986beca8547d8964679599002efe3c8cf8fab0e35fa828742ba10f49b9f83a5c896a23f2dbc2e2f92fffd095eeb589ad5f61ae8bbf34b516b77010001 \\x6cb87e0c978a47cb17789a1060e89d30f097f3aaba5e1a06689e5626c42f49ff049494a4f6c764fdfe18803486b3f23892b6dbeb6b8c67e5812a71bd62210608 1675968761000000 1676573561000000 1739645561000000 1834253561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-211 \\xe3b1ad914d2f2ffdf5196b5a3561428ced59ca622ecc427467451eee925a18fdae495b1579e0947183f304c4d0ec3e83835c1e41976b33329e0d5cb1b73d747a 1 0 \\x000000010000000000800003cda35fb5c6186249a09e087c34ad67d2468d8e936bccbbd3cd95ccb75c4de58e0ea1fb55eb649467bc1f22c888c868ec36a8f01b53f4e2c51891c4eca73181d9469f48d1d403f3ffd19933ada38979adaed15b2f4e54327ffd890021497ad28bea47aac27ac51a9d8627827d3550889fab665dcde8f5813f2605fb808cab3fb5010001 \\x81272d07a926c335fca5e8011de26aa150ace3994adfcaac7214d5ab1269c8f83f0bfbb59f06e0cfdc453db2b9386a71cb09788c186b7245bfc059631ab2f50e 1674155261000000 1674760061000000 1737832061000000 1832440061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-212 \\xeb355383778c0878c542b21187c1e093a6018a5b350518f326c4837cbc517c86c68a1254635603c7734f833e8fb8f3f2ab8304faef952d09940ffc9af755e3ab 1 0 \\x000000010000000000800003bc7f02b29720fbaeab0e0f74c4ca61cb2904b46e16d705406c99aed546f872d438c96df02741d0fc04347a05aed3bdea3f67807b8d1e2b175baef9590ac6b2b43d06f043a3d345902f34c4ebe7da8a923825315c15b6eadc749e71dcc996f83e5bc6acb7410f23b593617cad4327c4ca1f0f579dc176836ec2506b250f026d3f010001 \\x52de419fdbb3cf949e8b5ac0b74e3117a78ee2fe75bbafa13ce4c6b8fac08b818b6feaeff995260c7801c0e9206256022503f8e68494f6a125e82892fcd2b20f 1668110261000000 1668715061000000 1731787061000000 1826395061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-213 \\xecc961bdeab669bf5cb340c3223082075300bdc4ffe29bcb5d3e83fcbd216443a4d88725a9a5fbbe195891cfcf2a0cb0bc5aafdf82130017440a3e802f6039f0 1 0 \\x000000010000000000800003cc84bd00c2064c68fcc1f1520cb110eb10b601a7110e612d76114a6f31a9bd1fe5fb63631c907f6ce1a01676be152296054d922fcb88278f07f59c1785209d54c45aad5cf0575d29ec615e89eb68d74525ba6592f7c5def991d5a4832eec3b4be8857e4f98cfd9060dc1a10dd120072896dbd88b0609bcc478b58f540c050e51010001 \\xe2be4efa82fb17c77129d34bf924bff1e0d3815f9b728aeb2731280d236341889337e2bebb64a599d093f381618ec8e3756f232fb23ed38b8f5e651daaa72d0a 1687454261000000 1688059061000000 1751131061000000 1845739061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-214 \\xed7d964f5716688a8822a72466146d6a2f2f28ba2b7509f7dc9e0ec4ce94b1178f0231c116dc04726017f92a1362c124be5995c63760cb2386e204a6e78b2e6c 1 0 \\x000000010000000000800003dfb2303105c96bb02d76031bb49a7947243cd87060eaa761e904064a8f687f091c35b0edcdbd8a5633ff2a03a8bffeba70692dfe3cf99f79781c041214249a1051caa617f2389e911133ddda09263679f1f935ac91068cf0dd4c381f8bd7fba99b779402cc7202dba398d3dd596608e4872a3249d162d99aa7336d216ddc2dc3010001 \\xf24382664972e58a4b2fd2fd510fde4b7ecfbec5d941fd46cf6d2e8d014eb181c276303518600689fa0d6a01de0d3c313b54daae3195a22fa455c138d091fd0e 1676573261000000 1677178061000000 1740250061000000 1834858061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-215 \\xf0d125c9f7c4e24135919a40375be390bf7ca3130653ccac7c315167342d817f4f5a0f14520d32ee6237fa19816c9856d2515f91406c2f0099adb8f59b8e30ed 1 0 \\x000000010000000000800003d6537880ab5b11ff53ed9768f740757c9f02da969be344dfc9d3f8c5879ad04691c141bae4f79c8455d53f86ce659d63c550e539ab62d4d7b288bb563387afeb04c1d1bbf1c686085ecf6a3104c7158a682a1757c0e610f9a747fcf44bcd2f63ce90c9882c573d589e2d4d11add8f7b805ed970bd5c06022a73b60250fa6d877010001 \\xc9988b89c009f30f0c8b0a04644b35261b239ca917b27c74177251fa14d5543b0fa42a29ecebbb252725d855524a1590db715a87d7ab9fa9c35b9421afad4209 1691081261000000 1691686061000000 1754758061000000 1849366061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-216 \\xf3a5ed15109d714839534d6533df59da9d50bdd39963ee89d771c5ae03b548b64c8716cb4ef64d22e56c8b02eab96db8ee058144168f2e53ab133b51133c1b68 1 0 \\x000000010000000000800003c7edd24fe3f2c8c62f659acff5e3b0026c468062fd4b2f4389874076535de26ffbeb1a18d1df011abc8bafca8601689cf54fd311f60fa9b52edea0817a0308ea173de48500c784b4b825324164413f1a4e64c69bf1ffb29776a60060b25e0add97588d299d62cf6261f84116a3d8f59b5643859a3f9d2a49dcd141d17be8470b010001 \\xe34d8b02eff9a7d801b0951ac9072b534607510a6a100f70fc85557335ef7e86e0d912e8e22085126f78e8fc5f225fac69f141e8e6adb1c79d050e9279248202 1690476761000000 1691081561000000 1754153561000000 1848761561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-217 \\xf4b1d580acbf88b74ecb8662bc8e3dc5209339d8f6becf40fe5640b9d4ce9f0fae093fb0d15119e414d169c085aea0c3b68ad9b61799e3c85c54f23f3b2f5f7d 1 0 \\x000000010000000000800003d62865f5773222609fdd7f49b307ba39bdbfa15984cb5062f216b196ec5052e870dfcf70b1063144a2bc78049abcb444a85c666ae2e6c1cbfd5d22193ea6cb2fde9d32ee59b2ff83548341d515367955eac1dcbc186d2c144fe4e4790907d83dc597ba260452bd5b22838043d23fd10ae8846c19e13a73fb7f8bec7b54b4b2e3010001 \\xfd4428eb25cf2b0f6b85b4f87523a8d827efe2351d8ddd202d3aa92c1cbe376ba2fde43242b9fffc5a1ab17cb74d785c8207b9d9d161932779cfb62da037ee0a 1688663261000000 1689268061000000 1752340061000000 1846948061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-218 \\xf53108f0c203de2ef1fc2f43b5d07cfb139927e1abb63b69aa40362be83423625d246317ec27f3ac63b84d75c19880b9702713d5f605816b2ece848f8fd6cc03 1 0 \\x000000010000000000800003ab0c02f6ea3691ab2ebc78235ff838905770c0ef20f5db09d2a17a71b8c6799157e718c4ed32c23e8947672fdfdc162adbfd5131ebb3eb89c068b45e9ae401c27504625c1340d3986264034d8413025d08c6b9d5e33baa93df31a46d6d0fcc31716a953652b97a2a560f342ae9c20cf91c20b443eac55e9cabc5b0d0296006cb010001 \\xfdd9c53d627bed19b083fecdf016680d9f3ff34ec8e801c9d13ca566e8e2e3f8f91daa2ed54c6b9b2873f1144ce0a150b39e0bc02df0c306cb131297d4b3d60c 1671737261000000 1672342061000000 1735414061000000 1830022061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-219 \\xf55968c0cb17c65195a4bdb7d35bfbf460ba0db87e9a57e0cdcb441c93ba3569d439331937c3f5688503b42f4f2818d43f613090bb7143ea1dccfc32feafa919 1 0 \\x000000010000000000800003c130d83fafda2aaacad93754c2b7c030ce31df0f4daf76dcdddaab100f187177cea00a07bcb3fba2aa5471e24176e848b768e0315157a3a148e2a550313e8ce6f9a43403c10c7235bf577e3a1458d357af71bd45c23fc1d2e90b8f2f8fb68022f9751bece1964bcc601844d250deec81ff2fac9e2352e4a0ad0118d961b10527010001 \\xb75d90d7bdbca36a28e4270a5d25dc755d040a7e7751d55d15ddc23ee1423f24f90dba80dffa54d2ba6c22b56d37083f32933684ee2eec22d67e9c818138c909 1671737261000000 1672342061000000 1735414061000000 1830022061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-220 \\xf729b30faf7f4e17d8ad670fc9853024c20145fdcc9b0f1db57691eeac5740c36eaec9a90ca9635c9dbad8ca1c2fb7be4d9143da9eb282a5a8bccd8b9137577c 1 0 \\x000000010000000000800003f16a6ea91aab45b3d66e32df9784a02c3036bb996658575aeb0a3418b94b6747d40eb6798c23c5ec73b4b8473bfc91188c58cf4c45d5ac888612673000e6166466cff4a534004667b704da1b6cc8167dace47388256304e79f3df764164d344bab4ec847c60d00e1c0d693178181c2a9d8a3233746adcb7485e2fec1825884a9010001 \\xc72a14aeb8f35bf29f30ce2d6e4b79c744544fbdf300ceffb1caba949987976def219ec2f23c343ff54706d22481ff7056eec3876a81d4bf470e7b7b13756809 1685640761000000 1686245561000000 1749317561000000 1843925561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-221 \\x024a97ec0a652ac3d8fb754fbf4542a999bcd5af7ea6e69b602d4e2cc7853f5a7a17e425c0b652a612e1b900da7d397d8e2eda0c9d20733bb92c3c404cc18555 1 0 \\x000000010000000000800003c12597cff809efc2fd7e05c1bc1b5784f343de7fe32f2d42fafc903a51e330c173010187cf11a67dec947387213315055decf38e6f69c66c71ae20936f10b80aa3409426a5a219b130db5d07e18503bb0c28661a31d686d93552640ca4347f8100d4e0b1dc2affd469ee67f051ff67db46beb379a11e7213b5a8385ef09a6ac5010001 \\x5e5d2b2351fd7da63eb0df6ec3510105f86ea232bde2a147630b3c397b93ad2adc2fd058673e621307993b2cef19d35d302da83b6ad78ee0bba8da5c6db20807 1677782261000000 1678387061000000 1741459061000000 1836067061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-222 \\x043e25a37e06df67c2b3df519b1156c117ec95e6611e78fe2e55f5fe077425561298b87471cdee61462d44aaac3b76806563ef006ef36361952a7b57386bff7e 1 0 \\x000000010000000000800003e2c273507e23a1664105be617c90c063a54dc59143307c3a2e428b12b7d722f72dbadfc71f3075430d3a0e5fae37779c5cd519a9527476dff9c763e668e2aebaa8a604e157a538843dcca2fc89de5c19402adbd3d5cab2b5df69f8fc94186405fb41dc7e6da60e78126f20ad940fd94c39ad4580aafe7b132aca879b245a31e9010001 \\xdd42001dae16b185fc7f82162e71f9de4388a9df7c444392c2590b425ebb44459d83db0a60e2a7a5bfd2db995361a75a640d3be82f898126495560013fc21908 1689872261000000 1690477061000000 1753549061000000 1848157061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-223 \\x07de0faa8dde02433b7a7d49cdad2bfb8e4be74a119566d6b8f9f2eb34f70db9ac501014fc2ea33588dc9e2f4758b849afdde6e4a0f07dc4fda1c024e20d9b70 1 0 \\x000000010000000000800003cf8cd3e3926be7d0d4b9561ad313b24a77fe9ac8c4286af473373adbec7f040b17f9f1a84d79ff4a7caf724a90380f5086c0462e7b80613a704a1127293e657ac54b4a16878004c94d276e90f477a3b6325292284cc7e5ad2f9269fd159475e4f223825d826c3779f95c9b73c533ebbbc9b132861f496d509bcd7885cba9cf09010001 \\x8c161bd76ca6d1809a74d6bb1fdf5d6197a9ddfb40bc317bdaaaa0a761262f690b1670f49ded59c5ddd22aa24c0a861f63a66570ceb5af11b93a68891e210e01 1675364261000000 1675969061000000 1739041061000000 1833649061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-224 \\x082e4994d004d8cba6ccaed3ae91d3de884c9082f29017e11eb6e7404635d3264d8475087c7ee417c6a5a6e6cfe763d55831f6b8a91f1bd6fd081b00b7b60e76 1 0 \\x000000010000000000800003ed12ea337a2939996c84e05e3485147bf1e496c6d04dd2eb81829581f5c028dac115557e890cc956484ab0a54c18648b35e86d6c944572110778e0657ea8358240a1d75f41e0513bbd0290bc567a7dc5c94a1e995bee0078f37655153fe8ffed247f08577b3738d84d15a4e9d4610a70a3a82b9077356031f801e816cf09c023010001 \\xb709419f8d82b48ab71dcad50563d8d9c13bf4af6f9a11a59194159f39c7167fc546c64abe45e1cd57bedaba9f5d89ab370cd47bcda8317067795d796e8bd607 1675968761000000 1676573561000000 1739645561000000 1834253561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-225 \\x082a9bec2058fbb773cd63bac09e302b63771b2c2b5f5245b7992b696d876998ff16d9c8f1e02150c63dfcb191ae468250ca1c7d4056e755fc4b140a323100ea 1 0 \\x000000010000000000800003cb48256f3754ca4f601e7a099b01c212793b8037ace819d1df813a448630410e2649471eae6492e188df654f2943f40f8736df63efab4735557e39c6bc82214f3f32b971756ae2ac7cc44acd1410822e6c76234b71746c8f3e569b8d29747be5c20c4f8ca9af4a83d9e53d652ef4772b4692e3bb5dc790ea0303ca70158dbe07010001 \\x34c6287d9c0882ae6faf612ec542a27ac963749eac635fbf7add560ccf33f5478b66d1b01d27e04e2db2e67f838505b66486eb035d65d5afe8c0f65123b64106 1674759761000000 1675364561000000 1738436561000000 1833044561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-226 \\x0ac68d28ad72e8aecb172f90aff9f6ae46266c75a1bf72a9cd2288bfd826992f1b69add5f3332ff817bdf82177267ffaeb2b06a274c61bd2a832d9460827f03d 1 0 \\x000000010000000000800003a2160b23c996a699cf1dbd4cc7bbe0ceec64c34b782f287c90260ebcc0b75c37210b19b53917257c0e264005277f3ad405c8c51369be58c6288fd730a103447e1cb484968e257674ea76f83c146b3e11428921fbc2453b601f1030caaf149b90d71c97d09b6270c5c428f51f9f7f9f3179ee5fe44d4b5df72e1283ceb6397fb3010001 \\x154746aaa856d5c812789d968c78af30ad8d49dcba2a9f767065608d560bec5a2fa0003ab6e597a356208f8910ace5d00d229c7b03ea84259a1149d0378d0001 1671132761000000 1671737561000000 1734809561000000 1829417561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-227 \\x0b9a10c47878a19525d5d1732542357cafba08946a659196898ed1e96c9bb215e389621637649f150872158cfe52afb1a0c47f0f6d2b05f087e3c780595cd5e5 1 0 \\x000000010000000000800003caa7a5ea28010bc9f5578004c83c61b1a635d13b0541340883f81faafec0e6e53ea7bbdc5f34bd1252bba3b7e19b4f52bfce802a13268318f741f7e4fb58f716af7d359bab9cc2f3c2953999ccc0432a9f5b22bc6615cae153a0eb149970db8c15298463597ea680518fba17330f51fe523950522bcf95967b753ecfb8eac489010001 \\x704ce7288a541f7d7e2925ed99ff9bc83af44d6ce4c0ff5de7cf42923cbe2fc6a5406645fe3d834002e9a309e3b80c1a8d23a70ab612d01bb129a1e247cae90f 1671132761000000 1671737561000000 1734809561000000 1829417561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-228 \\x0c72105da703f1b1a6f4eb8630cdda728d61ffcf2db31ace1f86a94ee3f494e18407638978a685cda13d36a414614a87ab1dc4550a5370261bbc942ab58eb157 1 0 \\x000000010000000000800003dd001a47902798c0383892f47d76a4ffd06bb7f6af11824435a8831002cf5bf0c34f8f6619f7cad7c940fcaedc363ed0b9de33a3fd54db2d49ff82f42ed34d13ac7f5f5904e77bbc1a53ddc0e789a8ba58513563186f452b957739ecac8301d7f9ad104546f872b8e528b7754b15b0e46ba95567fdaf74c49ad24e6dfe9ec2b1010001 \\x074d4e4159c4b6e0b4c741992a6deda59836cddb70d14e7e72d6da8a4b0a4285d0cc4fc9220f9068c4c0aeab7367c6f27e2eef176e6f40cb6da4d41d2e73f800 1684431761000000 1685036561000000 1748108561000000 1842716561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-229 \\x0eda61369ef60c48877ab195c4d91e73b9a220a2d676ff09ef66069f43810f722a2b2b77e737ea649550718d10dec805d74485b41026fb4e59c2649f211a27c6 1 0 \\x000000010000000000800003cb705acb3c8d439c705e6b17e85bc906f94ebf420af2e979bf45f1221ed118554a7b272d88d805713cffa08a77e0c9acd48b0188a942d78bdc5ac3752d0b1c0dd98ef19cc5a9b85d7a8588e8f93b4d7465de8a3f71eb0b158a5a78eedbf44380b1bec9dbe773c93b4be47f246bdbba14d8d1f951be8c9a7b426b2893889ebee3010001 \\x9ef8866fc1b05701e66c77405d3e8ee84651164f1c71d50caaa6835eb18abd73f51f8a43f7e66c8b3d4cf2a63d12dbed3dc9e62c32ea6306acb23ec3e0e26001 1686245261000000 1686850061000000 1749922061000000 1844530061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-230 \\x0fc6cc047b8c8234770ce16e7570d663998e80d2e46f9f376bc6e9f25db55efbcad85f9f4fd6144100e8a5dfd9dcdab23c8c6f4cfc1368ca32acc336fc7ee41a 1 0 \\x000000010000000000800003d0a3f664671f78a738fe288096a32279d21b0aaf55d2612d4ca4e407228c48a92919e4004b5d09ce32b5ceca597319028a8506054c78e9a724f61b43ee4f2da643dca7b8ada77ed9ef3807d7d66296e42f176830e8ea799032de40b4079667ec128188c2be697b38d91ad7a3cc0f224bacb7eec312ad55a2d6950b4f3e808f11010001 \\x6e6e4c58fc7e2661b8f7f33e766357cf6b725391c0969137ecf805cb697d8b45829869371cb287953d83b6d6a255662cdfd07f43944ddeb205bab4789378bf0d 1669319261000000 1669924061000000 1732996061000000 1827604061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-231 \\x109e8e4e1584a90d9f5db375d7291813d070187a6272b9e5c5d97c6f35df5521dbdad48e1e40b8c65fe9500b07b3e1e50ab429a429b850f3989d9fb57d1e0c29 1 0 \\x000000010000000000800003ba2dc7ed74053d22e108e976c0bdd2c36eefe430b4098fbe9e927dddfb541b0da3003f407ef91aaffb726f0e48b4511343f778ba0e3340eb51ddf890a94a66177f2b003cf827af07d838fd158a81a32b3cd5617948b71bf254911790d619723ece0c36e803e7253b6692429449ed120b1624a2e292f5a254b5ec4bda559043f5010001 \\x138aa3ed9bc3707f01218634f8ac5ade7350225d037c8049486d52873d1ebc441b2d9dc5f24eacc70a235dc464eb906180a449b07cad992f0bcdb3e87ad4820a 1688663261000000 1689268061000000 1752340061000000 1846948061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-232 \\x134e041819d5637fc900030bcb542787e3c8cae581b9e26e78207327cd4ae08901d65025082d77351bc5afaec0d106d300e976d4e73de9038af946c66de7f7b0 1 0 \\x000000010000000000800003ca9c11b4ef0f8fefca25af19ed48599c450986712650ffd2e7eb2b382ab3058e22b74cd0b5c6194a2c0162eabbde1b04e0b3f95b7a0cce02da2927fdb4a5428fffab56bda93e576cc2fdbe0403cf54b428ebd1892d49703b5365af1b62630a6ecbf366c00fcb0d18eb3933474fe57f848a46b29d2b503136785dee7c58f1f833010001 \\xb51c73f8f9994427fc5c5498560228fe06c6dc9e401a7e8b8b2dd1c70b90aabe0f11bee1bbc6a414151be5615cd15c97c176c66931413c7e4eb60ebccf24ef0c 1661460761000000 1662065561000000 1725137561000000 1819745561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-233 \\x1706250bfb2ff95441438b325e2012e5b4f63306cbe69d60f23f23a1c48893e8cb83d5767bed9ed1e81441e983b6ba1c4f5475255b70e2369b7681776d22f8e5 1 0 \\x000000010000000000800003c22d96beb20a11b5a9aeed50e1d08a91ebc78620db223e803b1c18367e36fcf7d12236f3b4a26d4084017f3fde99cf0e603a730ed8d0885c1febf7aad7d8bcbc3840b0af447391c3c28eb757c2fdee1520226c4dfb0d25e3efb0f83121bd5cf637b336561a3fda845cf6e7f33e5e7a2e9d87e4b5097689b0f4558a584145f9dd010001 \\x2e685944c621cf49c8ffe8b5d9d925037ab88589e7bd8d00cbeac35f5b217931888bde34cec235847af37e8cabc8419d2c4a749cb99aa130f279163e3478110b 1677782261000000 1678387061000000 1741459061000000 1836067061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-234 \\x18067231c3fdbf4cf4f11b208db5b8dd47fdaca7983b6a516c5476ff7601513953b792e5272dd994ffa260bb3411f921f8f7b3904fb4cb354248da79317ac7f6 1 0 \\x000000010000000000800003c2a7aa3a1563dd340712f1533eac2246f52a09c057264f567b14ed7b6da9b5a3b203bf564d060d1bf16a0f1c6226a381597f0696f64c503e1943e21a09adf7086d13bfb6235606876a4973335b6a9b4ef343acde1f596595ee7e0b558f05f829be1b16474e8e59e48d8ebc4af43ec1f6e3480a1ed0bdae16576248e65a6e6a35010001 \\x8d606bf3ac92c8987b76acd020c8bd0e0b83cb2225d7f8154bce2e9a9a142bb682948cd53364ad33659514d3ec8ae5edcce67f7e00472d3c24df201af648630e 1669923761000000 1670528561000000 1733600561000000 1828208561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-235 \\x1d0e0508be9dda05bf9fa19df67c0a13eb3b162d452796816eb35b8f24e825d930ffa8b380f7a613a8252de7dd01e8ba0c88cece8fdcb23c2590f5b91be48015 1 0 \\x000000010000000000800003bfcee2647ba7b0e88eec1e0d62835635e49fee56ad526e04d3690bc801dbc05fc8ce205d1d6e21ccccd9ba53e873594673d716bebb3dc3e0406ec6dddc010af984db7b530a362ea8c42c4ddfa8c394226e0aca1abec52b60888438fb5a87b755e463e93e3867eefacd432c0f731faaa4e671c48f27227c5bdf087ac313a5b7c1010001 \\x97ead8fd93b5d49157cd849572f6f07941d6ee8b7132de5b9235a39d0af6a3794bedc9f96174f85f52930b79f24ef7be621dcbb31c50e9b3acda56b0d6c46205 1669319261000000 1669924061000000 1732996061000000 1827604061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-236 \\x1d121c71d515ee83867b6742be4c96995f12e178c268991021b1c1e01aea969463f590fd67d7479b2def55f344ac3c8d7f5d4f5bb434e5b99c64175e4ff5f41d 1 0 \\x000000010000000000800003f164833453b1ba525f7b98420e5e73ff8c849c117195a7e298c87f1229d763c2f255ff952cd16bb9b401234fcef1cbf601fe6be250dc801292020f01483b55ee21d3a25e969a4abe0506e8ab8a1ff55c6acbee929dc222d22639d475431ba5f609d72d7bfd4d74a98539ceccc9953ac46ff5591f5f4e6456ca6683d6673bdbf1010001 \\x64890f639b17c9b50fa61007100ea2acbf3387b4217d068415c822604052aae4ddb2e3c182710b113ad7de6ffb174466610a7805eb494e1ff92b56a6f64c4c00 1674759761000000 1675364561000000 1738436561000000 1833044561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-237 \\x21aa75fae3eab421da12b49765ab3f6d0394b8a41f005b578a2020300a5a1977f440792eed29221622d0cdc95bbfdb4d94bc096d56710f10bc2e73d78b4ff334 1 0 \\x000000010000000000800003a93c51e17e99d4eb07d9649c567ba1bf9b589ec4c9f1aeb4ddf3ae5cd3c5df8b4a5e621005c844440990bc48e693150995632d7c0c7e3e358294b10ddbdc261ce3b677569351b05b5bfe3de4660e92fa7a36d23538036ddaf954352260581c0561deb54fd01ccd057d9765ba11121a479e259867b3726609140757c1cee7b037010001 \\x02c789e819d4f3183fe16ff44cb98bd8930a6f366287a328ec9cb7418b814aa5880bd789d19a4d11d33d2ad90ed87318e8faa5b0d74e34fc39682a50a9fc5c03 1679595761000000 1680200561000000 1743272561000000 1837880561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-238 \\x226a8723e8bad65021ce43aea0566e84e0a4e3e09b71212a92e7727322c131d56aba20db4db317f11a0fa0dd387dd7f24f875cecda29800ef9e20fa34ca6a69b 1 0 \\x000000010000000000800003ee77764cdc0e16eb2a5f15fda0ff7364e9a76d89446485832a5ac12f309227b0a75fc08bbdb72c631714881b5d4213a96a3733046c83ce9102c0dff1e4981887dba99b19835306c27cf2c78aa8673f8192101626fc953d8950b1d8a7cee17df453d2952c74ace67801587b4a7e7729d7f44bae5004adf404ab84f9b0d001ae89010001 \\x5bc889d953a794cf94599915c279fec40def8f53e37b5e6be73e4f4122ee6248625e4e6d2dd4bd786db1bf79de96b64450630a1f68a458d4485ee62db57d1100 1672946261000000 1673551061000000 1736623061000000 1831231061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-239 \\x25de9c2c1c460c93bdfc3303a5d7a89e5c07340803c66fb1abd77b101cc9fdc3dea5a1eb722f1b5fa3d382d4b74ce6a8d7585c690cd9f991fa426da15dd4842e 1 0 \\x000000010000000000800003cc2a0fc98f7e4505ff9afc9f0df6fd39e94ff01bdb9ec64a0f81bd2fe4f9a6c13a28a16f4a172614725b29053e31ee9826c22a51a8e21ff03e68650ad38df6445b520c7d5f71c6377167d2733db871427e1a73d0d86f41f69df43725bcd2a4ca0a7b5a604db3a025411735537470dbcbfc8ae6b08ebf1b0ad64493d83e80e45d010001 \\xb499d97ca816fbb65d32f7afbf6a1386e87283dc57e424c988fc638009b110980dee7d4865e88904b2ceb20496b9e06ce685a9c2ab636693eb210f378980a900 1675968761000000 1676573561000000 1739645561000000 1834253561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-240 \\x2a169cfe0eeb30987cfe01d0466a5150d4a851d083f09708be4c002ee92e9f9313f9d4c962ffc3f19ef04018e261cfec62c029086212f04826b80145b540e81f 1 0 \\x0000000100000000008000039e389aaaa5774c0b1bfbe8b6b53f88eb9a8155afcd98454cffd07161a3ab5a1a8a1fb08d9d7ad10b973223de6fd5a47f33aa7fdd74d09531ed0a7c3f3e94bbfbc636317900aa43ed1b16ed6fbeb5fe6dd9a99b9e636de48758f0ab98d2d06241ebd40b4b6210eadc98900f3883e0361d6a1eb42acaef3667c9ab39bf8392de75010001 \\x022aeb7b913bc6851b8d047f4ab408efde20e82b57c8365d5dec3b1de5790d891078fccbc1d8cb557676c7183275a8128ce44aa30e6d8a34d2aaa32c4a920c08 1660251761000000 1660856561000000 1723928561000000 1818536561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-241 \\x2c164f1acfc00b876b0af4635bed8ab64a6e572e161f4500ee6e1245dd6e1292719f4434d4aa25dc1825da334d2b094ac74774b53886bbbdc40c7ca6b081a572 1 0 \\x000000010000000000800003ae85d7be8fdf8e3931c27f14a9e89b1820d0bc9927e72c807b89c58a99a719ae1d30f3c833b8ff8bd72d6036fcf3164e203af5b91a030701904ed82e0b5c5817eda9eb36570511c1169e0d6af84e7be88b47cfce8294812843b97a610916f6b52f8f1dfe29bad05fd89a1aa313a996ae7049c30493a7e95b462f33082a5049a1010001 \\x737c60e2c5992151c1a198ac3eeb219f85233bb8b6af55f4c57e8a431394d967ba637ec68511640c3405cf628889c77df4f479168d497cbcb0f90ee4b5229c01 1665087761000000 1665692561000000 1728764561000000 1823372561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-242 \\x2d069f05a5d5bd3417d2f3631a88be6789dc1e253bb6182577b52e1d96cc1857c5ae0693778112b6b3951c06256ede79538fce5e33f79379721396a12562dba4 1 0 \\x000000010000000000800003b513580110f90f5d0278ecb27855e1bd6bef3d8c9c7ac79a1af184803bfcc4f5ab96ccc1006eff3c9a83f8fd4e711ab9083909cf13acd7246b10598c0629bf7b9037b9ca6e94404b9c7a352a575df241fbf7a0beac5d6264155b75927656c8467a88d719b05f1725c7df2ea81441548d65be899b1e8b87817402a7ccce2b7b25010001 \\x684e98bf6802ebfc229fa2b10be348acb2f31ea13c165357250fc19e60454fa3dcf2505a0bd406dd1337d622672b10d59ca5fcb034105726a2108006cb73ff06 1673550761000000 1674155561000000 1737227561000000 1831835561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-243 \\x303681c2aa4331fbf974d81ff4d54718a82ec348d0181581a509a43fbb864a95d92fb12c56c4f609fc3369e80cadbf79e161237943d1e6b40f1a19a52e6c0965 1 0 \\x000000010000000000800003c88ad21b9cac37e54d5b403c0e99a86f3c617cbef1414e71451fdf47fb68a6dce0a8e424104ea5c85b5977479c84fc07f6a3c7614b1fab97bd4ea7d22911196d1d6871d2f4643aca098664dda3e6004f82f3b3d92b04a73760760c500e6fb46b2cd2c6b8772fbf8b0a0801b0406ed03e9ad32c3e50c4710f0f38df9b2ad8cc87010001 \\x50cbf1d7f0737ac3e34e315390ac3d4c913c4438a5a8a444d2284f4bf7a035f5fd1e593c922cb8e9e2952456e0c37f2e7b9b8700ff91d659a670991460fdf809 1666296761000000 1666901561000000 1729973561000000 1824581561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-244 \\x332a8d9139e4399b28e2f57d6ffc57f474c5d0ad59a7096bf1c3cd09c36eeffc51215e73e9f7e1ef5c6d669c059f9cfa86a0e3a1e32c36d9ea64c270d8f8aade 1 0 \\x000000010000000000800003d25071faaae181b489cf523adcfe964d9bd53f7cb1d89f5cc16e88e24b53a4160e34c2164f0d686bd9de83eb19a94ff4e619005559cf8f75a1cd539f540ebc5c65cf34e8fda8d6ab63e5a2d3a2698dc0598a25d1bf9a687f15ec3f44191258a7bfe5968ad05f07f1a59a0baeac8fad69464bb87c07c4516273e53f6560e26803010001 \\x016134d201f98bd9f1b83168f9c193845738d7a6367839fc9b140e452d530528caeeb0f3cbf815ecf9673341045e32bbf06ddd591f25cd1f150d6fd94235eb0d 1683827261000000 1684432061000000 1747504061000000 1842112061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-245 \\x34da2be1be8da2e59d6cd1e55a8931357d68247abb25ceff3e22f477383240d8b538f10311495e893825d5d5655271147f37528fb5afb035e24876b6256adfc1 1 0 \\x000000010000000000800003b41fff1a658d552a7cde02dd28ede25d5295bf9de796229aa4c4f2c28cba6e8351676d78234bd59691d283ddb025560b93f5765c396ac6adbff6e2806f7d8809f948b36822952838f6836439f2cacf5c14aba7e8505594284ccd83c3a7bf311f6711640c1e33a71f71fa058bb893827f48c7f7a81061677a20ef736c80af8083010001 \\x373e3c9bdad8dccf4935ba8c2255f0c60764ac2fd1acd17f05ba90c2fa0484bc6cde9163ed38a31f28ae0c555ff81a94f4eacfd7f83d1be2029c4a485a16950c 1663878761000000 1664483561000000 1727555561000000 1822163561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-246 \\x36f27620a2430556f46ff1f0fb01127d1b87e373c38cf2079a601a07e8e592af800cc2352f57aded9624d3fea39c7dd21aa41507c465c2937d2f5ec7da249a63 1 0 \\x000000010000000000800003f7cf4164ce8c2423dc6da8ca135274b831bad912bb8e48c1a5de4d7bfc3aac957425c5e73beb479ddb5ecb3c1922dc0d55aafa873b347c56d73c93f537b471c5905a46442992a850982f70ec584fac545fc6e92a1940da18a57712ea055d85ed2ce8c452df9f33cd55e95db35a970c1a696635058ef677cf3426b4abd749ad09010001 \\x1d5f334ba120eae13a9d956b21d763c2e29aef21ec2691c1797f27334131301a6dc7fabf46def2d99b957e602933dae17bdc7f63b7609e0b685cf9cdc3a81e03 1691685761000000 1692290561000000 1755362561000000 1849970561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-247 \\x3746d56db8dc9f4a1e759bcd8611f484795da9a1c82bcaa3b2ca2ffed447d3e02bf410db664d1160ee150bc1bcc62bdd469107391c5f5107d519d9f2db39c8cb 1 0 \\x000000010000000000800003dc3b6ac6c0cf379add6666bb585d511dc9cf6e3e597e63a35ba8049da2386e263fe7204ea409358761e0d2b3af78eb850a7bab45334482704d6bd80a2e724a6c435dbfc6cbb29933b44bc820ff57404fbdccf49f9ba5da26466dd8c72047528e3d139a038f0a01a43932ddf6cec8eed60b137d4410c83f814ea328fa378ccbcd010001 \\xd3dc704857d69f0d005d0dcdc16d3d8db4dac309945fa905afdb34a2256a34f3296db1fc60039ee2764d1dcbf43feb4ba0beca9b855de0ddff787e6717369c0f 1676573261000000 1677178061000000 1740250061000000 1834858061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-248 \\x379622f19898775d81ced7469c8698855ae286b98c95c9fffa8117d7f4f595d7c5f4b6ce5906db18f0156f02b4933b90158f24ef87cd672da7e77cda6495fa73 1 0 \\x000000010000000000800003be7c98b3bd3f2a9952a9ab5546f05b9967f1f95458ac5dd1594d5af20a862f57388935a563a42335b559e0b3eccc37a404454d35dca1425f9b9e43ae58f152f6387c726729562792ac48fa8d2d65114a06d1a1c0157f560b215b29d54ee3bc5dbefeff4acc730d99b298f9b24eb2ef31075389faebd1b13fb1a033c685a9ae2d010001 \\xea9271dd39bf65676d79eb8dd73501fe6736da1f898626f8153ded8c38ecbe810282556f2149354de887c93f44bf02a8851ba48a9627e0634d8a7ac63ea9f605 1663878761000000 1664483561000000 1727555561000000 1822163561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-249 \\x3b4e462aa8c3d469c29a3fcf86c8feb6a806d6ac10560e72dbb146a90d0a87ae03b384ba89dfa8b0e2b3416478487529e98589ee43cee5fa5ce7b2ac7d973ac0 1 0 \\x000000010000000000800003a37eb08b0b0678edb82e0c691de95607b1512d1697d3e8394885d129428d4e8d2e0f0452983f70532686739cab9fa67ba8fffea8c00165915b9dae2fae576e11aacb14832717db53314d2561b82191989feecbbc97551edd809f39d2be0aa2f49b1a101116e1274b084971bbd15b6f85b105c4ff676f167f28d41cf343d7b11b010001 \\x275828755df8c2116b9dd2c7ddf8c04e0284861a23ff223bf2e570be526be3227578819ee1448ffc9cff743f2ec0ba78cd7f6b9efcf1676ae797852d766b9d0a 1682013761000000 1682618561000000 1745690561000000 1840298561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-250 \\x3bda9d0eb703d3643344a87723b9331ee7a4a588c281ee7c57f1297eb74198b510a753b56fc4dc951c6f5b0d075015bb6efcb8d29892183feb202ea1920dcec7 1 0 \\x000000010000000000800003baf709d12d23d6ac15deb62f26f42a4d4082ce87c8367871294397ec13bdc3412b5836360f502c2060437b12db4b185ca7672e5f15ad32cfe8fd50686b7820c60aa7c3b86555737747d0c3b82c864277e87be85ec6ba2dfbae8aec6af9694e3a4d69acd7381207cd6867b4494588f0f10bd34dc9d1b082da34be6127a00266cb010001 \\xa8144d8c1be8c6fea35594e8d0ed70fe1f373970360bf644abfd7c4085281b9c949df955574f4ea6baa0001f6f93434c7dd0f48ee46ea7a55728deaf84d4f703 1660251761000000 1660856561000000 1723928561000000 1818536561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-251 \\x3e16238c04f4d989d511b5b56def25f4625847e0ed3121f482ae4e16d9b980341fa68c3bf1ab5d997d248be57f849c263c0868f759d7dfaba6a0860d55351af3 1 0 \\x000000010000000000800003be9c47f938b3c1899c275d9ecd1b17dd206ab4ae2e5503ee2794944ccd18769388cedb3ee454e7d5a39a349fd1c326225f9dc1a042a1253557facdaabda7bac144e9c79d87a8fb638d1f1a89277c05ae7e7bc62d1baf3bfd1d72ced80a7f11b45a1e87a30f25128d33002036fafb35ff86076cb18fe18a2f524d2a275b06c901010001 \\x0a2647755a1ca44b414d11772747ba274781e93d1c5095c4815832cd7b92d5367654759a12cbe50c63de98687532b6ab2752fc04f54802ccbdfd1c2e0841f20d 1665692261000000 1666297061000000 1729369061000000 1823977061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-252 \\x42928e45d0cc3dff0bf701541e716816328b8cc0dc633ba6eac74b859333bc591403877dad1336ac823e114c7b7d7deb0363f9d285a0873d088fd965868f14d1 1 0 \\x000000010000000000800003c023e463e3cd1716dab51c64992b543c7331bfc0ec075bdd3deb3075a614adac7016389eac5aacf15a6c678a9ecbb896fc21b14d38d9fd82247096a97330086e745cf24eb697017e1c4e665992bd57972973391738c624aefe099b3a8ca84b89087204832dc931679e80b8efcb5c949990412d712352c96b39dff531507bf2b5010001 \\x16fb4e9f6c9522dedef02a10510362e0161ea0611142f0aebef4e3b884e607832c16b8a48edafc0c8206e4d52c9e68e6f1afbb9bb40b89d56597ccd78ff9c106 1671737261000000 1672342061000000 1735414061000000 1830022061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-253 \\x44d623d5da41d86d44d8ee382b2054d6c385d5fa9c7ab5e23e941054a4dd48bbd92b37dc938f83e262df2240e39a548f91db128acbba633271bab9954a278055 1 0 \\x000000010000000000800003d69134365671112f3ac03fa2e7a0ef724afcef6bf5cbf32674b359249e4a17cb8cbc653e2bd941f27f33c54bcc2f44528797af5a29948a1b94ef6e04b8ff154445704786d36cbe443eef2d5156a7549e0e565a6acb4610b7a0983e20a3d1b1cdf0f4b3a3a56e93d494239617485b9e8be83570eb405c7a0faf39ccd23c494a25010001 \\xdbc17a3b2a81317407d4cf7977bc9247b5e6e8efc8f9232f3bafbe29ea6591009d28232b5e3e474412071683427c1b64e14cd60c6482222f5cabf04d96ec8604 1660251761000000 1660856561000000 1723928561000000 1818536561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-254 \\x445e1e6ec5cad70fabff2fe62be747759b811dc24bcad123b7fae87f7a00ce18eba7e6e9e19d166f98e117819683bf95be8ad0f5469c2e3382f1c13ca1dbf1cc 1 0 \\x000000010000000000800003b231dfa259905a23da8cdafa1fca5f4883ccb1ad02a282410b490d7499685def0bca7590cbfff6a5e467d33054a9eefa3af8350a429c72bdc334f05f6b5a23ac4d04b6ec3231b8b0f4faec6a947f2cc57fafff56ec568be3dd36c7616f805316b7e4651cd7f3de44b7d5377bddc9b4068dd78c10ac2273176f6e571b8c909191010001 \\x7f7b3256a27b2b89a087141b4af2cd47c0b8363fa6b8f510c1cad69540472ad1d90fb978768a2f021562fa1cfff3f5ee5ecafd8aed38a1280716c7f6f28bec0e 1688058761000000 1688663561000000 1751735561000000 1846343561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-255 \\x4766393384659c95bbcd7cbc870487d954197bd924ac66362e8d9c34d7b8e42a3c6e7dee86f63cd5e577fd5a18a7a5866c5e36dfa4b81b1fcdb1508d0fbf0db6 1 0 \\x000000010000000000800003ae09f3ceb7b9b5ca53d62896feec431e42bb2bc9333eb63d56619c28d6c81a2e2d5b08895657ecb5c66a8a0dbb31f5d1b74c1a0f1b13a78cda58d194e25b936b1f10c4551e5cbea8cc395aeb8ce31c5c036fda86313dfe5279cd358c675bdbe949f863f03124cb4172cc95df4cadc82ad10d2923bfd74d6f7442618ec6398251010001 \\x965b92cfcf0b7925e9ea0b937b6dbcdaf90a7292ca94279f3afa4c4efcfc105dddbf64602f7427f3f0e56e2bf88e8303bb0dcf2f94d9846589871c981d4d900e 1680200261000000 1680805061000000 1743877061000000 1838485061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-256 \\x4c0ee36c0006474b092147b5539d55da421ca7f1e1dbf144998543cf7476e005cacdd5c476f6dbb0fcb3a6ef6bc2761613573c38eacfa438cab782513a2fd2ed 1 0 \\x000000010000000000800003db893f0ca71128fbd79849703c5d77c2ebb509d1ee059f7d8285a782a44c757f90312115cbb205a7f67586802325f151248b17769e6f6a7999d1a3877e6d421c59fe78d05be5f2da31fda2ae6902e69010b1d950713c0318c9ebb731ca699e6583b3ab9857eb5727b8ffb20e3239aa2f5313916bc34d96583b46a6b62342eb93010001 \\xac21aa525ef0e662057cb355e74af42f4ece3d1d2da155fd8e0e3a1e699253d25ced69a0b38de6ff96a2be253238d62e132e716c49c7c056e959d64d4d16a701 1678386761000000 1678991561000000 1742063561000000 1836671561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-257 \\x4d06c7b03845e7fd1ae8909539fa759d0f1e7319e74521521a43ae2fb66853edcb01a3fe3014c0c65c62a31b7cd411edf2431fb55f0db8f5d3ea87ff4701eaa3 1 0 \\x000000010000000000800003ae56986ee18f67f27c4c61e445a15e4e64c3804f0d525d582f1ef36ad1a32826873003a8ba677eac2f5628209f4e819328465add184aaaedc7167dade361d5c04f4ca5fd3dd694bbe4974ee2f31d6b27517f5dffa7f29337e467dd56ed5a337fe33f8936cd3cf4f982289327e3d8e33d4e9abbfd0532b192bc55bdb936bb5835010001 \\x34645723d78af40b4039a7892d9ad5330f598a589e88157a5feb3e8d31b47897cc1b53e243cc408828142a79b0916273b81f85c40cd537e0de8675dc691e2c0c 1664483261000000 1665088061000000 1728160061000000 1822768061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-258 \\x4e2e324c96fbe5ac1439ef5c7c92e4a618ee19098ce7efe5553a6eb75656ca599ff213d42df368df74010e72c54307bdb318a0ec4d577c726d0abf8a0333ab47 1 0 \\x000000010000000000800003d68cb83e8c8a8680fc0b97e0e7936e9c7428c94b9f1ff2dd45eaf4bef58cc791f6da29d5249815231ad9d0cc67c8d3760245b96765eef21c8cb27659197019956770284ad040cbf10754f3be8cec402ddad9af6f1fc6801017431918af265a1b35e68eb4b3c21d2065f29782f318b89cefe873f0690e36119a546d33ff1c302d010001 \\x415240ef62f9026ee7ee59dc3d176783bec162ba4a657b6be4fad66ba60b222120251d77e478c7ac688a5c538ac8a0fc6b7b372b14a9393d3e66dc8df3ae6e05 1686849761000000 1687454561000000 1750526561000000 1845134561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-259 \\x4e3eaabb9ea49875f58052225f50d6685fb4bd5c544b8115f823ea0927b242b9776687c3aab4d7aa53c83f393af3d432ca10f1de86481f77108d6fd4695d8a13 1 0 \\x000000010000000000800003d875d205db72557574780cbc4aaa54cc2999438029c70c8eeef9bd925a55ed0ddaf3d0304ab349d24610a71460bc379b9f446370c3a9b7bddd3d59ae83279771f90212cf3b650f2b46ac2e4d32d13530d41ab5dcf2069eff4309bb2c1b231b1b309d96a5e084862ce65c08ebc0587db8f0d55ad93da82a21794618ae117ae02f010001 \\xfa5ff2c736736163cadc0aa8dafba3b865c6816d224f9972bf87ce75c7f9e172b4394a3a72e800f39baee73ea23e598875bb87e4f8e62870edd6b43d2c393007 1671132761000000 1671737561000000 1734809561000000 1829417561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-260 \\x52fef378ca3bbf514b574ed4ef6d12e00ec0b0519c3165be516116b20e7261f7292ec8fa23f460224f00f0939b31bbf2f6415a170657d3f48be7f1fb7324e301 1 0 \\x000000010000000000800003a046bf9a38c2f79df79768970076aea68528e96d5eb88e7369cb17a26441363c75ea1cadeba1df0f0a10b86a5e668f058f0e19b56e5e6082df5e0a354cbc17363368dc226370ff4ed4ee50f797ebbe0995fc994de5e67e1c7e9597a3db479b6b92132acfb9c9a74d9c88dc377aec2d5e47143560a1d76b34c443850037b5b91b010001 \\xba4f1f3685ccaf2a9fb671b0d68cf3fa6915e44439dcfdb78ffc8ad37d0f8a17330345b0423ab3db6a2a7bcf5b875692f685de5509e68eceb73754a791c9c80d 1666296761000000 1666901561000000 1729973561000000 1824581561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-261 \\x5752729b04fba8952fad8633e3408d6219cbda90c851ba72beff3e8b838422b07803dca753d1a7f7809e3a880e791ebd08a89bfc940d3b8e65d60e21288b09ce 1 0 \\x000000010000000000800003d4d3087763b6797a210793f867211491c6bba59939f9bcbbbc91eec4bb606c62a86c615daa657f0f41637af951b6530f90e11ad6dfb8eb942222239e537823892d82e3d051bac7f25bee16373185b9dd96d1c0de1909805b2b0c1420da989d731293202a4e28634a9cded7921384679e0b6668ab59a4c432be7b6e469b4daf89010001 \\x4e8445a3fa6970dc5c476033f1e8366d77dfc1e6f515e59d4e8e8d8ed9b71db3b03c6eed37c931f1c74b14e17038d50f1ddd388c78174eb5f95e6314f6b5b308 1683222761000000 1683827561000000 1746899561000000 1841507561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-262 \\x5a4e96c09706cbe22d0b152c046e5fad53c67005ac9723ce7f6c82c5be1f826b5f01b22cd790e49aefde18ed8ac5c2911a1cb0eaac39becf28a9405c95b5d3df 1 0 \\x000000010000000000800003bb581b8e5a6d880e807d4669483ba8ad358f94d55f340acd49bfba2180ba6a280289b3862ffe67693c38f42267730e40367c5ecaa035944228ca5c35d3ee659bcc4aa966ed73412b6907976f6969607c8a3a90dc978c7bad560b6f094cc26d4fc89b10dc882b259cdb1afdb2fb0a11c841a4aed0839d6d974ceea2becbeb3825010001 \\xb97fccf453a2dc0c6bebb1b76e34dcc20862dc6f3771450b1ad18c96a86400b90218ca47137277183820fb38d44ee4221873451953cbd0ebf930756201a4a10f 1690476761000000 1691081561000000 1754153561000000 1848761561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-263 \\x5a1655ca73d6d023e381dfc7b36b2823e47e0c6ab7efaaf137f70e47414f8e47df7d3110cac86172d7836c0b2b4509e843e5f67cb639060e9ed7ca88e5d67715 1 0 \\x000000010000000000800003bd799299106fc160b35f5c15f869430608693e43cdc5b79fb339af3556e2c57601bbdc36889ede762903231b6d419ab913d3ca26248531001d8eb2a8a080d00b01af736b713a15e748d73878e8197052cb6486f2310027c36369fecf1469e626f56c194d91e1fac43e2d39d1b352ff6d788727ad87bc68b0d0931f858ebf64fd010001 \\xf67911566efef9f94f8dfdaa96c15c2c6b9d66c6b91a1eb4a5477c472450fe5f2559e5f6a45434bd8f8ed55c4eeb6f667b3a4c9fc68852240e169b30df644400 1688058761000000 1688663561000000 1751735561000000 1846343561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-264 \\x5e662f3d0989bb0c5955cc93f74e72fe271d5a1eda6ee20593b625930774710ee6b2d5a789b391743216c58a0808833d246853248d0b8fab95c8404520369599 1 0 \\x000000010000000000800003ca7d0f9b2b4124b13b740c14771cf57198b9d1fc9e2d7d4beb46e79e2603d2ae5cfe94afb2368ba67808dbbe71b1efea14c24b54aacf6d57545a9a6bafa70def1119d4584cbd43a3f4955232bb7860e50f1f700fc157d797a4352741e6a796f07c0485de71000e5eff2a2d7bc74ad129f4b68293b95708ec338a0e08ca2c2513010001 \\xe4d89cd9860e8603702037c72d26dbac5f7c1c91e2c910d4b2e8e67a8966e229771bda0e5684abfcd7b26aad6b4fd40f4d175845f964e592640eaaafced60e05 1688058761000000 1688663561000000 1751735561000000 1846343561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-265 \\x61bad410de25d381a699baf3cdd292cebcd70107fdfb2798508880f55ceed4540fb9540ee6492f63325bf367f5c8de30470e8bf68dadeadba711b89fe4b1ab3a 1 0 \\x000000010000000000800003aece481b83bd09aa14c66abd2ff24f508ecdddf7cd4456dace5bd652a7271d96ab9f93f9ef15497a9ada6ee5847b8206dff1bfb91401043a6d4eef9c896fe37e889989d7fa4a2df0772602798b8cdfa95af78314b8ecbe67727a959d89fa321d1d2c83af4aabf65aac5b8e43ac97aa3d2dfbea8df6256c7b036324ec01ad209f010001 \\x4bdef295ee7a95cf07620761c3fba2992578f880c5f88358b1210dd17af57c1b4d43dc16c545374a723f8da92b8e2e3ff0eb76aea3b9c8a94a50862083a68604 1689267761000000 1689872561000000 1752944561000000 1847552561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-266 \\x61ee5e0b558b39dc29fca57253ba039d2a7ded8501f45177b85e77e433fe4a693f3df0f77bef2b3b322e503558c55dd691696d1ddeb47dea0c5e1f6f1179238c 1 0 \\x000000010000000000800003af0cd53beed1491d933d61df2d33f5b076030b61fe6e2aa2804b256f34188e77032ed1a17573ed0d52fed19315f8c42009bca99eccc1ab7757e6a8e80cefee0ac3b5bb302653bd65bbedbad35c9d09465141cd6f41e596415e550ae4036b1a3e2a0ff2508f829eb54cad56f6f3e73f43b9163bd4a4685533cba5052731a85d27010001 \\x2fca6db6e9c9ea4da622be035568f007ee8e4182f420000020d2b8b07af19aab3d3564bd186b5dd87f31586b2e9becdaf70a3c91960d704af0bab90e14e01009 1679595761000000 1680200561000000 1743272561000000 1837880561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-267 \\x642a3bbe4da155aa77d00768bc2d706138c28b8dff7b873ffb0d90d885a2bd56bfcaf68374061d7a1567e041a46fbcb39df61511e60259f4165d7e880f865a3e 1 0 \\x0000000100000000008000039c763c5dc6f25de81d9d5d3c089ac7951a580e88e9873bff4a2335057c1c6f551879e9341c231443cfa7bc8a101a6bc30cca4b84de13ed7ca2cef106e81a5179a015f2c4253c9a24fd0928fc42f5023794c9ae5f0284a38b62b14ae902d5ebfda2b79ddbacec7c3ee4c71a193b402bd98f062a51fb84151899a6ef0bc6ecb4a1010001 \\x506e333daa14438c329aa8a3d3f5e78c5420407a0caf84a812ab73138b756f6673a7fdd37277b17456d1f4bf8501519a21d2e8568f3a918d37be067baecb0500 1674759761000000 1675364561000000 1738436561000000 1833044561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-268 \\x659e2113217fcdbe641d09dd21b174da0503038e5166914fb933268e3b872041a66d64c79aaa506f43d79c3634766fc055f05f618b890850db4c6bcd72af5e5c 1 0 \\x000000010000000000800003cd9573f9d4080e9dbce356b58d2be3247ad24ce420b6d159618e72ce042611ce8afcaec3b8ca6e04e298dc381e9b593cf234e0cd5962ba9f2fd8a5e9f512056ec39d3a35eb3be0b4b33938fbababe52fada51478651b337e5a3c9cafb923c0f11b7c2b0e3dbd1faf21c09a8a24d070d16ff492066d64632150eabcc39a3c09eb010001 \\x57558026cc2d6fafc74c4dcf3e0705e3a237d314fa3681706bbaf2c49c05c1649def883feaaf9c3356b7a2026a2e7c54bb0ce11aec241bcccfe4e5856138ff07 1661460761000000 1662065561000000 1725137561000000 1819745561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-269 \\x67964d8be644c81bd5661eac764d7e3a6d4b5f61a25c642a709c88afebf82299c84f210e3bfae69746b5b368b008f2cf384e2b8bf62079462011282dbce0d246 1 0 \\x000000010000000000800003d7a975c4ddf4cef5d2297e7c5f56a383be456bee7cd3dbdc465667f96cdd21447a94efb7189e8744e45b37919e767e058a54d6f090bd7c8a744d84ad0c3633bfb69f3d546324789cb54e18cd24b461602c20bbaee4e6a832c1dedee945e738710fb66e46e66e907013721aa9abe6085fce581e41cacbecc70644f34117fd39e5010001 \\xc7441dfba77574c3d8b6f6fff77605444a9780d28419699b69e0a2e8a02e8074a3f1a57440dd39026df638e48c95ae8da23ece8ea2cb5ba868837a0c11ba3d0f 1680200261000000 1680805061000000 1743877061000000 1838485061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-270 \\x68d6b5975fa273ffb79bc7c7dd1803e2628f7a99abdd96a4b3e1c4f4c514ed5c8d48afc623161bd499c88036d627c396508913af44d54debf8249f693410bb3e 1 0 \\x000000010000000000800003a9ae5c2ac3f1f684118996376fc551f9661ba4b8c96ccc75679dee1bdf8a52b3f3ee58c85194c65286708401c1eea6e483f3f8ad12e03d72a2db69969b55da16d7399e8e82c84331bb5cf2ac5efd7f0fabab481dca627b81df3a6c79fd4dd3d83293cc9069cc254dacd0cfc815a9f67210849a16f61e72b945bf9a5fd1a36a11010001 \\xa2cf020ee2d92d99604789773352f2aa5ff08db9adfb81453f40d5944efda0de2f96debcc735275f8bf83e682cfb033f873d9f185ee6e8a7e84b746c0f48090d 1688058761000000 1688663561000000 1751735561000000 1846343561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-271 \\x6a2a17697295369205232277bb180c9ffb39ba89bd246ae2e962dd25b28b57a60260cedaf4afbd2f6f0d815d84e85ad51ee78554ea9503ec024ce60da4d7640e 1 0 \\x0000000100000000008000039decf88f7dea47c54dadf744dccd7137d9b0d4cf15748c917f52e8890501867a2ad1eb70d3df275279e652d54c813db361494c905401ab5bb2b04df4406fc1a6e4de14d9aa0f2eda74f440a183122d09362e2d993869b87e0098d9fe0b34958f674b038dadd5b22ad543768355bff9ff76a43e455b990a2eb87355c0900d98c1010001 \\x568335c4f8a8e3ebdbf277e264a9875beb76fd5ea29f6d00ca3108c79187a13c33f08abc0a7b67c24a0265d36cfdade7c9629d30bc050188662cb6fa41deb70c 1667505761000000 1668110561000000 1731182561000000 1825790561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-272 \\x6baad82db7b4ec48c7a4532dbffdbd116612174b9d599bb0bce4181ad78efc14c1e5a76cd3cd2db0db5acb7e6de6f20e00c55b014eabf9e063ea71c75dc70314 1 0 \\x000000010000000000800003b5ecf7847da83b72a23154e3bc455d678a04fbca971e724d9e94294ebacd6aff312337417abc3b06e77fd66d5aaea78425aac3335ffac35f97dfe8a45be31ac6269555a336ca0c32493a0ad4aa8e805b31bbd090d520af3cf7b79e55a2c2a4cd4bfbb6aee9695487ae845ceceffdde67a3310b3c24351b7fd65d0b978fd023ad010001 \\xfaadf518fc7686902153628379e98e05c2ce068d8480fde67ea6f9f2b660a4ef46b235e7ef2d9ca4be6429c78c9dafe6e2b00192ca1d3c5046e0756fe748e60b 1678386761000000 1678991561000000 1742063561000000 1836671561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-273 \\x6c3a121a5d4f28dc797db8524d2fd3913e0e52f3e7371882c3369129e48331e64e256826d5c36bf0f8b0ec3b903845553f1cc4d6141aefce6930b48071980dc0 1 0 \\x000000010000000000800003c47f8b388180733953f5e32f43185161ca634dd07c604bc17359646d0d3280177f18b1f11559db33b7501d1ab58cec8499a025a1c334073ed9a80a7ba6790e1e92ea87cb9e1bb27e09c0d22c8b3e5a531ba7b7284a2d834c2b41645f6ad4045227377c03cac5151bc8a6ee69af2a1bff34ace6fe17dfcdd8e9224c5068cc174b010001 \\xdce725f9ef68d4ff6226b0e230109392bcc7e76f0c6ab158359d876b149f7f7fd06e27835abd4d3d156058b15e8b52ffb44968e59b46cb92232f0f9f5c7fea05 1666901261000000 1667506061000000 1730578061000000 1825186061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-274 \\x6e46eb25098906b18ae513d96e62a261dd51e1187c29b743bbdc68b25de281c1a061b71af16f4bdccbd7b90e80b82d3d1c2d0846d7150e76916e43012c998eb3 1 0 \\x0000000100000000008000039d94f77de5ffa2a6638ba17d89196cb39888cf1b816250bdc30ee1988f9d657e39df9f0d7644aab3b2c1ecb910210063d4bf36165b708667696b628b968a486472605d386a31cd1fd57e379589e2e3953897b86051b160e7dc536d2826b90a7cb69ceb4ef281c6e0ff4061df4ba6e29789a36918e8fa971abf7ad89a70a4eabd010001 \\x9fc87bf1bec3b27b111561e3f87cf3c38c6537a27aff2bf93c099b85ccff4c2d42f153efe170d26c1d0180c530440034dad655ced5c925e05adcaec4531f9a08 1669923761000000 1670528561000000 1733600561000000 1828208561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-275 \\x71c2bbe82d5c326745cf99baf5c78f1ee3232d77afd0f3877911a95d9f9e0cac9c4fc935b70669ab134fbb7e0a96c56ee62e54bc7d2b7ff23ad4ee6c3c3353ca 1 0 \\x0000000100000000008000039bf85553c37b6a88433e5a7950fff80908dba8d7f47c73b95302851ea65dfbe42a395a5e68ab7b9966baf91975459ff9d42dbce53f2d15d9f06f02c3b2063e014e703c66d9414674da4fb1f6d6861c8f7d261f57fbfff908ee8f888ef2b263366271def24a3fe33e50d3cd07eae99eddcc24b3759f38eb700b3bfecfa8b429fd010001 \\x3a444bc4f1d136ce9ccfb6a022daa6f44cc6b3f43596b9c26944a3b11a588dd5dc203cec7a37bcf0b01d74b95eb34dcde0f873f65b0b4b344eccaaec88c67e0f 1662669761000000 1663274561000000 1726346561000000 1820954561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-276 \\x7226a5c9642e8ff83661ea5d6057a50e14758d6c6b93172721b1476b5e46987ee87f3c54117e7f346d9ac2de398bd6ef5333637d380c86697694184c3659eac8 1 0 \\x000000010000000000800003c51d414cf1c859cedeca5e7142ac029452ee4ded04ebc07c3b6bb3e94c9d442f71ed32cd92ae50120696a32e5572cfdf34ecf5251dbb01db35bdc73b1e4be54196eeb80ab1dad50a9288489e680e7319a38f4b24b37ef76c01f2c158e5b62f7e8c4897bbc5a2eb209fca469ff6a9596dea08f24f1d63c8bd2d1d77bc84ec7347010001 \\x094a2cd56a5e56769f8d2d76ab10a60670e4d3e3410288814cde20bae9121fceab6e3b7b08bbbeeda1898366c5d0500439eff9c71f438be4cfde1c5b5214c108 1663878761000000 1664483561000000 1727555561000000 1822163561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-277 \\x72aec71d8fbb72f7f7543648ab3f60330ab7a3954e75604c6990855007ad5898754c0ad80cfc0d73ecdeac363abc3e1ba64703e519e5189ea23b02c3abd23f1b 1 0 \\x000000010000000000800003c2c99616a2f43f77de66774ab8cc0066031fb636d36cb4dfc834a6c7d976b1f365ae5cfaac8af2a2b12e12e51e87db762eca5877be8cd21a1596a58cf6f94b6736bc9f17dbe56f9363d5295fe2c32abac6ebe273a66fabb4b3759b53b2ac4aa3752c67465f9190b2d2ce30c5948039483e1c455ec21966944249470f8962734f010001 \\xd0ff51ba124f29d0d0eb55e34c3ef44c5ee9b068bdfef50f081a712fced41904fe3c8233d977d0c4730cb9ac045b91dc48c521f020ef865cfb80d43f5f9bf802 1684431761000000 1685036561000000 1748108561000000 1842716561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-278 \\x736632fdeccc13429ddb0ff72d8009cae0498558de7b2b6d3f782c2e1ab1133250de1073d289d0e3c3407d4c7247c0171218bd4e18ae08f08f8df6577a7110c2 1 0 \\x000000010000000000800003ccf1234859aeac57e6331d1b0882e04b046b456806bb1d68f6a7a4146a25e29cb2a05e93ed7a64cc84c0224de69905c867debfd2018d2422679d904e8f3ba548649af287d177ed68ef117e8c68f6bba1a009cb65d650aa709bb66563248ab51875479a13928960b8a00baf535ae4ddbe3c9fcc40177b34d0770759032ba55001010001 \\x5ffc2474890b665fb9711b34c9c1ffc85340a02f525d4ff5084d6c7898345a4c57df9c0ccc33d91a7a1ad7332ce7101e051998db69eb23511821263e7836e309 1688663261000000 1689268061000000 1752340061000000 1846948061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-279 \\x74f6543e448c02bfe3877a9a257d3328cd01c6db2cf71926eda1df06f7388ed6ba28be72cabc58f0622bdfc8d06fa9555f76240b6fb9ae4e8f6c4d80015d7001 1 0 \\x000000010000000000800003cc500da47a12a4b7e17ae2d54904c39e5f85fcc89085d45df9b486a9514761875ff040514f6eaf22ac3196ebdfd30c297693ad70d0b70b11294b8ab2d6b8f8e199eb7ad8e9b604739c9f4711d28b9dde4c113e70551fcca8a160eeb12232c20e17b6375240861ad269f65651bb9460d947f532bcddfc2180977052160c1370b7010001 \\xf3d8ef735bcf8fb7b50b95ac83765cca854e1f6b39e53f2cc50933c4030c418028b57c82a1544d5fe77bf8eb693995e0f640544ea9aa1de274725f169a382d0b 1677782261000000 1678387061000000 1741459061000000 1836067061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-280 \\x7faaa29811a3141388b893b402126d3fc0e00e13adbfe618e5594997d13770c837e11f7a0aa0b35b641d2dcf4441e878add71daf831c412651c7e03be9e59c8e 1 0 \\x000000010000000000800003cc1ff1146bbb5d8a04878f6eb35cc727ae6e21b5d7bca8f37ddb9bdbe54963353ee8bd061e9c9a99a587780390849897683ece62095f31151f9159e9111aa40dde4c77de8b3c4938d58a7a8fb345d3e4f4fb19d807961028c1e2f9cb5f5997cc89eac235a2e2f720253934315b4cdd12acdac995f690b3a3b54404da8a17eb0d010001 \\xd991eb17d7d3b4517be2f9df91104a0e5de72874fefeedc0e861a85d9af39128412a29d52f7a042ba1073dc3fcd91101a28eed8cfdd481321ab3572055caab09 1665692261000000 1666297061000000 1729369061000000 1823977061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-281 \\x8376fa5eec2b6ab188873a4fa40966934737279eb742438a7c83f762ef8f5b31bd0761d1f851ead466f0f17048de0d42ca0eda0ab9491707fcd5e0d7d23f3662 1 0 \\x000000010000000000800003b6d149541132e5a8fa8b165886302d4f6f2637be72f8b83f19aab2b2b3c1c8a4642d255e7dc610170e3f1cfffba852f9932ea3ae0032851348aa194c4dd794da23add468db9ac25aea013fc95bf75b037e5c073c2515ea8d3840643023ed18c12dfddfad2c3c8a8a4167afcd25b1c54bcd77795bf4fb586455bdf27d6990b8f7010001 \\x6a72c22dae6907ec2bfb46d8fff821bbb3a6dc74394776cc8b9f161f4783105025d3aabd61341644bb1032dbb9ce3631b3695352065de0b18cc0a82d683e750e 1669319261000000 1669924061000000 1732996061000000 1827604061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-282 \\x84fe6e4be66b68fb86eff07216aede43e6a103f10dcb5025681325dcb5ba7cd819b5bfeb88c56ac1d90d03511c482d4ef44c2dba435d43d6e6dd3c40a7b643d4 1 0 \\x000000010000000000800003b42e1211e07e8c480005169c64a03daa1f6ca3625d559bacb1bdd36d6f3f1e7bde937e2a80219768ca660e9da1a4c310c38a95c15435fc3139e386d7f149f7d928e27da0c5999006a6d517676d6def2e59ed76c86324497e032a23a47f6c47c4d15e2c03d2a02707ef41555452f1f827fc8b1387d55379d3f3129d48ea3b4709010001 \\x9e015a565469d0b72d01b8048bc36822265056738eca8189c0fb8d4f15c5bdadcd2c03392eb3e8b3a23f9904d8a87996485d3f78ebeb7e221ac1d8a9dcb12604 1660856261000000 1661461061000000 1724533061000000 1819141061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-283 \\x85ce9633681a1e025bade67fda681def75bb0391ee1fd6441df4571356782bca4f323ae72272e3394e0796edd930e86c245c4dc425eb45442a19209acc04901b 1 0 \\x000000010000000000800003b702d7c171daaaf6fdd6e6855a8c61721d632bcb6ef4aa9480956d9196be7c832e0d3748805e5a39c1e1d5b496053fd74bcbc88c4966bd0d2ab7f509d225183ae837dc22558e547dfee886443e24b82ebadcb77e36089bcbb2a2c04f8f1e471aeb3404f63a5f5e5195cb2760a40e474c6788bfff4a6d8d489888aa503ff7f8d7010001 \\xa6c0975eb8e3a754c58150c6d7bb01a1e5bd3ac062d4dd037043e3eb827b72b0475605df2755f4342cf2f4f67be93812805172e5b171731c1e78631c53aa1a08 1670528261000000 1671133061000000 1734205061000000 1828813061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-284 \\x877e2bb4e264536eb2114ade07fbfd960ba4a354625dc0aa994e9497399a4d3329fd0e1ab09c86184097076163bb764d93da507e5ecf23de4e068715d2b945c5 1 0 \\x000000010000000000800003cfcbc6d024c197011ab193032a8e1f91b5fd5a6c038c4a815eb830e73522107a2c42bcfa7efb5d732f8eabe1a328edb2fe1eed2b5af4bff98c894350af03fa2a1c71d54999ba3425735c19308c6db149eaedfef588811c1adda3fb37fa940ba5bbd5218e7e69eca949a61b9548c51f95a16699e716c84bb5e6abcefa1d77d0ff010001 \\xfd91c2df054ee915f7b478f786eb134954a395e845e718b3211e79acae2ae6eddbfbd6e6de4dc8ee492ce584322ee89e995a7ac4c087765eee31b42f10974e09 1680804761000000 1681409561000000 1744481561000000 1839089561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-285 \\x8882bd636b066230a5877fde343058320d7027f0bdfb0635bbcd76e211b121559fca4c9a2c6921940262c053ae7b71adfea31c7cf9c6d99735e8b83262505d73 1 0 \\x000000010000000000800003b61be9da3f44bc1beffc7795c68d7acebdce294b6ab0a2c0fd41c60b5391bff437e2dd9065b6e40ace2d15c7a610f4a92197b2221733bbaeaa3743332bc9a729a31ba12ba49512aaa33d5f37100274072a8d0bb17676c0d4e364a3718397c4ae9a1daa6ed086473adf6f9520bd11fabba288946107a35d95f77db45bc9b2b025010001 \\xb3a2533803d0d2cc17507732eebbca6783d65cf98ff2a773ab21c43f2cb53b5cd7b9a4c688ecdf6ec499f4186f00c32e693f3c8d95f3e242549c90ac5da2c70e 1683827261000000 1684432061000000 1747504061000000 1842112061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-286 \\x89fa2b8ab0abba60a0c76baecffce3f91506dadb7d0df6ddbbb324719773008e712a2a260f29f590abb746b5859aeabd81a112a54213dbf0d6eac4d480257d7d 1 0 \\x000000010000000000800003a154227713c7a381bc614ccfd0a43bbeb2ccc7f233fd080a94c395019bf5c28a3b9423641a3ec877407585ebf0e8deb5998089aa8cf82326f33edb3952c8ed593bc6f24bebf2e426b02a6971386c7edf3404e9c5fbc4b281168db496bba74b2846a2c87b8040632817ca67140e47fcb83f18e061d51ee5c90afc1c3a03efe02b010001 \\xe4fa6e969e76a0077a5fc76d0929cfe020459ac7c7db23b24dc9cc6c4283ff59e661756d53bcd8c580c900f8271f1878492b9020ef1df7e8270ce058b553cf09 1691081261000000 1691686061000000 1754758061000000 1849366061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-287 \\x8a62544e127e9743d72857e54faec835caded45aa47e5f1b5e33d4a923f902354c706ff200ceff58020561d674e2fd947ac07e939fbb99da1f8e3689dc766a14 1 0 \\x000000010000000000800003e692eef2a1a6f0dba348e39ebe6270f7d9e9962e97d97099b4f1c648e9e803acd556171675561dcb89d6ac6a4b6a430fcfabac1699a6a51e8d80df2a2f4a8bb60d2c4271d8f77aa31a3cab2553de4493cd8e18263da3a113d9e9ad60dbcbf62d78d52c4b65dccd69d6a8c78eb07e0f0548a68e7160257090211517c9035893c5010001 \\x954353b1150238159082635d5c54a0d3ed81d16bd6120ca0bfc37cbcadba8bd77967679b87edc6a579dfda8b21ab30434d97e4723624f8252fb9ad8338d2f903 1666296761000000 1666901561000000 1729973561000000 1824581561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-288 \\x8e2265d342c4002f5c3d47cf6ea3a28584b0324ea33ef841dc0ab934d0de4e988e998aa626cfa52806842ca9ecc9000e1731d0eeb4d73f2db31db38230b697ac 1 0 \\x000000010000000000800003c20db6540ad104cc411bf0ed4e272b0212244b8fd8dd36bc9759cd8a64e345bf22926a1335dfd0c0e216e4f352b0c6af82380f4700f6fddc8153b2fcdd7746a5bdf9ff67f5d3fb484a72c15edeb88702f46d27810903871a83096a53c1667e3986dbccd599e9e2527c1196cd7eeb13ee90a94598a0de13809b655711b4d6323b010001 \\xbcb2fc16b150238fe6a4258b1ee6aad1ce3cf9c76eee3c6f46049750ac82e30f5c8e5f129c511d633995c4ebec89ecd26a4ccdd18063d70d313803eba54fa60c 1671737261000000 1672342061000000 1735414061000000 1830022061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-289 \\x8e3ecd979909a2bfb7cf96c47d41dbbc558b6973e5826a16636048d05f2a6b2806861c9c61587fe56c586f0ff7b1ac1f3e8f40d0cd488d7612dac24a33edc7e0 1 0 \\x000000010000000000800003d651f9680054b69bf05eadae58bee53452b9b7468b5710edf300ef8b341ac4e782cd0b034e9a849e0e4a3b7ffc7f4e17f8995bd8796769fa8c132c3d401982afa62ed2a63cf9c85ba54ae1f85a10aad8fbe661627aced40dd5da17c0d89482d6d8ce84aeccd102380e4975711ea8af8ee7f9b88d49290e7d39ecb7d9464c033f010001 \\x846f6f46358676113d290d4d6f87fc5e707ad501afc0b476464920e03ea3873dac601d5b4650ca0185cf5eb885edf3c00ce598d63254d95418d166a201df0609 1681409261000000 1682014061000000 1745086061000000 1839694061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-290 \\x8fa2d21f88d9f4f2a29613364da2fea2c46959a10e3845b422f14eb5d2cdfddda1208522f7ba689f8e4c4f69c4df191e743d8a73e3fce31f2ee1a88a9b39f19c 1 0 \\x000000010000000000800003cf25fdf6efad68202dd34e66a2421e4087764f726127c3e1a611b001334e748f6f45c5e149aa705c908efc0d25afab3f29f2e6a1e543e832794fab5bdaec256c4789f7a0f0f9b84684686f5d9b0c55992409dcddaf64cfaa267076b7fff58f4cbe3e9f113084cf4147df3cabb0338083c27cf5d5b0e5a454fac972df9bb85457010001 \\x6dd6373c01f21744fd77a3914068f3dadffa34a2379beb3083cbe6b32d4467a3bc7aec4dc10845d4fe9ae1759549361286dea8e2773a4a676829f630d05adf0b 1674155261000000 1674760061000000 1737832061000000 1832440061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-291 \\x90ba7573841d1b838c952fdf88a5d0a216e4b6dbfbe27b596ec33d0756218124bd73dfde1a2c71e152d53f3cb010471e0e49afede71334505f8011bea31e3263 1 0 \\x000000010000000000800003aa175270f619f1ec9c36278c5423f99786c5750b608aeb7bfa9772224894060f0191441accb45c7a1931d9da920440684b6803b9ecd6fdbef7f64b574fce49684a5d7cb9a57d01fa11eb09049e212377930387712b64b78ee70ecb6d41d95ea124c7e7caad9bc287c78d7e49f2329c196197c2100adae66a8fdaf9af3e1699a3010001 \\xe476fc47cf133b7facb771082223d073b8d29e02e5c9962b0247a1d0e2e54b458e401133f22564afe9d420124a0390389521621f0d711f223429050794095f02 1680200261000000 1680805061000000 1743877061000000 1838485061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-292 \\x921258b9a2f7cfb8cdc5ed8d64d5829b7dbbe4d75ea24cd955a82beeec58b190c4cd12bd413b5986a74454fb7d0b32ce4cec2abcd2f5f191f6277ebc3dcfbaee 1 0 \\x000000010000000000800003f06438ddb1ba1d2ef45d07aa12a402ac05b10c02668d1e9be61e61a7dbd4281696f027636bc5360f4ddaaecf067fe789b759932843bfa0eab98e99f582ca0da9b281a6d3c473ea6ba74dadb6680d9193db5c0c5fb1bc2e6fe297319fb40d371faa81a0b2388bcabf77dfb70a82b6c2a540046ffa1d8f3c4bd78f96a00f8d1679010001 \\x882e3e8dabfbd43e334cea7153ee5b2869b92377f955b741f5c6d9546d1a5dfeeceb6d7925692df3ba252cedd856626fa764f3777da10541ace90ae413defe02 1660251761000000 1660856561000000 1723928561000000 1818536561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-293 \\x9c36459cafe7a30c29b0d963e409198f1d179ec8a7c2eb5c53482ec9645960d621064af87789265eeecdabd30eb0cdf88ee3728d97358802af567df4f217520b 1 0 \\x000000010000000000800003c53a5c76dd1e2fcaa5c29770b0051c2c68ece9e5de3eb46f057f5807034eca0142ee0da71ae88e87947f871eac8ee1790d7643130321963416069f0a37b5fee559cc64e3a0483dbcb5265f88b4cf5dc60998e1e66b596ab0aaa1b6aa9fecd45393c9a75c7c5c9252d6127bb364c69f2b55ed7dda9dbc7b80a65e17e97bce92fd010001 \\x6e49b7fe12b832c8936c84bdde3fbbcc28b6a1061ee8f57f2bd1e25554cb649453f825ab256d4f6374311fd6278e7d63317fe84def2b50c26f0ee5fa8be41e04 1678386761000000 1678991561000000 1742063561000000 1836671561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-294 \\x9caa852a6827d61e82a63a5d327e12e527a7289e69d085f234333cc5d6706feaabaa2a688a5ffd091be571ad91135910e0dfce1cc9e716d3c2bbb057e60a59a9 1 0 \\x0000000100000000008000039f148c6a7c75e5852df9900414af3d7c3a22ab46b84a34a7d3ca6103bf2715d092a846386e81f6a6362f7af1242405ed041186e6bd51eb504c5ca799a8fc7c2ab9c46fc217f4e1269184925167c845d71958676029a9eaa3ad779c524b948ae0830960652739718e8d01eb3fbe9f3c5deb578d1f9a924d81f2650a2c82bdf513010001 \\xa4b9b1e1f8b8835b1474eef184be8556d126702be8dc48adbf1be2b6bd218fbcfa467c855ad31cdd453a72315a303f792f32119771dd184e3da00b371de94007 1680804761000000 1681409561000000 1744481561000000 1839089561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-295 \\xb4760749242ba3bd53a7d8b6efc709502b07ad5944dac5419fb4ae1fbfe93f13b9a29860a8c6efd80fa156418d9a8db938e840dfa3c56b7426dde017a1e71d21 1 0 \\x000000010000000000800003aadae66de06d27473a31240895c364497e95d8ea3a54b7c51b92502d9cc022bc86bc486c4c4adc4ffa10f66bd7652b4c5bc2dfe9cfc55307cbee6a76f98ecfea9e26e28c0186d2ed801d5b0604b06b6600796e74072f1bf8d065634c563093cf221ddfcf26f8fea81144850b5ddc8f574672ae3cbb66353e151f25685cd2662d010001 \\xa2d35a294bf6763e33cffda2e019ad365504e9ddc0053a4c512a3c7aee48db38cf0d752153ea9b6d1e6ef9145c1751e7f4d276dc8571e73b3fb5354a1fbfde0f 1666901261000000 1667506061000000 1730578061000000 1825186061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-296 \\xb4863a3235cad2f6b0db7194f0f126af517568243f7b4a693ae3d87e5e1b4b8202480027ff85f6c95d4484d63822405a9b9ad1314d2e8d44ab53f72f8955e712 1 0 \\x000000010000000000800003e7ff79f9d01f6e34f697176b8e1d6416a12f40a84abb3f198cf2e121b214a5a92207df7787033f29cf85be14613491020da3521ed5f8130a3e3cd79d47c6dba9ecab543a009b3c3f1c31f6a963bcd8c78c4b8378572b9889c5a92f458f01587461f097276e5ba05594c573a5c82f40662ab886f761f1d1333d01a836d8b22c4b010001 \\x85d4bbdf0a0574e4359000b766e77d0deb35e7d289340daa29fe768e026f3ebd42576507957f445b522cf00bdbdec94be7b5d751edb2977e627939072e162208 1686245261000000 1686850061000000 1749922061000000 1844530061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-297 \\xb6d6232051dead7dbd5dbee11bbc7587bb5300c8058422f72dec003830c88181c3332f17547f19903a65434b11125ac635922eb0f7a06896b519dcf6247404eb 1 0 \\x000000010000000000800003bff87b7c66743edc35b3d422be6d9e8bdb013fc535e311367e1be44b040bdfe97a386832409bb0bdb52534f8dc8bd4a696c920cd60bd50b6952c6b21d119da095ddec1eee7a4267dbeffbbca415e9823264f6a7d890a6ef7606176e55d6619b41d6cd31fa58c8d7c76af9521449bec9d69645c63ba2a21e18097bcdf9fbe4af7010001 \\x364643c8fbf5692a02a557a3d329ed0018fff1517d95b5765dca5cf723a0c264f37c39aee0e8aefaef203ca4444b5114067f92eabf476563a4c91b3a634ce30c 1670528261000000 1671133061000000 1734205061000000 1828813061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-298 \\xb7d22a27e90330cd2c5ad35086e6cfb1ee2e330488c56f6089e56327d2aefd34f3709af93ce055d76517d17e343fec2a188238d255e253898004ab1189b6e473 1 0 \\x000000010000000000800003df4aa0192fb88215b251b5ac049304fdf821c0f39f74b98a933110a79f96e739ad46bb34a579b793ef5d412174ab75c8520a105a5bb16bed79ab47e60f9fbc4bfa44709c515a7623935723878d89c58865c44d264cc561008ae167cb250939bd8d60bdac07e8fde3d769cc179f74294163b38f35f5bf4b09826ef2dd881e5c8b010001 \\xa0d72a84f5a6f010159266ab01b48a7ed45e2254b2ff77ae501b059deed25ebe3d5a932057de05e50b9461a15759d1647b1de9e1db52d395d1332e052c6a4c02 1677177761000000 1677782561000000 1740854561000000 1835462561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-299 \\xb75effded0e7adba2028c2e81bb7ed667c19207794de6f8877af3e6a8af98c037830b17c5d61975582bc863396781d2afbc252dd4af3256cffd87f87d18d2d16 1 0 \\x000000010000000000800003d4de63ff22ee8762bc38df62e43f06ec3a01a2689f6f63a9a24ec48058fa5c300233b65b44ed6d98f5cca08ed0ef5ba84b60faf6835e087e5e5d76eb487593d45ce40d9f5e7f1b9fc8a6248181aaf5d9d92e9f6344957131e1f25e606ec7ac460b1fecbd9e0b6d2c6842e39191a724d5e8012f9f9bc00315fba3e8044a6d402d010001 \\xdf8f08f83e4a55edf0a9c908004d8e70ef8aab33e37610c4c8964feaa7085426cebd6ba2d01660e580df51645a4175a161f4d8cf84b543d7bed26d6249adca00 1687454261000000 1688059061000000 1751131061000000 1845739061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-300 \\xbfa64c162e245aba3d2cb346afe6840b566701d2c4697da1e29c635a7175fbfd622207bf73bd262bb0821154e7c8ebbdaede8c68d06d460921796b21be378b1a 1 0 \\x000000010000000000800003a8d9d6c5cfad0be71293016421e77033e4a23aecc8b6a81686ffbc8739b77defd37a294c1909d1773240a33ea0ce48fa206e72014c6c6ffe9406983a0cb87efb0416932b937d458934744271c95ba14e5008fdd8016acf13e22b0f154a65c09cb533df31e11056cd489bfd21927c84093385d10673361eda58db999fb8c20267010001 \\x2c4d9a95cfb67c73434cb7f1bf9d8f1fb1d8064053738cdb11848a986302b7c3e6e44ae06d070644ce564e0774636255dfe655a7bcefa45a68631bb41a2f3d0a 1679595761000000 1680200561000000 1743272561000000 1837880561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-301 \\xc09e6826c4f46be47a83a1cd6e891294cec9edc763005440c8f3c552e58ce6a12bc22d56442514ad8a7c8ae8be25e196f8bcecca5c55b7b9b9ab90284e0d9299 1 0 \\x000000010000000000800003bb241d4c1cceb0c75d7ee7ee955c56cb9fb577de2e9666f7783b6a539f7683e5bcfdc5640ae7d1232c150dd2e9cbddb7a1315b7e5b5894733205a99e7cd0f6d34d0b6b47089ef5920f6ff79467f27d3911ddcddccd4a146f00d03f12eca330ae25a395892f88a5f6df63adf0b18f9c335ee335c076c7a2faf4b0e19d0b12bdcb010001 \\x746f8622dcfa3c05faa9cb607250a056ec36f03d77654c0a4003bbd8a70e50caf2bb133e8d709e961141f263d04a2cc1f0bf89a113cfe5747427f746b0490c06 1683827261000000 1684432061000000 1747504061000000 1842112061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-302 \\xc1bebf9e774cf0e0df002a8de718526e7e87cb95fc5ab3ac2cbcaf928ba6bef1ba9c41723c226146f5dded00fba86384fe3ba17929ddca5ee3b187df1fb5c35b 1 0 \\x000000010000000000800003bacb90fd31e56bf10c1f09f13317036a54a9df32a4dc6bbd2ad238391e2fd835b3a69e1882cf45860cdbabba37c2c27eafdc0a5cb342581810bf268963c70a8ec113c720b7a20ad4b24fa1b3f2d5bde5915fbb3dc323f7836a2cf539427204508814d2dce8a0ede396aa5a4fd7592ccc172192541be5374866d6cff138db5685010001 \\x4e31a37b1b5fcf5d85b40e46954efc7d432035d742e46e3ba1374954d38a83061b7922236dbf61061a954b1561926fce888c816f79d16e08ef9d672da3bf0f04 1664483261000000 1665088061000000 1728160061000000 1822768061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-303 \\xc33e14ddd024af4e46f32b147e2367b39aadc8af50307312d5358ed537bcc6ed58030b99742e863b8e5349772a818e2e9e9a7e0a197d2d792ac37a2eee9e288c 1 0 \\x000000010000000000800003b56eda3a163e8e294d868a47d06cca53ad74634de70ee4446ae93259c1d6c6d0ec9ac914648a7b960f07cf858141a45b52524b0de35aeb8b3081fb3c7d6e52baded8e71ddbe0b9b40c02fa7456ddc1e469189d819d23a16afe8e6fd8b99afd7d4b2f61ec07345e48ca933ccd1482c79b84b75dbc7cce80425cec3dd6bcd3cc97010001 \\xd9738964563ff90a799799228355754393b4a384d6dda9cbd3cd3931e34b9873cece64f710de87c68cb017889ac0afeefb5017ede083d27f7e9bcaa15088fb0a 1684431761000000 1685036561000000 1748108561000000 1842716561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-304 \\xc3ce4590875785bb925bb6b59adafc100f531ca343cef8bb5f9077fb6616057635b36c55a58bc4ccc35ca82e09ec76795c918499ec32e30430c26d65236cb1b3 1 0 \\x000000010000000000800003c68b476df3088281399dc089d3a10f667edb64ebba2f5cca043cf0e887f1f2872684eaf78a4744bd8c03653ba5f94980c234c16e88a237577868af06e7b7141dcb5e9623bcce167d21fb8e2b9e9330535ba22d9d48a099f1939a5f2e4cbc90da90f3606b5806b57392d6dd60e8bb9176ce86e7fa72d7736502ef37089024dd35010001 \\x81b3698b8df5a8b961b1e56bf4025f8fc437b3aa6e292fffed3d38e53ab4769a8c4659e5fe50b245e65e96410b7c8ef7d8a15ad256a900dff535caaf53d35007 1680200261000000 1680805061000000 1743877061000000 1838485061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-305 \\xc646f3924357d5be6ccba66ed367ea648928b5807afcb0fa0886731716d098b3f852c519b8c568cef0f256de76702b74d7aedaa2660920654e11eee79c76d135 1 0 \\x000000010000000000800003c47661e82e37781312d0b8aa3da1cb58da4405d80280a791cd53d75e9e25c8b276313c35b837ad552d7bdb0bbe2509e20fb86d5493de632050f14950ef1e718b4b3fc766455dd13cb07dba6e463b2bd19ad5916a13db6f2fb325710288199b63d9434d6e5fe48746ee60864f82d2320324452472ce97879d4e44e7942089eb41010001 \\x506b1d597af6484cb452f9b1d37bec30a8a24e6587ff8fc8e784941247830b8a785bb480915781fcff6fd6958dc0b6c8bc43e1050984999938e4abf96e8ae301 1677782261000000 1678387061000000 1741459061000000 1836067061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-306 \\xc8f6eb452ca1ff7f49068083c2b1bb4daccc4f21431d8a493b4cf4143e829c544f940e63a1c144f508fa2b4eac4873c6107d2ee7e5a666702df82455aede3021 1 0 \\x000000010000000000800003dcad62581173432db54fe256ff04e63779a7c7b7f24976b646b1f3b25d264a6a1801e76d6c634f0b3c1b23b3e55e9d03f32b93e1038c955054f2ef9b52812419ecffee4d60a912cf3c0e60167019094249f58652c838611fa7508845116cb075a3782e5cb7d20cf50296ad1d57215ea63a5ca6f526a5620268de997f6de6c439010001 \\xa68752591e45538206f80273d4f2564cb46f3bafb60d94ddb3a935ac2795cc18bb4aebdddc84b82742863d6da31232cc4ea8565aeee793759317e8471a165306 1691685761000000 1692290561000000 1755362561000000 1849970561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-307 \\xcc2e40bf376bc0d2d425a52ce8e0b84b1280fc44ae42bf37c823f99e693e2cee3aaf7a13eda6febad561f1befa4b775395eab410029fd348b95d5bbe97fc799b 1 0 \\x000000010000000000800003b95bfafc68982292e17e80e07546ca82e28ec7e37954c9155b7455be2306361881a11656e9892797fcccaa2548a74a5475cb545451d10b9f8bcdeaa4bd7914df88b42b7af8ef3d377abacc6368684f784258da169e9241e71e6f03cbba2168112ca80f6aacfd71dec943f3d716ea7f8c91489b67ab3b27e52955549d35fe1795010001 \\x7cad5c6e3739f0057f01e89771a5333211ea4ef9db82319cb844c652c6e14d74495497f87e2d818c85311f8d431b43a018c7a50f3c70170df21f49bdb1879705 1684431761000000 1685036561000000 1748108561000000 1842716561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-308 \\xce52353ca608b741ae43df8df2536d4aa9de78003c0712f80a63c11d8812dd3047e8f4f49ded6b38588deed830c5fa0677c65f98f9a72b2f0888054c7a7b2886 1 0 \\x000000010000000000800003d477e97db1723ed93704767f7750eb48abad9811c30353a60bb895694a6066daa4c68724efb279fa490df30491bd62898fefc3c3386846e2d7cbf94fca9edfb2c1c2b9e6cca8fa3934f7888a809bd18444577e0c07b11fd3a143f021b81fea284c663b3f728c88c90493a804dba11dae7b1e8b8e6d29c57d400a63400e73cbe5010001 \\x8035bb21d1c70ace0eaf6bc0911db56c514c9b4e0a84a350af87090d63025606711d7dba18388f4db0a8cd623db366611f847bcae01bd25ff4dfd6aa3a235907 1667505761000000 1668110561000000 1731182561000000 1825790561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-309 \\xd1ea188a0888b62a307d9c7737a6807710053b120deca4d981e5438002fda6eb512633dabfc502eb8bee3a9784109ce2fa90a6716bd9a53d4964ccb95e2c96c9 1 0 \\x000000010000000000800003e7165134f2d20d7bd8d59fbb47a050fcbd39c036732cae582bd5a5c93b13d1d432f012d18de01bb660e562b408fbe935fa7471270d27cbab9e92df880e8372127604a7f242d4768255412a771ba59bac9c6441cabd3592d04edf84a41f0f08c413de3bb93c5204ea54ec080ee3048240b688a480ce8ba5c7614aa62ef0af485f010001 \\xd9a4bf8ca11802537415f49ee52377e9352f159df7d69f3c62ed8e7b2709fa1863ea5443d3d88ceb09f7cbac68d2111a7040c3e4e0c9e3fbdd2d1f259410bf0f 1686245261000000 1686850061000000 1749922061000000 1844530061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-310 \\xd4760a8171ec3e7c1d09eb0eaac424aa1a6bbbc47a595ea5b5d212913dacb207273042e2d98e0b3ce06464a535260df99b24fb2d0c6466f32090f0220e0c1e59 1 0 \\x000000010000000000800003af0f2ae6b1f1044caf168f90685cf68f57296f577c926fbe8017618842a00ac5d9b22869f5a437a6cd39c5540b702ac6cfa52ef2cafed6f40bea8e8c9cff904037fe4ecaf45bc6521059c1eaeb5021c318048b6d8f323c1b3c081f1abcf9527761aaa513caa021e696a27c09b6e6bcab21c5758f91f5d3faa23afb15c5e2ef13010001 \\x00d67e41fd7281544a81daec9a1889d0919a335cd259300b85cf5c60c7c732720989f6d2b1b78bdc04d1483117bf89d9c4574021265936a1eb3280b58df07f02 1678386761000000 1678991561000000 1742063561000000 1836671561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-311 \\xd7e6a4d2a136254948e44f2b7d150bfbb81ce36aa954013662576c90dc5dc7e74c0d1d893156fd6bd067171f684fd3fe3c3517a412374ac2acf5c06052aded5c 1 0 \\x000000010000000000800003c8f58d72b98cbef1a690dce2f1607dea4f12c5f5d2bef4b85cca8004781668fc7991b09a264537313c9f63d2af536fceed17b1b3543b958de1cd5d8aeca82c8871f8d3b16b0e6275953d7c77c2b97be2012bc4b9e1112478e82f0eddb51ade1fb08f4e3dfe263806c6f2f2c603a5bda5711a36d9540f9eebbc61dbf2ace9b9ab010001 \\xd7cd49aa2d87b6ff7590622805025e22ea41d3b38019aa2a8bc500506d6093f85599dee2f51d86811cfd3758cf677b3a0290ff56c731ccbd078b5ad838d6a704 1676573261000000 1677178061000000 1740250061000000 1834858061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-312 \\xddb243767fb3f5117ddff98ca0550085987f0516e38002851ec31a8ecf631a2b0b5e1b764429b588f28cfa8645ee1b9a1a9c4f27eb3e5b8e35099de3976361f2 1 0 \\x000000010000000000800003bb2c9dd77c429684b60fde7746b47236771b8dc93081efa9df4825729783ea9924f491c7294e2efe06171e092918f3c91c086e3e86e81dbda6d6489969708a51ef06672295594a1f6c25383f8bd50d5b5cb949acc86cfa2da2338fb045e18348f5b8c04cbd4c0d1213d499cb740450232ef9f95354a6c8794eea28b848e1d793010001 \\xde190c433f1129ffcec619fde5352c97148b45e58e0b777bc87d9bfd0985efa01b160f7749f5dfcfb0d1409692063f960e97d9a1d2920e9f597a99797d60540d 1691081261000000 1691686061000000 1754758061000000 1849366061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-313 \\xded293ed264f86dfc81c6b3502e1c7d65c8a6dea4011ca38d18d466981580f5f539f38c17c7946d01513148e0f4b4c09e0679e0b79e711a48ee248876dbfd37a 1 0 \\x000000010000000000800003bfeb31d4a379e59cfcace503c9d47ff9fe8187ccc72d9bd87923fd1195a89befda77a8e5f34554cb07b4f7d918983598383d97f3cc25d856061aec6635985a391e228005b958c1415074d2b316eadda6acf3d45f741ec6c347b75367b59c8dfcbfb7c40ffdacbf293007958f6084f272e095183461b4049bef90161d07efd07f010001 \\xb959877dde647d8d8d3989b6aa3c9faad919f58ac7c0c15769f5526b01ba253d6ba23166ce7e4ef3498e6d4fd6b93e6a96373103fd06c02f75fd9d475bb6ec02 1691081261000000 1691686061000000 1754758061000000 1849366061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-314 \\xde8ade5d8c62404a36a960aa7754da03754d4e52fc9e29711ceb6b8bc10bea4eceafe13667208e8c5854aa9d390406b6b3f25418b0d0cbc5e06b0af262e8d038 1 0 \\x000000010000000000800003b2a17af4ecbb3a4931c5d619858290931c395b2f7672790085f04d8a362f8024a803e5726e141a049e7a391de9449df9b577e7c2e9d6dfae1167fdbfbdc6c0b21765caedf40e8411d4ea47406c3b45cc8532a0079b34704e01eccb34de5b0a2d85b4cdf73e7790af5f983f9e21f691544744dcae9eb6681ebb6e1e7c5221ae6f010001 \\xc0a0fba4fd9e3cd9ea1a5b5496c1da639d043431dbeac94b9efc3f0cbad1448ad0ea4fa47488874d0046a629eb423dec9e2904df9402b209404e1f7110644f02 1680200261000000 1680805061000000 1743877061000000 1838485061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-315 \\xde0e8e44d932f3f56e7590a26dcb2cc011a4b888dea347c6c14c1593e7652abe7a8e3df6ded5c87ce258d1f8ed349fe1bb0062576dcf01d6beecdf247f6cf6fa 1 0 \\x000000010000000000800003d947abe064d35030402b8a8942eb456754a72b67014429e13f5825a108cca9b43c34ba7bb22a9625b1b90978618bf9e38e7bd022d9fe33c266b53c31cdc2a676dcbe7e752900b0037a95a6fa4c809d6e443cc32d62dfe96fa42818b30723cc4cf7a663ac0e70b10adac463e42f20797f91b55d4c8695db325e4fa6f387abb5f9010001 \\xd93bb67d1490815b8a2a3ca7ddf4075239cc18537287fd6e0c8ac4a44f54417ce385774ddef36ee76a4b6ae8ba5fe4c08a0c819db7c86e9e9e27ec44fd673d0e 1668714761000000 1669319561000000 1732391561000000 1826999561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-316 \\xdfae5c7f3d4c39cbc43c496fc455125ce4361479660b4a242b5427483d773397ed42437a5b1fc13c322b4fdc37b1eb971433a81a165fc928fedfcf88de44a2c9 1 0 \\x0000000100000000008000039e1e1a4ae82b586d4d1adc02c727d62727dd496948520b4ab4f4e3c25416a968e96fa74f631a4ef6bd43d81b25984f7530b79e3d1a85d6a6ef614bdd57d7708c6afb596c5315d25e889b0fdd9b7406d5ee89124311f5d50d149bde03a363adf9759fb37e89bc978f19b654b1cb505640178590a75bdf0753ee7569c5cc78eda5010001 \\x0bc61a22aecf97d79ce3e99c6e470f1c14d56a3c6f2bfa10cd24af5df8b0d322c6ff2812cd07fc0e9e8101505ff54cc60230a0d3eb4a90099a1c1ba86b01cf01 1676573261000000 1677178061000000 1740250061000000 1834858061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-317 \\xe10232b77ca618b437a05b3675070d663509daf5ee664583796087022b0a006f8c2c3437255e01dc5675f245a17579d120213ae659cd0f0f07fff4b3c884f3bc 1 0 \\x000000010000000000800003ba74bbb74bfdec3b574d41f3e482c3526ff7f910b31e871c82e6c759abeaf112bd3660a0f91b319168cae830588ffa4f4ae550269b9db01f2091a56edf78293aa591f3fad5a565b9be08d789770d6785cf53582a092ba84fb8ddae35ece0f00978be26a840e5fd4c6a99ac3e14b7cfd214c7af5996f781f4afd12c70821b2089010001 \\x35eac16716fc7307bec6c4dd0eac812f19fbb11e6ce68aeddbbc622c7fa7804e876cd7870808e765e145938da8586582c675046e409a90ac9423dfeac0d5f905 1691685761000000 1692290561000000 1755362561000000 1849970561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-318 \\xe20ad3e98d4a36c569b456062697b11b834e13ab1c0db68e2b627ec461c9a2995a5cc7138238e54465caa10ca624bc54f2f9251d5d988eb5be7f08c2494e2084 1 0 \\x000000010000000000800003cfd7005f4ee7fde377da4c045035452607c6c5342e25ec887864cc1289fe16b7b003be4967dc75b5dbd6f7f170b42ace5347c30e1973205f575f78c38be98efd341e92fba426be19011bce50d9ff23867ca77fa058dc270014ee08e7b2a664576b86efd444f46b7af0a4e5efbc422fb658cb4b438273299194ddcae4c594c635010001 \\x14ac8aa67b451092f860069606b306db599c742978a609f43e0aa541ce76412e1500bd3929fa68ef7eb559cf5af7beb5eba060cdf24276326bfb2736d76b1402 1665087761000000 1665692561000000 1728764561000000 1823372561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-319 \\xeaaa45164e94ace535065910f810c1dfff7f7d28b6c77747c0d29d316afaa361bbcd2fc779b209a10754b34264e38222c5ba987762af89fd64013c8faca27e0f 1 0 \\x000000010000000000800003aab200583ed88b7900fb0bce35fd47e56b1420c79fdafa69bb2b65951222d1cf4b5d8532e835a71a1be7c27074a85b64abaeb65063ac6fefde9bbaca9d8c1ea00e9fed2ae414e63be9da96f5fa339fa6edb33c1666d786724a3eb7831aba18de94c47c7fe752cb2c5863b30a0f318b3610ec2f22d9c8a6666c9c1d033a102d1b010001 \\x963a605777f659faf189901cc6d9cf046a2de01e776a53bf85aca01aafa5adec821afe68e95ac415d85c6b98d154e5ef87b4c0f42fbc5ab6d0eb9a9c6f05f30c 1664483261000000 1665088061000000 1728160061000000 1822768061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-320 \\xed96d511c4ab29364ec70a934c144a9077c8e07199d4b2dff7e416345e4c79aacae05ae2b2328905c51012cd3378a57d71661b9bbe897de023dc4f2b24a7fff0 1 0 \\x000000010000000000800003c91dd2f41b1b1e583b84d6b816e742e30ec42c6b423921b8c95b52653a3a10a420fcadb4aeaf2d851210d430b383790bce86e6927c3c8255ae9d3c7ca9c06192d94a1e08223cd181afd89b1bf8a8235efd288aa7d9136a06f1b5adffc6b2e063b7c2810cabafd2f5e7acc52648e9c96785e27da2ecd1958c655fbb4950c374a3010001 \\xf11e8fa6676fe65a45c7365e31227edd95a8c2b70ca3f3738bc1a38b1caf100753d69172883b649758d306327267265af61655492979038bee3102ce17c71502 1682013761000000 1682618561000000 1745690561000000 1840298561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-321 \\xee7a93b376816adf2b356b9f4a107f208e0428033caab9b573abb1079367e5721250dc425491301f7084dc34d850ff896fe6342e531d3ad9e95b46500e6339d6 1 0 \\x000000010000000000800003aff6a3c5db5fe863192bdfe3e438cb730b51412f49a1cc6ebdf57ab0298b2014e9c685762276f14ab5e0b27130aecf013c717636f70e60d4abd5b69900bef9e39b25b1298e3b1768e3be3b160b8219a368f00ffc4a6327e09f8ad3648302ad5297c55e7d746c4ec1809594df19648ab69acb3a57de5f2394a912660c4daa8a5f010001 \\xa8955fceab21976bfaf175f6283905630a19f9aa33c6b0826fa55d6012adfec4517ddfe0194bc64db37841dffafe97fb46bd2b6bf87296fc4eab39fe321bd003 1665087761000000 1665692561000000 1728764561000000 1823372561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-322 \\xee0a535551ddfa571f85e97bb3a6799b9233171afe5f7a0f1bdebab29a1e7ab61683a489c4ab669d35074ce998047d37d7575c9bcfb019ed76ed7c918f8e8fe9 1 0 \\x000000010000000000800003f4efe263a3008827324984be8287c1d14dd37b29a732744d36bddde7c0348c8345a324468bab03241d9fa2684f38766f838a6d275b55e7b2340cc3302d4c37cc23f19dd1cc6b97e45fe82e7c77609f273409e5da94412f03d65d2cf1f2de4a66ba451a40cdbbf4ee95b6b21323caaf1537b29df075e973dc489dfaff1d0c2161010001 \\x623c8d149126aa1769df0875a4a9c7d53b03353ac7439e39f2fa4378299b39290575fdb56b8fd4e9821716901f80d2cd1f1ad9fb76f007f4711814665ee18f08 1662065261000000 1662670061000000 1725742061000000 1820350061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-323 \\xf0f683e6b1700c1b5a776a47ed4adea55a18e934061f15df6481f4e981b711f2460a25dc249a5da7460401091c24c2345954d6dff444a44dfbc90e49a47f3077 1 0 \\x000000010000000000800003ea1980ff9f6770f23cc32d847378ca39f2ff27d850cc8ebfd640d36fe91e4d410ce595ba58414826db0150c25f88438119c7c31cadf6ffe2d360904e0d0f4c92d0da97ac9d07373df687d24a9edce97513c33ef6d0b4da8f36a00216c2be106f715c046436c55eade7502f9a3d6c4c3dbcd2fd3b39833c79e542498f5ff6ca75010001 \\xebe47e4c099a854a07285775201a495b752c7f33f26f7e9f6df10fc0e22072e880f1273f063379158ba67629cf709aba88292a5c8691b0e2d02c8530eab8a60d 1675968761000000 1676573561000000 1739645561000000 1834253561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-324 \\xf1c62555d27d3988eb32b8e468caad44f882d4e8df65207224df1910633957d96f623feda025bd81790a9f4a6192e90bc2d6d0388a4ef169a9d2c09e9370d805 1 0 \\x000000010000000000800003c99e6523cef7eb6798eea9a5922c2a23af4346907dcae2cd12623b42e1ed730fc71ce3a141283f5583fb14477c126a251c595872921fec4487744004dc2e7004de05fbd4ad4d0ea99a00734aa7b46378b55c4d03f7844091bc26dec43b1ed2fd880e2df5379af331b4c5520c50a33f3cfd07e92e9573faeacac2c8336eda4979010001 \\x208f8ad19f9f3b7369f58dedce79216ebe30c71826a0e3f86dbc57d56df43d87203d139ff73fafc5b3af26e852f9330c9f171d17a444c2e39fe82b98c65dc20e 1671737261000000 1672342061000000 1735414061000000 1830022061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-325 \\xf2fade3c88bb31fb0aa816c3f3bdec645cbef041c6b7076bac31d4ecefc2c4656dd429fda37b277a609d6c0d01e8a1c06d782ce2822ae1ed57806f7bf8f3ef67 1 0 \\x000000010000000000800003ad915fe81f1752abfd80ef0c8d02186d9b52c338afad0620000948b670a31ca7997d16f6afd07152b164e8972cce810018a42029c2647dd45e6ab74871a740bc62e16dfcaa229563a50b1edd6e4d6070bb0cf78f5a5024e22f9035deded94728d8201553866afb321a469e11f8597ee17a8ca644e189d3155c3b67e85ccd33df010001 \\xcdec388e2a506a9ea3fd6faac66082e4cf2dae60b68eaee6fa4a4dd5ff64385aa8a1c49234e016eaeb23ac2648ec232041a213df87dc1397ab2ba9c7868d100d 1663274261000000 1663879061000000 1726951061000000 1821559061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-326 \\xf3ea3c1ec1646062aed1a77afd4a749b692a486881fecf3292f1296c345d888bfed16786867511b54d2a4a6637b579714578ec80e1bec1e09ac65b0e21113e18 1 0 \\x000000010000000000800003c607ea421f1d272dad3b5d1be053857cace68bc004b3dd22f35e5ec13127c2f1ef0cad6245955660739a9f9e34503a2092749578275ad25d7c7deec2cd1f7898b83cfe813a5eb2c9a4cd8cb90e85cd55aa2e3e459771f534a2d5850cfe1a0bd6d11984f1d44431605481a42a878214ca98553e98c40baae4f347b5099b46bf61010001 \\xd7003a65e628a5ceb5f785bfd804005085f4e8cd4fc5c9e7f6ba35e811778a56a80d80b8c2d683d7e4b7a44db68298bece8954a61cd62b452b4a71d61b959207 1661460761000000 1662065561000000 1725137561000000 1819745561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-327 \\xf77e97424460bbbef111118720f1d67beeb077bd2f2046482e89cfac4d50274adc2839a4c0198f269bdb37b17c59526240ca8c5d75d58f768b70b5e48335d580 1 0 \\x0000000100000000008000039c059dc33529767abe652a281ea40d19bfa6b5dd1757db23236d13ac9900fb2a48f50c71de5daab10e26f6814d7219f6b0df63188ccec5986283dea1573a47ba53fa84cb15c25df0dd5a5b4c8ef8b95f2d2b3d7244e6f598106ab265afe458099ba1af02e911dec033027fdee8c0c2a581f27c7dbb258d5661483075e64b3ec9010001 \\x042c19d17a82a2c3a1b75ea8a7b12f00789f75a83824fcb1681e38ff863bc80ef12d1e6c7378a620d78d0a423e5c5b2b821b5310a0a0b9011b93009ecf572c0b 1662669761000000 1663274561000000 1726346561000000 1820954561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-328 \\x006fc345d84b419d83631f9964b50ba24a9b31d8cf212503aa933d03281168e7b99dc74af26a24736388a37e6d8fad5ef6821b7ca55add35c23211a9546fb529 1 0 \\x000000010000000000800003f6f47ea7bc9c2537318016458c0679155df6ac43614d82484e221f806ca03a37064302652b71c59a4e8246fba2b3ce7f71a2f08a8ea573a6f3fa434c197c95b7384c09cc5bcc90913f60d105beda327c8b699ff035e2831e5564de08e1d0e41cc212ffd5e1abde5b313b89a2aa0bacc296bec2ebf3c4061f3259b7a822b10d69010001 \\x40170d05b80b8c9ecde440fb0af40798f53c342b9ae3d36e8c97f64e1331c72dd44d8fab18d44e2404c4f95d47bb0679330f4169d3093238115d6083f6659204 1668110261000000 1668715061000000 1731787061000000 1826395061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-329 \\x007fd0dca983083aad7c6237b3d6be2ddf81f0fb0ca716245223f9c5b3b197838174d1ca473c9ee4ea27328520a10b325d09f0b570647c5e6046266c6b29ee97 1 0 \\x000000010000000000800003b722d16bf6ab47614a7d3c2adba9f4997acd78310a9b66dfb42c211bce7eab8d860ef414c3b76af5e7e6983146cd40ba4b1c7d69e5344d051ac086ff49eb90b8f512fff7a941a2475f623324391e5d43577d147e02188b1330408d722ce8035c7a07982e6373ecbc7780b96a3df1f50c573e00e9c803bd816b2ac3d3c0e7197d010001 \\x2d551dc95bf8033490e4f2d507527447318cca5b26e5e563f1b288b665feb1535b255966a20cf5c72c78170aecdf3f078c94d587a06270abd7495dd4e928f001 1667505761000000 1668110561000000 1731182561000000 1825790561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-330 \\x02cb66d95cf47760c2f380ef38aba0244ac2ddc3d8e6f90155756963719a9ef0da7dc2d4a568e5f2b293852c6b4adfb0de24a64950566a6bdfa17a2d647bad9f 1 0 \\x000000010000000000800003a1eccbee8dd965f357189ba02ebcf441e776a86527664e2eb071178e55ab9e15f9dcba195e3a300e346822a239192218efb15e7ee41975cc95ab048e3001ac12f0a1b6a745229724dcd5f6cd3610ad58694b92382538c881cf229bd9765bf78b9022e9b7c591d4801251d367b38f21574487b2bd1ead58e3d0c8a30ad1d6fedd010001 \\xf237ac4b8a2fb69468cad46bbddfe46312315c7d3c4d5d93088ca941765ab35238e6e78d233b308101388f4c5d6b77a8d764d580a03937dadf74d7c1fb7d5100 1682618261000000 1683223061000000 1746295061000000 1840903061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-331 \\x079f381f2e81560fed2ebf1eca5622b2b30ef88509a539aa9a57e0d3a2d7901ce07021c6c101ae569870560d17acb154f4ef3366d293d710a5104608dd3bbec1 1 0 \\x000000010000000000800003d169ceaedc05ceccefc63ad7bac1047a20ca0d3299f7958ecf63c78ccc87d95706150aa08af4de81fd25b7246ff820d880f19863f43001fb46abc55e8a0313ee4160d4cda2f5996bb9ae0f700a78921c61950b0fd003b17c7b21dbc3c4f7002610a89f4a2efd50eee05a2f2d22ccb773c7cb6e716abf890c93bc00350507e6ed010001 \\xd50f5b496e4cf8d5020292c812c9fedd64ed3d152b7eaf0a89a2b8f559e799d8cf359e7ad0ecb44b3e0b034d9075fdc05d4a5fe150f6893b7b1f506120438a00 1686849761000000 1687454561000000 1750526561000000 1845134561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-332 \\x0a5fd4cae2dae4b1a485075ce4b3e204e845e34e880f96e1d79ec4460efcb3c9f0aec8f9c75a8584e6eab446f049782f7e15196a05562e96d5dc8243d4804c46 1 0 \\x000000010000000000800003d1bf17af95251ebc76aa780c2360cc64ab85e2f8617fd80cd9ac2a09dd14f67cfeff3100c45dbea51abce1671ae0e284964df47adbc3322ef741bba38f527e7e27793121f309a93141f23c3102663e74ba415fecbbde40d8da959fe018fb9dd0eeacc71897741eff24b461c682f54f27e10101dfafd01602290137c8731cf7e9010001 \\xfaed9f9364fd9b010e2c2bd2d60d892b308e1ad3299d707178513bddef61d7c5e34a1f586f98874c695ceae808e68958c7b8d9d60e6bb5813be8aba5d8293f0c 1686245261000000 1686850061000000 1749922061000000 1844530061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-333 \\x0b5b19b38ca6a3a3279d410dfc5775bb4f50b04a874b0e003e41b3ffd65915b654c4265c57ec08e7698ded7667b2f2fb990c46519cee9647529564c2e5bee8b7 1 0 \\x000000010000000000800003c0e40a12fe1ff20a24cb9668cf00a5364ec60d44212e624ac64dbdb2bb65d0551736ed27fec9de9a87bc28932091005367a60242a3a755722b2361cafba2b5d4097b51265d34752adf6007ff35fdb059a555d1d69aa75af6d481c03b273da916640f5cc87e75542c84cbd51d4487d5bda38a68ea819ddb88564756f67b59e6b7010001 \\xf4d9bc2c5a596ab105b8a59f177f2e7ab448cbb220846154033d20d2e44e4f90971feb48d6db72d1b16392f96cca99de300d5eaa80d20a842bb7faa6a6f4c704 1678991261000000 1679596061000000 1742668061000000 1837276061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-334 \\x0d1b657984c4ef4c54a669e2f24fc686b8e3d7c1d7b0631efa63f06b62a79970abc73753acfba0a73a97ae1fb319125cd20e362e551f2bb50750bbfbc963e7f9 1 0 \\x000000010000000000800003e8962d6d2b95da7eb1c0c3132626ac3b9b3062645c1a8f355f7ff5d6ede1e0b5e4567d671faa2d5d1f5812214118fedbb672154058524212872408058221ba27397d1a1fa46a3290d0a39f431d6915bb9f8b915cc63aa4ab1ba69b8ade38e4265979b8ff805171e34828dca25096d9f3518431e31e5d665f4e1971ba7c18a465010001 \\xf3b039191995453c675a6c4a2752b9a12fe3cce73c927ee8abc54873065f9226676ffc765dad6f7402071c10d59ae1671aa6c442033a5c3ee923c9ec59fd6305 1675968761000000 1676573561000000 1739645561000000 1834253561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-335 \\x0deb2826f13ec8c937ecabf945c9ddedfb8b6c26a6b1190fdb55271bfedbcb1b0e5dbbdcc4a53699abc25f722e19dd6750cc484881bdc5a8a0dee91850093180 1 0 \\x000000010000000000800003ec01e744a84eead3d5c1ef2dac5b34dc30a0001aa4cab6c416f6f792807b8156df930af06572f3e0adc2bf6d17f03168e086cfdad6c3288f8e521de60f34fef0a6a4797074bfb1ba24ee3b6b6d715665b80a176f2e75439c31b83b8bd59996daabbb4525c60099d22ef4eb1e0aa7ac18810311589e44520e979404b8cd25ea55010001 \\x8d538f030341d0562ea5b37ea68fdf49ba6ab4b75f0c57605b2ef61f758de224a2fe237a93e2343b25ec850daec13d2a1045ee62cded889b1b95652b385a5f06 1687454261000000 1688059061000000 1751131061000000 1845739061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-336 \\x0e3f5c28bc7c4d82a02a39cb77935b9a665807e4ec6a424946a14f04e4081b150d6f61f4056872f965da2111a7eb5009a16e08595a4323d2a3d38a421b59af56 1 0 \\x000000010000000000800003a53942a884bd7ea1dfc9da472bfc213bfb21d1a2c9d24f6ffe038e8585b07ad35c3724153a22662aa231d9b29a5ca41bb88aa830dad9bf571d43ebba95882caacdf0c885b6af5404045785216826aae88e9c5ec2d06ee44b52ac837a06bc59191995dd3fb4ef8c50720331fe7ac2574625f2a7cc6340dd86638871d99397f6cd010001 \\x26b58d4819ecf5a5c2548e3eb3c14af372ef0a894ed8e9cfe6084dfe494b151d1a8a7df884af72df7f92064a22a90f074da31b0cb4ae4608653403b65958b406 1691081261000000 1691686061000000 1754758061000000 1849366061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-337 \\x0fcb767db5aa80b42a04bcb8b34b9374ca076c4203f144c617effa4949f2dc29ec819217730a23ce02031147574f5736e3ee3e6d666fb6cf9edfb649b399156b 1 0 \\x000000010000000000800003ddb1452c216cf2e635163e4193e76055a294e9a2c502c29bb0d53dc4bd42bbf2669dd22da437834e77e694f33f32e6f812a9da195f70aa6469b08cd5e11d15db259ba73deeeb4160ed3d497615009f9d46687cad5307242d4b11fba91377c747429d723894041d702472b43c6c1ab6d0cd3810975994f28833b95dd53b051551010001 \\xadc0e5848ebbd154e5c2d01be2a9c7bd343a3b170b6eef25ebaa2f14a28d546d9ca1fef93552e378496028264e618e2f4f78a75bb9f687f9ff4ee24c6dcffe0a 1674155261000000 1674760061000000 1737832061000000 1832440061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-338 \\x1237393c33829a14b9593c0ae11048a90fe44d477c6d24345efac823eeb6540f7448a9625d4c1a1f1b510584014bbb03ec45c401d845a380a2f141e5a50f730c 1 0 \\x000000010000000000800003ba915fde4c93171cf6d3e3e5ce039791ab867583c7186f9a5552ba5793079030d584f0bfcaf85e8409dcb3e74d83531eb1ae72e50e7ff0b458386057ce5a479ba13b63eb66fb3fa2ebdb2c5800eaa357b3800ef4acaba28eedebac315d4c8bf73084b21fb4ccc5e60dabeb545a30ec6a0df59b89c9acbbcb8f16cbdc7cf92c11010001 \\x26717c28bccec44f0674483f2f1e0a03c6743de6a61cba44a90dc592e94d68309d08c040e8d84ed4e55e4a0fab493217915c202db2ef3cbc1d33f4ebd789e308 1686849761000000 1687454561000000 1750526561000000 1845134561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-339 \\x12cfed4d5a62232f8811067ba842308330e33bebd6839f5dd3eacc36a9231d4b5160a92cbba5f44e9f7ad3c56123835b9fcbebd1cf3760f0db38740dbd3d5f46 1 0 \\x000000010000000000800003ccfa3c8ff6207de8ff1e09d8f05ba7064f69e35bbe065232af629dc2143f346bfb5563d991c1711e6b9b430d94d0d48c53d36724426e47211da019f74d2f6338962540842762abd1d78b79b8bcc89107280f89ff11ed374d1289ed655c3c6dd512a5005199c7369be71db45e73eb583fd1cd435ff32c8b7252851865a0e645a7010001 \\xb6aa1d0f1896d9f31289d59dc275b15f96d2bb6b7b7274400b8da8fb86e087ae189f629bda4fe1e098e2ae3054aabbae23a52f6f2efaf000024551bc4b5b310b 1681409261000000 1682014061000000 1745086061000000 1839694061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-340 \\x146f84657918eabf954c73be9d01cf75bb82d39643f41f1f5576705cbe75273886b1fcf123ea441a52aa58c73591e6144faa8d468f946764e4ed1da6e488d863 1 0 \\x000000010000000000800003b73a445ab7a5b65c903db660ec957c60ae6faae117cedb76e23f7e95267e41a7ef2ca042c6c4234736f2f60a87b3c6666348f03d6016b4eefe4a83572ab7a50b2c46686dd76ba11c50e06e6b87fc29cfcf302e36b4bb8a30baec4d6f96abfe2ced14794146d80a8fa29043ad236d95b1cb25a015f25bdc2f898fdf3b40cec391010001 \\x8cfbf022954cc2b1c340f540d73945b27ee809d4c82c101e12468f1589f35778e9e6cda1c8d3dea8953d54d3f317a27e7d99a9e315b05cab629848c699c5270e 1663878761000000 1664483561000000 1727555561000000 1822163561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-341 \\x146b250bf323b20e90b231f99c52e37d647433938ad6369898ac5b6ce0a05e186f684092f9d220b1eae19571a7876abcd09069cebd7cb2fbc1e45cf2ed824966 1 0 \\x000000010000000000800003c976c16d5b7ba9aade94a5cbbff5c4c778c68f6b7e02d2a6c5881bbf8055390994419396cda300f0bab033879a1021eaee0afcf152d49960c211838e6cfc94b7c2a60e981be23bb4fdccb44a7a4aafa4239689644b187ff8ab1e19928a8b0b4ac1afa1a97f1d9bf20d60d3687ddc86b212971e001f7bc8df53840c4c8de6fcdb010001 \\x1d531451a3d8aab29052c037d89f9ffe15fe24727671d6136aad70917ae20c20248bb03fa90d64ed2956be1da3f83fa98ed914cc5e0aadf492211fab77610607 1664483261000000 1665088061000000 1728160061000000 1822768061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-342 \\x15f31a302ec78ade08d2436c4d91d1b444f4af0cc541eceb642a20b0c5e2762a4ca8fb20b4c72246357d51a459c58e6577e5f2c093b598fe57c42665fe30e13e 1 0 \\x000000010000000000800003bd997a92771b0d0e48e760b8ffd232b5964a79d8eef250ef2d5aed5c0c368b050e1dc7c9dde728058e540445cdff711a9e435c8915a688c3c2879d1e79ffc079ef6b9684f8d72e127d71ef9dc752e20bdcfba38d44718a7aadb25adfed37b1671c6c9016691b39ed4eab54db0908bd525c7d63ab3cac2c97d52be6e8c0fb85cb010001 \\x845287fdbcc644898ae263118ea7dd615265a33c7caa22bd230018215a82872872a63909f4e3c5f7737de10690171e7791ae6f884e950b089dabb3976d4bf40b 1671132761000000 1671737561000000 1734809561000000 1829417561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-343 \\x1643bb2d58e80175e4d7e2e07eb1d03d5294bd8b4724b1ca46e10898a14c745f64d23960ec072a98e76e3b160723cc672b6648d5c6ffce38970d6514d6a43263 1 0 \\x000000010000000000800003d8e811cd54de1cde61835db75538c5eeccd85aadf1d905d4c77ad9e266fdcded11818030deeda27fdcff3fccb147faab709b849591e87945f9635e12b358ae8732741f533ae50c323870ec32d97518cdc0285e8cce12198ab54fe817dc98844368df394dbeb4e1fd552b19bd9fdae2114276ab9ccffcfbc7d24f7877190cf2a1010001 \\x95de471afd73e59851c9ef742a1ceadc4f2e2b9870ba19224a9829ac635d5e0d603844eb72fe24a5c4bb47c051056dc4b9ca59653547533e9bf4155872070a0f 1668110261000000 1668715061000000 1731787061000000 1826395061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-344 \\x167f43d31c7b95b759e14089ff9e9807e7c2229cb1858e4b440a40228bb76cbcda9d4d8e946481747d1957d3a3da72e7c2012f60312a42174b5351e8bbebf404 1 0 \\x000000010000000000800003bb1dd9daf3cc5dcecb68aa9ff0bd2f5ab895d08c2810d9cdaa77a9831cc4167c1c07705979def68b66a99cf9160f05d94e36a5ba12a3356f920db532b9dc321a632d7120186fd69988197ce22308a5feb34f4ff9112c084d5c65f83c9d97692d93240e96a4e0b653e50bce8955059ef0f4c561f9183094373e1df301aa92178d010001 \\xe2741aed83a0ec8f69e5107c49fc3429f9ce022611880414227a9472df573e2e284b6478a1d80175036fc8b62ead7d7bb5593cf68571cafb529a93c9ce5c2b05 1663274261000000 1663879061000000 1726951061000000 1821559061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-345 \\x18cbba49c4f4afc6d7c0aede31901dfe4843970d39685d5c71453396f8f964bc06a4dfb266d369a91f5d5350f66ff1d1a2d2d4f43d85ec981d7894bc1b5dc9f9 1 0 \\x000000010000000000800003d94732b4eea9c27980eb0c2895d1f2874d5393282c81d606b24c173d5f8563fad2fb2cf5f3ac544a578aa225960837e37e9fa0190d8791c04905bde468feb61e89c748ecaa1e1e3949a1b2044948d51bbe5463279433e44621e88403d49ddc0533cb67aff4c0886237e19a9154405b165368aaaedea8309c38b67faf81d92005010001 \\xe795fd994e995cfbb019e6c4e7555a976316542e44edbf1c4797d82fdbbe7e9768d4f69ad4389b032f3eb4af4213de9656af4915e9a168e372b359a55c1ebd01 1681409261000000 1682014061000000 1745086061000000 1839694061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-346 \\x1ecf62e404f8e2d19edbbfa42c838570e05525da1ca4882b75009998a5d246f9c298877e1a82d6dbc5d3f8bee46fc4ca9162419ab7027eddd8b69ed0bbe6cf1a 1 0 \\x000000010000000000800003b79e7be33eba94e54fec3c595e45d1323fadb787c4f5ba5108b93b5c621e2e1dddc6850990a53efa9394ae30f94bc36cff38142051eb411ed786823bc1c722a216b9d25611c051e31e86a14e27da33c78a3eb36bf2642b215058eff4a2336d66e86055b8bdade7ff8bf32ce79ab4c8bcb9f7166c76f9c4b4500f69133058959d010001 \\xb2123a95254ba3ad61244bc5f75023c89282d706b98a7c3e9387da0502072d1ae9e9ba1ad601eafec4923cf8490816dd76242856f35958c9debc347354b69b04 1662065261000000 1662670061000000 1725742061000000 1820350061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-347 \\x2467cbae4ca240745ac683adf3887a18e91dbfb53521e73538c0b0bdee77453424aef197b3c8c70747563a38e19c7b873ab6f204ced10a606cd5da9dbca54773 1 0 \\x000000010000000000800003b5d05798bc19fb4c9c117f71bb66dc1b7c0c8a18d652af259613475078dc8472dabf024d20450fe4cc949a86c92df3fd3edadcd2a63c4f33d78599c0331fa8aae7cbf03b4d3d7bf6f1ef1f5fddba1822c5ce492076658c653321aa88b794886ce5aba6081b365297bcc4084757390d9c6b6e80c31e7556f06ce562bf46edeb43010001 \\xd6387808396819ef80eabb18686328b7d1076abed0974c7087dce31c1f1d46f7d458d8bd733c468833facc291232ef2c059d0887d04ca64d212b1369c6408503 1672341761000000 1672946561000000 1736018561000000 1830626561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-348 \\x2653a731393468c90c48866b41eadbf62df253f36ec53d35285b0381edfd29f8ce62a6690d0f9db4d8352e96155612cca26ade232bf94a0205469c06ce2178d1 1 0 \\x000000010000000000800003e8d06c4588f3bd8f349081c8b98e73032e73f732b0bb23155c799c8fe5a9ff8a815be0f423f978bec4cf09e22b87fa2c7ac935489d8f05e028d0d0cd18232324b623fcfbbd5844fbcceb6de8161e222194b6366216596c8e5bd3de96b35dc055c29798085087d022d39279f61700c3d329e273781ee97cd673ece7f53e1a53c9010001 \\x84b4f0760d15ab4fa18f8c2e5c061195fa2b6c30db09a1e6aa4c278c9657e4f64208ecb29ef017fd4871dbe92617c1c852b1408efaa1cc08dcbffae906e0cb0b 1691685761000000 1692290561000000 1755362561000000 1849970561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-349 \\x2647283c5ca5a6422cb15d99e8cae722295e20df7dfa08e2d6de6f96100a196ca2376000287f0ea39578af1575a6d48d62c8e2c542d7c83da6a4eff6979c3196 1 0 \\x000000010000000000800003dda383bf7a89f2d146166c9c48c0c08d6445972ae93c52b4335e8ce1281f6414064e8e66664aa928613f868e13955fca6c7e3479e0b22830dfd401ff6c0edc9bbed0fa7cf885b43a13c6f707a4436574ad0ba1a1c0716cefd26f79b1ab7a5135bb577b803c90b6edbb6408f31da307ac13736ac527ecb6a1e166aa79a32ff7a5010001 \\x44495627436e5c00dd0d59477245ccd2356a529439d67eaf4bed033af055112f681eade0ad010cf71b668daa3ea4465dc063c28665e4f262b26b0623e8ea8004 1682013761000000 1682618561000000 1745690561000000 1840298561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-350 \\x28cf846512d0d9eea4ff5a5757fa0a87ca1d2fb3bdfa93502960de05ab1fa5185e3c7bc70a2e910e8836a4a7e513c11ca68e4be0473e4d5dc8339371c8c6233e 1 0 \\x000000010000000000800003af87a007c369b39b3806e880b0134ec2bd5662669666b4bbed6d121953baebb8a8b912cad9c5ce5bdc0558e0555646a8765e3476d6773243ce50abefd3a350b3de52f2cce2ea951ee07adfe930844ac0cfcc45b50cfad2d4df62991ef5f1951a19db199b09f127c8733ece88166cbb942fa0d2166a3c3c511eba989b43b01cc1010001 \\xab03acdf264b16f9027a98e9bcfae14dd1f27c4a21539d1db26f30508c97f9c29c7030ce0f5e4e3bbae0f4167c81a7387d4289dab627e27a7598630dd4af0206 1677782261000000 1678387061000000 1741459061000000 1836067061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-351 \\x2f0bed1491c17eb7eb8ecd512e11c41abcc46b24c5144cf48dbecc2c664f801e23c3ebb36d63e61e29d9bcbde9af868c90d18c3939f7853994f4c2939cb296a9 1 0 \\x000000010000000000800003d61386103d39cc8500b8f463c6a9be4dc35947a833f92a372c0a371d9429544e0446bac352d12c1582d95028aa5fad9a2f38a5a379d5b3c7331a18b7cd93391df62e5437e16d8ee95727a1e27b0464462bba3a4b5273a19e39543b6db020c76ef01a4e5f17ebb830b61c7f23145affb207b216022aa9ab01bc5d72c26a1f38db010001 \\xdc3daa18850cfa0ee3c9096e4b40316a8f6709f020825d6aa4e188e90c2df83746a6d908f8c73b17b75dce68c4d6778fcdb679cac815051a8bec91748a039f0f 1661460761000000 1662065561000000 1725137561000000 1819745561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-352 \\x2f2f96d1791ae963365f6132e5965c14d9e0272bcca5c6bbbded5991716c8de00b89647c7f4dfb5dfa80648bb2df22600bda86d4a00b90b378f2855fed9fda57 1 0 \\x000000010000000000800003b4cf6c874c7bf13cde8fa0e10bb3ff9ce72234a3972e64be27f36ff74239ab59d84b19bdfd3a410a89c67681d8995376136ed7eceec79ab6a255c9343f7a820a97a553a2e0a55b8696e84d9cbe30d950b3448990c309448457ac05a4a52d03e6f43ced199d31ce1322fea47eb9107a576d52e5561105219d894ef794882b3ef5010001 \\x6053cab59fa9bd7a6bb0391a26a3734112c3d245cf26d59ab32ee3823aead218b72da6002aa843466fd051959e74e22b88bdd5ed6b3e46f2ae9223356257660a 1688058761000000 1688663561000000 1751735561000000 1846343561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-353 \\x39971e46dad13a25f6e50854cd2b4d49a3b5f00105ee502c7e177df542c9f919da74560c42c2abccfdbf4a2e9ce9423aa42a1e4f5d8125322b1a8451adcaf97c 1 0 \\x000000010000000000800003d10a7f45fe14c0c4a84398752d3ed7a3cf6d26743880781faf8522c8786a3ac8c5495338a42989e7842f7c0168a68c2f1f2d5073da9c71d794dfd328e9fccb563bb7b1a45a760cf9135ad22c350ee845e3fc77bb89973666bb8b809d299bc78bd38dbed9ea14b1bac9b58f5ced2d563f7efc4d47a0901311fb0f9ff064e48a73010001 \\x94a43e3c6c8a8b68075ade7621d69c4c2e5845aaa4ee82b0e26509d4211f23ce9ef5eae1cd95330f801c22c80fe80fa16a9f2b567ca82828fa026c9db0c04a0f 1676573261000000 1677178061000000 1740250061000000 1834858061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-354 \\x3923f86d87b54c4ba083c386eaab08eaabf641e0bc2c5a3f1bf75df1b877d329ca0360c861697a560bfe71cf48b1d3ba21ea23f9199e8ff2ce06ad2cd1282ed5 1 0 \\x000000010000000000800003d6ec79dea8aeb662778751798cd027a0d399eb073efe6c34844a6475f2f19942b9732f41c9b6b09dfbb451551cc7b8191d3e0b83b0e990a6898b880a6bcd86f5d93e6dbae64f0802692a389f2992074339ea2ea1998e5c916931a5d5f0c92e72e8d0d38ce7cd2cb457372709e5dda612b396709b9c7e33982e5beed2b0ca326d010001 \\x5cfcb035169bd3d7bef5e510e0470a6ece89babc6310babc0a59c5dc528dbab47b37ff044b09101e6e8a0df59e27fe5ba06a9fef582ffe8a8172fd18d2edcd00 1662065261000000 1662670061000000 1725742061000000 1820350061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-355 \\x3fb71123e6a25b9906e3a573a5f34f7cd7e2b4ef065d34c4c7127515473401b710e2be25f12fd9e4d113f71abfbd72b71a172ddd43db4217b5959e60c82364ba 1 0 \\x000000010000000000800003d9a2fa1379697a4ac50cf6d0e7621702af21ac73807b7f75ff0073690ea44e2bb84efa2727d818c2dd6bdadb4b22d9a22093086073126a36b63aaec9178181d2570af79282bcf75bb28300a1b78f195e7f94975f78fe9c058a181b4b07033fda66b633d6b8f6d7b9dc7991666a5b12182abfa8fda64404f7f5ee144e8faf6c05010001 \\xc9d15eca59a04d78c74a6984649b44fe2df33ebf70e9e1f08232fef49283b492584a6c20d11aeb4232b633e58cf348d3d73ed28823ec6ee27fbb21ccaf288605 1671132761000000 1671737561000000 1734809561000000 1829417561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-356 \\x415b0afb3abce003c75e8312cc0f1e94f5375dde31f921eb67ad5a736396717dfa7445dcf078908fd7eb42530782566707f8e34d0995ea3bee2faf43298d83e7 1 0 \\x000000010000000000800003a4f3561f1c06e95958fba78a8f0e739615f182aca47ae27bd94e9036253d202462d0e42efa4d1ac75d0196b851eb7b94faf956617bbf68bdcbda6cc3686bd7c10eeec9f8170b72addfb61c9ff1aea34823cb5d1b6dd91ee6c42f241db10055cd4e3a80a0e7ad15e0de9cc30787305637be07e50e530e4dbd438dd1a66c80c4a7010001 \\x44975a39abcef77b9e820bc24378429c25b769573349865a9c8674180e0afa65bde9111343ee20688f0d9999da2507368756cb052f19ad6e6e3911e399ff750e 1669923761000000 1670528561000000 1733600561000000 1828208561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-357 \\x42a7c765e4c684fd2f2963fed834e7c0ebd18927b6156d2b42722075c8bfc7d71dfb2dcafc8a7540e719bd2c40f1b7611ec8a78ab081014340b56486d3fbd387 1 0 \\x000000010000000000800003c5728f6d63fe3f058093698b04f8964f4d628d19c60f2fad5bf3d54882460d14aecaba9cc413fb4e766c63b0ab7c3f4f4d573c65ef5ea3dba6544910909ed33851f42eda50fa109cb738e259031d9d256fbcd59bae77fa2aae36df238e047b77e8687b13c732636d9e70f5b22513efd46e1aaeca48675c3801aa8cf4346e0c67010001 \\xfb96c1ee4140a292d0c8fd14c63471fdc1bbb22f37ce856fc253af71bf0a7a3cdeb26ffee2658318c3063b61d5a42ebf9a663f137b1e756f595bc88a5841b303 1669319261000000 1669924061000000 1732996061000000 1827604061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-358 \\x43c7d5d3e9f8b23610407ce5f669e10e9a0726a8be62a15003449e7ebdaaffba0745e74b81c12b2bb03dd64ecd3cd8ccb2943b0c8a197d38ccc0d8ec8f9ea145 1 0 \\x000000010000000000800003b03a97b4c59addb900944aa0abdee0c8bb5f5f16484b49e9672c3c21824731b2ccfff66420c14de66d377a2e115cefca6b6816e7c60fba40f074daeb98273d661ba067e6bf0fa14a9f7b7fb2954a1dfe876f4256fdb90465c5a5a12acb3de459860d5ab31ed086c28b3767ede735345e6cb581f65c8ba49e5cac6847221cf1bb010001 \\xc63ba5a543b5196ebbb30ce92423553b8ce9dbaa31a1b975832b27b4852594ff002fdff6929815be23aee5a5afe01b0d679650e2f40bbfa31e90d6d51825bf0b 1678386761000000 1678991561000000 1742063561000000 1836671561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-359 \\x4597f981bf76525f647d078da92c5ef4e99a72199cff705ccb071874ebf28090d8375a027572cd6bca86d87c662815f0a19b86ca8e89e259ac5d268b2be92222 1 0 \\x000000010000000000800003c1daefa34dc8e141a260ed752fa69f50aa53ddaab55368d0091608a66738beb0a6fa48f95154ad14b0f6255baa57b5a75ef30ea15696c6fa81ef9a49eabd6d4f3e9d3fc1b69d72ab7adb940dcd40e3198c0034c11d4a8e1bd59471d72f03668ba3e3a506927697725eb550328421b1f261579fdb7b68c43c832999aee9683369010001 \\x40142426cf99b7682e527c101d0052fb78c1a7d6e74fa22ca436b2333dd493a55bea73d48ce1ed6a5418b33a1d0ba3f383ab1ec52e929a16ef3fbd6cad3b3a02 1663274261000000 1663879061000000 1726951061000000 1821559061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-360 \\x4e1bf140c83e2fe1511f47cd801b680bea3524efe18d8d1139b4c1737b90418d50da480818530e7fcb1c8d3266ba6442f6e141181b0a58f2330efa8fab455ff6 1 0 \\x000000010000000000800003c3e362f6602cb212787c0c8ecb51fae476766cbc1dbca4c660520411b9a98887108d05ae2155c332dbc009d8b7734559b5a16e9d6f43164428288035339d809c8a01380fdf6358654a221fbf68b748143b2e366f146ff184673fa98212a7f2aaa951929520329d33e69b877714bc09dc3cf9f61e5d95395fa527fa216ec5af5d010001 \\x8bbb38f48439665bcb1e090e20e00522a8b4eb955403f2d9da293b3a7007e267eceace5981863e3bcad2915ce58fa2f32240d5e0438fac6a3bc8aab4f92fb601 1675364261000000 1675969061000000 1739041061000000 1833649061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-361 \\x4fbf46302e33710c28db9cd7a4e56a7e8716717e07d78b0863280e1efc0ec686bbe01e2a1835ae3121b5a27bf92d5a9437b18558142449e4d4f781e91466b1b9 1 0 \\x000000010000000000800003c0025652dc9579725832bc1867748b00be135cb5b0518f59e787f8de1b0836995231910120f5a6a6f003cc428cd106de9101aff5b5c2175584c654b94f4d07572adc031885dfada21fb9127bb2d7b10e18daeed2befa12d69bff829b7cbd3d32aa5b5f83634f5748239637377b1af8e1fb2ed0668b1d95169f4ad15d4c3c81f7010001 \\x923e6187a0c190558622c281cd217a6713efad15f7913f7e6e4c1828d54639f11dfd4995295798d73ae6a3f3e59ac8f5754994628b7b0b55e857164028997c00 1689267761000000 1689872561000000 1752944561000000 1847552561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-362 \\x505b589e89ad0c6dafb9bd499b55741d0d68518f48d1a82f4cce456a5180903a93afe56afcdc0cab4feac1d9f8c094f1e85061bba87f312943aa917b2c66b50a 1 0 \\x000000010000000000800003b9f6fbbfb99fb7cf350c9a6c5a2c6d728830514096e1240fc68c20fbb49c8fb9ac7c2ad8d6a2fa27d4f12794e4131818884bbf7bf60f516ad2ffbf0e5d6fe5d006b2918deca68290b08db576a96515a4a3869f74f7e9a1978d4a523f074048ac571da32ff1abec288ea3ce0549ab8a9cd4d12b043e75c0d00fe564863b302a43010001 \\xb2f49837673a05698323fcdfc57a1a3e36251921d900e2eaa5030f631802738cf686f2a2bced58687ad507963db1edc30081ad18d7c75244bd1384f24abb1c0b 1672341761000000 1672946561000000 1736018561000000 1830626561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-363 \\x52ab3a237d5b066256aaa34fdf7270c5a3ae243eb53bceaa9ac94a6f76b6e2ed03d7688d4732dba8e75b9501bdc7a74115f4a335b47dec75c14f90e488760ab0 1 0 \\x000000010000000000800003c8c3ed5e7515fffd906b867af4098f24c6240c3e0f4e78d06d2f6367d0bcc72d80528d862b73b1d8a7b739789a3899bec1536b6b14385f4590207ad98415125decbf76498586525816701d86e39731ab16d912b0eff29893516880f56bf9e23c0eb3615f04c4011f82283f4c2fc4996a5d6645f44b5cdabcc0baed2fbfce25e7010001 \\x20214d1d8118dce3502e43d99e304fc3c87ba34ca039c8cca2e41529620d730b64c106652f867d5e79ea3bbb817d8ec53514e8c02d1d77a1ab36c4d41688100e 1688058761000000 1688663561000000 1751735561000000 1846343561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-364 \\x52d782138a391cc598ba4a60dce5390fb11a56dcef1e29cdba2edac96ccf8e05999685a25509114caa27369e82d4e826ec35aed24e3e6604855f0e88ec0be314 1 0 \\x000000010000000000800003ea81be9fd0fd02d41504395fc3df98bf74cba96654c574cb7cdc32559e5d5011f6a82bdc91491eb52e52cf99bdd2761146e3fb7edf0115179d7c55cfb8d3aaf4b3ad40635f089eeb52e53526ed5596d101e4720fc648de2d8e1007ed9fa33a80422871e6f36cc432de4a6180a4e30067eab5fe8cd8e20e5cd39320b7638b3e25010001 \\x3998c1314c9444c3472efc5dc2929155da0218b18a03bd8cd1bc684b4c4c2fa1eb1047ab4e4c4ece4526f01b1f6c969effeae729fc1e661800fd464a22d20207 1665087761000000 1665692561000000 1728764561000000 1823372561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-365 \\x5b3bd25b23071e29d6bb856ba702e9245c16dfbcd14da510b8f43ffc074647ce4c58499e1617d881760b91bcadf214e6dbb92c956aa88ab87f339b0688fec3b0 1 0 \\x000000010000000000800003e73b4f2c2f2cf3cab7c08661c359b818d6c1a4aaacce898f866af41d592678d400bd4627b71f55eae02940300c6d93716149d8bba6f4836970a5d714e45f0d66976b1b53875ef69e7ea9c5e90f4299fbd2f9bf57059ed063b9b9396d1af121677d9c4ba9078bdabf2cf3d91a18482a543111929e2388689c431d2c9780a3e0a9010001 \\x52e0332424f47a980d66fa6f7ac013b7836920e09d966082083214b53b1a4c53942c763c1ed8938c1e6fc93de57363f3e4da8523e7cd84f90e2fc7fd8f88790a 1685036261000000 1685641061000000 1748713061000000 1843321061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-366 \\x60a34023c2dba363d771c79c12bf6af6a8d795a098fe3d1666db013af8eacbe9576222f36779b2d0106dea01e055787f5612abb723318f94ae8adc028cf90d9a 1 0 \\x000000010000000000800003ac59ebd469cfa14fa31d47c42ca14a46b7fe27abf47c9ae870f5058eb9de93139dc2afedfab20057f5966062a061e9cf0e167f5e7ac5a502a4bcec89c03bb660e941b84cb6494d1d43d1ce1df7c301bdbb06b5898ae4adc3c4ec9e9a421bfa828ba106876a477a6c2e46bb3296aca2cc73297db3822d3391b24bdfe7fab6e701010001 \\x19243c42c7ad52a281a4e777318d93ac72fff08f740b58731bf0b7888395401b3b32b7bb4e86766d5f3f59f13443b9c29378f104b79d8c64ae193163a8a5390c 1691081261000000 1691686061000000 1754758061000000 1849366061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-367 \\x61cf63269bf57d423b88e2c7c70e816a52c52788c846c3baa85683dfa3c424a965c0ec4ecf0b772841dd6e279a7eecae8678877444e6aeff325474883e6a18d2 1 0 \\x000000010000000000800003cfa06671f7a4362fa385998e3b9fda79118769f017f6a9e1d8ff424eb11d12f3f159127fb0410c7d609df79ac646d97488d2992bf57459e86c5135979c096ff3fa83fcdefba8ebb90960cded4973b594173c447e73c3b89099157011df7b1900e53f2f5388cc5c1aff9faeb0c426438e2592b4d6d92205a93023da8f36048401010001 \\xa293253c7285a3d81362d5772de8bbae91b40b408ed7ac1e84dc5817c3feaab6dfd31c40dcd178d2531c59aca4b0b2a855cf1c27ac1547870fe9803977a5380d 1689872261000000 1690477061000000 1753549061000000 1848157061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-368 \\x64d3134cd9becdd87faa0b1ca28a442b80de37a7471d9d5bd5b44c691ef2b7bfdbaf978bf8a539c487244fc9c9be5b4e97bfe93f9e607835aeda8b25875cd3de 1 0 \\x000000010000000000800003ddf3f4f4e49db66c04329d2fc871902c93fc0597170afbeff8280938ec829715b38efd0af8918d6a978ac50f8247c258018046bea15a256070980d41aa1cc1d040fe626ecb97d7f208e61090e7b4e3fa3a0bfee8af0c91e49463e734b9f67002dde606c40c5ce049d13d9aee58fb83c6fc934190600533afacdd22f3a0f57ac3010001 \\x623341b59cc1addea22b91750ab81e81efe55b42fcb285a8a05b6973c612b6436a946b56dd8f800c1eac2ea1f2d8fc38ad383619e59c970b2ddad59b907aea01 1677177761000000 1677782561000000 1740854561000000 1835462561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-369 \\x699be68d120e22e2a055ea1433548aa03cc425f46e7602825f936699c31a5531e35ce0661c740bd977e88cd4806f875325c29333b9721cf03db41b0c915b0767 1 0 \\x000000010000000000800003d5b348c8fb2224b322ba02ca6f9441ec9b9806119647885f49cf5aba047d8f862a37583d8ece96371359068878b5470bd7116ece4eaff93f68ca9da540017e945c29ce374f4c87d512704b19f8d67156e4f72baeed55700edb0484db8df76d44972127ce00f649c8000b8baa1d42966d46ebc74e32e2a9cf90fe704b8e79cf39010001 \\x03f450dd89349acd441a3683b4e9ace2bd9fee2ccbefc96bb4784518575f38da1eab067c89d942f40393048fce728a706e1c13af24ccacdec69073bd7b83af0d 1660251761000000 1660856561000000 1723928561000000 1818536561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-370 \\x6d4b971c65e24448dddc16becf9cb287b5c070cab46b833cad1a08761aabe61e68f47bb55292f7dce0a37b970634964466b7065fa4b1df7e6bc0fb019389321c 1 0 \\x000000010000000000800003a21836d0888ab8069b67fe27ac9d07ad993afd3af5fb292517810ba87e74b078e38ebc765334f996a003478bc50ba5cb656384bcd9ea3f6599893d7569f46c71a30873fa65735be8401ce554120b42354fd7a084aff5766a3cf76b613c9b67bab2430937ad88e0bc6a5b8bf4c222757dcafc49cdd798709f1d656b58dc2f4b3f010001 \\xa337550fe3985458f1d4a02ad217c016e6bb8ca8857a0693703ece994bb46d1b058eb7a6d20ec6bd999793eb0f9b7d0d9f433c482878f432ec85e826483a970b 1680804761000000 1681409561000000 1744481561000000 1839089561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-371 \\x6d97b78cad463301d8993b9c22ff3750db7600ff6bc1b1c1a19ff377d58ae21240fcd4a34c82ea514da8ad0bdf992ef2a8436b53e2c18a13f8f9e9f90b75914f 1 0 \\x000000010000000000800003ba01a96c40ac52b675d180e82f9fc430d1a4cb0ca0bce9f70ce021e325a163b6ba3911baa10423ef111f58ee1df064a3038d3d01c9237664733078bc925f0c33b1436b6a1cf3002ccd1b3fa1362d38ff5fdcb9ee44ab943545cf4bee5338b2d6077370126da8b10453d0f0bb5fa053934437f3d0e3f7143aca4008006042c9ad010001 \\x8c07e0f34c52ef878cd7530d64cb2d0cd08059f743f4758ce8da60245863808d73ef151186823a4849c76b1838ac7ecca5b6e4d4e3f173fd6e227c4fd0a33205 1680200261000000 1680805061000000 1743877061000000 1838485061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-372 \\x6f0f15d3aaa2bbfbd3b5faef63483b88741c6e22b9dc2a60ee8880ac85472c2c62836bce596142e6d494b63c99a2e29494eec2ad379aa6f532d6fa681e8becef 1 0 \\x000000010000000000800003b62fe712666f251147cde6795a1cca734805045e6b202715a8d256a656fc404383d8a8b16e1f8f7c6dbc68e27a37123de718ad7c78d75a9c5109e00e02eb9375de8a2160783f9529edde10f2282bc580e2e4391e735a0b0e62d1cda889ea93f477da721d18d9daa189624da909b686aa92fe9acdaf3b51c11ce93c01048703f9010001 \\x19409af61229920fe59b79fde7144937f603103ea6151fd493b2489ed7bbf7e20d4b3f862ee072cee10cd8ec79c80bfcba5d953fab70165452e7f3c738aa8f05 1663878761000000 1664483561000000 1727555561000000 1822163561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-373 \\x73378e85b7bd2ada57e31aaaa40610dcb6d94aaad32529a7432cbbda79a5aa5c4ad0926d5fc0872dc576521f99e0fab9e77ad7e798b5dc40c0fa5431f361b567 1 0 \\x000000010000000000800003cb0e328b6cc45e7b5a9f72ee375d01af2f0894a8b8250597e4df7a9813f62f0bee1efd65b04ca7332e9ec1ffd7a247d539881db8c70883e2bfafad20b8515c57f3b973ab9d0a373f831beeeb4569903d98c39c77dd1d04d1dfabd3831dbc62b501a9aeda4490d3dc7e257f35f5a1260957ad026d6c8c3daa2b83dcf94008f259010001 \\xfa4d8f2503db37907ca88f015bec562d183c72848bec9c6a242bde528a06fd8212e69c460149ae6e18e103f078a8effe81fb02444b56928cbe0d87b55058e30c 1678386761000000 1678991561000000 1742063561000000 1836671561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-374 \\x778758fb0c5247f25c7aa0b0e11945e00032cf83df6abf89a6b63a5cf510a62cf3e9be3bfc28fc757b68b4cf3b1bd1fb6dfe035339c6c2d25e8aa51b8a134a28 1 0 \\x000000010000000000800003e00cf2fc071caed1d7cb83569452dd9a76c7af14e646a409614e34aa7755e3c3d5f990b967b348cabfc82bd9e43167e3c2f4f5e08bc0cff8df2d543e7ab8b1f41f8807ac59be6fd98aa5ab758d6d49175fd6e3915bd9a0698d2c9e2e0a1549d793fe5c8590a677b3046e1fda0acf432e29eadfb12e665e3201326984fb74f88f010001 \\x5e8003713f1bbeb315bc72822115b64521715d00a374e7a66b9d46662bdca30865814543761deef7cf5a621e04f3af834f3029eea796b5e955f067b21ae5a90f 1669319261000000 1669924061000000 1732996061000000 1827604061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-375 \\x78dfcab1217a715cf49fb6c20ce040ae63ca3925b6c43247b13b9dada7a90a37b69fe854267e2c3716c93a0e7ded9f1e8c32b2b36b6c87c06782bb0226d4eaf3 1 0 \\x0000000100000000008000039a270426bc354652c5b98b3c9b20bb5ff034736ce707ead573812fc5c4071b8f765ca81a3d4471b51e3ba8faf0e1a09744dd44582a9b9dc693cf86ce764b8eb68fa68c55edf7407ae77162840fedae2398e3c0dafb85d1891015d885502c0c7ed451d29606f70b12113e593bdf7614f0253f71605eaa2bd035b2e7072d4447a9010001 \\x293daee628a2ddaeabcdf2d2e74163b4470c829b0b074acd5fc47a0f3138db9e640aea574eee0d6259abdf18982adc54fec6fd32de7b77c7eb8388cfe2a6fe00 1660856261000000 1661461061000000 1724533061000000 1819141061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-376 \\x792f81f1eab9f09c67c2299635411b32888721cb0b2aabd1f3d8af1f882d01d376abab0b1e032c7fd9c08d7af12156a565e48a65d05f32e51dd4cb9b36fedde5 1 0 \\x000000010000000000800003cc3567db099945af3ad5170b9a1249edbbe423989126b906656486cc73c5a5e740d78c07ee8b8f67447cba88fd3bace783820c8c696cc6c6689a41cb0fe01896f0353b1434d660c3a755691b9a6649dac69cf348baf58612f50a37c50464c2085944bbc762111eb9489d4deee64444dab9380d12a7a1444e39b466a3b560cf3d010001 \\x0240e7477b9a45ca48bcddf5b40b840086c563cf1d821d8db8414b65c30219ccc9e10d32fecbfd2a34588a4498438f9fc2629e5a7c9a6079ddd3d5aaf982c101 1686849761000000 1687454561000000 1750526561000000 1845134561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-377 \\x7a0337f87790951db916bd73f223f019e1852425b41ac34a40b1a9a3f4c6df4242ca5a3413999573acddb61136283ab98767738266a1fa6166835142762e89d8 1 0 \\x000000010000000000800003af4a780a2f4a3581163c860b3fa25e4991efedc5a0d6ed2f9be27ac6a922aba8ee8bdd05a5a21a005af29511a3d4d1a68886e84df3e1bd79f134fcea1bcc843c59e892605359cdbee588c613a4f496e79919347a6141315e9f72129e63ee6e2e6f5d0d46f71202a2027304e449245e78be3aa95b4a511cb0b8541094c0596ef7010001 \\x14ad50feaeeaa6bd183af04171cc2ed29ecb2ef65ca978913317861dbece50af850302e80712971799945bdb38df8698cb26040d02e11f0c2377b0805dd7520f 1678991261000000 1679596061000000 1742668061000000 1837276061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-378 \\x7f378eca7dd0051a8f4ccdcaa93cd62e322e3832bd34126e5da2edaa4ef70e98afa08b743e6143194fd3b0fc6644daa532123d83666d44a2f1a13300b5a57a68 1 0 \\x000000010000000000800003d2ea114a177b3714b9b1815a3f275f9c6b26552b17f83ab47112f60ef88b3ebb032c12095a133d2c22c672fb7132503f6e2bc6d2df62a37b05b38d4e23aba95c6fb663755f7acafc712c80245d0d803e6dde58cc3ce5600dde9fa9e3bd75b4f6b54c74e5283c8d5f471704f2ac9a5ddb40f05c2578b70e8b9c75e610e64ea469010001 \\x64a8750e1b607590c4f4ad5de11f0c32cccbbc39c2a77228ff3aa22209b378d38fc48be31192b2a0498217212158e929a2dd6e30b98099ed91bb498c3eed9801 1668714761000000 1669319561000000 1732391561000000 1826999561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-379 \\x7f4fbe49ce857486e6f857bd44129932a67d8ba332b37587b4b0342f3be9fe5badee8335cea74a306a0005601d2bf380f320eddf53270a8c6ebaea09d05acbd5 1 0 \\x000000010000000000800003c1382f6e63353db7041f4b84fb22e2c1a1969a9938e6200281d600f1ce6b596b76f08ea9b81eb91b2522d3968473d10b0296a1ff411badc750f84e0fb73b850e4649b04d9ecd5430a93e72da96958944f1b652839fcc847b15331cb89c7a4ef0249646832f5660373ea71c68163210320b8153d48dbf72219a49f60d92530cf9010001 \\xf34c9734cf1d9d89ab3c34f1966fe8be443e00cec83a8d6a72b735a12f48505822d43345eb7c05c11671d9c2a05deb1bd28ebfa9bfe52ee2bc0e5ce6502ec601 1686849761000000 1687454561000000 1750526561000000 1845134561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-380 \\x81038135761e09951544d5d2cf19bced1e5bb89e1507887282a46911804f0fdbb9adf3c1da2823f5c9fe0821a8e69afc07822ee4c13bc24c042989d119eaf005 1 0 \\x000000010000000000800003dced034422b74018206a47ffae51a0b61e1c646b88cbd347bfd2b5c0c54fbe41d8666f9238c65691d4adc9333a5053df908bde6b75dcc05e2a57d2244e5000de77355c901cb933175e93185617812e215cb3c8762ec804b0fc99bbd66cc807ef4dde9fef5f348d5dd66c3eeb467f39b3f2489f05f6cff612e028598e8297e587010001 \\x969c96c1bf44f8660644a1a0b4ff05bfed1966a95b30aaffddc0e4f44d6f0c0b83e5945064cf7846d71eb8de7294e8f2d4e963704fe704a64de4e4ae7794470f 1689872261000000 1690477061000000 1753549061000000 1848157061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-381 \\x833f4a2adc4c5890f10f84aa6633bdb60e5e5f25502c07d1be637be2a663b48ede4df36a631a8acd57bf2fb00c675ce8caaf2c9fce0a337ad0d74adf58ffc5cf 1 0 \\x000000010000000000800003b8ae6f74195f66b6ba0a48a94b0b75ef23bb65da485c3f04f078a4aeddbd14c21e319aa5e79c0bc33dbb85d5dab3929f17412c4d8d2e59b34d89c8106186d64f9235cd6db71c808fc68075e66c4461ae0fde409b87120a72f52a431a860e447a90fd4dd2b95e680c70c77c3ad7dd5922ae187ba4d92aba61022b2b621e9467c1010001 \\xc58118f18dd55f5ee232f046ee684bc20e8600a7ad412f27f9ae105169df3ac66e7694caeaddab8238424647029cd62b1863bc8d0013b90895b3415194145307 1670528261000000 1671133061000000 1734205061000000 1828813061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-382 \\x858ba2d937dfae4d0cd6ee17b7bf8262ee3c51912af7589bc1cff0f6de964341116fd83b5915e6fe07c0876377e1b67e382f19117c69e74eedd1fea1a9f006b7 1 0 \\x000000010000000000800003f0407fef534b458e02197fd7d71b71f86c5ed9e542e33eb167c257fd09932602f5c934d98b57860fc0bbd7975202f25939b12bba70ec98503a96e7c13cf3315e844ef2539c9a9dfe68600c1827b0d133a86fcb228a6669e600d610d7f84227d30421a05c55da4bc63e6af3e4ae72f137ba195b0c53cc2199dd86d394ccaeb1a3010001 \\x01f8f4f03c5459fb0e012642762972d81e996a013cc6db69c6e531875848391f308661c5bceb601aec4ba03ff2559206ed8c3b680b93c9f2240f8a713cba780a 1666296761000000 1666901561000000 1729973561000000 1824581561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-383 \\x86e3b43538aaddb9dc028e570441de4fce60f4e5e7b59bf31848f221bbdeda01bd82411b237a4a3d382b24285c0bf42076b2f235e0088d027cdc0ee8dad65811 1 0 \\x000000010000000000800003e1651e5c322a4c150fcc0ad334f4b9537a56830dc6941274e27178f229ba42f7262524973847cc7543e43cbd4dfa621b0422d5324d89f3f51a2ad40688792108560aec095fbfcd220235e01bf155df21bd29e5c84ad1a99c7613a9d2fb0a7968b7ee196cd297dcf272016639e65a331a990e3e0f808a7dabbf5ace688e52fa31010001 \\x382ecaf2a51b9ce4ad8225a43c79ba5417559c0d2f3d4b0c94b153d0959bdfdd3f35c18d828f137c3afade97545334aa11a5d2895ed5af3b8fa22c212ee64e0a 1673550761000000 1674155561000000 1737227561000000 1831835561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-384 \\x86db79e1ecf47176ced494cc89f304604d343263bfa630eafda3eb4f53697e13ecc3bdc17338ae9fdb9e750ae82fb4c986f8989459c76889f588b23bc3a714dc 1 0 \\x000000010000000000800003a8c2c8a8f26e620d0f7a3120270ad85818550e0c0f4b7029691a0a30626ec36e416181bf3711fccb0294c901024a18b8355770f96b9043b4f669f7262cb30ce34a75ec94fac8537aeb1f7ed5393f8e9aa850d94d3c0af68359c76e4208a6bf6f171d503979ef0829f4d16161e95a9e639d2ec599fa9955a1ee6d93203c61424b010001 \\x70d4c35dbac069058715d19b4902002d794b13729d82182db97bc00ff3caa9d4861ec57cef84481da423d47c62e2b4185ab87aad7522a7e26031e235c070db07 1691081261000000 1691686061000000 1754758061000000 1849366061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-385 \\x87ab12ab98e364cb9ab407299176101abeb9f877c1d413f49ba7ea02cbb2ff13c0a41043bac949336eb7588fd3ac7783a27f1b93ef3ecb5cd25b9f033195acef 1 0 \\x000000010000000000800003c5975a92a19b7256687856f4bd2049248b98ce3b2471f8aabda946112fefe8590db36747d69dd5ada41e76f9047b9652273623ea5569c1f0a56c3e0240833abe70a45e0b540c517f86cb17c24a7b42ddd52a8fff00a71b29576536b386b80a73354552fdd3d1ca9ea788e30d89971051d193fb7f754715c647a2b241a1873c25010001 \\x1fcfd9796f3bb9f3dccef943667b416a11b7b91a3c3d9709a68af32c545f30383d704be2b0610914f7abb1bd9dc332b4410bdb42ee002a387e58db46901a8f0c 1662669761000000 1663274561000000 1726346561000000 1820954561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-386 \\x8b53d4646a003e984fada9dcdd2accf6a9cf553bc2891475f341b469910f6332b9ed9b2615995fa95975572479d45bb3a655e2a53bf139b1e33d3f9d4030bdc8 1 0 \\x000000010000000000800003e4e1901b7ca4584eeb70018053761f4355570c9165415986891fcad5544c264a00fcb0361d96b3d8db9c588f62a2b3cfad68dabb962fac3cd754d3f6711a01e61ab01686575392b2f0f3651b9f7537883835cce196c3b36b20d3642b4b7c96a6224cae5217a1123bd61cc649237ea68f7cbddcfd70acd772a0006522cc366c69010001 \\xd8c5770bcf70d674f7aa97ba9b95239d4119db2450482e9637ecfeca564f05897526498ddaa1f6215eaca9a54ee15df89b75e2578a9c22d898a6b6eae9bd2c01 1662065261000000 1662670061000000 1725742061000000 1820350061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-387 \\x8fafb8ca756bf05615ef459d20858d0b3d9e47465cb85e4ac3205415706b358ea9cb82f1d331fe2bc3a266b38edf031273fa7188e507247ca0d8137e87533e37 1 0 \\x000000010000000000800003b3e0e018f9f602087540651519ac0dc2f6d1aad2cd518150ae32ef7447cc1f5bf063c7f526737bb3ff57ed8cb015d64b6f0d29896f6efc3a0f70b7748430eb7e802f74ac75872edea668d031f726370fdc52f71142016d72537bd6903c6d704848fa8549ebbee1f35de92712d3fbc8ee6bc76349f0f60415b9c0fd06747373c1010001 \\x35d0bd536bcb53887a864e4175c50b5f87c71a867654c2a64de60584157e697aedf70b93c958d8489ed76f9a330a087626d872066b39783bbb3bcacff2a6dc00 1675364261000000 1675969061000000 1739041061000000 1833649061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-388 \\x8f7ff816c495fc51eb588b86f60b512db49c7fe88ca57c576d0074442377291d2d09cb72055d1b310ea5391a9dddc7edc6d27fc2468c5f031f8fcd7b00778959 1 0 \\x0000000100000000008000039270d808e317b9aedb3ac697b469cdc03dba6b8298f57184c10b45fdeefd4780789c3a3162e45725390d897035913ec5c9f668f7f494493238e4a6ab6068024b8613d69d30bbacaa5b1d8619eb3a918d8dad80d8b7d0d04fa7a73276aebf6c658ab745ff5b76aeef90ef3ec5a53b61f1e45ab5b37125577b3912f0af31c19115010001 \\xa31f307e104b65a05fe08539b77a03530bdcee5f208ab82440d177879616df035fa2f6f17f8b12917bb25ceeacf1476f620d27a4747ee6e99f50602af00f5806 1686849761000000 1687454561000000 1750526561000000 1845134561000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-389 \\x970f7a014bf28f29a1fa4829ee55f790c3c58eb8d87c53e0f5492725d76d7ed2e7d887711448d126dc86edf20c217c679ffb7e373a18099673d120d8e75750cb 1 0 \\x000000010000000000800003d0a7c611bbc7ebe4ccac60b90f7fb600b7285c4fcbec35c94bfdd39aa3881210528b9aced036e4825fc4ea8417eb56c304dddccc5630493c07556bae7adc5b73925b1c783dbc978894d0a9aed3d219ac6e4f55421ca9415cbe3b3e860e55b90ed57df57cabf92afcf24f5f2fdf59f64c2bced82debb68651db2fdd1a2fb982b9010001 \\x04e1fd2f245c5a25fa71d52ae12ce72c9e9327419c1328ed47fe70eb16ab9e34108dea9e25a6430d8e39ea266f99593d126f7ed418d4f61eccf3912064c12005 1686245261000000 1686850061000000 1749922061000000 1844530061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-390 \\x990372a8ba740ab39a93d16406d8ab46a4c67a30562b9f9c76df77d4e0db55bd6e19ccc2a56aa6630ac7b356a20a482494b6604b9bcb6361125c0e6aced401cf 1 0 \\x000000010000000000800003d98222b5c0fa260af96ec5bc957f2ecd69470de0976f8014421f9b26ef0f9a9328379de10a014e1c7058b5b5aff84aa5a7fc7fe0f15f34f3796e6eb5cee048266dace302acc301143de62a9e1d5f3c520534dfcf77d481c6bb0d8e33fb166c7238eb2179f8b7362543426ad63446f90189ee4ff25265f25e23b3c22df596af2f010001 \\xe4f3ab59b8fda36c6cfefe7c517251308322a23052a5e7a64cec9979fab61f4f4b8d7b7d5a69c2ad58870f31793f5e2a1f0c6ab7ae1663e4a98db018b91aa407 1669923761000000 1670528561000000 1733600561000000 1828208561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-391 \\x9b3bd34c8e14bad8e272eda4d7284bc89303f4715175c87c0fc87638053ffc800dae156da306ddab6cc20134e70aa719d623b5bce7db09c3ef3947d9452f8f0e 1 0 \\x000000010000000000800003df38a2f7a29e456d01651bd728f24d8e90acfb791caac012eaefba2fd091ed4f8d7d240a55785d3b9100e9faa4d8398079429f9eb7fba143345c8eeaef03e1a65aaf50faf6f382db65d9b2cc3851b729eb4bf8fe54a7fb159bf78408b7cbcd2782ac2a626937b3af87ca27b11c66aaeda07177041dcbff910fdebdb08d84ae81010001 \\x5d3cf5e75342ea6df77489060cad3983c0f21a9e508617fac5b8351444236165e87eae0af316cdf46db5e46cbbb2941afb34e839958297aaa93f129f73274e0c 1669923761000000 1670528561000000 1733600561000000 1828208561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-392 \\x9de3102b4c03be0799362ea0f9ece57897e875d7e2ecf56c45d8f12eb60f3acc8ec892e809983735446358656605709a30b927c57e14e33a550be3104abf4743 1 0 \\x000000010000000000800003d09ab405ffc8095d1f588aa50a5028ec2a4ec0baccfcf67aa6bccca9524acd4740e180ab94eb135bcb488e78c171cf0072d8e0b718866f571ee42d41e28e13bf17cafc1ca80b7b8bfc91c4b6c6232b40a7e01a590ef333093adb9420206640495f9b27768be63c8b4b7b39f28a9008de6cfd9577864ae34bb45cd924ef7f7edb010001 \\x334df86ad6bd5afde6bef4c7e81e02bd76f58fc5542b47d6b83bf22bad35c8c877d00825798f36aa4ada23ec69fe2f4e122ca733cc0026326f04f0a49b4f0f07 1662669761000000 1663274561000000 1726346561000000 1820954561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-393 \\x9e474a104c3f8871bce3f99335ec595fafed0e53fa3839be95a7b62ffcc1b65935ff26a21447ba62e10111e274a0540303f4469f506282a047d4f180f758b58e 1 0 \\x000000010000000000800003bab961d3e02560a91e9b77138de563b61edf0f0a85a24cd468cf5ab68f92c792a6c08f080ca51f9d40ac501169560ebf61400f521c43508a916e200152a7931b238ae502901bc3cbc2c17e7f38a90d635a18749b836412523965d35a469095312fefa643c02d1775b36424c74d60e77d6bc1e3602a4f8389682d932389f89727010001 \\x491e659152189b25ebe36e92e0cab9deb690a1cea7edbb8c58543303b57707370de0bf48261c14fe24bfad69ff190523132c4f331babd0e9647fb2e93e525605 1664483261000000 1665088061000000 1728160061000000 1822768061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-394 \\x9fb3a8b63bd6aa2fc5ae799ca421de63a8055fd49c791393ae27851543cdedde914004c15c76959d7ae6e5992adcdfac29e70db0fe52fde106fd1112cabb141a 1 0 \\x000000010000000000800003ae954bdb2b201e08cc57a17e28e1f8022c1c689a6e72298fbce29e3e970c96e87fe069f8846779847fa312664168cdb5d941b196c5797d921598f411a398c510f77657dc16d96b6c244c9aad0521518b7e389b4d041e2d8819623156449f81dd8f390bf25fbdd1942e2b58826484077020a615ad3c88c0bb6f5be6f7434c77df010001 \\x5ae77082b16c5502dd531ce694ff698a4bd01bb8d32c25e64deb3f9edd7a9039c8842283659f71b9055abe0b5ce910c8eb8a28b1619ef44c889d67db0fe30107 1669319261000000 1669924061000000 1732996061000000 1827604061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-395 \\x9f530a6229b434a33d2ce0d0a17c13752216f908438c6b56d3580c4a938a6fe8e196a256137d5a6936b4c75732c18186a101ee48afa4ba50dae92988368674d7 1 0 \\x000000010000000000800003aa21f91faee28a0133206e536884955fe94854bcf1b92a17eede5105613be1c45126db522c9cf46aba00688c55c2f0f920c7a946a65c6f09dec3487f932e7cd3b7f182498ade179e3a8b8e8847993f025540a6e6530a208876466194c93c3fced258ecfb55fdcb0740895e9a9575de42ebfc7c2f877653492956ccd9925f9369010001 \\x165828e066e8aaeac316c314911724889ad0b57cbe625a9b38dd922d71d0d9fd5a1b45591d30e091aa2ad28b85faee5cc94dd91006778cd163304ef80c060600 1674155261000000 1674760061000000 1737832061000000 1832440061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-396 \\xa353e64f0ef90a621a684b3cfd65296c9dac2638d05f04c475504bd8eb08f0b47952082c969cebe76970a5a21bbb30b8dd6d787f30df74f9c4ee5ebd46cb2d68 1 0 \\x000000010000000000800003c93251d935f8e2c5090149f9ca8720462738c7785f133b038ca9f54f49c456d2e349abcaed244505801c42e60b8b254e6031228e8283b19b1cd3144757f8e63bf4ce14b2ae76b932af881f91203c13b982dbe235c38f2d6528c4215569baa8f1904d1055c8fc11c36544f9738921bec67a3e46630df6686370ea8fd6a1e02c8f010001 \\x9f5b50464aa4e085e8cf552c989c8f10351f858ec210e48914df60a6127afa697f1db34ff4d1202e1abe9621cb2f099add04f2d43ffbdab0ff0a6df76ee74c0e 1681409261000000 1682014061000000 1745086061000000 1839694061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-397 \\xa57f7a6d3ad54d89ff27a171724a4782c77129ac91c455ba73c1d5b4215f1e5eb37dc49864cc6e343960559bc9f67a676455cf30e23598241f0387d64a93c09a 1 0 \\x000000010000000000800003b5be2a765b85def12943e36a30fe561f086ac908257e9b401bc97b7eb3a03c5e701e3a88405b636f847b5601793e82e9d583da117ceaeaa5f524958119577aea2856815b91da1c97bdbf05b521699d459f4dc3f2f2aabca5ad6e08a8a3f3d56df588520e427d3e3bc7b8e0615b1be5c875a5e1f32cb953e03049c7189603a089010001 \\x91759d819920ddfa3b37003fa7e6a9b179f221ace2cab900096c48870d7f63ddb71d50a989f7174db55995187a771e96edb6a8929eb7abcef1e01fc98230560c 1679595761000000 1680200561000000 1743272561000000 1837880561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-398 \\xa6172fae654584c41542fe1f4ddfbc43adb8f6569595f1716ad16e756be3cc7f95cd3fbc499e4e73e61666131769a2d520c3db487c144607a7e48dda8d853955 1 0 \\x000000010000000000800003b2390f3498469806c61f819136e47d4693ecf5a58f0d3d1bffe9c289d58a1e1174137feceb4fed878ce07a97b0332b80d96450c94cb01b0059ea20369b18463e52f97aeb4e3952a0bf9faa19d9b0b4eb9d24909483f4f982e972b6f1811f779a649825f70224ab9e8ce2b0b388e49b089d58d5d414ace0dee1198eb3594ec1bd010001 \\xf91ca1bb3f5382015e90a82782f460a33def20916e2d1fb707dbdc488497d30831ffa06172eda10a1b04117ab6e6ab54550cb2737a0c987835c4b6fbb87b9e04 1663274261000000 1663879061000000 1726951061000000 1821559061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-399 \\xa967a1e06f1a5632922561502fc9ae66a79e0a37b8c758720718f5b85c98bb4548ab5c9407fe6f0617f66ac1e000980e34aa74b7c460350c960124dcec5215c4 1 0 \\x0000000100000000008000039fdbba13d6941542f1d74fec3e55f3db137f0397d208adf295602aca19817bc236e29f562dae8bfc44e086a25c0b61541864b7a2c88060e414203a52e0afa6b40fe0f079389185d45c0b409df544d414d0ebc4e38db4252823ae3dbd6a4ac6b923f3edf04227a34c6e4cb7c85ec09746eaf936308f82f890512f56d88553d391010001 \\xe495bf06938969adbce809fa6fd7afd5f99cca3f73d517bcfb83c69931240a6bd1f5dcae06cb2b6a5a4aa4b6efcd52b652bc7f9afcc55116a0829c4772686f03 1670528261000000 1671133061000000 1734205061000000 1828813061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-400 \\xb7ff19919280b2400922d3ba69b99aae6e89a747eab2557adc5fb14a4f81dfa968e4579013644246ecfde8df9b7c3832f294701dcf7a8dadd8d4c643e07143d0 1 0 \\x000000010000000000800003c1ac6ae4c7514e4168d6db8ac48999f497de070294b0fd55f05fb1af8897c3f559b550040e16b1250bc26abd2d691deb331877ae5ef7d5362da485828b3f08d08ab55a2ba51d15195fe28dece1589c8f13cf7963f36aa7b8abe258855402c8d792346ed1adc9b0dadd981d060d4a31d03490e587bd2f84860aa6cedff2fc86d1010001 \\xa2b745c45423103469df4fb118129cdf84940f0481395e964de6ea44eeb47274b61d8ceabe64521cf3dc1cbd406d4db026aab11bf2565143fc4e836bca095c0b 1687454261000000 1688059061000000 1751131061000000 1845739061000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-401 \\xbfe74ac87aaa32bb0602159e153e47ea0ea0a07bdbd01cd4a48d53ab62f1b3f242daf8e6ae8daccbab1bdc5a90dbbb9283b33bc07225569522bcb22221ff4a35 1 0 \\x000000010000000000800003eea8faf0c43e4d2fea4c378fd74f69ee95cf2f4a51ebdc77e8b2f8e8ca59b5de76d3504250d71dbc97651f3d463a4f10401ce6b69d1599f557a36efb1a46f9850666060f10008cd2e360eb72097459d20e238f81fdee1b3f902926e0ec7c2845658156c9f6adf366aaf51c90e1aeda49b50b7261560c7d16273ba4dfbef48743010001 \\xccc159a3825c34ccdd5ccf6af5ae306450c4450dc022acde6b146c2da25aff60f9e79f58d79e5624c229d750e357657e74ff2db7435078eaaadf857a6d996209 1685640761000000 1686245561000000 1749317561000000 1843925561000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-402 \\xc08fc4c4c7ec7c798c0ff9f98f7a1c7f04b51f0fbec26a339874ad6aea669fc927a6940c089c0640ee4e5151536eff4c292e84dac9ac21bb2da825cf2cc4e118 1 0 \\x000000010000000000800003bdfc98d7c49d1710fdb32b663adb0e734bc3bb34c445426c0f272a41bd1e77a4a110db149c828c4f5703c076dfaca5349269c5448d9ad8493e02b68e5b4c971db791b17f033c13980d65cd36ecd8ab894ad4890502643c34f54b3853f6f7fd126c9fc58dbfd12f4d48c47434f8ef7e46de5f85be9fb7d0dbd44b6a85abb61c1d010001 \\xce7caffbf7af2438e22ecd884f234ff17c81429e2a49dc4323fea101016d76649d14c3883cbd1917719102c2edc6b18115630c04d4509b67790405e06127ff04 1662669761000000 1663274561000000 1726346561000000 1820954561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-403 \\xc1e389d0b5b54b95e82269c4d7c669b4668c280ea119d65f0505bd060f870f45f5ce8b97c451f6d983acf69f87e5f168f4e6736b50707c400a04eda341922199 1 0 \\x000000010000000000800003ce387772c6747234da9f25c3b4c6bd5372aac8f08475faf55d9bca224bbffa59e6d74af48f884b8ba1f373c3b4e89b82f30702cad90046658c6cf77b5e98168f0ea44ce19a9871d5a5e5d16bb7479f9d27ff7d0ac390e79c5fcdd7050173ca669a0286345c13cfe745d4b2555d500ecb16330c6d6ac854d10400e41f57a96401010001 \\x509f35ba14f064da53f2b940c3c18c64ec7bf0d28cfbe54d09a101caab73560e584fe48b4adfe6307af114b4e7b9a41ebd572d27b5ef8c8595486f21dcb5ba07 1668110261000000 1668715061000000 1731787061000000 1826395061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-404 \\xc1bb4baaf3d786a37631e80a9ed799f423da4214fd42b2f21d5457ca7fa0a60d3b0d8fe8082049133a665a68cb250e2a8a638f4f0f55a9d04e15ccfea80e3bcb 1 0 \\x000000010000000000800003e8a87a812f922442736c15b1bebba523f5d7e7c32f074d8a72df8fecdd30035cf01613d4c39ea4f9151f36227547e027c7955283fef64cf9bdb1e8c6ff6a383169c94d3e97ff340c50594240a2f1498d3e568946715e3569ea85b25d0dbd94c890b6051ec4cb9a7adee9492a50831b9a1b1755a786afb2ebb4cab076193cacaf010001 \\x0c45bdea9382a726efe7c60c11a4b9fd649b73358da77d3458c9fc6cd6a3a4604e43377fabdb06a2c46493210867ea6bcef09fd702e9cc29a31be210e5288801 1673550761000000 1674155561000000 1737227561000000 1831835561000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-405 \\xc8bba3eab71f03616f5e623a43d2cd40b3e77966e4c8d9a63b570eeccbe87b7f8b6bf229e71ba7ffb1db62b84e4736856e7a250edc1a28a493b6538f779e8445 1 0 \\x000000010000000000800003caa215d84d98c4bc77a0350c39334c0f53080e0971a8ba9d55e5674cdf36e6796d373b90e4ed625ae22b36c5611cfbb75dceb6836710cdcf60a926fb169e23025087f6bcf29a57e59312da8e911d6b56a9fe679e67a74c34619ef2451b48247d1a65681fe21115f2875708e6f83fe52478bd09aa249ea20a62f30d8cb2075f8b010001 \\x4e5f02a23e84499f8cfccef26afdd1e1b0b66504719ef0ea3dad8a1a06565c24ef083f35cc1914ec8ded2a1d123647b867b88817623e194699c8920eba5ea80b 1683222761000000 1683827561000000 1746899561000000 1841507561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-406 \\xc95b35eb839ba371c04707e442b249341bcf13daef2548dd10355686fc45058dd0f69236c6eb703bce21d4398bb2ed67139ebb7625df8fc2d2e443112c17a696 1 0 \\x000000010000000000800003c092f17811cf787fd14dd086b5d44017b82a875e3a73f0b3d890eb75d4f22d2debb556413648427b4bfc7ea7974401dcd999fc3725f4a5b157d950b5552b984b9494cdcc9e3ce344e99f788eca998843491cc265e7d9bdf0ab38d8b2a666d6c052e43c01edf956d56989b179393d15771f1882871a954f9b6514a0eec09f13cb010001 \\x8ad83453696a75513b805db93453e52d9f4db2a8f9d4b03b5d8a143bd74b7a7ef1e7bf9cea73272410cb0c714358bc33faf770344c4a1cd76dab18b2bb380400 1690476761000000 1691081561000000 1754153561000000 1848761561000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-407 \\xc9d7b936c32fbbf940258e3b82bc1133964379dac6c7f8830a711d3b482eb3dd11bdbcbabf43a833ceb9b88f32eebba4bd8ae85f0e4b417206127d52d7484782 1 0 \\x000000010000000000800003b84fa45e8e6609a6b79c8fd38bb883d5c5aa723fbfac79e6d8f8e589357e9fab3018d44e3b7c8b791f61779dd36fe28198377c20a5b7ca42124f59a5c7cfcc2fa38b8a3503022f740055b0856d52421e4f51aaf475a78f10549eeaa7d688b937d74757ff7cb8470a783244867576074e3a156d03d69e5ad6fe8269c012c76fb3010001 \\xfbd2f30d9dd950fba7c25fb5bab68f100aa81bc3705c6167f1dc0897c447250d05ce9975929028ff1df043ae9572d0d01ae970f96e186b0d1292a3ecb9f64109 1687454261000000 1688059061000000 1751131061000000 1845739061000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-408 \\xd10fbab16cce83d3c216279fbaf36557687d2e6dc5717eab6566cbcf3c1c461700131eda6d7e025b3c8c6e231064098ec000ccc28271ded748f3105763d51844 1 0 \\x000000010000000000800003caf8690b2b9539f8590017ee1d3c0e25c1564315576630be524f721a73eca99ca71d44e2ff483fbd4e3466724b5f5ec30350e4072132e31a3c83ee9d6069d522d03f7df75c31e26f621256ae91ecb69989f44c07edc271d7fe1f73e7967ada28e385e26b944b407732d2f1bbb8b55587705f79ce7f69870f34285ac225dddc01010001 \\xd17a5af7a147b569e5ef0b5dc6bc4cb11221752354d5640d97997d8cd9d307897ba5dc65730c20138e1681c66bec5f76f99e1c595e613466d5363e0607fc2904 1662669761000000 1663274561000000 1726346561000000 1820954561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-409 \\xdb3f97d9d3fec07b10c019979503f266ff6ab48636439e11c6119840fb554ceaf98d994828566bf105e1540035874cb0b571f3b1b749ac3adff985de10d1de30 1 0 \\x000000010000000000800003ba3db6634e88d3a2278a1d469b3c7969f4eb0a7a276b11e763cf4cb19e1ef2f0fdfabad2241e174a2003e61bb4e0d24e172e93701ce649d79aade2dfeb5260b30d2022683c4cefff7d44fb073ab85e259131f7f0056bcf2bb730441ed5c3b7943cfc70e3426b2e1bf63eea1e5bb18ffae57a8292ecc538d112e4e9a28d5d3d8f010001 \\xcefc613cf2d0110305c964e3c7f23cad5e6c67d5f5addbc9f25f4bae84b99f83c344d94e57ade8ca6b5307c43b036019dc84d5bb3aa985ab2c865c395397da01 1683827261000000 1684432061000000 1747504061000000 1842112061000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-410 \\xdb6b32b56f90ff42cf4249a6ba6000dce8ea85f590cacb3050da4d853aa332ea8eec6bcfd0ef994c140f1fe4a7b8db7ad890f89821bcc5e5c6b61b0c9f1855d9 1 0 \\x00000001000000000080000397f7fee8bb782dbb01e7bc00afef87964676de0bc02562bffb3527ce173ad02ff5ade00d53f93470b80aebf4c278555beedc12922ecb2ddc6b5ecb7c6cde7015f6079c5f1daec32e0f9e1e05ab3c4ec751482cb530051a6b2688456f9116e3de988033394f27347649e7a2668722d9722d6b6ac9d4be63b80899c5bcce61ff79010001 \\xaf38d3ea814580654ce4d3d367eea1cf416cb59a9955180bde4f70c1ca3e5be8221238835ddbfcba9eba578498f2b595dc37b11feea26ab6dd760bc6d90c450e 1672341761000000 1672946561000000 1736018561000000 1830626561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-411 \\xdbdf73f60a708481492ade55748be2d4debad450c8d80a2a4fe954aa050befc5ade810ef02045a9e9956bb82903fa5e3333a4d5b4ddb3af2570dad86ee5714b9 1 0 \\x000000010000000000800003b5c530f5181e45569b07fc8dd91409576cab18d7ceff3ac7e5cc3b96541434f904fd939ea044668f9fb082c35db2525bc8aa6bde52f4eeaeb6ef70f306ef2b91def47b8ca2d5890d18a50ab4f396df0043210d6a089545aabe9c1ecb479d6e2d64efcfb28b363ad978e4883433234939ea2d298003f35d64b055b766881db31f010001 \\x1cb63ac62359c7a52d462890408a150cc936601e235a25b8759f85f64a225e5a19f0807bcceaef71e0c555c1f9ab796c63ce992a446e9cd3b2671b7b640d5109 1683222761000000 1683827561000000 1746899561000000 1841507561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-412 \\xdf8375eed669936b26c4c13d10d49508b358ed580c7d9c8f9b2452728f2e5c41488cb5b3532b4cfca57c16e5f970706db8f9a0d4b0d0cca94d47ade6bfd4da8d 1 0 \\x000000010000000000800003eb310e49209d7c182c73ac111500cc999d17c78f93865488a403870f0b76def1c794d3ce3685f1b393115ae3f53603eeb304e8d5bb008e4c84c002a058f9daaaa0a48372545d342f6e18b7d2db1fd5c27148672e42cae1bf88c235c5a05cce295b547e9d0591d7d58548a6344b25f892b63e66d18eabf3f8afb1cec6ec49b189010001 \\x97d722a49f5c390660e5362282f31b6958e50529ebe9ef347ea3f8b753da01d7465e9d5ee825ef492d6739ae6d9b1c938114d77ee24892fd70306261aa375603 1684431761000000 1685036561000000 1748108561000000 1842716561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-413 \\xe04f059c5fedc52ff0a04353550ff966f4c39ea48542048e4fd683c84e4e24d0126995ee8e90295a1b20ccfd4eb2168c7d4d8f4d371500cdbbd54d9853817336 1 0 \\x000000010000000000800003beb56e0097b46ba57eabf9d48205d1ca38a78b790297fafe87b2d966c13278a212811aeb7264a4394b44f88691a14685cdd33f1c5c9f6250302cb216e0b5e59971ea5964a830f55a91a75e28aca9ec2bc26d5d0a88c8810af9d56845fa2a2afa23dfdfab3c61145f48cb26fb214ae4ddf8f8eb7da2eaece48d989096efdff95f010001 \\x288bb986ab2e4fc377ce95c356ef213c74c6bc0704266a35ce3f9bf7d3064204677d2bd1a82999d22eadc3a914b430c8c80a243970e5d3fb2d62b3470621b208 1674155261000000 1674760061000000 1737832061000000 1832440061000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-414 \\xe0fbcf5054ea93db0c4111afa075b449b3743bc9ec36cc07dedbda78ddea3a69d128c283354720b6396b24d8aa50173b4ac2ef02e0719e70bc7ed67608fa9533 1 0 \\x000000010000000000800003c4d87c5b7cb1e311026cc48afa0828e1da3cbaac7705de50215891217a41e8fba2bfe73320c4a6b6a56c0da84f25f2ca21076e66b74dcf91c505229aedb0025e648224673abaf59b7d3a265f486b0b3f89c5b70b05c7542dc22de7e6ec48ce00b4349db083bffdb838bbeb456083b0df14f6beecb5bd5c88ce53a5bbbbc1f3c5010001 \\x57926362d019edb07ad91e7b045abae3c6cf7002128885a0818545d6229e2f568bba2c37d1e81b3e91d92e21567057fd0a01af4438acdf58e41536a7616e090c 1675968761000000 1676573561000000 1739645561000000 1834253561000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-415 \\xe45b57d72887a480331867116c9e378a0e5cd98dccef8d76a5e16589eee7f99eb79217585905e9589538b05c9b5fce5e8c0e4be6d94a30f6b966c24581cd235f 1 0 \\x000000010000000000800003e2ee046b7afeff3b6bf053484b044d1a2ea529277dc5690126f63ea6a856e46c2b28971a1cec1d9db782eb6894c2c6ba72c2eaa30fb4fa0ee1d01efef062056e519c15faa44bdbb5a0ce120e22ea99e03444fd513042053ea67d697c9645948c41768dc5a5dbf5db308aad42173cf07daf88cda7a9bc1fadbb58ad8c4b7fb63b010001 \\x78698f0907377eb565658a68e5516912548920f224d6e29b7448435c05fccce45661cc181523580cf8dcba14833522369a3afe87545597616bc1d6e9714a0202 1674155261000000 1674760061000000 1737832061000000 1832440061000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-416 \\xe553117c609fe644a6182dd3b2466ed2b8bedc29687a77eceef57e366278d200ee3f6204cd3e961714276446ce85013f6d3f7a391a03c77943c36c09919b8c8f 1 0 \\x000000010000000000800003c7d6188fc9c24c2d1075950d976c8b374a851cd08c607c313a271f3e5e23d74b15de1f4ee7b4fff9e3c2de76992e4ac9aa5fb8efdc4abd488566d473488e0e85dd5df0eede310470609a9f5bd791e3407b3ef667723dc6678754b974660192321ce7f3e43c74d25902d7d84e8ff23c109777217b5bdfc3b54ffae8e33555f373010001 \\xf8ed462257d86b3c67e3b23cb2148e6e7213dfcf6071a8736b9fa3c165bc579bf05882280576a4cdded6d931b6fb3b942812a703204e98b75b0f6c1c52fcc504 1675364261000000 1675969061000000 1739041061000000 1833649061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-417 \\xe93f3dd918edad7d86264cc54d90109d524f174ebbfae26ff06194ec02fb1cc8ff893ed7a515e9a895d39fd5d61a82dc229e679eb2108e786e4d9bb704261f06 1 0 \\x000000010000000000800003b885469f2fa6b16b30d1e37085268913e2434595741c17f5081dfbeaa7ea55b9b6ecf77c39c33f315ae51aa17b75c8455eaca9a193a89cfb4a734f32dad41d7f62ca4b43b099d029b89ae7ea6fa4fb0e1f249408f13fffbb84812d16d67a0b9da266595b7a38ac0e6dba446d912cba74b276fb6bbc6e9545ccb1301e3408d6fb010001 \\x2d87a5d9d8cc5597bd688d82ebc326a5c527b93087765e8e7297a82b6c18bda52f04df861fc4f7ef7146f5490c8f3b7fc7b56d0642cc3f48916c765733eb2e03 1690476761000000 1691081561000000 1754153561000000 1848761561000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-418 \\xebb74be3017b011f57da9fdfa65ca62368aefb1169c5e44a7d1ee4e324567261eabd41526a7afce3350c4412d631d963d8f665f332a2dbdb73195b77f8bb51e7 1 0 \\x000000010000000000800003baa2c91630a050538c1bbe261fc1f89a7ab8a206fe01a811c83cb7a61644fd733f2c595175a1d91d37b19cb9ad7e51af0d11e8cfbfa6a5cddaa15e1682aaccfc171408d15fabfd410e6a0874524aaaf732f8d0c2e83eb7b8aed3b80377b577e5fb98cf337e7ad11cc98c53709b4073711a55a5828caad79c4bd305fee449ae5d010001 \\xd7f68217c052178aca0d6e823f6cb20ee5d353618e521622097a41c40fbcaa9990284f04a0262def6a1cf44470377eed0383ff8f89b2a181485063134815e40f 1676573261000000 1677178061000000 1740250061000000 1834858061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-419 \\xee47b72ad85e44d4909db961640947f1e789efdec22379b67d9a3e7b9d2024ff56096f5e824b7243bf1aea00481a6ca03795cbfc1de699b0846486a4b14cebf1 1 0 \\x000000010000000000800003bde2bca722814fc4790901a93b868dc753747076660141cf9cd7a2d139b31a690ce8bda683d994379bb0ee91c87db4db8d9ef09464b0028ea7c0053127df9cd2d0c81089e90fa3357ced07e62310646b90c2f08f0b12a9ae8a0d5af7bf5e34af6d9d78ba2f9185022c106a7b9d62da6db1864530d9634f14213f6b7b1e26db09010001 \\x18df66498a7efc14ed4602bfbb0b3390ad67e05a95702361eb873cfc33c730d4e317fbbd18913369c22c99c25256e20893dbaa7ec1e064f6386f590e5241e301 1670528261000000 1671133061000000 1734205061000000 1828813061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-420 \\xef63e1fb97f84aaf72176743e23e87acc8f5ae20a9187043ad3507e9d6482a8ef37093cac450e5f98d32764ff5bafc1c9ed5d07484965588dc799063a32978ae 1 0 \\x000000010000000000800003ae80d6b8e02e7e2eba056cc93e3a36370af6599d23560880bd174b07d27247ee6c499dade8ab36a83ee96ad987042e363f8939026cb17004f748ac58824281dce8cb24f5f7963875103f8d2b199abc523585fd1d3e523bd723b8fa24e47ae9bde5e92fee804358b8823968045bee59a73556d69959706be1353f26877f83052b010001 \\x74198dbb2fd9678e6427e3db2e33cbe2562781bd72ea3bd150f36225f9fd054d3faa3076865ed67250aaf7a47d2f04389e22deec0a6f0c58c5056c54389d2d0b 1677782261000000 1678387061000000 1741459061000000 1836067061000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-421 \\xf64bac42d6dd1712d321466812e1e745d3310d0450e92a3488ed007844e1238d52c662a2e38861cba061dab1c8ae7543a1a37e9f011e0dad65c058978d50d2a3 1 0 \\x000000010000000000800003c11433efea074b67980a8350343e4980f01cd54e44934331adbe40ca8364025fc3f7ba4800ed6c954aa48f0d512d2b26d1c43b306b58f53ced37ea742d9f64eb1e5236ae8ce0af01ec5998778286c49e78ad4adf63c3b560511711a655c5c00319422e8680ebed462d7f9da7f99c670e9a2dc9ce4b31495a0b36a31bfe6006bf010001 \\xe5621579eb46487986b4c0c18a7cb9b710151e3203754adfc54444a509af1cc8434ec8c2c3610ff9f10ea7a9c9453c4d09dccc4b0a173aae9ff553b02e7cb206 1668714761000000 1669319561000000 1732391561000000 1826999561000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-422 \\xf8279dbcf00bf86da94d3300e1b0a6a346315109568e98e968b97fa48f44247fce6bb5a233021c8e89db2785fd75da8cd48ad3692bbebc50872834f70483f26b 1 0 \\x000000010000000000800003b87bd0cbb16131d5bee06beaa631e74a0e6d99a01dc384be770382238d93cdea7ea4aa80ded2db4e6d8f5d8633179ccea3b64f7db0d9f8a771a81d48a7ab5cf70b6c0b506c696aa39cee88dce10d066d47c01c659d6cc8d96fd27521e072ac18788d347f4b9fe1b5c36a48f9e4ac6ddd2299626e1f95d6c3b3ed2ebefcabfaf1010001 \\x479d3f924346e74d395325b67504866c9edcc2193339d79730459fced2da875afcb35295ef2a70753d24762efc226b70ff75bd8eddc401db3e2ecc45a55ecc0d 1686849761000000 1687454561000000 1750526561000000 1845134561000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-423 \\xf997cbdec3c9f22d687bbccba7e6592f24ad5d4e63d0f79cdd345e5b333c65f1aeecdf5fb6372fabff3c42eafcfc29d4b26816e0d713d558aa61afc1f2fa267b 1 0 \\x000000010000000000800003bcd8485083f625afb47993eb3d0ec4c1d16347ea3ac4cfbfe27d3512f1a29742b6308f3a48c8833882da2b07ac4213e8528fbd6bd28be24636e693ad62484a8864d747e82379c35d8d622c340797a8e461d34f30bec2f1f89b9000d1b8ee25723bcc4c7cfae7577b04b43d2812b2dad13a59a8531b6cd12d27eea3a6bd971a01010001 \\x2ef1d36995c073b756dace2d0a6af4bb8c82d95ed5adf807a1767fab57ccd07f45cddb9c34827901e301d6a3e87180745a8b40a0688375d9e495325e7cf7aa07 1662065261000000 1662670061000000 1725742061000000 1820350061000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-424 \\xfcb7df20dc7acb7ffec0364b9e1dcf408c0329ad656e2ce7000bd39fcf02964436162781534a30ef6483b4b1b726ab52711cc46420e2044bf1237e4abec8972b 1 0 \\x000000010000000000800003cca198684ac4df61638fe6f920ae4d0c5b87f9f62e4e2dff57ea6c0ebd205122f4bbb945f5eb73b506370a52daf27e81a16d1a7dd9015e7d186d1b281ac9457552e96d761648b9f9259a543945cfe502703b251f095e5536d04a372d4dcdf4882e48590598f969c2b0521870ec6fa74e68780288ea71f16774f1fe87c7a57a8b010001 \\x125de2da649d618d0bf98e7dea3c62fdc9e054c4e0624bf853116d3e0820b6bb18dcef259dd8246721e3c319fd857bf3201362ac74d00a46113f5baf485f730d 1671737261000000 1672342061000000 1735414061000000 1830022061000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-\.
-
-
---
--- Data for Name: deposits_by_ready_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_by_ready_default (wire_deadline, shard, coin_pub, deposit_serial_id) FROM stdin;
-1660252676000000 1455367116 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f 1
-1660252684000000 1455367116 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af 2
-1660252690000000 1455367116 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 3
-\.
-
-
---
--- Data for Name: deposits_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_default (deposit_serial_id, 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, done, extension_blocked, extension_details_serial_id) FROM stdin;
-1 1455367116 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f 1 4 0 1660251776000000 1660251778000000 1660252676000000 1660252676000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x3055636e89f269e560df6e787197f475d0ee80ec7fde580d98ebd494c66a2c7f603d2e8cf3f4b5d7f0119fe35707df4a27e45cd2c32a58aa6f66f7f926b14989 \\x682901c6597276745a08a1a91ce67062dbcf9df3049b4ba204595b20119fc8d042920bebbee4a39ca6b5ae9bfc463792f91206c24c7cfb98981ee77558927b0e \\x2b8270802bceddd01e56777d30c8a81f \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-2 1455367116 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af 3 7 0 1660251784000000 1660251787000000 1660252684000000 1660252684000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\xa5e69e1a65ec203aafa4dec8d8f3670ac54e97dbed5e3a274440d57e5432c1c99191006515c26b11279394f71ce416ee9b1c5ad881411fe0ee84a14ae61bbba3 \\xeec2892e88844c6b3cb446f3eaf3ebdd6cc3acaea5ce71fe375db877b385fd2f4a0a636dbb6cd9367aaf2a5228791309919be7d066edaf32222522e4e5d79c04 \\x2b8270802bceddd01e56777d30c8a81f \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-3 1455367116 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 6 3 0 1660251790000000 1660251793000000 1660252690000000 1660252690000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\xb44b55b0bcfabdb7ad1c10955b62d7f2674bff99c58610e73f34f1d12ad2379ee7b9051c2f1706b23e1b94c93afd812c407f969b6c09a28f8ad82125697db1d8 \\x3a805ae8aa1fc95265bace1cf63e5ef1bc36a2365816ec5214efdf2a8407235dd5f7b87bdfe580218437d09d0d0b8ea1d80d76ab9f13eb62def18e487cc91a0e \\x2b8270802bceddd01e56777d30c8a81f \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-\.
-
-
---
--- Data for Name: deposits_for_matching_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_for_matching_default (refund_deadline, merchant_pub, coin_pub, deposit_serial_id) FROM stdin;
-1660252676000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f 1
-1660252684000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af 2
-1660252690000000 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 3
-\.
-
-
---
--- Data for Name: exchange_sign_keys; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.exchange_sign_keys (esk_serial, exchange_pub, master_sig, valid_from, expire_sign, expire_legal) FROM stdin;
-1 \\x03f5e4ee136ac823b2324d057c72a4acdf006e4485fb00a8cb6fd7a7d95cfdbb \\xf0d5615e090ffb1c5196dd0a9aa6a680c9731f23c8d7aace56edfdfc9e4d6fb71a9a81423134d69f6b6e3a737d2c8f874e3fe9f3c9fb145823628ce6a1b51907 1682023661000000 1689281261000000 1691700461000000
-2 \\xc53e68243951aa823c4df89efe2a4768ed056b90993499889ac22d8d38ccd736 \\x074668a2dd1e4299108fe8666fbfaa935167341390d0b26399122c3d25d2519a7e30beb7a671b4fcdb89d151d981062baa6ebbdb115458464d047205a8715400 1667509061000000 1674766661000000 1677185861000000
-3 \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b \\x3a1198bc48724c589ce73c4bcf89635166d15d08ec037466bbb1be2aa7e92163babae1e7619803508996c5d089a2479dc2e6651dc89afafb138be4492722660f 1660251761000000 1667509361000000 1669928561000000
-4 \\x8859787e9d258b1873a2b914385a3cf15c8332445e3ad73fa3facdba7a8978af \\xe12e0ba4ac5fe84e1bdc2c49969f123485d6a9481667e38675a7e627ac704aef2f0e0a776ed19160d37066494e87863952de293268329b2d3f1f346b3195020c 1674766361000000 1682023961000000 1684443161000000
-5 \\x360a6fa91038e3a6e4e740f719ed37ac7ca84b3b69cb4ec49e701043aef2033d \\x9b8809aeaaf249e93b4ab2e4bd7eb985dfb0fafbc84cd1ff1aee0223d4976bb721efc0a4824574b0aa28d860c4fe1b0b3a8b58788f7e12cc93aa4d57f906230e 1689280961000000 1696538561000000 1698957761000000
-\.
-
-
---
--- Data for Name: extension_details_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.extension_details_default (extension_details_serial_id, extension_options) FROM stdin;
-\.
-
-
---
--- Data for Name: extensions; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.extensions (extension_id, name, config) FROM stdin;
-\.
-
-
---
--- Data for Name: global_fee; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.global_fee (global_fee_serial, start_date, end_date, history_fee_val, history_fee_frac, kyc_fee_val, kyc_fee_frac, account_fee_val, account_fee_frac, purse_fee_val, purse_fee_frac, purse_timeout, kyc_timeout, history_expiration, purse_account_limit, master_sig) FROM stdin;
-1 1640995200000000 1672531200000000 0 1000000 0 1000000 0 1000000 0 1000000 3600000000 3600000000 31536000000000 5 \\xa40b9fd7f50aaa05a5e8802256aa8ffb091af0491ea634baf6b50478b463200de2b72bb70f07821c2ba61bf59c817cdfd88d576fdc12251273b7cf8993180409
-\.
-
-
---
--- Data for Name: history_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.history_requests_default (history_request_serial_id, reserve_pub, request_timestamp, reserve_sig, history_fee_val, history_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: known_coins_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.known_coins_default (known_coin_id, denominations_serial, coin_pub, age_commitment_hash, denom_sig, remaining_val, remaining_frac) FROM stdin;
-1 195 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f \\x0000000000000000000000000000000000000000000000000000000000000000 \\x0000000100000000dc3319a8a18cb2f009be5011d7ffc37605403228ce60af852a280c91cefd85b41001321cd159b6c7e59c9a7fc39ddc2776d4f6f768f695e82c98e5200e8c20b905e94dd665774152aced4ae5b2e2c12b3d99199f545c247b7fd337749d6aec0e24e9199d8f5c4c02eb94c7941a2ddf9572cbba28f326ef9c1c55fd34eaee5274 0 0
-3 253 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000063030b5003dda821ae9555e65bfe7c778bdfc64cb7479ea445b99786e812488d7313dc12ab6a91306bd837ebb5c5383f43020e8ab34af3a5ddd802ddfa6f3465305a7d494bfacbaedfd35e74caea0d2e4c04162275cf47dec0bed7599d03b478071423249be8267bb4a2ea3ef7fad5d7716510b88995c19e7d89c75e65d94aab 0 1000000
-6 190 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000046cc1ddf8c431193ebcc093e93a5d7bd85615b21606d4532ef1299d3976fed2531270a8e7a1b85e0e177a227f8fd446cad3f3bfff6e2bf83b213d94ccfa2110f5e4ff3a940c885831b0e44a3431866cb7caedea920aabd5c6f2ab8fe383fe1f8312a9525262c020183dbd6ca3283f31da7420f786a285c25fff730c5a0acf5fd 0 1000000
-\.
-
-
---
--- Data for Name: kyc_alerts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.kyc_alerts (h_payto, trigger_type) FROM stdin;
-\.
-
-
---
--- Data for Name: legitimizations_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.legitimizations_default (legitimization_serial_id, h_payto, expiration_time, provider_section, provider_user_id, provider_legitimization_id) FROM stdin;
-\.
-
-
---
--- Data for Name: partner_accounts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.partner_accounts (payto_uri, partner_serial_id, partner_master_sig, last_seen) FROM stdin;
-\.
-
-
---
--- Data for Name: partners; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.partners (partner_serial_id, partner_master_pub, start_date, end_date, next_wad, wad_frequency, wad_fee_val, wad_fee_frac, master_sig, partner_base_url) FROM stdin;
-\.
-
-
---
--- Data for Name: prewire_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.prewire_default (prewire_uuid, wire_method, finished, failed, buf) FROM stdin;
-\.
-
-
---
--- Data for Name: profit_drains; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.profit_drains (profit_drain_serial_id, wtid, account_section, payto_uri, trigger_date, amount_val, amount_frac, master_sig, executed) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_actions; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_actions (purse_pub, action_date, partner_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_deposits_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_deposits_default (purse_deposit_serial_id, partner_serial_id, purse_pub, coin_pub, amount_with_fee_val, amount_with_fee_frac, coin_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_merges_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_merges_default (purse_merge_request_serial_id, partner_serial_id, reserve_pub, purse_pub, merge_sig, merge_timestamp) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_refunds_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_refunds_default (purse_refunds_serial_id, purse_pub) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_requests_default (purse_requests_serial_id, purse_pub, merge_pub, purse_creation, purse_expiration, h_contract_terms, age_limit, flags, refunded, finished, in_reserve_quota, amount_with_fee_val, amount_with_fee_frac, purse_fee_val, purse_fee_frac, balance_val, balance_frac, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: recoup_by_reserve_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_by_reserve_default (reserve_out_serial_id, coin_pub) FROM stdin;
-\.
-
-
---
--- Data for Name: recoup_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_default (recoup_uuid, coin_pub, coin_sig, coin_blind, amount_val, amount_frac, recoup_timestamp, reserve_out_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: recoup_refresh_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_refresh_default (recoup_refresh_uuid, coin_pub, known_coin_id, coin_sig, coin_blind, amount_val, amount_frac, recoup_timestamp, rrc_serial) FROM stdin;
-\.
-
-
---
--- Data for Name: refresh_commitments_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_commitments_default (melt_serial_id, rc, old_coin_pub, old_coin_sig, amount_with_fee_val, amount_with_fee_frac, noreveal_index) FROM stdin;
-1 \\x71cd77e7b116906efca1e3b3948100fd33998c89b02c225a1826a03f643507529671bdbc5239edb5ce8b4b19ea58e623eea9671cf1821189fb77f7f8c3bb71c9 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f \\x4a13051123a3290492a6cf67b0e81bd6dc1835a82f1760eae814bd58f017c573bd8a570e9397dffbf24e7c4586f15e40438b37427f99b835289415664951eb0f 4 0 1
-2 \\xa42845b99bfee8de982aa857910b4d3ebffc619ef1b424fd8cedeefc322d26f653e6e3d27fb6124a9bbfa9b31a82fcef2082b791d17f7ff7cccb203cdcf58be7 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af \\x4f7287ed2cfdb10399d31413665906f395e40273c7cb51dddbf9f421244e83dd3f4b09310351eb613bf91e13f92028e056a846cbe8477ba5da82f1e0a8b9cf02 3 0 0
-3 \\x99c270cc6a7535ab9eb4d1dc9765b3b65cb572889e7040fcc5c6909995749233ea25c3688b57516bc5cb2f4ce9705b02a88ddffe6b0a2fe04d70fd61e981da97 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af \\x11ba0d691a26b35c5615d750f17b515e9d694c0706c017c173d29d37b94984d8c6cc6422211f38d9a049d0cca7f861206a5694226ff718aeb91a6ab2041c6e0e 5 98000000 2
-4 \\x7f3c56ee2722dcfea69f01798ebbbed7399de25749aab92d39b05d7b8667f21836ff7d57eae67be8bf2ac7e71b54962037002d0e0d73270bd8d08c051070167c \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 \\xa965d460e03aa592543a251ef7f2b9f2df4c29389771ee02dab507fd8ba00f87f908c42370f79716c7a271e2160a3b6278a31d846b93051b66edcd4d0cd7710c 1 99000000 0
-\.
-
-
---
--- Data for Name: refresh_revealed_coins_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_revealed_coins_default (rrc_serial, melt_serial_id, freshcoin_index, link_sig, denominations_serial, coin_ev, h_coin_ev, ev_sig, ewv) FROM stdin;
-1 1 0 \\xfe7097370f26ec076317152bd33f3e25822fcbb8d61dc75b7f35c5493c0c03b55cc429f4a57dca9d76487d19b5a51be0ce1af88c240e1ad6e5535b37e22db102 250 \\x00000001000001003d12d996d29f698bab0705d82d0299c23e106cddf0e3f232b44ee4f489b92d10fc9ff897e0e0b890cbd805f5bb1005b025128bd71e0f44b698aab49f258ee21a3a8898a9e73a0e859b5259dc7cf5c00d47ccceaf2d8bb4dfec71ce856ce08c8e5076d31f6a4bc8226e2a153a7aae144998cc6c7eb91cbfdc13b5f4fe6d9aaaf2 \\x8263f485b4b5749e5d2298c2af64f4816d81903535b734e15c9007e0d0c981db8e0056c9a64ef0787258dd52cea9f00217189596692cf5814138a8d774c95eaf \\x000000010000000117b2d01b15f69254bb6c711e0d70e5fa634e8fd0cbf63d9763931c01459d5b49deb2e0dbc7ec2ec4eea1ea68d8ca3e4a520ae60955f589e863f5e534e0b2190915406d1c544e7decb71e0554e71db1b791a9251edd9ab3a1499d3d498549023588aa275f19b41d0b37cc1392b9ac933070419665a1f93185a1a5d92397c610f4 \\x0000000100010000
-2 1 1 \\x33be7e0079d4227be4c88b5dbdb4adc45e62032463c2e4f9e4ad8f7b82cf2d1f8938f24ccff78272a31ba3d02583070853c8cf37005c30104c59cdae823c4903 369 \\x0000000100000100a6158c44d5ffe3442d070a9892c1ae1202f5656e3cef98ebd35fb53a1eb0f012fc5e079797e610d912fded21ef34668ef79e3947b6e6f0179afa76fe8f376a5980bf931d451887590cdafb209553350a543df2f6b1487fad9543d847fb544c304bb48b44fc7cae39d24f8870f20d0875a14bef83788ca738f0b20fc6a93e325d \\x2ffc5e82e71b7d357b70a16d40ca35e76710aaf0f326d59f5d36c3cc744f808998bdd1251be4d43f6c39c36d0aa64d29bdea04fda9a58e31b0cbc21379755b6e \\x000000010000000158dcfea4b6bceba992a85159e7ec0e2ac70bd65e7d1e7781090bca9627839c8ed3a88079c3019ab4e8221936fd81fab976d39cc36bcb53ac012611c42c541a7f11e8fd558b9aff394c342a08d09ad20222d0aa254d0b87d083fbaa2a484e664c58641a43c2959ebb10395c99892fd424a79b62afcbab1d4ed22364f5c27b7127 \\x0000000100010000
-3 1 2 \\x62aaa09bcd0bc62a54ad4641c2927b53928dbfe72de99cca2e4e884af667d4ca0fbfe766df7e1e9b3b8fbea21ac091709f2c73d6e2aed25e0fcb2fe6d3226002 292 \\x0000000100000100e34c48a4e25f7c6b66249cc55cfba1d60776a1d8e65d7707d0d62eb8b7a145a91ee0b61f09cfd162c613e6fac9235bbc5b9cb4d3f1fce4002f91f2e72fc2a4d0bae3ecdc54b0423798b24167d804eefcd5329605267c5dcca27eb572303fd51c1a552fcca42f52864c75769edb99bd74aee818e4660201360e3c1786562afcdf \\xb6f75b8655aa84219da415345bc55bb6733c9b804f9728dcb397d7e975965c0f74a9e8819beadacb0669e380fb85420fdfb13b6ab7bac8e3bbfbe1e1088e3670 \\x000000010000000117872bc8205eeb676aa664a61b97230f08820fa6f25d6ad8af03863f337f5cc120177161bb0af2d71d03e1d1b71197ccc63e2ba9a1c33104daa2d4d754c2803443aad17115eb8d810959a9cb701ec5075876422b32fa7c445f324d8000c7048bd9ebace0ea93b037dacf467e7504e036566e95e413e93bc6e60d98bf739b1cfb \\x0000000100010000
-4 1 3 \\xf901f37f3f9680dceaef66c034cea31aa96bd46d3b946fef1d6ce9b3a54d3dec5ce251d88e1394d645388030b46d6b84c826749615dababc6315963260a46802 292 \\x00000001000001000f2c95dbd29a9c6029021c82cda44acaa756c95bd12af53b88655e30e21ccbf85386658e924ab6d5ef454efb4cb7c2b67b381eb693c62e79c0419c1354c73e87a064d618c40fb9649be631d69f8fcb4a407fb30617fa2e8ad94a0c754c657281d6ab74c03f9aff1fc6235ba8e2ee7fa354e87b0b150369ca6fd0eb412b66f6ec \\xe1304fa8b526ee1e41d3ac10776014a469d6489a7b58177ecb39a9d8357d4d90333eaa920f7a002c5d33bdb458b2e9d6073d9c29c3dba2b31149a3e0827861be \\x000000010000000111a82d5e69b6e03e29825d511482241cce025ddd572b779464f709c7820e5de5cca044745175b07ed7bba97a83c3a080ccfe0169e764189158f54ca79cd6f133dcec2213b0bddf38d3d4e52c0d8542eda694fa9164c3771a5db13e0799b6b0968f266a97c1b13e1fa57f741c1078049e2b7bb5ec5cddbfd8d7d202cfecbf24c0 \\x0000000100010000
-5 1 4 \\xea1fb7b26dd0bee557930a33edefb9fec0a91983b3671dfb9ff753b218f7d75d5ad87e57b31b756ff9abb4f33cf6a2243e61562b99b6f5e91e939a44a78d1009 292 \\x0000000100000100742178621c43a0a9b8b964c271dd48b98070fd17e20fc876053a40833386935d5980662bc1b1ed8fe5b02643c7ae9dcd0da91c09d41e9fcfb9f3122bea6f38827155f441eabb6f263c02605f954f1bf646e878e07fdfda0bc86ebec9f22b347ba5d8709825a4680261658da0ad50ddd4940c547a35f6120cc668beb350254086 \\x2147d6d1046f2da3ce3e113aee7978b1fa65b72e3759e5511a7149612d5b84c47a4e608b00695737b2fdda9ff6ef781da7fb6aa4135b617dd9307b76034cd70d \\x0000000100000001ec2953e0fd6539652888251d82b9f071440323284e110fada4a01cd039d80b9fbd3b66749ecbb62885c400eda30ddddaf5ba972a9864c7107bbe3f8eb2f5d790e552370a13757103913dcacf8e25e34b2208fbb111d1444f86d04cb89aa2ca91f9485fba94d0cefa0a406ded7210dc8c09f8c9692979e06ff315e653a616c9d4 \\x0000000100010000
-6 1 5 \\xe74fa749a1c4bcd2f1e513fca8e2aa4f82035e9a29736b2335b231719918ff39f11a3cfdadc9d7f01a19fa53883b2dfccd0cba543192459f5a92576e10bf1204 292 \\x00000001000001006b6296d6ab9fec66fb66704eceb8e8bea261a580b96643861299df90d410b09e923e2b3c9ea3c9bcaf4da2248f14125749cf678ecf505818235376db1ec5e143e672c1817e895c0c39fe3c4b46f58ffadf5654c5145ba45c27459aaf499189a05ac85389cb3a70f5fbf2d2e80c4b1bc516d66a0906d6302d83d32a4ae28f8c0e \\x8e7554e03316aca336f1df31a49da02ba1d5f1c03436bfdac5d8be457b0fc3b6f2ba3a6e0c5efa0ab42e81401656019c44cb2192486974916903ff85e7c9772c \\x0000000100000001194bc41028ba7b61112e93747b33811bc040d90bf01e93172da1f5d59958b24f047d154185d9ee02b92c59052fb5cef451f52ab66698d61d2784c2cfa95fcfffe2ef255362879b5e0c4f14c045463d9b77b46a306b2998bc4cf84e455d6324029edb3716fe66efd39efbe075a97ba4fab93c9ae23111546b6d0f46e2307029f3 \\x0000000100010000
-7 1 6 \\x6c18c24acc3b666ef8e9f3d3ec80872d29656916b5e9565bc2139e767b00b1245f4893989e6e71e48977bc1f01d04ee566383f433e0108ceed8b77f3332ea508 292 \\x0000000100000100a4dfeaef1b2af0ef25dd91a7123466b14098fc15f6fad0c8c65705e9084167ca2a0a88394ac4377ca6fd372d78a5fdc614e4aec2efd8081601774989fbbf7d5d4d444c7335d8d86bbc8ac179f2d1bc2f974b87f0f56f850be450ee392518fb5a87f42b2d377b6fdc629c33d5337ccc594ff0d6deee3dbc78006451255f4431f7 \\xb857d901c0b879b332f0d5b5157c4aadb18c217917178fd342a700d3922dc0bddd3c15929f7a318a3b8b14bae41f427e073aa76688064100a0552c957a0f208a \\x00000001000000014d6060270e8715c96da60d0bcb735b54801dae9343eaaf51fc019c4a26f4e532c6d8bd5f46e63e3268fcf1ea26f19c4d23dc7d724e533ff9a4ddae44415e601edb10aeca77fc22be34ea41bd1d4ad78467940b1ee4c06c253f68e185ed8d32ded5cc7aa9216cf42ec0b76a6e9a132ffbac703b3058cc617bc8291d042e432b67 \\x0000000100010000
-8 1 7 \\xd247dbe689ac194e02dfa29aa3126fc4f80543e00e13c77799da523ea79f3ff79cfbb3ab51f0f08eb14c8fcba7e97e7c2fb19f48d32073d336e554ffd78cc60a 292 \\x00000001000001002bc759a6e041ebfada07c0299b20ea39a58691969f8fa235b11316d191a64f8bb6bd5e7e473c4c630e52d0d2946b673b5fd9b6ab2f5d1ce8c50a925a76bbaba37e9ab881133dabb45d089f2793c12057bd9f1a241d38275afbcae36b1ed6f19e66b0c6a086ba3443380dd70ecd6355704571b79e68a9ec42c9e392446ae8af78 \\xde7eebf17783aa3105a45f53f1bc585cc0c0ff3a5387ad724efc9cab2261e6bebc248f3207378673ef036ede3b726f9bf36f65e154a7d8d2d17fb3d9e85bbcbb \\x000000010000000121ac2e0dfd7e7b43aea95bcc6073792fa3c7fd8f2c326ed11e273044ea72fa397d9ea0e787a048f923f86f3884582736dc1da578d6b98589415826374ce39bbd6405e0dc23c86b694426be747fd846682fd3447538bb581ac279fae194e74405ddb71a9dbd951ba8a6a82ac765c7f566ee427275af1672b799f784a3e110ef96 \\x0000000100010000
-9 1 8 \\x4242063207e82e10825cf8b8ce2c8838953185f8bcaee31041846b788dc736835ad26d16f3d2b65f60364d43537f45630f3dfc7485f5ba9b7e934d4bbb56cd01 292 \\x0000000100000100944baba5039ad2b58cc33aac8415459894fcd63e4202f310b06e21491a941a43fee1250aa5b6ac266ae4fcbc8e2f1832098e5ce714c6c65aabd83a42d473d275609c2cf131fccb16bfc9bb9d89b8f8f1dca7910353155afe0c13ba982e9cac52d81a583abad3a76021a8f4af9adc92d0350e5ef85a113fa584268376b40d68d9 \\x42e7a564756bbe5d373c1405d5a8cca7988b8fb68a0c3f1345da1a02a381f68912a1e7eb5c10ab0d6ce9b7f24a108aef032fefc40255d958b00dfdd081e02970 \\x000000010000000121bed860b3c2fbbec6b2e1624291d2e19c6aedc637257301c5139e33c686d53bb8979b9001b2acad5866c3f4407e1da49b31027acbc8980124fd6009e5ac1361b78e4149223f234be159e5d32497c8da2bf50dceee4b9d8bb19621e72e875eaa1c95a108e506ce8cb08f53e6e4302cb369fd5e4b15eac5a4a77d5ca04e4839d5 \\x0000000100010000
-10 1 9 \\x717ec74ca114c33693fbec46085c5dfa3e08ef265dd6f0db07e3a12c834fc3928cbaf4e0da830fbb333cddd37f92c357ff1e0f8c5fb92410f44e7d20dd5b120c 292 \\x00000001000001000f2ca0e117684328b6247ec3279dcde273ad9b28e2837999a14cd68e11cd2c8fc317c68878bad9cd8621b0ff4336bc4dcd258689d42f619711bf5f39bbc5bdc57271b3453b2689f6a382267b61c2e3e1d7717cacfea4880bab57285f26d547841ad3a7253b8c6a1cc0ac44f4961230644c4e39cd69197c2b30e9adf1324555f2 \\x81b3bacc25a8406410eb026405bb0dd263ba400689020d76378dbb78667d3cd0aa3a131f879951e5c7c885d305f60e613f94709cc8c636114084f5cb007e650c \\x0000000100000001906d5aa4231fba02ebcdf93778edd394767347dc5ecbe95436aa11be42b7494cac64c4e01d51304b62897e38cb6b22a88f640e584533a64a675baea980370384a29289272435c0ee60c9494f604a108956135763e803bd7365fc4d40eb0bcd483b67ba7dab84a9c9877ad35c66973cd4d274091e9457b8bd3b342be90306acd8 \\x0000000100010000
-11 1 10 \\xed7c75f22200af0d135b4f692161093054468ed137d1a2e7a344b0a2cd2a8531bb67949136ef0b84e26ca54573b02132b288998f02d63c6a0594e14c8111d30c 56 \\x00000001000001002a81c2c92088f95f0862901ab0cd46a9f1d2754e5597bf9f8fdec43da2ad22755fae0526ce7fc74e702844d193169db8b92e4260ebfd915798269c7c51f755189a6c7041d89f9177a56021f6d7024524141ac951c2aa080cea25bab804015ff864fe155b96f982f4084abc9f3d4780f770012e94abc2abf7df167347b78d19e2 \\x7145faf926df8de7c8cd8b4aa4dc74d4dcb7863fdfabb7299adf9aa41c09ffb54046ff11adcb5c0d413c7aa8549a17556c36190d1fcf30052f49ad8089a2ba5a \\x000000010000000197c46acf7af5c12d6acdac600f98c5fcec49fb2d9d9340864e2ede89d7056c2178963ae31396758060c0f22a416235a5813884bdbf7e9e4d0e40d9b53dd053d52279c25dfc78d13b9a125e0d9317f1d12bc0d7fddbb7ebf2d1c972cc72a473a0ce4b5b200990889d78e01ab86bba73cb0659524f40e37259b690327aee5c93fa \\x0000000100010000
-12 1 11 \\x8474364068663af0a3fa1e227a1d3add10b2531be840471272503370f663bf25e6748dfe8f349cd2c0d4e35679258a8942e6796d4cf67929f40b5979ced4d60b 56 \\x0000000100000100a02fbf72ce129a51aff4640ecfa19fe87d49c46bfa34c17fe7e33811ad71548349a63879c91220bf678da1947c403253ca238622548f200acce26d9a4e187150114a1f2b1d81c2134771ce3b9a74dfa3110ca7c3f47c0c46b327331175bf29d0bb579340dfe6a440ca2c262215b031bd03995a5381e66217e9917dd06ab19d20 \\xa60fff8e8bd55851be2d87231a5e3b81b982c6ad701253bf97d1080a6e82df68be7d6524f071d3d334522891c06b2f6f283476b3488583fe902ddbe5ac98c405 \\x00000001000000016eedfc8b968c12048bc00805f8058e224b8b3762c0a7abff14067a7bba95d50b3402ab4f18706596301e64dda0854b2cf4e0bd98fe425dd61b0fdb193dad22420ba2c0d64bc62903de56bdb9af233eceb1fbb6b81b13acc9fb1ff6059ea48257ff7df06f3b812cf1e9f9db5142c774b9ee859ff52cc51bf28f343bd3c7ff3fb4 \\x0000000100010000
-13 2 0 \\x35bf10b7c82b18a9b5febc879751da5735b23f024bf493da742f9440724b4d72172c071a8a67c66910dfc296461c28d943de8b588d2fdd896c62f83a97ad6609 250 \\x00000001000001002c6f748924cc64042c337e0ae3e1bee01edc404e954278ea3140ba2eeea8ddee657328d473a440e8b6d5226ce3e67a59a06b86b6590fcd5af0bf1e3c97538d903693c365289cd3246806ab752dcf89d6019fa222e52197e3c7af573079116c5054f1fa8ffb82ebdd22b3506ba99e4954b532da144b8b5c9016b6b0ee9158f3b2 \\xbb594cbb69b82fb5daf698354e92c3dc28042d6c8ce4af0f51affe63f0b56cc50f74092686f0f84ca8be9196f3b9ea29279d8daef6bf2ba95e2bd8e907912ac0 \\x0000000100000001883c4d0a7c96b10d9781814da1727a14963f0f1496e6b972bb8673779a997980f92f742d9d123a6efa9055f14a02d943ce116a4108c2987ff43e506931f372772875ca9940b30d9143b81fc5f7235897c68fad626995cc0ec176c68ea91cb81c66713c5f6961ee109f4953dd9a89b5bff96da1a33b8416e982aeae1d638f4a8a \\x0000000100010000
-14 2 1 \\x25d80e8e9913e504bac5abd996e8505ff498082cf51c8e2b0ff25b52a06eb4fca20105fe29702c7be498bfddac311d2bdf477b56a1ffcb54ef1d6e6e08149606 292 \\x00000001000001006abfd4e39df662d5d4687f49992db654c21032bf5af0b4211be7743054b06b46cdad73602f7bec2f43a5e7df94feebc28947878256968b8a541aef6a2c6084cb58578e72f152a6a78104a7cd56f608762b592b9b37c9bd4aa1af2b5fe7d0a08281cd2ddf9e38790504f5c595b75ad63b8a015f94b5d99a1077ddc3deade2131d \\x55ac069b0d18a4c05d2d98d3c211ba0e519d96629af25e228387134f5fce0edaaf224f546acd4bf9ff66ea5799c5829797c4cd935be8f7d5eda3950271c88598 \\x0000000100000001bf47bd2dbc4ba36f0f8a6c566f742aad40a4dae3e6315fd851bfbba8e2024c6bc3e0b613c98a4f7c483ebb53c4ff21a8b5342fe6c23abc1f7fe9e9710c3de6177e86c0ec5170a0fb66c5093dfaaabb45f04131775dbb78be8f21707d679ac6d0815db015af023d3901ee2fc9e410c84bc8575436e8b0be2113e58dfa7450151c \\x0000000100010000
-15 2 2 \\x7f27a0b1d9382662523980616feac5125df4f5c8e1c2a7ef5df7616b5f8ffc0f9689c1a0d22f51b6e0ef79e39cf81e8589840f616bc851f9b5083804f999dc0e 292 \\x0000000100000100343f2543f2a70ad84cb07002f529297991b461a817c9ba80c43d5673555fb3eafb006fb44808290e79f9675b315f1e1d595330475c531de599a23dde5ca5ebd0c6fd0a73d6c13c2ac7d48c7a1594414301fb17f51f14c757b6759b120869d071cfa7e20e19762b99ec3073452b64bd4b094aff3c8e20a6c68b62dd169f976785 \\xf05093f5feecf70c1d3f34f5a1681a160b5d10e68771438af28b0247cf1cdff98d9b6465485af59fd4ca254568a509fe4f0aa06ce2c94f61122c2f4247c5f6bc \\x0000000100000001e6e5f683b8e381e46f9faa73af77a9c93023754108016af9b804ab64bf7e5e58ae48a9c3def8b1d5a832e66b42d50dd584f9737a9f34cdec1a061109e5183fb1a7fca4510f685a16ed2cb605332e9d2ac9fffdd31d3d6a33f613b838000898943268775ade5f6f64600afe300c88a4510dbe5d429790c13b70fee929888500e2 \\x0000000100010000
-16 2 3 \\x452955fc921a7769d7d1ee1513cf62bbb9becaceb02dd640e0556e35f4b101c3f6fd9b0587a758c742d4ad773333e68ed2dbd47a9b45b7fd275859cf091f070e 292 \\x00000001000001000f2aa513187113753f45f1aa298e675374f6444b9bf89186ec540953a869658885239cb6a74854dcd1d3f59d59b148a04aebcf87124b18f599456187a71d0902c3a15a738f17b2a233583fc14cbd50051ea3146f9443994839dde7fb1da661259346e5b6f132b82c928e5194334a120a7092bfaa7aaef75fe2647160ff26e19e \\x57bf9c47ffa0f2a8a71f6f0589ee220aeb817c7399fad79529e474d8e3a99d189ea0bc403616934a9aa73f10d4060bcf4fd20fb541a390984ff6f05e31ed3958 \\x00000001000000011916e516dc7591aed341964279329f22ec44513fb3b3a16d3394fa6f0f32afa5df5c17b9b742eb2ef03ac5c0dc17d7014764dafab77c38158f2a1223a82d884733947ff7f8c841e21f5b78f9071cac8ffba43b3f3811c2bf50c346d253bf6923f2e2f5f28e353a7aaa875ceabbb7824f08e5115f2702583984d010841f7a0f8b \\x0000000100010000
-17 2 4 \\xcf7b7413f710ef0b084adbacf0b274a7ff833d2d7c3d23c2793303d5cce26ca0617758f979bb4b0917eb8ed245990241ed8d161bafaf2234f8e811dff0108e0f 292 \\x00000001000001007e90a12ebca3e741464bea1cb43350407f9d2b5bb9db057bfc2bcc4d037095badc8f5ec5cd77f4f26b200a984f48d397bb04df7f2bc5bbc7f1009a2f41946464ab9949511197446809bdc1b60b6822ebe2115525fa5e8af92f922401ccf093eda5b4a5f925cf60564e384d9d15d25eae34f2d2ca59952c1bcb27b84f7ea41f2d \\x3ab42c6f45d9e27d11a1a203a58cfc2e12da956a51a6a7e12a2196871b1ef687ccddb27d4b2792c0e6f464c98dba077d02a15cf07ae032994dbca3eb1bfc071d \\x0000000100000001646d92e15a2e865fb72e703dd42a68c3003ecc48ded19958c6ff5c9c87540a8740251d2a8ba252f4b8d59143db38e6e9c4b893c255e0a8d9dd814cac38999feb8949db0ccd73f1e26b159efa933a337d6d804839fd5ef20f3d205f8752548cf0b4b4290d3188f890fbc8cbfdedbe5aa4e6fce80b816de2ade4c6dddb41aa1d63 \\x0000000100010000
-18 2 5 \\x67cb38f7eaa9177ec261f20db6c1c6f21b0416fca847044ddbd06afbaca97bdbf63159193fddbce2e3d92e1c82a127697e3b8bb7102941b62c96f68345a1cc0e 292 \\x0000000100000100b2a2c511b2ca72f1adf9308f832d15b58173b2e03825913c06ff9d6a4f720109bcfd27cc92e4b9970e542aa0ddc1a71308590ff65d16c84f53bd57e005f3a4d2bd965a2b5744fe0e63c4ace475e0c2dc159309086c1a5b9382875bfffd8820e4dc252016169b96478b89b6acc42335151d2adc6e9f27ee22269aaad608fbb829 \\xe79fd07d3a3034f9e30119669dc9b7bbdc9ff9515e6311c3346393b08e9cd72c223008ee8e811e3d65fb1a1a58efbc8022d3b53a167195b5a3eec23dff863acd \\x0000000100000001bc6e5739dc6eea141467b84d8c19a024b968718c8a79e025ccbd95b97039e0ecf750a74a3a2018a5843ad69364d8e171aa3f0c8a85abace5bb276da735005279ba0094a0881fe52df89f19537fd682323bc1c21c6207fb9ed490ca3d4db76b3e10124d46377cec9914602f6af5709225ddafe149ae4327d03469b65d965008ec \\x0000000100010000
-19 2 6 \\x0ddf34df168b6d11aa07870ab8415cf47e6ee148d2a9471d0a2bb17469b3737a2c1136d5c2a655ea383b54c3a0f0dd89707facf4470001d6b3fd5cb562d63d07 292 \\x0000000100000100761e73f46687544ff3a0de8d763ba643b8f0c2c324f8a92882d08d8399612e56c66f8d2f56ae50abea49edb7b340960372cb0dc01c62cfc53086cbde4e720e4f2a42e6fbc870f42e134f09517b94ec516a7cca34bd81427715b59a90067977858ca5753aab896669ee9db758f95487c951d05a4f400b31b759e6dae16708e331 \\x67a49fc391c9be46771fc14e5dff33104f48043bfd43c1a5460e1e6aecf70f7e01dd2fe42d72f7cfa0ac28213dbbd375cf3f081f66e00b283e5c9dee91696a5c \\x00000001000000015e51405217bb563947ca7fa9a8072099f42a85aa73b481959a4d1125dad20699903ead8f4771ee4d9c0ea2e9211ff5aaa7af3e5552969c044d80a33a545ec55b8f7e53cbf7a0c920c7c1a56699cefbf24bb01f98f52f1da7980a900bbe2bc1c52dd23b406cea7ba4a188cb9d494f79532b866e87ce301a1180f5fba558fc3041 \\x0000000100010000
-20 2 7 \\x182ddecb76f7002e64a8417e66e58766c73f40727ae08d1d6e3855196433cf7884b130ecdfe980b63de0fa7b70ef78421dfdf01340e78e68cb99c13624b78e08 292 \\x000000010000010029a1aa1ae43257a634e265f9975f03441211745e5d94c97f4fc3dc7f06733dfe9c706225c3b3576fd9db34aa0e597263205c4775d46e943d8d568bbd2828d929224f8d7ed18fbde910792ecc6706ddc8b6fa31e914099382c2e397c2d7b7ca097bbce4619851f568135c354d78c23ea86c4df4dee8c46e8d265fe5df8cfa441f \\x08e967fb20783287790869acbd3701a9377f2b974451ad5ab65dbf0a3c0f73a54718b80007e4d1aaa3f14f6e81bbb9171435ddc4fa5cdfc88341a28be07f7c2d \\x0000000100000001cbfed505975c542c05ae4218cc2bed31184f829fcaf7dc1e9635dcef59460f11a5b167dd4f11c13096bacf6501f533e811cb67c293f0cb00d484b05c78cc68a8f5c2b9ab62bdc4ca0b2f472ca9cab7c8aa95d3cf1d3f6968ec9124d7aa0d555f56f943cba0eed7be5dafa607e84f6a66d9e5f45ed5408b87b6715354e06d7e0c \\x0000000100010000
-21 2 8 \\x6b2191bd8353fb7348c3c260fbedf2dea12dac93a42c75005a7c899d0d8b9b892156f721c9fb0b32e27b4a52aa7270472b9421cac16e96e39ca3ed276791e108 292 \\x00000001000001005834741f15e1d74a8746ece074a195c125c48240f09701c19ec59eaf4d4a76a2002b1106f37583e19318ccc50e7d262a12eee02878a1690e7e727dce9723423f3a64d54e2adffffcdb8c1ddfa83f7ad9e676a465ef73be6a5a2314efc597a9fc5696d79a2a4e3a4e9944510781776e5f826fa3e88c22ff21cddf480f983495f2 \\x77f958e7f8cca0ad641619ffc2a0c5df73e7a4277e681485b07e53188eea5f514b05aaa15b86a6476f16a66137241e5d7c49d1ecdb306ab211b9d37fbb0dbc10 \\x00000001000000017ec3b47ea272b5cc8fc2832fe00c5ab4374583eec85811495e5ea107600b37825609feaabe6558408458ca51810d0a63152514a6505b2aa882225f4bdc7a4ef3bd5c801662515d773c196384efdd340d01c1d7a1a21aae6c3c2a196256a6802febd26ef8aaf752670a45abb1d461b96501a3e43384eba5c63f3d947dfe552d93 \\x0000000100010000
-22 2 9 \\x894762cdc90d1c3aac1a19002ce47dc213437084f08d0724a41531dc4370b5167e5f22c43842e9aaeb826042b238f91e1f70f001befa17f17e822f157c3eae06 56 \\x00000001000001007d6e7d4577d6e8bb287fbc2568fc8e36ffd047abda707c54dcb6eccbb78f45d72c223e3b53b19acf4d20fda0717846cd38da5df57a4be5ecc0be4e32875b5ad08ad32210ac125f3cdeed0e3a5d0742d70f267011a9f3c8f8b739be063773913d3a82b5d4658b8313018108758ff07f41587db836b28611e2a37261fa08b323a0 \\xbe2bc79f385352857aabf5e35b0087bec57b5606fb6567ab6efc03c7a9c809312709c9fd40766ff9ec4ba9f6f0b69b1f93130497bb133456886d31d622066883 \\x00000001000000013193735cf425856f1f747ee38e754b7e516ea52247ab26c09eb0e1bc0c2473d88fc63b608caebe81f7bdf24e4778028b9417d2574dc3f977de3971292531dd99547fe36b6cb3a854bd1a6eb622fd8add84d2ebe64b9289ccef2464076ff167d002c0cc537011040d305178c51b65b580dbf4b8b5a40eb3d1bf9a35c1d44773ab \\x0000000100010000
-23 2 10 \\xd82e9df62207aa1ae7a90914cb005783439a6727cc5752f7fe00699ecc8454712341ea7409aba3f2324134db30c35dc039aae952202a5f408ba416a7f2bf1e04 56 \\x00000001000001003c24a58300bbab24bb8187407225a7efade5787380e4737e525e79a4db30fa66a923ca97456837546724d0a77a95084afc2cebb49ee5c8dfa341aee7543a7aacd231567e8d8ad22e5d526ad25b85f8f6d27da290fec5efe1f9cf4372dd12daf06daca10fbce3c0e6039e7eaf9af31011db96aa6ad504ad99971a9553550826be \\xe06c929fa93a3892645816239795843749714bae11e96f499ac8a15473c9a72bdab41213c9c27eefcce297e8890d9a1658d620bc177cb4537c076e5f13dc8a53 \\x00000001000000018870880abd6c90691dbf2b337dff1238412d90dac84a70307c5d72e6b2a6762738041fa31577a8d5dab4312ca20d7b0319478987b9cf9ef18c604c6eb14eff63a74c442486bf110fa1c096c124b265e9a16c95bc7de052e667c1989d89703cea4590f33653a7ea07339f3a022659bf85602dbf0ac46a932d1dcf02c420cb7823 \\x0000000100010000
-24 2 11 \\x8589cccabe2a948d9b0bd602476b25cfe1ca8276912a6e11133c89cd96da2bb490824007fc771729a852036557ea98afca11cda1b79fd097d465bb35a26bcc06 56 \\x00000001000001004888a6f36688aebc98de937c24f251a668137b163fbaa971fa991ed4b3225b88ff403f6a33f2472b9d0ba9d6db5941a423e508d775f10202ba45caa450d538349244513f6061038b61b9fbcd29a1ae28dfe099163b94dcf3eadd6228454cd31265883388dc68026fea8a7fac29e4652b208ffeefda1d6c20a6cf0565da100207 \\xac4d59eba4f2a6e892d03236f77a517b684fd51472ca86783d4a846161a97fd8ff0cf1e31bbc0cbd522596e0acc19f31d244ad218e45533ac5cc6de57939c1fa \\x0000000100000001cfe627d935e4231f9f2689f8d42f028549d2aff848bbdb319b0ca9aaccfbc9638f26660b93f8b78282b6aae7c242a2f6778e2633e0c545ec9d099fe3c897ea32701fa03f55de9a380109a2df8970d073795d93e533198d597a3c942ebaa3680390a5482bade695fe9724b13cb7a6740afe961af32dfb33ab419f51099283286d \\x0000000100010000
-25 3 0 \\x5c6b8dd058d6430505f0e1a2c0ad4633c12812b98202f21f90f105446a5d247582a3d530de2a0e97a40e35566159fb368f25c6102d805fed9ffef581139a4a07 190 \\x00000001000001003bd6c2c2c3810d5db51e6ffae1f7b2dce8f756d286a890f71235f21420e084338811d5212501cc516a0aa3deca122427304879d21f3898fb16a2da6c24cc705e4616debefdf2d3c9b69146c065d49acecbc5166fc7fc2656358e7c418a6074a8de36bedd2c46f3043707365aea1f4633c0737088a2b2e2b17e65cbe84bb294d2 \\x0e99b0d6b5ab03746202c3f9b24e4e162f9c53fed87be4535bb4ecb0213677aa28751b588c37b0f652f9eb1cbe2f4fee1251776dc3972f3a812ab261b72c2f79 \\x00000001000000012d68ba7c445796c7f0b1cdefff34b590641e22fffb8e34e26b49cffedbd000c9cbbe4eb88e0d7bda032ce5e5c9672d30bc0c9758061b8a6397048f0d0c541fafe0c1fa9489bf2de7608f9b569d7b98212e41f72508475b584b2212103a6d1d838bc01b14fe434b13bdd34aa4781159ebd3f4c0fc9498ab2f75ea03cf4692fa83 \\x0000000100010000
-26 3 1 \\xe055f4574efdc0334e859cce8cb65329cf5dbf5b988f85076b5655408c92f46dadcfebea09e701bbc8089420b30ebde9fc5dad583d8ae526e547ee77ec04df02 292 \\x0000000100000100b08a75478b7ce73d422ac702537f47110bb40b2a4918ab8b945cf7159f430304863a5ddde36ca4aab9929b497f7bb00b0a4e1274803330839876cfbda302add42452b5ade662964e29edf385adb6ce8f748596b7265a29b87bc6cac9795e0501c44c6f6ad3d8ed97489083fc57f3e72ca0fac98620083262713767d546674c04 \\x37fce2bacb623080cc9795a3ca023d4a9666743f45735b1d503896628d563abefb424e2b37bcfce6efbab786f591aa1ec4f1cba6095790685b6b644c8deac816 \\x0000000100000001d00c74731804aee3af690a7ea1ec33750dab9bcfa0c5bd31dee8c8fe4786bf4b8f07ae509e4dc860484edc18dbfa3369919d109dbe863b53b771afb74f4506b0dc96e79de339e58e11484f15cf6a8f722518404d3febb496636dcbf868057fc515e11b3bba81a6e2e36eefb11159b5bd0238d022ed03f9e633cc779f472085c1 \\x0000000100010000
-27 3 2 \\xa8ecb1411b606e2bd0a2841e45e9d7199bed0319e550412ff364957e30a2e23d2955088a58c27e121f430817ce9833453e75248a8f22509b95808ab9926b290e 292 \\x0000000100000100dcea3bc83128af8ee8e6c07b659c59fd729eb04ad480ec497adb8ac1fe4177b4522ea282798ae0d178aa3afc139be507dfcf692a70836c5f6eb02a4c2fe5629d4838a40c320c79ad686f104565dc00c71bac901f1ba43dc80da2d958d11bd11703c6427bd7f539ac9becd58607d4883483ae8ceb63f22d478b2b7ec2b2b6dc55 \\x78355feda4c464a9c56cc00d5e1eada7936871508ac23ba6b8e591b2ca7f8790d4093d05951a2634270c3cc71124a936232d81111647659cc247647e6d5bf7dd \\x000000010000000143467e679306dcf2eafa44f50673040fcac4341d6a6019b248af5ad4c637dad60c270f7fdd84c79cf8ba6a534fbf4a574909c51cd46ee0684360fbb0dfbfba3a7c61595cbb03f5ae358f931571d87191b372fa471f97b6f3f07bce8d09224b2dcba831cbf7df5f7365e1e95eea2ac9e69edc54d16c0768b0af81cbc934bdbbc8 \\x0000000100010000
-28 3 3 \\x6a6c17387061bb8a05c6a5ac2d8c1872f0dde11330ecfe3a16af662606bdbdd17eef22187c7798a660481632c79b68c74db8eaf0f8f9c32d5917ccded2cd9d0d 292 \\x000000010000010066fc70fe75d757db5d85cf020b49cad4b16333498c7dfd795ae14d8630df9518a9a3c105442e461febb2365582534cc82c052d36502944a55b2d0e25228b7d76048279a74a77d5368a056b17386200f831dba983f7fd84741cd9f6d8e88f5cf961f2ccf0422a3c9cecde810556e55b04e301b2e511bac1ebc157eac983225614 \\x1eb5dcb44368824447d5e396a734ded9adf8bdc8e7e56652b3ed0e10116b237e2c7d7ffbcd14f0452d10bcf8910aaaafd7e825d7ead004d28aac885af8bf0bd8 \\x00000001000000016c16b13045a6f06bf66018455093264a2c0e96da1a51a3294500d17e9f079d6c877cb51b11e24c4e565385652735e1b7fa2d167835b2d7d144e9fd6f7cbf6fd09427e70472ef5d5ca3d9f9b27d2fb1e6deb876b18f7b9d4dffa53228a52c62ffd165f6f45b82d8ff2061dbc33c3245e63f9be2b45e9a0e7ac0a585e0845a23dd \\x0000000100010000
-29 3 4 \\x4ccd2ab3d9f8eefab3ad2b0a5eb9dcff5053514bed2be5aaf79f5fce3611d14c1cb189e11964208f001431021c3b237157d32a419fb097a1d5fc078f6fbea005 292 \\x00000001000001002e003733a67f45189f6458443b94ac5d6584d458845df787e65d6f0004a29c72b4c62b21839c362ca9ee72dac5949916c2478240934ec932debdf1e6c6f0b5e4be02c6e4a82d3165cea44df5700b07beb4a81c38c5259b4e7df812a558299a6b6331e60f6113b6a1f957f847395b1e08cc19326c8169116cc8f819e3f02b9e6c \\x69da2d769da70739f94635273d48c75f3b112f273d770d669b6b4d7a822eda55a831e36241bcecec752195ac488911333a0e5c929989f52ee90ae61cf302e57f \\x00000001000000017e9ada932406fdd07784efba2bb5c0e95f39c587bf4b5a7ed67e0d8887600f637c01c1f7f6cb5fa1abccbdf3dad8acf4e540c798b9937e577b3f086bbcd9db1f654ddda9a1911f3cda16435db096072750362344777832573ea2b1c3278782764b054f4098cc40408b69d51c12c3ffa94ae18a009f013d74896dbe93032dd7dc \\x0000000100010000
-30 3 5 \\x5f1f5a304e787fd1b97e83fc0358ee359834592e1f3ad8542840e1b521e2d76dba3bff60b5f5a3a78560183435cebbae53ca1e05a28b9a478ddf89db6169310f 292 \\x0000000100000100572ee50294b2957547cd38a7ae99a7553c3da3783abcee08a40048a391acf2e1661621a70f13ca72b5b1752d6f0ee10dc443152519a424c3a5f3fe31ce54006474c066305d5e1303f205cc2bf2996952818f628483ca8f37928d09afcf3a0e5dfd26ed5db8833108ae9b8b9b236da469a0cb3484132a82fb067ca1b0a13d993a \\xf10924655dd8a1a5f227840677bca7679b025da931cb366a70f8c0a175630854b664210b3144e43e1b2675694da8adfbb60206a59796a95de71ee39de48c1711 \\x00000001000000016baba3ddecac750458a3e7dec7af47e25c21a6eefefa8807491462b31028bd0f94ffcaecaead288c46babb92fce250084ad1f5ec6b08f41ee6615814e345ac88682f1d4813447abff7a5a372a7f3b1a6614e4bbc0d57df325ad1944908a5104862e6c9a2fa45db0da539f49cbf78d29bdbf806baa1f244142c0f525dcc31f5a9 \\x0000000100010000
-31 3 6 \\x553d7dd8db1aa8a5c5970c3a684cfbeff43face10d8c7a143a58539c63d85d26a64e90073167390d71bf69c02113db0ef0a25b362bfda5f41457520ad07eaf0f 292 \\x000000010000010021cdccd67d9d87d94eda7987579821a31b67c57bc790497d0741695258859cf13090fa4a2c56632564857581baf6addb320c764c4ee0ccc13fc4742d41abbb7700e87debd7dd58233c1852e49a8c468a48e41a30d162d16a8b3f15952f2f3bb23d5a64ae6e06ac0133676dea7201e376a4815b797bcba42a6c62a00becc55af4 \\x6aaf9e34b08111e07655e479cfcee68337a3a607b391546ec94792a25464839e1d5aaee21d39634c8b94b9260bd0c8638a05d1298edc2258e1fdad5ec6cf6f0e \\x00000001000000015274173b506d1a9b4c426f2c6339e8c9abf0a19737ada83da59cc9bbb964b80db2e16d6d4fc243dca41af9d512f465f0703da081d507dbfdb4f2a1ad8f76891d9c585303095745e8b505bd38dfba5731b82c060bfc5c73fb7b592eb637ec042ec879318909bcf0232d25e5030661c353f4509cf234e20e24ee1f0d9df2d3f6d3 \\x0000000100010000
-32 3 7 \\xb86233fe1613fc6b3564d72382b07456838ef46005d954b11f505f7508eeac9228243b17535d79ecf2d0686360594b0db04253f1c4bbeaeb1b22f5b20d2afe06 292 \\x0000000100000100514de95cecd94ee74b5b271cfef8c129ae84e0f40b0fb2b85d72218739252e0fb2e1e5120acaacb87136136a2994074d7f2c6384fec0970d615e999046734297f884dbae51be0d31f61ba275ff80fc3d52d2ea967de631f1795b94ea983bac8ee8f845c8ff55cf39709ff1fe44e4eb4e9f6553634835e52a862053db02719f9b \\xfb27047ea76bae60eec661b3b9c633c77ef4d0131432de20d76cb2431c71792b3e6c0658c76d72b50eefadd64217960e4a1aa124e0be079b938091445dd31a3d \\x0000000100000001b9da2daee5fd250dd11cec3a7ceea135d61a8ca31af325b25b1d1bf5052e9881c338b5d848e4087cb4b6dc6c603b6615c0c31267537f0502afa7f07672c1084b06695066cb1b9f1a124450be5829ecabcd48dda50d4c76ee2729ab27fd3d3fcc3cd2216c1e13d0ca4728e2a97902c424864c8a39366ef28291dfb1b1ec09538f \\x0000000100010000
-33 3 8 \\xd61f8cb78e1610adef73cd3aa0d4bb424c08e92c6e4f019494e1c8cee31f8154834830b6d69109d015f76e5048e14e01b6a7c868cc4ec4ef0e96d1de8774ea02 292 \\x0000000100000100686cb3bba4d8e4819c5208189a4aabd37bc9e684e897bc5238b281684fa7bbbdc8a6288d6f2d84269e5a15eb04c6c8fe17389c057189e8d16825e8320bcbbd3bafc7776d170cf26a8b42dc7723e0130e5f459b4a6e85b4626f4b69ff10870f0924637ceb0a9481f6e87d206d5370bb77449a94fdb74e2035295defec5130457b \\x327b8cafb3c9bfff626d9c57609030b5372257b2aeb04f96d6e7c25595d67c8ac287e6f46bfaa812e424935f440704ddf92ec8a148f4a5c63426b89bfe8395a7 \\x00000001000000011338602e648f8097e45d9029afa2dbda25531084af5c0566b6bc6f9e26a33d93154cff0390f6b60b3f0e2a88d3dd28d87992673a057a6461136639ba5baa6418b1e9dbd6de08c7dec401d4e7cc101aeffe8b3e93f140ec9c67defe2079ccaf4c5d947f8fb95d3ba45984faa2e45b2969152fafbfc14b05952a83848173f9cae9 \\x0000000100010000
-34 3 9 \\xe4b83d990600f39d3c45ffe03bad9032e5dec3ab87214ab0900134c9fa3ef7aa6da8cbf77130ba56f06a785a8925704f1a36a4d026f692c53bfe302bd0ff2b05 56 \\x0000000100000100c140e609deccb8928795e321ff3ad655914d66f16e61e611286df36f77af2f4404406941ba1653e4e975e91c70171707d5bbef954d7f545296d530884895164ccf5b29811503ad45cda380eb17ee9ead351fe12082b3ad5056c5e1a0eb9aef727f1d686f75aee308477ec9c59313d938cc13ad87f9127df7725b3288cbf877d3 \\xf9e18c73e02b96910730c8b994c4d4b972a2dff432183fa2e8a91c3e2b73943a0c6bf4d206f537d8a43a88996421b66f1ccab9ab798734a223230aeb910d76ab \\x0000000100000001e00bab4e3d4724ac706de70969add4dd1b49eb752aec6d505c065414a742008ecf9dfecbf23e4efdb3a83e867b80e9722caed36b6d304e491bcf2376c656276f3f7b9dc746057676dc7c856a773a0bd1cb3075248d18485396ff5e030c55d0e2a4a36a4ecc8b2f274ca79909d0e2616647da00873deacaa25fec1f1b504de96c \\x0000000100010000
-35 3 10 \\x63cf09e93e65a2caadbb4247580cefb0e327abe751632d13d97b7f904bf86bbb7e1a7b6b8efb43d9c1d68a68a0839537a3372febe68304525103365ddee75903 56 \\x000000010000010006648d9d7061382f5b0f8bc23b79b8d728bf1dffce1adc4a4b97165ec2eca354c9222d4dd2b17da249be94113f86278ed5210a2722aab8ea5a13da81ce52eb01f7d606bc20eded78975a129350377ff6dbc62fbb26e5f1efba069eeeefcc5c76722c48b5764e2179cd91710324b762d59c6d8a54e9673cb249cb8c0a95f18f76 \\x5e820f2ad96fb3a9463f8732c8d274f2f8305c1c931a36a80188b774f33b30776d9f34f365a1e66be41f0c1047808c7c7248fd4ca7c3125981d499bb56b799c8 \\x00000001000000018fa066892af390c379a734c87a0d1161853e4112b733e4618d795df0fa5902a559589cc80ea8ced6d14a1ed85a714f2106853021fb161e535b3238cd626549e0a1fe9c4b539a498db21de945f4f58dfc51898fca0fd421dca8ac24e864965b69d08a4bb5cb88a9f472a495791a4edd24a59b307e8268636d44d2d194edd921ae \\x0000000100010000
-36 3 11 \\x2ec4579b3bb5fe47deeb9f349dd1d61c4eec998ec753b413e21ed128f41372981d2f71c75507fa04d2b3588bdd289de3d663922dd22a7f275049511b3b949008 56 \\x000000010000010058db327cfd64f71b883026afcaf6db8ec7f652a814c4f343a8667d2ae98c1a7867fd800a9b6bd86804768134cbeb85c443f6d0c7bbd3bfdd7c380eefd7017af4d293ef357be317c4d091f3b931324a5120a90708423e48c6f12aa26aca2687b49c39ab260cc3b4d912e0e07cbc74d333b87d37f66ee726d0309cbd483fd2c779 \\x09c2d8ecc6768a946576dcf2ebefa6fecd372875344a21308efd92d7a957378f82027af75806de4379446c8903ee2a53114d6c66ec81484cd76204e1d2d8af26 \\x00000001000000010b0e9cb0c13b31917f0d6a4ab542403d148c4e6d79421b9d303fd73c5456f98538259f8f57ad23b2c72eb42e9605fa4bc2a555eaefe8c3672be45006cdb1237a61072c2bb9e2cdb174eef8989bd24a049a8af9184a27fa85252919a3581c91d8e14888355b3398c202e799f02f505d188fa0c5c936ec415f5b557dbbe327c952 \\x0000000100010000
-37 4 0 \\x425c22e4f707db6d9151b07c5886ad1eec8ad2018900838a01e9044b3ab54b118c79d5da255c5f17539cd95d21033a2d7d38f56b3656bb4b6554259462e5750e 369 \\x0000000100000100d572ec78f32975fe3888050e647fbf2e03db8d533542d773c6a26c0d2a4d39499eb20edc5511c6fb2d4e275dd10dacbe71600d7439e6a90112875e8615e94320cbf58bc891706d36c0da8b9ad2fd0ed6ffb2e77e8a9b03254b657017750762a75908612152af59e73aaedbecf843a7bd5ed8384a9c77a14d0a94e02c292c5d67 \\x2a03a787eba7418ae2a49346dff6252b96f0fb93140fedb6981fe53c1e69a12f16f642ad1ae6f23b1855dec8305eaf78823505da28affad51f65b8eb0a292555 \\x000000010000000180880cc08d5f7f38cb240c1dc12dc33130f1b211c49df319738bc8d5af151a4cee6c7852ec8423d899c4e585b32605fc429b9acce7f15cf165213900a2833f110db3133430915e6c9d502203e122ac2bcc6180ec44751d15e480bd254b75703af070df17173ca083b3c720d6efd902f66c9e5ced65b0aab8aeaf1fa5b8d38f92 \\x0000000100010000
-38 4 1 \\xa95ff92d9dad6774f103dca5c9497afed8da70d5542f8f34cd1dd42fa299584b01ae1ab7b6914613cca23fc67884838355d9b20f5665fd0219f003b3b8681e06 292 \\x0000000100000100a21c3f4e49b56bc401de6652cf477c709372815d707e90b6959e3e10ca146ea8df3832a839e3a9374c54ff606b0fffa6c6cd2d78b6f9da4f12265987d49627dfbbc1552567414699bc6e5a2451bcf89e3528bcd4af74e98e6d181362894fa2578f72c8e937af47db4692fcbceb713d26e9fbf40b128605facc14d4bf98770572 \\x6b23e1aded841a856ea0dd4ad37fde903569bd4983560a9f069764846e118950117a06dc55c72e3234081300cc002fcd623d0b0fd2b71f75f2f828961c6339c6 \\x00000001000000010c9f0d69167a0441ebea73468fc0e15925b9716a644db6e25d6c082bcbaa121e42924b1d3506ca17fe0d4537db106bab4e5a92b3e7a3e3a6f41dc4a8fe97f4e9e84ed16c607ea83cb5a3cbd050791d812459ce5ebd11f996a11b05ade784b84e14e69ea1c90b8dd1f822e45a02e25030350dabb2c741014daacb0605bb5ff5c4 \\x0000000100010000
-39 4 2 \\x50d281fc7406c8b7de5a3e3e405f3db1cdbc5f7f0938c8d274ce4e07ddcfd2963d27e607ff6219e5aa3e1340a8bf80287fc44c94c8c5cbe8ff8b881b4192ff09 292 \\x0000000100000100b5bcae47106cc65cadeb8f12add2c3b03dd75b34c964a4d34aef6ff9ed8e3849f210bdc21bb632b8f3783958e36647799d6893d50811046d556e3d42967c8b79fa399adfacafdd2a5e27a4e142887405fbedcab08e12da9041f997a01a6d451d455209ebaa591281a2bbb4b853aacbd88989ef990c8a2e6d48af2af975d9419f \\xfc1cb9a8e462e254da10cb5b566ce3b9f03dd906312905b155f41de1d5ae1e3598fa94e7926e6175ee9c87791176d3208e736ed529c1876d9b3d7cbd64328c9f \\x00000001000000013d8631db360ac8720ebb4f233229b228d4da8a8d0e5354454df75222ed3d1572b68e1cf3e450771f398e9f8ce19effa141b8237981d060c60abd77b91b77a80b05f21acaead5716cae1eb0e7acbebbb54c8b6dd93dd870b7cb186f99490fd71bf8f6c4c441fa4cfd6fac7190a11a320360c01c1fce51c8f09fed6a78e799c8b0 \\x0000000100010000
-40 4 3 \\x2d7ab32fd7e73944d9680ed29b00bcbaf9e1f7d8a8286634dbabcce0d8c103a85bfad98d9a4d35a5f2a416a15fc19ed22fa1d684790bb68437cc4e4b665ca300 292 \\x0000000100000100a8ac20edf8b71c72960c3182ef85e6ce7e164524e40be485902b6b641d57920499a451cb06b12eb3de40f1ca8dff204bf0b9a48a64532f69156640426de1a317678f1b0181e6e207ff17c561730d567e42e05e37fbb1bd979772dcb7f6bd6a7edc7320665a08176f845e069b96911c49e21b63a7ceee281eeac05540faee2b14 \\xbc0ff705102e00bdb3fc0a37239bab38a12581162701177cb1d225c9dafb82961de93426a39df99899a1052a6aa44d008ba4c5a8d6ad957f8cd8b2c6d1ea5fe8 \\x0000000100000001b73b3675a3bce9542035659181e082807411d4cbbfe9eafdf174eece3f584f037425be97a02e245569df25b10a0cf211447bedfc8dbd42166e0f34586579696fafa5223631c15dd083aa53820913609453eed13beb15204310d928ee339c57ddf78276458754042dc3694bec8cf4e5fcecf9c393a91a6d1a2ca3b70259d70165 \\x0000000100010000
-41 4 4 \\xbeaf6889b34721d79c131e0a0157792596ba2e21457e9457b6f0b5975b5e59c829b303800b7c2882a697e0ccdee2a8f0d5b3db69cb8881b6a184b2690a4d9d0d 292 \\x000000010000010069d9a446a979e6cb247ed7ac2ed3a002934f07726cb3d203a22ba65bd4ecb8690d6f331e1f7031583936eaac5bc1502d23dc56283f16a99998f27006a888a6f465499c573b393230e1b1c7f40a9df0c93ff0edad45b03c5358202f139c8ce6ad049136f3d9a1b8e9bf68583c0d5a21908cfdda634815598a84be3fd1dffd8b85 \\x7418a1ba33c9c0010669682d079a8ab805d9b8dcb54029a1919a59afabfcee7cdd37c4a57996f7e68573d28e13e7e6808cda9918622126f6045a39abcf99a7e9 \\x0000000100000001353f8bf5ed31c326d48a52cb98d271408916ecd1a9b296c9f3dd9321c43f6eefb7ed9b99cf806f794fb76e540f2a680eb197de91a95250b22a42e435ece107b018f37bd4277ea3e4dfd3cb206f65cf998198d3ed860b95b5bf257929dc816a9a7efec3b961dc5a1bd71f4f9e8c7cb477670b9868dcc9ec30924332f2d20498f7 \\x0000000100010000
-42 4 5 \\x4fce9716aac2f3a621a6ab481911460ec98745d7befba40143ae8e7df5285dbb682e880b74aa8b621f60c4824938a5415e8e384afdc8dadc48e4532f80ebc409 292 \\x0000000100000100619490386bba7fa9021ca2af5a92a17eccc18257a58a642e9141eed028945955ada3abe3b134234412cc136c84880dc2b80b5917b309f0ad0ba55cc4380c76bb8ba2ebe7c0e8f961fb291b982827476144850fa87b2f6784b3b2edaddbffab79c74c58bc9bdd230e463212bb3c11050c17b83f11be76c4b3b439cc938a8ed386 \\xf1c69fdb391bdd5e810964be17029ab7baf6d37a1d3eca22fb3cc2e116906202e06508b68e9797573b6ef579ffcf26fdb6f883a1e4a61981ee849a6535a5fd09 \\x000000010000000131808af1194a5a28e83d66802fbbb057b2ae4d9938d3a80cf7a91aa376de3d3f16a68029af36b7f7bfa00a8e7560d64348f835f5b0377aeb5812570ce6900ac0c184731f92fc9f64885e9b682fbab4bcb41e8956484ba8d5d5c7572025c3be4dceafe8c5f62257bb587811fe2e1eaa64652a0205d51b781a44a1c4cb9fdb43d7 \\x0000000100010000
-43 4 6 \\xb7fa3f95f46dc6f1b1dcf59b79edf28aee6a7a25fb28ad035dff6eb76277195a7c9dd15dcca408da56ea9ab0573bf75d4211319b5cfa865957b6c69062cdd90d 292 \\x0000000100000100904685ba448e5a6f6027b4de4dd86e959976f37cb1054dc01d92598e434cbc846f403cddc1190e994f10a2ea9440a3debbb50c15af3f3107babc6a314e35f38fa527dbaa9bae6a927ee157d424a0fb6cb52078a9c21ec1cb5d073a7c9b4e6d8ce615064885dd3da97d00798b182e1c45607cee1fff36ad4620a1ec36d173a88a \\x2562d084f98639de71072ce141a60cc1d93b5ef864b31a7dadd4d0dd85a70827e7961f5639d609fd929a131ef152bc9484bc9bed0c2b8b092982a55f3606f985 \\x00000001000000015067f4ac39494ee57e51a7e043a0744c57aaadddbd907e5a7e7a5e79e08a5b3cb25615516ee05e1640c47b17c550a8b128bd4fdd7d0bd9b2a2123db9ca0eb32b59d3884add4c845aceea7570113517cd3d8e0bf6d1d823c872db48b190c6c180653fb429a24b206406c6d6906ea423fd2300708ad076b58037bfeeda92342e20 \\x0000000100010000
-44 4 7 \\xccb1ae7d5a0d7578afe40efb4b85d98f2a79aeb8f603854ab90a7e0a232757270d783dc670222cbcf336e5877625b3bb31f846d208c884baedcdb91b3e581108 292 \\x000000010000010066f3b0d317c9798b6d48ee92134b9752416d3d24258797790068e3e672c0a521c2bbd0554f914d47b8bd1b784395369f66c259bccbb51d336d7e8c1f80a84265d4b11dc991435554528eff089b4aa7ebe447ab56cef39955ffe4624cb21fbef92f03a0c5ed000f129935c1a99fc61a8bb28cc936e0e7a2c0a252d62c48ae683b \\x92edf110846918bfff8b3b14f6bf7d6f12ab033a0f2be9ff09823d41e06d025dd6ac3d2c72d486f13da779b516c6dcf701669337ee8cf5e71ab6323ddd45d29d \\x00000001000000016837a3f128e7fa8a26a7f0db8b1854d066294cbe3831a3135aa4b5fc0850505cf33b824d122660fb5d173a607a55b67703f8e75ea7c80eef0b22618ac18deddaeb6f9b4f847502a010fc0af40be6ef16356c64086e3d3cb6f5c1a44f06b339d20e584ed02a0d6a7151502862d017f555f0cf2f7a94ccd4a199afeb933c8b5f4b \\x0000000100010000
-45 4 8 \\x7d9fa4fd370ec889af376e16fc6538665d661f1d048c20b066d444888302036a6a164b3a66e7643f0050c58ef2aec35dcd95d839eafa3b61e091e23fc46fde0a 292 \\x0000000100000100b845079de9ea3ca350ce0316f50eb89d8cc94a99fb95ee126ce9fe09cefc0862efd958267233a2cd4295c611e8ef0625075e2c49731c356db645a583390d06e7e91f2df8822dc6f6f392455e9f95cdb36d1c0e4c9da2ff470eb46d91916b95f126e3a68eb252dfa8feba93390b55a3899f05f2b09f8adae7f463f6390206a08a \\x4683fc83d7a1d3d267dcce416471c9a020951c3907cd1e108a51a77502f1b66bccb9ab99fae5a2aa89ab13e46e2e30a8ab0908465378c56584a970c877740bf6 \\x000000010000000194a3220dd971ab04195996af1edcdf3a98e2887f121efc1950a20a54cc1f4542ed0a602322de18323e74b78bd33c5a334bfd29aaace7c6ff0dc44ceb75e9462eb6a4f2473988b49e90fc4c7deda6dee34befa6495e2848ba0fb23cc47e98997c21e4a20ce6530f0f02cfb1a8b51684e2fd185e7db5ec1bce7ddb995ca8f18d9d \\x0000000100010000
-46 4 9 \\x488b6afdf5b52a84dfc191486176363044fca73c096ad57be3e6c35f84b5a119832c8909001e5009e2ef54fbc8614b63b0a999a404671b6d5c6e643080754b09 56 \\x0000000100000100aa0766c87ad99db2d476c3b3a29782ca96c6ae86a7a5b6985e11d3747b404702d3b4ba3ca33f048ee9702c5b5b0e9b100f9be96a1ae851c84be5c02efc9e32048e1d9def90813ba1b137a0b316aa8ffd000a8bb508846fa98a8f63c16aa10422bbc336c894aa95db9589bb90d7bc81ffe55b66beb2c661f195ec44b3e6c55ea4 \\x379f194390a30bce61a35b487111f5addc9b3673dcb7b40839cd9e513be9cdbd4e348bd019a903f6aae0b9d81b3a5abfb929141c4a0adb759579edda8ad703cb \\x00000001000000012a7f158873f417ea5aa4bffcce9f1d966a8cfa512f622f085836d4ffde662fec4028ae2e71075f4eab34c864853074b2c0b1044e7c7682015a7d2d51613cd8fd635676b616d0e7feb56b0f5192fb7378272714409958ac50df8638151aaee8a680ad77cb365b051c93ca6fa41c2dc9289d9651591a369aa797ff7c8b3f3c9e6c \\x0000000100010000
-47 4 10 \\xeb87ee14774a9a3edbe9a44b5a155ed555d8ce0560ef40e3dc349a7e492da7622bd9c4f18fe5efea176c6d4927a33854a942b242ed0f4b4241614aebbacef200 56 \\x0000000100000100898eaa3079b64dc884ac82e866de53fdcbe6cfd9874310588babed7ccb78ebff76c1ca8e0e6cbdf0c158f26c25c721e490499f903fe304e4288d07c907cba2fcaead7ba584cbf8bd3336c42ccf4f3ad9be83bfb78495ee088ba6b438f9f348947b10dfba9cbf4ba85d78b2a4a27a5a165f64c3850c6db76d74e23961a4de4383 \\xb01d0dbc2da76f5fbe0d0fe7e1707a78afd4cc11e002845f77fa9b6df356539dc47d87edddfcccefd351928db417025518f8d356ce25098f6254b5adaf963c56 \\x00000001000000014fdfe921849177a360eff8f3b41214f940c2d8aa7679e658291a7ee7aaaa2f6a6dab6ed9014f7821622121dfe7fcef6613788d058b49511abc7d01a3dec92a5e3b54206c7b232746377b15ab65ef1c413005211c85d636f012652baa1562cd0aefcc7d236056e977c4c3c90291726ee182799fb08e97bb5794a4d03554af2668 \\x0000000100010000
-48 4 11 \\x34130cee5b1e449045391f49198e99e5e3fdd53d524fe136e88aa720e4dd877f2006050d57e8b4fc215b0e9202c1c0fe650370f20a9d4ee1fd9176cf8054cd00 56 \\x00000001000001002a30139818fd105a6b6a7df42b6755b2fc123e9c52d8c3d9488b7803aab7f4e5895176ce68774f8b7fe0563e52e7b7d0a314c41e95d8ff834c80402257a24dcd834ab1af966ee03ffc9abb84f473a28b9f9b983c931030c791ae1f9ff89197e7789448b8d07d5084b35956b925464fcbd160a60717882a113e0a751f45175f0d \\x2b48e4c24199228987782197c27d735294ea37dffa4f80e6023c86b2bce4828f4bbbecaa09f20f6941b6c09cd7c423f06e3eaea4ac5afd5a1c1d71ec7746d869 \\x00000001000000019458c52fce81a64824e183e8a6f3c7464cacac6e6f6f2af7fe69708f642a06df5eac88e3b6b8f94d48222605c3d97bd5109f9e8fff7cf0ec1069a85928315a4452b8bd80980ad8a347e9592db023d5861eef4f54bf3bcc7c41332599fa80a6d1612750385aeace0aee56b6e3dea50a73999aa04a775bd04f26e362855110ae1b \\x0000000100010000
-\.
-
-
---
--- Data for Name: refresh_transfer_keys_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_transfer_keys_default (rtc_serial, melt_serial_id, transfer_pub, transfer_privs) FROM stdin;
-1 1 \\xa06a63b5c45a8648e20585584d319836b00079223255cb7d203e5417e41e6448 \\x5f0fa80505271f6cba2411ff46e84c00b65149bf3be3a1bd4a23de877176a30dfc3d0af9837430c37f566b92ee01d79691ec53df6f3c418ebbf2d56011b89a01
-2 2 \\x959f5ad72f0b7551931d710d6c88ba5ad73b560c92b65c0aa6321b62583b2676 \\x094d9091e8e5d0c400b0a8b4eb7de385e6fdcecd58379cae99e77acb4914d2897123b1b4e9c42c6b607a5e46a56a062badb665c50f71d1982899b40789e8329c
-3 3 \\xc3e50bcbe481fd8313b30e3fc78d1a72b0310805ee9e969bc68fd078b76ec025 \\xb49095163f34a52f172446ebe02332e34bb7824ff80b979b6df9c7a51694935698f03e004c8604b4383a883e11980624463b5f38ac64adf4ad3d36bfe0185ce9
-4 4 \\xae96449e07e4626fa166d4250d11c39dd19ad61afbdaf0ebd9db9faadf386f76 \\x3e478006fba4d33218d3cc6903f2d9decc3c549aaadd1cb3c3ecabe8ca27a76eae1b30ebe36c1bf7aec7dd16df125f6a2247aaabbec8451ee7d2fc472f2debc0
-\.
-
-
---
--- Data for Name: refunds_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refunds_default (refund_serial_id, coin_pub, deposit_serial_id, merchant_sig, rtransaction_id, amount_with_fee_val, amount_with_fee_frac) FROM stdin;
-1 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af 2 \\x8724068701806b1768e9dee761935b71373320efa2fac73315163b95513c5d1be3e5f0d81f8fdafb70682d47ca880aad1361b4a507a02fd5d58a7fd300773a06 1 6 0
-\.
-
-
---
--- Data for Name: reserves_close_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_close_default (close_uuid, reserve_pub, execution_date, wtid, wire_target_h_payto, amount_val, amount_frac, closing_fee_val, closing_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: reserves_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_default (reserve_uuid, reserve_pub, current_balance_val, current_balance_frac, purses_active, purses_allowed, kyc_required, kyc_passed, max_age, expiration_date, gc_date) FROM stdin;
-1 \\xd861eff5c230ae965384a2fdc113926bfa4d7e29696095fc15d83d438e88070a 0 1000000 0 0 f f 120 1662670974000000 1881003776000000
-5 \\x3363ca4d3bae0c18d5f9e7fff9cd75a99f04f03a502f32088564b8b4d7749b96 0 1000000 0 0 f f 120 1662670983000000 1881003784000000
-\.
-
-
---
--- Data for Name: reserves_in_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_in_default (reserve_in_serial_id, reserve_pub, wire_reference, credit_val, credit_frac, wire_source_h_payto, exchange_account_section, execution_date) FROM stdin;
-1 \\xd861eff5c230ae965384a2fdc113926bfa4d7e29696095fc15d83d438e88070a 1 10 0 \\x27ad60e4ed488950c5fe0698032e977273fac7c98c6609caa4ea1f63fa1de493 exchange-account-1 1660251774000000
-5 \\x3363ca4d3bae0c18d5f9e7fff9cd75a99f04f03a502f32088564b8b4d7749b96 2 18 0 \\xec24b3a5f585a661aaa81a89f2dce646976205c32e73e68c6ff338e097e43005 exchange-account-1 1660251783000000
-\.
-
-
---
--- Data for Name: reserves_out_by_reserve_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_out_by_reserve_default (reserve_uuid, h_blind_ev) FROM stdin;
-1 \\xb66fb37cb9e3e97eaf1235edeb2852996a762df4b981c332dd062e85e20955a64d33a39c33fd0c38049f28dc1854ccf024d4cc52c57fa8b1e37ea5c89f8a63a8
-1 \\x45beab6e93509092550fa760e705e3bf3eb3638ad60a7e507e798be9b87821973491988798e7d8009405ae3565264d52980e4d9755ffe5065fdd700098a057e5
-1 \\x27c1766cbe8c21906809a583a3e1d0c69d021b3c93ec2005d87786de8909a560f7c288baaa620d4208aecbafacf7a9a77c2f420456254e9f6377fae4e0d7622b
-1 \\x9883198de58cf5787521da3ec6ecf1eb11caed84d40826d0fd4ea32be0f829a4eadb59eb5e52e4f1d8a99d9f38f56de7060a90ede8ef1ec66e0702337221c926
-1 \\xe1d051b6463fd59ae1483dffa9bb13f8a485bfcfa28d196b133609826deaaaafcbe22c6f3ab7134f030cef7ce0eaa0683930ea5cac969f3fb6b0868b318dcb22
-1 \\xfcf19246e210b348a1840982f524e36c7f4edab678a9263c70a5f0158445eb8affec1e9fb817451e7f0e09143d854b7e5075b2a39b0bf8dd91223d15d5fed9e1
-1 \\x9080a3ef1d447a5bd836f3e7f9ea069d30c1d7fbae1e776dbd6cb5a975ca3e0dccc74b7cae5468d10ecc9e6469d48f3102d40acff678e9cd4be17e076afa477c
-1 \\xf5cd1d0de2c8d2bdece963ef75d08c7ec9cc941de3a262ce5766bb84e223708bb3a04e088372126e6cc1a4df5c4cc48459990f2bdf1508f961fca74c35d86bba
-1 \\xf232932a753d62a389f50475b5f9f223eb5eaeb974400e4a9e31d75b398ddcc5dcaa9e9801d452618159489936cb1ae16bacef4672acd5679d460f48f54efbf2
-1 \\x9d4152f05da514ca1de06a9bbddde78d36ee67985f9c45cf274c1c72f2ebab8cbba52d562431fa502b0690bc9ee897a95fb0457d23a5d2f25a24d94ab0f7302c
-1 \\xf09832b71339d8c151abb0e79a848df0865a1fee29d45536f1139f2aa457cbf419ac1c93836ec06eb6507b58913554f83402807bb32dad7721e4d00a05701ea6
-1 \\x19c627139275cde4769301641c791f774302c5deb4b4057dfee79733ce152330c8127a4e513e4f352c484ee26ff44272f5b57d6c39ae36b52f7a052c131ac96e
-5 \\xcf61243313e7367c08422a08aca2213306d3645e587338acf6c632e93860c81384403ee95511ba3a2b26a58288f9f731edf87bf50ab33f2481111ab5df813203
-5 \\x38dbc00e048f0f036acf451585ccb9e68a1c6b864ab27e35e36bff5147b0c40c05e694a87b39e84bd7593f72a448e9371182978877893165ec14499c7495573b
-5 \\xf0405f9605fd43116c2f67718d1dbd34ff208d28a6c600f6e60a6429e082054f5448438b42434362586bf0359635de8b0733dccc9eb75800fd90df47a8055cfb
-5 \\x6931c5fc50013c12b8103c0fb5d7ab97c41b2ee43aab02a824056308e680b1767aa503f8fedac0cde3b4a47a5917d7ff1124d9b1db5c18a001dee1580262c580
-5 \\x3805ed064975a354be2928562fc6d015d856a22c11db714728d694b2aeb7a127bf86e05788ade9b9175a610b551e9a70a225dae6f9d8ccb41655cc6cef0c570f
-5 \\xf917c334ea160bd642ef4662cc7b3b2971611c46f034ca1fa3d934ccd3d717e20f9bdd570785c6ff462d1437a1b833cea9993d6134957d5498490ae1ba325907
-5 \\x81d2521b00b74d71429566bc1abaec5d65c96ad6b55464fa806e2295fdf19366adf14009c24c58c8082ee84ea5d2a975fde53d9b19b98ba5378592875524d25d
-5 \\x5111c6b99a2f44bda4700d4edd01a66ac1f2092fefbec9d7b845ead79a782ef1227a7276cb9ac623193e69bbc80f04108c3cdfbd8d142b43e02a286933bb037c
-5 \\x703b1fdb763113dd73986b4ecab79d20ce8e4ad74cf3591a93b8281b7f81cf654c7a2c0e38493b296c04bddf79352e3962552c30a235b0e70a3bc76a60ca8a29
-5 \\x6929eb237120b4c25d2d8e99aeac705fa1363b8c0174616c89aa194bea68789a3138d43fc9f090a54ab67446a2366ad856be96090d10c68005580903c8d222ab
-5 \\x4d9b7f38fa7efa959f69e1677b613799b64aa000b1042221a01f6787b57128c6a101e1c7593c9164271443c121571c3755224bd14f6ab50036e044a47fd2aa80
-5 \\x5964322c9eb19f30e06e7b475eac18192ee832aea772c8cb801a638ff8007ca802ac47eac03b045e59bf338346e6de6f8b77cbc0f4a32b002488ca727506891e
-5 \\xe025370e9378fae4b643e7f83e871f280ad4b021c8851a4391580cdb18355440e0351178fabb7ae40f62347a38c4d94fde8b7e8168016fd7a5071bcfac6221da
-5 \\x92b12fb4fa1b29785ec6908531ddb6acd757f6d985a1964c153fd253386c1da8b832bc8320c9edff888d4abc07e47d8bb4b3df5118f595c85b52a3166b55f1e1
-\.
-
-
---
--- Data for Name: reserves_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_out_default (reserve_out_serial_id, h_blind_ev, denominations_serial, denom_sig, reserve_uuid, reserve_sig, execution_date, amount_with_fee_val, amount_with_fee_frac) FROM stdin;
-1 \\xb66fb37cb9e3e97eaf1235edeb2852996a762df4b981c332dd062e85e20955a64d33a39c33fd0c38049f28dc1854ccf024d4cc52c57fa8b1e37ea5c89f8a63a8 195 \\x000000010000000130f7edce1335b42d7a9cdac2bdc2b1dd8812c68711c03fbf01ff9ce837566f45af816040484743082fc7674804cbe9ece1460e60bd36917fdd7d377e246f4301cb698d05b2b33abe649c096e43ad470342f952d70ed313d550bd6a97c13180bf2648d472919544207690ba4e68d5db09338d94a839fe7c2f455fd60fd6753e66 1 \\xd4859b7c2469255fbc079084225f2312ed962fd57c3bb413ebdb4901cd02088d1aceacc383125f172052680104bb2b581e7b2b877836d7977e464647594a1400 1660251776000000 8 5000000
-2 \\x45beab6e93509092550fa760e705e3bf3eb3638ad60a7e507e798be9b87821973491988798e7d8009405ae3565264d52980e4d9755ffe5065fdd700098a057e5 369 \\x00000001000000018946ec50d087f338c6d17c2cffecf8ee226ad83f63b68f12ef1d1ca1b3be6ddf69321e086a04bbd0d28dcbe48b252ada1aafd18a90b2880243eb33f6aa31325518a9fa9d0354503911a75bd9c1d70c7e6e89ccbb81fc6b8e6d23df7338fd453a84459c990c3bc3a4b846216f45568d3f90b244ffc7e07c5be858327701245b6a 1 \\x72f3a6ace7b2283c21537add5c434fd81243fe28744873b281617a04ac6a907f422b756e745d3d5c2ff77b0b58eb64e00195e5f44db7a928ae50d9b6c04daf00 1660251776000000 1 2000000
-3 \\x27c1766cbe8c21906809a583a3e1d0c69d021b3c93ec2005d87786de8909a560f7c288baaa620d4208aecbafacf7a9a77c2f420456254e9f6377fae4e0d7622b 292 \\x0000000100000001b2a83b8f0d4b60c389dbc810ab7d93571576c9abc84d900d6cab44472846b9c854c35d38359f848a2e9c1674fffd1daeaeb84e9617e9e156de73f080739b4ce4012f1fea65dd1df41684a195624df02f9729bc34e03d51fd8de0b958fdd93a50cd052700346a24ebde125cba4a8e5f0d82eb6e30bd081b7cc38bf3cf49ba7194 1 \\xca83b1331961128b70a90b98580a1d0924c649a792c55cf015b840c91975e324c228476fc1f3bff33bcb5bea18b3e776cf921a13186420480993700223a94502 1660251776000000 0 11000000
-4 \\x9883198de58cf5787521da3ec6ecf1eb11caed84d40826d0fd4ea32be0f829a4eadb59eb5e52e4f1d8a99d9f38f56de7060a90ede8ef1ec66e0702337221c926 292 \\x0000000100000001408881077835fdf3c22ddc9d524f7d2deae9ae88db642abfcc175273f0b595073cd29abcc35f2f0e4026f9fda361d9ee99c5a9fb80f9d2f6785e9dda0a4accb42522e5918c8e1ab2a084dfaabab996b62980eb55ac3663eeb964616159d0ca453135a02d069c259d51214227f91906098e5dabb298858304f9f862a71bbedb89 1 \\xd9e979044597143395db833445dda783e13fc311cf5fd0ba230ebc5bd98cc0179ed42c41ecce3d9bbfd809abd0c91f97954e4b7c1baa3f8ac04ee7df5f386c01 1660251776000000 0 11000000
-5 \\xe1d051b6463fd59ae1483dffa9bb13f8a485bfcfa28d196b133609826deaaaafcbe22c6f3ab7134f030cef7ce0eaa0683930ea5cac969f3fb6b0868b318dcb22 292 \\x00000001000000018ef2dab5b9f6ff11f070b8e6466ae67b69ca1946a1d50acb05ab951c47285d1099d32fc45c03dfc3bc900bd7eee433de24801118fa0634a3b50e4f0a598061c04b01c46f2bb088ce945da60181514ad1adc7bcd052a57defaef4c38de163dcdbcfcd79fa5bf09d55bea2a86af4916f1bb23f5add7010d135c3541a79a006d064 1 \\xf89d534319d914e35e968e553fa4634f5a168a127269cdba90239f2a246d7f4a6a7982704654341b99a82bdd3e03295133b9e7fcf6efbad78991b6fd5b76f703 1660251776000000 0 11000000
-6 \\xfcf19246e210b348a1840982f524e36c7f4edab678a9263c70a5f0158445eb8affec1e9fb817451e7f0e09143d854b7e5075b2a39b0bf8dd91223d15d5fed9e1 292 \\x00000001000000015458d1f643f3652e81a254765c5f49284e2f1a9e452a19cf4e0cef9991c3b5ba39307c6fd58682cbf37002c29d2e96db280905e66bafa73a34a25b169a4beb70e8585dbedbeff5937a414ba55e006aea701e02943b71b88370e3d87a497e590313fdf9ec15f1c4a228a91a3f0434092689bdca8c71096422e0b61904ee173bd4 1 \\x4d5c5f9ea5857e304a3bb457dc23156b0d64c31f4c75ebbc00412c910f05c75a4f86c8f18c9f7f8620153cafb10c03b5fb414c9c07e35ebf3fae76eba656580e 1660251776000000 0 11000000
-7 \\x9080a3ef1d447a5bd836f3e7f9ea069d30c1d7fbae1e776dbd6cb5a975ca3e0dccc74b7cae5468d10ecc9e6469d48f3102d40acff678e9cd4be17e076afa477c 292 \\x0000000100000001285c1a1a0385bdb12a649784e25cd4d74ee6eb2c5ea18178933fc315ea1b81be4cb7b9a403232328dc606ce42a0a6b033d59ad3175ad50a3a1d14547fa8a75ab5abeedb69d5b4dce9fcc67bb5734da55424c2fb8ff4341315bd120a7711d17d5ab86e25fc71049a653e8920a7a14a71985e82e24c331a3a7fa2aac67e678b83b 1 \\xf6c888b6c4d6e1afc38803887a854f39f085af64ef2ac041aff737b2cfd611cd654ab388ab932dbcba4cf47b91911c970d0e00f660e96f6bfeedfe34420a4e06 1660251776000000 0 11000000
-8 \\xf5cd1d0de2c8d2bdece963ef75d08c7ec9cc941de3a262ce5766bb84e223708bb3a04e088372126e6cc1a4df5c4cc48459990f2bdf1508f961fca74c35d86bba 292 \\x0000000100000001acac59b790455d0324029011f79bc00d1a80824ae299b171589e1dac77e1ae0a79dd5d000f382ca75e013c90b63e9915fdfb4eb04b95a7b55ad6a2542b305da864daf7dbe6ea078bf5e75c1267dba1f1b75f81db340b42f1b228382b8490273bfbc0accc12f7db034dac895d0eb03f88d1c66f261c47d73740c16f790536aa6e 1 \\xc53b82d891b1c3a1cfdd6e1c80a857a0e9f8d588809de6522122d84faf3b031356f03030f12f59ca7135c3c0a800b79afd42938410a1eb4ac3a849bd8f0aeb0e 1660251776000000 0 11000000
-9 \\xf232932a753d62a389f50475b5f9f223eb5eaeb974400e4a9e31d75b398ddcc5dcaa9e9801d452618159489936cb1ae16bacef4672acd5679d460f48f54efbf2 292 \\x00000001000000016717b9c09bec1221ebe8c61da1aaee0cd3b86a9b7ebe3f42ee321020cdb26c969d67a5be88dca1981ab34bf594a80c55e31da67a3043dfe7571709a0355ba3f781850773300492e620f501d07865afbbd54e36418b83848317c99079230de04751071464792ca4abec653dc806840a0c5d4dd793c53e1fc27f06813137a5f5a1 1 \\x1d2e5f7ca8f8da36c208b3960c648487093e27f6cafec6b20e9b60335c84d6e4ff977ab8904a39a9fd9e9744fdf985dfbb6d4422f674e1688b465f06a8b09a04 1660251776000000 0 11000000
-10 \\x9d4152f05da514ca1de06a9bbddde78d36ee67985f9c45cf274c1c72f2ebab8cbba52d562431fa502b0690bc9ee897a95fb0457d23a5d2f25a24d94ab0f7302c 292 \\x00000001000000016af9ce48f5a05fe80c29e310f19a48dd51ad0acc563a8dfabe8c972a30f6eba87608ee2fa0f8a5ed5fad316d5783fe95de2ad2b04ac42f723f76f52a45ed307a52f291e65a9436627db31ce8c1f61992495ddcfc74393f705513ff66b8fd318a398541a1ad1ad32abe6d1e80af50041d96269fcae8ba8b4700fab9e6b10a24f0 1 \\x4a6547e02cfadfcc49ca6555e7a1b879685659b32bf6023598842fd9cb5ef3b056fb5666d66b2d3c14795bad829cba51c8f2c1e14a838295791994d1a740d701 1660251776000000 0 11000000
-11 \\xf09832b71339d8c151abb0e79a848df0865a1fee29d45536f1139f2aa457cbf419ac1c93836ec06eb6507b58913554f83402807bb32dad7721e4d00a05701ea6 56 \\x0000000100000001b7a5e5fa62faa7c65bc5ced914f76677ee18880cbb9434bd16203a25c2f3b074ee9ac98cdd62e9981adc6c6b06b5b559357d5b732937f41030f5743f8e3c175eaa9a0b5d8545e3e780e140fe4465caad21247eae38c110e222d84926998392459fafefa3ac0a992d75fc2bd4d16e29eb9d5f23b95cd8debff36bd7ddf8703f81 1 \\xd498817b7ec139214abdc56d387ffa0aeabec28ed59fd739e0b26c52c60de9f27dd7bfb89aa4976d31cdc12cdfc7c59a7e6f54e87dc55aa42b48bf94dba04803 1660251776000000 0 2000000
-12 \\x19c627139275cde4769301641c791f774302c5deb4b4057dfee79733ce152330c8127a4e513e4f352c484ee26ff44272f5b57d6c39ae36b52f7a052c131ac96e 56 \\x0000000100000001470fd6fac0049eee0ab6b742ffa31f0bde2a49eb47d0be0a957041926402a40a2ebc2fee9c18e6e2acfa04d3d15be6d09920d6fea21746e7893053d57357d94e956e3b520dd6e72426f572e0418e7783f46e9ef4335dba191234a776f67980f0272098ed53ddcd916d6f6f9a4c1a221b1c45b8b805931710b295fb2189a3689f 1 \\x62af17f660310a07aa34712b918937e696b6101b94de510c9aabd497045b5a88f47157b707be663aa693b9014c65bdba6c840a7b7f2b118acad0483743e25008 1660251776000000 0 2000000
-13 \\xcf61243313e7367c08422a08aca2213306d3645e587338acf6c632e93860c81384403ee95511ba3a2b26a58288f9f731edf87bf50ab33f2481111ab5df813203 253 \\x00000001000000018c2f7ab446feb486b155aa37cbcd2aaef98c2332d2f0dcc8664426d832a4472ae457fa42680b730a3e444c200b3a6520abbf75fbd7a49cda71e6127a8a50ef51abc5e911df2a007c4d23a1604e6d2813de9025b3b27df6470237634910cf011c0877cc4e6881e549641cd9f945921ecd8e830d657739698a035c4d187cc41ac5 5 \\x86ee187c49db9a7893637da8464fdefe5e99a2735f012213ba3afd70d2edd3cdc47ed62e03d90f98f916b7cba62c79643547253ea20cce8744e322b9ba57920b 1660251784000000 10 1000000
-14 \\x38dbc00e048f0f036acf451585ccb9e68a1c6b864ab27e35e36bff5147b0c40c05e694a87b39e84bd7593f72a448e9371182978877893165ec14499c7495573b 190 \\x0000000100000001686458b591e28ce82d73f10e8f81c1c7270cd2999f92dad64753e5ddf2a50cb135961e07c340f48adf1a00aa61e6956d2147699be2b6789ba245eb2e6970d6eb412fe9b3037cf4c4ac4e246fe99a2fa19d791ac5a84a1b324579854f1825b51bbb899106bd6c72e77c2a6f33ddfc8673125117aaae0db69a57901e1a4300717b 5 \\xb88cea53240f2665c2b56c46eacc18324b595ab048a1aa3ad1a0bed5752997374a007faecb5cc28a8d15887ada6a7400ddb2588bb205debcccc2587bd2a67005 1660251784000000 5 1000000
-15 \\xf0405f9605fd43116c2f67718d1dbd34ff208d28a6c600f6e60a6429e082054f5448438b42434362586bf0359635de8b0733dccc9eb75800fd90df47a8055cfb 250 \\x00000001000000019bf2e0865a97812b77002eeadcdeae92b636d22b8f23f33017349fcdd176086dd05f54e5ff425454c19e81a8e9f1b79ca00ee351234799244d9c80e82d37d79eb675c420f25dcf99940a9c08224091fb99f059a4b4bc7c439c7093a90a00a08ad95c20771c90652c7d1c3da5d73673cd098269593b432bbcc1ae12253393ab0a 5 \\x2a8dc3e8a00cd3d1d4513b41a6f694ef9c6a8441de8e79744d3e69df5ba630429c48500d5a822c7b4255888185c4164c717c856067aa43f27e44220a6023ab05 1660251784000000 2 3000000
-16 \\x6931c5fc50013c12b8103c0fb5d7ab97c41b2ee43aab02a824056308e680b1767aa503f8fedac0cde3b4a47a5917d7ff1124d9b1db5c18a001dee1580262c580 292 \\x0000000100000001587ed1e15c31c178e79fb71f8e4263221e46a37edbd47b207b1713004ff8eb1a4527dbfa8b1c80c6ded817c9c3d6bbf84263736f657397709f225f62f7a47b66db8798e64384a1cfe1982a8118e9cbc0c1f2e599a463ff1207bf1a20a9ca1a423e62a864382ef426321020073938da3e62d97c8c921cbd96d4791742772b1f45 5 \\xc18e7d483947e819724c076aa7ecd4ad2d296f9892dd483fa90affacbf734caa05ae2ad3a96933236b99bbd145f796b26b5acbec50b29d09d2202167f477b507 1660251784000000 0 11000000
-17 \\x3805ed064975a354be2928562fc6d015d856a22c11db714728d694b2aeb7a127bf86e05788ade9b9175a610b551e9a70a225dae6f9d8ccb41655cc6cef0c570f 292 \\x000000010000000117c6c804d9ddd06880bd15bebfd59d0b81aa86d23fea68394f2dd05e7c03f0fc48fc1ec33904613ecc20ae67cf645891cf3886e8bec3dadd234aba2855b5e81c8cc623186015cfa78244524602e409601dfc504e7a6baf4e497865756890830715cd00675399031f01a92ef6b3e5af5b117d1af66c43cb60f7f7922d6ee01d67 5 \\xe548a9247be0b37f929856f3f0a8acc7a5100a8e171d8bbc67bc30dd8e817f244076bcc274fc25831e9b7ee1a250913092836ed2eb4205bae1ff1559c08bc100 1660251784000000 0 11000000
-18 \\xf917c334ea160bd642ef4662cc7b3b2971611c46f034ca1fa3d934ccd3d717e20f9bdd570785c6ff462d1437a1b833cea9993d6134957d5498490ae1ba325907 292 \\x0000000100000001437e107ff83d6c8ed517e5fa162518ad9520c192d8ea9cc2371c6cd20097c69bb73c55bcb043e397c58cc01904085ca8f4c036b0e8c426da04f881de5606be517e8115241c50fba14157a87524629f856e4812105b0d67c1eec2a3a5cb2ba0fe8322cc311bfa87f7f7500bbda06a88425a9894e8829912bf7802651e0dcb3c5c 5 \\xa13f6c7d78e1dc3cf246c2fb4e17af41877a5a01358f05785437b8aa3aa413a85ac4d802a50d707c58f117ff6e1c4012b4f76bf6a406d2433e66b4d4fba1e406 1660251784000000 0 11000000
-19 \\x81d2521b00b74d71429566bc1abaec5d65c96ad6b55464fa806e2295fdf19366adf14009c24c58c8082ee84ea5d2a975fde53d9b19b98ba5378592875524d25d 292 \\x0000000100000001cfff3ac04a0b0f47cf9ea2e6657e5cbff05820879c473caeca3d864172307447f256490f332a4898da2fb62c676f8aa985e54fdabe524bb88b2c8ea7dcad790728871a73fee6e88dc70cab42325bc3bd9215b62e26907df9ec25f2bd3bb4af5a876a2d0cdd336fc8ab1a8e2d19c12b35cd9fe10b89af0e8b6343e3603e75c051 5 \\x7e69cce54cf62bd84246aa7a55e5666d4d0b8eb429340473caea86931c8aea196fd0e688a72a00ddf5008444ccd7185c160cd19948ed6fc2baecbc1d538a0108 1660251784000000 0 11000000
-20 \\x5111c6b99a2f44bda4700d4edd01a66ac1f2092fefbec9d7b845ead79a782ef1227a7276cb9ac623193e69bbc80f04108c3cdfbd8d142b43e02a286933bb037c 292 \\x0000000100000001d5cbc9c83542ac51101223e1d82b907c9abf1a1c425206bcd312bc472f11126dd993c8e595e8c5e248de043d8f36773593f34b422695ae5a62c3b77d01638250bb47c865375802aa2e32ce9fbdcd5f383b3253b8e17c2323e7fd5b946edc71d78946eab0319d05aff6a7b877876efe795c8c9239715f6006b215e4992f7ac7ef 5 \\xc443e5c7abe7a8700e591e62c2bd548d536cf611730e9b325adadbca903911f7807dd99af358131991f318e98a68d212506b3a6349c24d27e3d5757b8b003d08 1660251784000000 0 11000000
-21 \\x703b1fdb763113dd73986b4ecab79d20ce8e4ad74cf3591a93b8281b7f81cf654c7a2c0e38493b296c04bddf79352e3962552c30a235b0e70a3bc76a60ca8a29 292 \\x0000000100000001b291cd789a2200ee7b1e3386dc449c4d5f376e29adde8c915f188b54c969067ecd1a3b9dbd37988db84d5c4f173e1ca4b9e49c9e935fe901f0bf75be4bbb5b89a2ae6f93699be47cdb5b76534c847316412232a734d0749f20f2ca340692ad2f373461f75157ead0e9d3058885e0cd2a98da63f8b28f7cd77f45d7c9b3af4b4d 5 \\x820ef601a229bcc10ffdd0d1e03530ba0ac81e60c9fcac64269dd90c9719742dbc6ac430b49f5e0d3063cf5587723c5c53e60952482e1b85130b149e8fafad04 1660251784000000 0 11000000
-22 \\x6929eb237120b4c25d2d8e99aeac705fa1363b8c0174616c89aa194bea68789a3138d43fc9f090a54ab67446a2366ad856be96090d10c68005580903c8d222ab 292 \\x0000000100000001c2be3815cdacf5d89c927833f105414deb80abfae3256b93213efd26f48085b645243600453860ad78793746031c893e1bd16786864ea8bb214a3d4e43e841a474bb1d4e4c7f7d13ae760bb72a490c9e47d559d014dc6c1d4d4177335805d224b6158915980c4f15a5adc0e67497d158b310de851cf2cfba0e6c79b50c829a 5 \\xc22fc792a7582e2f2324da31f955c3ee63fb03e0491a37b23df90e6ca29d3c0f1ed0a8349b8908b0f8a5ea1e9dd755c9a6ad3d7daa2e473801c0aa0b6e5a9c07 1660251784000000 0 11000000
-23 \\x4d9b7f38fa7efa959f69e1677b613799b64aa000b1042221a01f6787b57128c6a101e1c7593c9164271443c121571c3755224bd14f6ab50036e044a47fd2aa80 292 \\x0000000100000001135e8d09f3b6d02500eed5c4cc98819fdb1a8f5b6065d538cd28501f0084670317d8dc6c0665f71c82454eb675c2e3604d76764d3376b2b2c6110ea07bbf1cd19a0d19f674bd4a7ba8a7a8d4e03004e068d1832b13c341172259901f8fb12f7dc85d8a5019701aabc96d4c6a60a995e2a3010886b398c6eeb208a2a420af896f 5 \\xb2c6c4e7f8d17c819e631bcef8c770d3012bd3478c09b2aaa9a8262ae63858d1fcf88a07a62df09cfc89b1618ba9f229d21abdf46af3a6f95655566b9686d20f 1660251784000000 0 11000000
-24 \\x5964322c9eb19f30e06e7b475eac18192ee832aea772c8cb801a638ff8007ca802ac47eac03b045e59bf338346e6de6f8b77cbc0f4a32b002488ca727506891e 56 \\x000000010000000165701957920827d7a3274416b7c9c2e1a0376c10af5acf92329e4afbb373ca005f4fd9797c188fbaa28a76a961cb9be84b011bcc5809cf25c587751b34d0d5929d51658d00b48510681ffe539ffbbbe2e51013b1b65b724713a40d7ebdff7d6347cb840ba3371cc119ccef85effac680c821007ef0326435ee865cf5ebc8c972 5 \\x92dc6c9d6c981fd4b5208c9ef2a81d34c1d32e6e5a72ff64e7876304c115124cc016677f064f568b86c3000404e1a7c44dca52e7c23f83ff016c1cf75b2e190f 1660251784000000 0 2000000
-25 \\xe025370e9378fae4b643e7f83e871f280ad4b021c8851a4391580cdb18355440e0351178fabb7ae40f62347a38c4d94fde8b7e8168016fd7a5071bcfac6221da 56 \\x00000001000000016b5219514c0b0cdad21e3b51750bd6c909ebf4099119a611b0ec5387123d7689310cfc9d710e00a9168996f487ad99560482ed8c40802ef6040cedc06d547c1710eaa4177a9abfe8b5e98064557ad50929a82fde94aa318b8c31c4d2622da76bc5757bdca61a0b0ab6bf162e9121fb3f252fcd31004fecd2dbc51f4c0d25171d 5 \\x1d63cb76d28be7e0e3496935629017ef5a548eaa25213971691fd944fdff41679eda1dc4d58e1b051f7f43edc00501cb9ad039c5f139d5348c6aac334c660e06 1660251784000000 0 2000000
-26 \\x92b12fb4fa1b29785ec6908531ddb6acd757f6d985a1964c153fd253386c1da8b832bc8320c9edff888d4abc07e47d8bb4b3df5118f595c85b52a3166b55f1e1 56 \\x000000010000000138505be8d0a9213bc8d160b7facd2bcf6b54c828dcdcc216613e3f9ff0388f6d34358a74fc15e3e6f63ea9ec38d6465d90b267b84bbcb12924425043397ec63a56cc1e32cbfed74810123b9435abd77c937a5e127b6d98db585da2f4d3a93e0df24532c7abc05614fac043da8981becc75458b04df75a2055e3e97fff6dc8a2f 5 \\x56b73bd20c661ebc9aeaae4accb634b5845f1621fc681e744971a964a0f0e4b7c11faa4426e0628d558a231e7f3b2505be848b933d6bb2a33872c51ce475c50a 1660251784000000 0 2000000
-\.
-
-
---
--- Data for Name: revolving_work_shards; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.revolving_work_shards (shard_serial_id, last_attempt, start_row, end_row, active, job_name) FROM stdin;
-\.
-
-
---
--- Data for Name: signkey_revocations; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.signkey_revocations (signkey_revocations_serial_id, esk_serial, master_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wad_in_entries_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wad_in_entries_default (wad_in_entry_serial_id, wad_in_serial_id, reserve_pub, purse_pub, h_contract, purse_expiration, merge_timestamp, amount_with_fee_val, amount_with_fee_frac, wad_fee_val, wad_fee_frac, deposit_fees_val, deposit_fees_frac, reserve_sig, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wad_out_entries_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wad_out_entries_default (wad_out_entry_serial_id, wad_out_serial_id, reserve_pub, purse_pub, h_contract, purse_expiration, merge_timestamp, amount_with_fee_val, amount_with_fee_frac, wad_fee_val, wad_fee_frac, deposit_fees_val, deposit_fees_frac, reserve_sig, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wads_in_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wads_in_default (wad_in_serial_id, wad_id, origin_exchange_url, amount_val, amount_frac, arrival_time) FROM stdin;
-\.
-
-
---
--- Data for Name: wads_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wads_out_default (wad_out_serial_id, wad_id, partner_serial_id, amount_val, amount_frac, execution_time) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_accounts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_accounts (payto_uri, master_sig, is_active, last_change) FROM stdin;
-payto://iban/SANDBOXX/DE546854?receiver-name=Exchange+Company \\x3c43057735728ed34a51e2f3f5cd6a9128c6c0b41432276933406671ffdfc07b9f679caef7a45c1cab4bf0448627fdd353ee4c473b166b15c9b981bebae7d001 t 1660251767000000
-\.
-
-
---
--- Data for Name: wire_fee; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_fee (wire_fee_serial, wire_method, start_date, end_date, wire_fee_val, wire_fee_frac, closing_fee_val, closing_fee_frac, wad_fee_val, wad_fee_frac, master_sig) FROM stdin;
-1 iban 1640995200000000 1672531200000000 0 7000000 0 1000000 0 1000000 \\x2287fdbe9828660f7442da450ed5907de4383853181cddcf0351eb6f346649bb7ff9b98ff23697e8c2b8d05ab2880273cc3a8d5bb90c15fe0c0eaeb9ce0fc60b
-\.
-
-
---
--- Data for Name: wire_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_out_default (wireout_uuid, execution_date, wtid_raw, wire_target_h_payto, exchange_account_section, amount_val, amount_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_targets_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_targets_default (wire_target_serial_id, wire_target_h_payto, payto_uri, kyc_ok, external_id) FROM stdin;
-1 \\x27ad60e4ed488950c5fe0698032e977273fac7c98c6609caa4ea1f63fa1de493 payto://iban/SANDBOXX/DE687184?receiver-name=Name+unknown f \N
-2 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43 f \N
-3 \\xec24b3a5f585a661aaa81a89f2dce646976205c32e73e68c6ff338e097e43005 payto://iban/SANDBOXX/DE871507?receiver-name=Name+unknown f \N
-\.
-
-
---
--- Data for Name: work_shards; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.work_shards (shard_serial_id, last_attempt, start_row, end_row, completed, job_name) FROM stdin;
-1 0 0 1024 f wirewatch-exchange-account-1
-\.
-
-
---
--- Data for Name: merchant_accounts; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_accounts (account_serial, merchant_serial, h_wire, salt, payto_uri, active) FROM stdin;
-1 1 \\x6000b5d64505986e5fcfd8ae2bac7d726fd1a3232a8746b5501a157876034075f66926a7f9b25ca85cfee7ebb5e5aa0b94b82adda8d0225ae924cfaa9e3f6f7f \\x2b8270802bceddd01e56777d30c8a81f payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43 t
-\.
-
-
---
--- Data for Name: merchant_contract_terms; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_contract_terms (order_serial, merchant_serial, order_id, contract_terms, h_contract_terms, creation_time, pay_deadline, refund_deadline, paid, wired, fulfillment_url, session_id, claim_token) FROM stdin;
-1 1 2022.223-02C2B3XFSJ9CE \\x7b22616d6f756e74223a22544553544b55444f533a34222c2273756d6d617279223a2268656c6c6f20776f726c64222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303235323637367d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303235323637367d2c2270726f6475637473223a5b5d2c22685f77697265223a2243303042424e4a353050433657515946563251325142335845395158333853333541334d4444414733384151475847333831545a435439364d5a575634513538424b5a454654584e57504e305135355235424554484d313242424d4a394b58414b525a50595a52222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232332d3032433242335846534a394345222c2274696d657374616d70223a7b22745f73223a313636303235313737367d2c227061795f646561646c696e65223a7b22745f73223a313636303235353337367d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22534134504d47484d343033563146325451564652564b483942545a32464247335636523746465656545946454644594733415830227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22584856574450564243424b3439334657464e45354132384e53394d4646324b56515a543330453145484a374741414b3154323430222c226e6f6e6365223a224a525344304653364834575038484b5a573751444648563741383148454a324e32515a4743395a315a4545335244463958334a30227d \\x3055636e89f269e560df6e787197f475d0ee80ec7fde580d98ebd494c66a2c7f603d2e8cf3f4b5d7f0119fe35707df4a27e45cd2c32a58aa6f66f7f926b14989 1660251776000000 1660255376000000 1660252676000000 t f taler://fulfillment-success/thx \\xdc840e04273b0c5960ed88d1ecd04bcc
-2 1 2022.223-03Y47X7EZRGQM \\x7b22616d6f756e74223a22544553544b55444f533a37222c2273756d6d617279223a226f7264657220746861742077696c6c20626520726566756e646564222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303235323638347d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303235323638347d2c2270726f6475637473223a5b5d2c22685f77697265223a2243303042424e4a353050433657515946563251325142335845395158333853333541334d4444414733384151475847333831545a435439364d5a575634513538424b5a454654584e57504e305135355235424554484d313242424d4a394b58414b525a50595a52222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232332d30335934375837455a5247514d222c2274696d657374616d70223a7b22745f73223a313636303235313738347d2c227061795f646561646c696e65223a7b22745f73223a313636303235353338347d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22534134504d47484d343033563146325451564652564b483942545a32464247335636523746465656545946454644594733415830227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22584856574450564243424b3439334657464e45354132384e53394d4646324b56515a543330453145484a374741414b3154323430222c226e6f6e6365223a224e3947334e4552343836373634564d323752353538393358304b335439535a375947514a52444a58514436595945414254505930227d \\xa5e69e1a65ec203aafa4dec8d8f3670ac54e97dbed5e3a274440d57e5432c1c99191006515c26b11279394f71ce416ee9b1c5ad881411fe0ee84a14ae61bbba3 1660251784000000 1660255384000000 1660252684000000 t f taler://fulfillment-success/thx \\x7cea457da3be470e41ca67992a56ac85
-3 1 2022.223-01RCBVP7Q5HFE \\x7b22616d6f756e74223a22544553544b55444f533a33222c2273756d6d617279223a227061796d656e7420616674657220726566756e64222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303235323639307d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303235323639307d2c2270726f6475637473223a5b5d2c22685f77697265223a2243303042424e4a353050433657515946563251325142335845395158333853333541334d4444414733384151475847333831545a435439364d5a575634513538424b5a454654584e57504e305135355235424554484d313242424d4a394b58414b525a50595a52222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232332d30315243425650375135484645222c2274696d657374616d70223a7b22745f73223a313636303235313739307d2c227061795f646561646c696e65223a7b22745f73223a313636303235353339307d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22534134504d47484d343033563146325451564652564b483942545a32464247335636523746465656545946454644594733415830227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22584856574450564243424b3439334657464e45354132384e53394d4646324b56515a543330453145484a374741414b3154323430222c226e6f6e6365223a2243374b5750545145335a3335584e3031543536325044364b525a4846304b3935415437454532464643365130353453354a544130227d \\xb44b55b0bcfabdb7ad1c10955b62d7f2674bff99c58610e73f34f1d12ad2379ee7b9051c2f1706b23e1b94c93afd812c407f969b6c09a28f8ad82125697db1d8 1660251790000000 1660255390000000 1660252690000000 t f taler://fulfillment-success/thx \\x3a2d493ed67fed035b6868582cbf0dbf
-\.
-
-
---
--- Data for Name: merchant_deposit_to_transfer; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_deposit_to_transfer (deposit_serial, coin_contribution_value_val, coin_contribution_value_frac, credit_serial, execution_time, signkey_serial, exchange_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_deposits; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_deposits (deposit_serial, order_serial, deposit_timestamp, coin_pub, exchange_url, amount_with_fee_val, amount_with_fee_frac, deposit_fee_val, deposit_fee_frac, refund_fee_val, refund_fee_frac, wire_fee_val, wire_fee_frac, signkey_serial, exchange_sig, account_serial) FROM stdin;
-1 1 1660251778000000 \\x34cbdeb37774f40ed3cefcd9686d70bab30c31a9afd4e055c2bfa3c8b8597b7f http://localhost:8081/ 4 0 0 2000000 0 4000000 0 7000000 3 \\x2cb1edb394a66583a8eeb50b600c85f4770e9611c8e56db24a7555f34f526af3c6083083c25c7141ec47734fa2a08c6d79b2132b64c0203650c693354b6a4603 1
-2 2 1660251787000000 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af http://localhost:8081/ 7 0 0 1000000 0 1000000 0 7000000 3 \\xcea9b3a91bf1c73acde5f85eae2af246671add2e146105849c5a0ddba7c6d036381edd6aed5a47a9da945d24878c22c45c78306825b59587b0c2c290d61aeb0f 1
-3 3 1660251793000000 \\x6182c65007227783a4d92d8509ef78d39b0168996859b65ab1443eb6fb943633 http://localhost:8081/ 3 0 0 1000000 0 1000000 0 7000000 3 \\x2a68da4393ce25bc6b7608fb5b6e7bf7f855926cb39366a84f19e31b3c98824fff8c0c777ca34f1aab7b224ca01871c33e271b853ac163c86ebb633c60da930f 1
-\.
-
-
---
--- Data for Name: merchant_exchange_signing_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_exchange_signing_keys (signkey_serial, master_pub, exchange_pub, start_date, expire_date, end_date, master_sig) FROM stdin;
-1 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\x03f5e4ee136ac823b2324d057c72a4acdf006e4485fb00a8cb6fd7a7d95cfdbb 1682023661000000 1689281261000000 1691700461000000 \\xf0d5615e090ffb1c5196dd0a9aa6a680c9731f23c8d7aace56edfdfc9e4d6fb71a9a81423134d69f6b6e3a737d2c8f874e3fe9f3c9fb145823628ce6a1b51907
-2 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\xc53e68243951aa823c4df89efe2a4768ed056b90993499889ac22d8d38ccd736 1667509061000000 1674766661000000 1677185861000000 \\x074668a2dd1e4299108fe8666fbfaa935167341390d0b26399122c3d25d2519a7e30beb7a671b4fcdb89d151d981062baa6ebbdb115458464d047205a8715400
-3 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\x0760064bb267a248d9c069856a3656fc9e824e3796f5d7cb1747675d5f67a16b 1660251761000000 1667509361000000 1669928561000000 \\x3a1198bc48724c589ce73c4bcf89635166d15d08ec037466bbb1be2aa7e92163babae1e7619803508996c5d089a2479dc2e6651dc89afafb138be4492722660f
-4 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\x8859787e9d258b1873a2b914385a3cf15c8332445e3ad73fa3facdba7a8978af 1674766361000000 1682023961000000 1684443161000000 \\xe12e0ba4ac5fe84e1bdc2c49969f123485d6a9481667e38675a7e627ac704aef2f0e0a776ed19160d37066494e87863952de293268329b2d3f1f346b3195020c
-5 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\x360a6fa91038e3a6e4e740f719ed37ac7ca84b3b69cb4ec49e701043aef2033d 1689280961000000 1696538561000000 1698957761000000 \\x9b8809aeaaf249e93b4ab2e4bd7eb985dfb0fafbc84cd1ff1aee0223d4976bb721efc0a4824574b0aa28d860c4fe1b0b3a8b58788f7e12cc93aa4d57f906230e
-\.
-
-
---
--- Data for Name: merchant_exchange_wire_fees; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_exchange_wire_fees (wirefee_serial, master_pub, h_wire_method, start_date, end_date, wire_fee_val, wire_fee_frac, closing_fee_val, closing_fee_frac, wad_fee_val, wad_fee_frac, master_sig) FROM stdin;
-1 \\xca896a42342007b0bc5abedf8dce295ebe27ae03d9b077bf7bd79ee7b7d01aba \\x21e4a5e9d5d17432fa0b1f7a02f8047c7634c1053d6aa1f6456ac134caa8bbf3da7776a78f85636af980472afd166b4edad654979a89d92c49a4ba992a7e3571 1640995200000000 1672531200000000 0 7000000 0 1000000 0 1000000 \\x2287fdbe9828660f7442da450ed5907de4383853181cddcf0351eb6f346649bb7ff9b98ff23697e8c2b8d05ab2880273cc3a8d5bb90c15fe0c0eaeb9ce0fc60b
-\.
-
-
---
--- Data for Name: merchant_instances; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_instances (merchant_serial, merchant_pub, auth_hash, auth_salt, merchant_id, merchant_name, address, jurisdiction, default_max_deposit_fee_val, default_max_deposit_fee_frac, default_max_wire_fee_val, default_max_wire_fee_frac, default_wire_fee_amortization, default_wire_transfer_delay, default_pay_delay, website, email, logo) FROM stdin;
-1 \\xec77c6db6b62e6448dfc7d5c550915ca68f78a7bbff430382e8c8f052a61d088 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x0000000000000000000000000000000000000000000000000000000000000000 default default \\x7b7d \\x7b7d 1 0 1 0 1 3600000000 3600000000 \N \N \N
-\.
-
-
---
--- Data for Name: merchant_inventory; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_inventory (product_serial, merchant_serial, product_id, description, description_i18n, unit, image, taxes, price_val, price_frac, total_stock, total_sold, total_lost, address, next_restock, minimum_age) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_inventory_locks; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_inventory_locks (product_serial, lock_uuid, total_locked, expiration) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_keys (merchant_priv, merchant_serial) FROM stdin;
-\\x54999ba667d8cdca9aedf5300a63a785d372d294d4439b92e760298758736756 1
-\.
-
-
---
--- Data for Name: merchant_kyc; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_kyc (kyc_serial_id, kyc_timestamp, kyc_ok, exchange_sig, exchange_pub, exchange_kyc_serial, account_serial, exchange_url) FROM stdin;
-1 1660251779000000 f \N \N 0 1 http://localhost:8081/
-\.
-
-
---
--- Data for Name: merchant_order_locks; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_order_locks (product_serial, total_locked, order_serial) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_orders; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_orders (order_serial, merchant_serial, order_id, claim_token, h_post_data, pay_deadline, creation_time, contract_terms) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_refund_proofs; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_refund_proofs (refund_serial, exchange_sig, signkey_serial) FROM stdin;
-1 \\x810da6c85252c3f86cb0b40494d07db1aa1860e2dd50e4e5ad753b6ca1958ba07f0447fef1ae7fb65ac356f93d52e51fc03eb2544d18ac7036bb20b605ceaf0d 3
-\.
-
-
---
--- Data for Name: merchant_refunds; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_refunds (refund_serial, order_serial, rtransaction_id, refund_timestamp, coin_pub, reason, refund_amount_val, refund_amount_frac) FROM stdin;
-1 2 1 1660251787000000 \\xa26aa63a6d21afcdacade214ea16e768a6386b49512936f0fb57d8c3761a96af test refund 6 0
-\.
-
-
---
--- Data for Name: merchant_tip_pickup_signatures; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_pickup_signatures (pickup_serial, coin_offset, blind_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_pickups; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_pickups (pickup_serial, tip_serial, pickup_id, amount_val, amount_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_reserve_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_reserve_keys (reserve_serial, reserve_priv, exchange_url, payto_uri) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_reserves; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_reserves (reserve_serial, reserve_pub, merchant_serial, creation_time, expiration, merchant_initial_balance_val, merchant_initial_balance_frac, exchange_initial_balance_val, exchange_initial_balance_frac, tips_committed_val, tips_committed_frac, tips_picked_up_val, tips_picked_up_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tips; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tips (tip_serial, reserve_serial, tip_id, justification, next_url, expiration, amount_val, amount_frac, picked_up_val, picked_up_frac, was_picked_up) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfer_signatures; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfer_signatures (credit_serial, signkey_serial, wire_fee_val, wire_fee_frac, credit_amount_val, credit_amount_frac, execution_time, exchange_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfer_to_coin; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfer_to_coin (deposit_serial, credit_serial, offset_in_exchange_list, exchange_deposit_value_val, exchange_deposit_value_frac, exchange_deposit_fee_val, exchange_deposit_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfers; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfers (credit_serial, exchange_url, wtid, credit_amount_val, credit_amount_frac, account_serial, verified, confirmed) FROM stdin;
-\.
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE SET; Schema: auditor; Owner: -
---
-
-SELECT pg_catalog.setval('auditor.auditor_reserves_auditor_reserves_rowid_seq', 1, false);
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE SET; Schema: auditor; Owner: -
---
-
-SELECT pg_catalog.setval('auditor.deposit_confirmations_serial_id_seq', 3, true);
-
-
---
--- Name: account_merges_account_merge_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.account_merges_account_merge_request_serial_id_seq', 1, false);
-
-
---
--- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.aggregation_tracking_aggregation_serial_id_seq', 1, false);
-
-
---
--- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.auditor_denom_sigs_auditor_denom_serial_seq', 424, true);
-
-
---
--- Name: auditors_auditor_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.auditors_auditor_uuid_seq', 1, true);
-
-
---
--- Name: close_requests_close_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.close_requests_close_request_serial_id_seq', 1, false);
-
-
---
--- Name: contracts_contract_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.contracts_contract_serial_id_seq', 1, false);
-
-
---
--- Name: cs_nonce_locks_cs_nonce_lock_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.cs_nonce_locks_cs_nonce_lock_serial_id_seq', 1, false);
-
-
---
--- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.denomination_revocations_denom_revocations_serial_id_seq', 1, false);
-
-
---
--- Name: denominations_denominations_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.denominations_denominations_serial_seq', 424, true);
-
-
---
--- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.deposits_deposit_serial_id_seq', 3, true);
-
-
---
--- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.exchange_sign_keys_esk_serial_seq', 5, true);
-
-
---
--- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.extension_details_extension_details_serial_id_seq', 1, false);
-
-
---
--- Name: extensions_extension_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.extensions_extension_id_seq', 1, false);
-
-
---
--- Name: global_fee_global_fee_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.global_fee_global_fee_serial_seq', 1, true);
-
-
---
--- Name: history_requests_history_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.history_requests_history_request_serial_id_seq', 1, false);
-
-
---
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.known_coins_known_coin_id_seq', 7, true);
-
-
---
--- Name: legitimizations_legitimization_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.legitimizations_legitimization_serial_id_seq', 1, false);
-
-
---
--- Name: partners_partner_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.partners_partner_serial_id_seq', 1, false);
-
-
---
--- Name: prewire_prewire_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.prewire_prewire_uuid_seq', 1, false);
-
-
---
--- Name: profit_drains_profit_drain_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.profit_drains_profit_drain_serial_id_seq', 1, false);
-
-
---
--- Name: purse_deposits_purse_deposit_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_deposits_purse_deposit_serial_id_seq', 1, false);
-
-
---
--- Name: purse_merges_purse_merge_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_merges_purse_merge_request_serial_id_seq', 1, false);
-
-
---
--- Name: purse_refunds_purse_refunds_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_refunds_purse_refunds_serial_id_seq', 1, false);
-
-
---
--- Name: purse_requests_purse_requests_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_requests_purse_requests_serial_id_seq', 1, false);
-
-
---
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.recoup_recoup_uuid_seq', 1, false);
-
-
---
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.recoup_refresh_recoup_refresh_uuid_seq', 1, false);
-
-
---
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_commitments_melt_serial_id_seq', 4, true);
-
-
---
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_revealed_coins_rrc_serial_seq', 48, true);
-
-
---
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_transfer_keys_rtc_serial_seq', 4, true);
-
-
---
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refunds_refund_serial_id_seq', 1, true);
-
-
---
--- Name: reserves_close_close_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_close_close_uuid_seq', 1, false);
-
-
---
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_in_reserve_in_serial_id_seq', 17, true);
-
-
---
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_out_reserve_out_serial_id_seq', 26, true);
-
-
---
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_reserve_uuid_seq', 17, true);
-
-
---
--- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.revolving_work_shards_shard_serial_id_seq', 1, false);
-
-
---
--- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.signkey_revocations_signkey_revocations_serial_id_seq', 1, false);
-
-
---
--- Name: wad_in_entries_wad_in_entry_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wad_in_entries_wad_in_entry_serial_id_seq', 1, false);
-
-
---
--- Name: wad_out_entries_wad_out_entry_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wad_out_entries_wad_out_entry_serial_id_seq', 1, false);
-
-
---
--- Name: wads_in_wad_in_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wads_in_wad_in_serial_id_seq', 1, false);
-
-
---
--- Name: wads_out_wad_out_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wads_out_wad_out_serial_id_seq', 1, false);
-
-
---
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_fee_wire_fee_serial_seq', 1, true);
-
-
---
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_out_wireout_uuid_seq', 1, false);
-
-
---
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_targets_wire_target_serial_id_seq', 5, true);
-
-
---
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.work_shards_shard_serial_id_seq', 1, true);
-
-
---
--- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_accounts_account_serial_seq', 1, true);
-
-
---
--- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_deposits_deposit_serial_seq', 3, true);
-
-
---
--- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_exchange_signing_keys_signkey_serial_seq', 5, true);
-
-
---
--- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_exchange_wire_fees_wirefee_serial_seq', 1, true);
-
-
---
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_instances_merchant_serial_seq', 1, true);
-
-
---
--- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_inventory_product_serial_seq', 1, false);
-
-
---
--- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_kyc_kyc_serial_id_seq', 1, true);
-
-
---
--- Name: merchant_orders_order_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_orders_order_serial_seq', 3, true);
-
-
---
--- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_refunds_refund_serial_seq', 1, true);
-
-
---
--- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tip_pickups_pickup_serial_seq', 1, false);
-
-
---
--- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tip_reserves_reserve_serial_seq', 1, false);
-
-
---
--- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tips_tip_serial_seq', 1, false);
-
-
---
--- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_transfers_credit_serial_seq', 1, false);
-
-
---
--- Name: patches patches_pkey; Type: CONSTRAINT; Schema: _v; Owner: -
---
-
-ALTER TABLE ONLY _v.patches
- ADD CONSTRAINT patches_pkey PRIMARY KEY (patch_name);
-
-
---
--- Name: auditor_denomination_pending auditor_denomination_pending_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_denomination_pending
- ADD CONSTRAINT auditor_denomination_pending_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: auditor_exchanges auditor_exchanges_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_exchanges
- ADD CONSTRAINT auditor_exchanges_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_historic_denomination_revenue auditor_historic_denomination_revenue_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_denomination_revenue
- ADD CONSTRAINT auditor_historic_denomination_revenue_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: auditor_progress_aggregation auditor_progress_aggregation_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_aggregation
- ADD CONSTRAINT auditor_progress_aggregation_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_coin auditor_progress_coin_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_coin
- ADD CONSTRAINT auditor_progress_coin_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_deposit_confirmation auditor_progress_deposit_confirmation_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_deposit_confirmation
- ADD CONSTRAINT auditor_progress_deposit_confirmation_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_reserve auditor_progress_reserve_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_reserve
- ADD CONSTRAINT auditor_progress_reserve_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_reserves auditor_reserves_auditor_reserves_rowid_key; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves
- ADD CONSTRAINT auditor_reserves_auditor_reserves_rowid_key UNIQUE (auditor_reserves_rowid);
-
-
---
--- Name: deposit_confirmations deposit_confirmations_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT deposit_confirmations_pkey PRIMARY KEY (h_contract_terms, h_wire, coin_pub, merchant_pub, exchange_sig, exchange_pub, master_sig);
-
-
---
--- Name: deposit_confirmations deposit_confirmations_serial_id_key; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT deposit_confirmations_serial_id_key UNIQUE (serial_id);
-
-
---
--- Name: wire_auditor_account_progress wire_auditor_account_progress_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_account_progress
- ADD CONSTRAINT wire_auditor_account_progress_pkey PRIMARY KEY (master_pub, account_name);
-
-
---
--- Name: wire_auditor_progress wire_auditor_progress_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_progress
- ADD CONSTRAINT wire_auditor_progress_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: account_merges_default account_merges_default_account_merge_request_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges_default
- ADD CONSTRAINT account_merges_default_account_merge_request_serial_id_key UNIQUE (account_merge_request_serial_id);
-
-
---
--- Name: account_merges account_merges_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges
- ADD CONSTRAINT account_merges_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: account_merges_default account_merges_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges_default
- ADD CONSTRAINT account_merges_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: aggregation_tracking_default aggregation_tracking_default_aggregation_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking_default
- ADD CONSTRAINT aggregation_tracking_default_aggregation_serial_id_key UNIQUE (aggregation_serial_id);
-
-
---
--- Name: aggregation_tracking aggregation_tracking_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking
- ADD CONSTRAINT aggregation_tracking_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: aggregation_tracking_default aggregation_tracking_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking_default
- ADD CONSTRAINT aggregation_tracking_default_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_auditor_denom_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_auditor_denom_serial_key UNIQUE (auditor_denom_serial);
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_pkey PRIMARY KEY (denominations_serial, auditor_uuid);
-
-
---
--- Name: auditors auditors_auditor_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditors
- ADD CONSTRAINT auditors_auditor_uuid_key UNIQUE (auditor_uuid);
-
-
---
--- Name: auditors auditors_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditors
- ADD CONSTRAINT auditors_pkey PRIMARY KEY (auditor_pub);
-
-
---
--- Name: close_requests close_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.close_requests
- ADD CONSTRAINT close_requests_pkey PRIMARY KEY (reserve_pub, close_timestamp);
-
-
---
--- Name: close_requests_default close_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.close_requests_default
- ADD CONSTRAINT close_requests_default_pkey PRIMARY KEY (reserve_pub, close_timestamp);
-
-
---
--- Name: contracts_default contracts_default_contract_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts_default
- ADD CONSTRAINT contracts_default_contract_serial_id_key UNIQUE (contract_serial_id);
-
-
---
--- Name: contracts contracts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts
- ADD CONSTRAINT contracts_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: contracts_default contracts_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts_default
- ADD CONSTRAINT contracts_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: cs_nonce_locks_default cs_nonce_locks_default_cs_nonce_lock_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks_default
- ADD CONSTRAINT cs_nonce_locks_default_cs_nonce_lock_serial_id_key UNIQUE (cs_nonce_lock_serial_id);
-
-
---
--- Name: cs_nonce_locks cs_nonce_locks_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks
- ADD CONSTRAINT cs_nonce_locks_pkey PRIMARY KEY (nonce);
-
-
---
--- Name: cs_nonce_locks_default cs_nonce_locks_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks_default
- ADD CONSTRAINT cs_nonce_locks_default_pkey PRIMARY KEY (nonce);
-
-
---
--- Name: denomination_revocations denomination_revocations_denom_revocations_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_denom_revocations_serial_id_key UNIQUE (denom_revocations_serial_id);
-
-
---
--- Name: denomination_revocations denomination_revocations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_pkey PRIMARY KEY (denominations_serial);
-
-
---
--- Name: denominations denominations_denominations_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denominations
- ADD CONSTRAINT denominations_denominations_serial_key UNIQUE (denominations_serial);
-
-
---
--- Name: denominations denominations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denominations
- ADD CONSTRAINT denominations_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: deposits_default deposits_default_coin_pub_merchant_pub_h_contract_terms_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.deposits_default
- ADD CONSTRAINT deposits_default_coin_pub_merchant_pub_h_contract_terms_key UNIQUE (coin_pub, merchant_pub, h_contract_terms);
-
-
---
--- Name: deposits_default deposits_default_deposit_serial_id_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.deposits_default
- ADD CONSTRAINT deposits_default_deposit_serial_id_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: exchange_sign_keys exchange_sign_keys_esk_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.exchange_sign_keys
- ADD CONSTRAINT exchange_sign_keys_esk_serial_key UNIQUE (esk_serial);
-
-
---
--- Name: exchange_sign_keys exchange_sign_keys_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.exchange_sign_keys
- ADD CONSTRAINT exchange_sign_keys_pkey PRIMARY KEY (exchange_pub);
-
-
---
--- Name: extension_details extension_details_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extension_details
- ADD CONSTRAINT extension_details_pkey PRIMARY KEY (extension_details_serial_id);
-
-
---
--- Name: extension_details_default extension_details_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extension_details_default
- ADD CONSTRAINT extension_details_default_pkey PRIMARY KEY (extension_details_serial_id);
-
-
---
--- Name: extensions extensions_extension_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extensions
- ADD CONSTRAINT extensions_extension_id_key UNIQUE (extension_id);
-
-
---
--- Name: extensions extensions_name_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extensions
- ADD CONSTRAINT extensions_name_key UNIQUE (name);
-
-
---
--- Name: global_fee global_fee_global_fee_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.global_fee
- ADD CONSTRAINT global_fee_global_fee_serial_key UNIQUE (global_fee_serial);
-
-
---
--- Name: global_fee global_fee_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.global_fee
- ADD CONSTRAINT global_fee_pkey PRIMARY KEY (start_date);
-
-
---
--- Name: history_requests history_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.history_requests
- ADD CONSTRAINT history_requests_pkey PRIMARY KEY (reserve_pub, request_timestamp);
-
-
---
--- Name: history_requests_default history_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.history_requests_default
- ADD CONSTRAINT history_requests_default_pkey PRIMARY KEY (reserve_pub, request_timestamp);
-
-
---
--- Name: known_coins_default known_coins_default_known_coin_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins_default
- ADD CONSTRAINT known_coins_default_known_coin_id_key UNIQUE (known_coin_id);
-
-
---
--- Name: known_coins known_coins_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins
- ADD CONSTRAINT known_coins_pkey PRIMARY KEY (coin_pub);
-
-
---
--- Name: known_coins_default known_coins_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins_default
- ADD CONSTRAINT known_coins_default_pkey PRIMARY KEY (coin_pub);
-
-
---
--- Name: kyc_alerts kyc_alerts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.kyc_alerts
- ADD CONSTRAINT kyc_alerts_pkey PRIMARY KEY (h_payto);
-
-
---
--- Name: kyc_alerts kyc_alerts_trigger_type_h_payto_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.kyc_alerts
- ADD CONSTRAINT kyc_alerts_trigger_type_h_payto_key UNIQUE (trigger_type, h_payto);
-
-
---
--- Name: legitimizations legitimizations_h_payto_provider_section_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations
- ADD CONSTRAINT legitimizations_h_payto_provider_section_key UNIQUE (h_payto, provider_section);
-
-
---
--- Name: legitimizations_default legitimizations_default_h_payto_provider_section_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations_default
- ADD CONSTRAINT legitimizations_default_h_payto_provider_section_key UNIQUE (h_payto, provider_section);
-
-
---
--- Name: legitimizations_default legitimizations_default_legitimization_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations_default
- ADD CONSTRAINT legitimizations_default_legitimization_serial_id_key UNIQUE (legitimization_serial_id);
-
-
---
--- Name: partner_accounts partner_accounts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partner_accounts
- ADD CONSTRAINT partner_accounts_pkey PRIMARY KEY (payto_uri);
-
-
---
--- Name: partners partners_partner_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partners
- ADD CONSTRAINT partners_partner_serial_id_key UNIQUE (partner_serial_id);
-
-
---
--- Name: prewire prewire_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.prewire
- ADD CONSTRAINT prewire_pkey PRIMARY KEY (prewire_uuid);
-
-
---
--- Name: prewire_default prewire_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.prewire_default
- ADD CONSTRAINT prewire_default_pkey PRIMARY KEY (prewire_uuid);
-
-
---
--- Name: profit_drains profit_drains_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.profit_drains
- ADD CONSTRAINT profit_drains_pkey PRIMARY KEY (wtid);
-
-
---
--- Name: profit_drains profit_drains_profit_drain_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.profit_drains
- ADD CONSTRAINT profit_drains_profit_drain_serial_id_key UNIQUE (profit_drain_serial_id);
-
-
---
--- Name: purse_actions purse_actions_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_actions
- ADD CONSTRAINT purse_actions_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_deposits purse_deposits_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits
- ADD CONSTRAINT purse_deposits_pkey PRIMARY KEY (purse_pub, coin_pub);
-
-
---
--- Name: purse_deposits_default purse_deposits_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits_default
- ADD CONSTRAINT purse_deposits_default_pkey PRIMARY KEY (purse_pub, coin_pub);
-
-
---
--- Name: purse_deposits_default purse_deposits_default_purse_deposit_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits_default
- ADD CONSTRAINT purse_deposits_default_purse_deposit_serial_id_key UNIQUE (purse_deposit_serial_id);
-
-
---
--- Name: purse_merges purse_merges_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges
- ADD CONSTRAINT purse_merges_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_merges_default purse_merges_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges_default
- ADD CONSTRAINT purse_merges_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_merges_default purse_merges_default_purse_merge_request_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges_default
- ADD CONSTRAINT purse_merges_default_purse_merge_request_serial_id_key UNIQUE (purse_merge_request_serial_id);
-
-
---
--- Name: purse_refunds purse_refunds_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds
- ADD CONSTRAINT purse_refunds_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_refunds_default purse_refunds_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds_default
- ADD CONSTRAINT purse_refunds_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_refunds_default purse_refunds_default_purse_refunds_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds_default
- ADD CONSTRAINT purse_refunds_default_purse_refunds_serial_id_key UNIQUE (purse_refunds_serial_id);
-
-
---
--- Name: purse_requests purse_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests
- ADD CONSTRAINT purse_requests_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_requests_default purse_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests_default
- ADD CONSTRAINT purse_requests_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_requests_default purse_requests_default_purse_requests_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests_default
- ADD CONSTRAINT purse_requests_default_purse_requests_serial_id_key UNIQUE (purse_requests_serial_id);
-
-
---
--- Name: recoup_default recoup_default_recoup_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.recoup_default
- ADD CONSTRAINT recoup_default_recoup_uuid_key UNIQUE (recoup_uuid);
-
-
---
--- Name: recoup_refresh_default recoup_refresh_default_recoup_refresh_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.recoup_refresh_default
- ADD CONSTRAINT recoup_refresh_default_recoup_refresh_uuid_key UNIQUE (recoup_refresh_uuid);
-
-
---
--- Name: refresh_commitments_default refresh_commitments_default_melt_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments_default
- ADD CONSTRAINT refresh_commitments_default_melt_serial_id_key UNIQUE (melt_serial_id);
-
-
---
--- Name: refresh_commitments refresh_commitments_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments
- ADD CONSTRAINT refresh_commitments_pkey PRIMARY KEY (rc);
-
-
---
--- Name: refresh_commitments_default refresh_commitments_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments_default
- ADD CONSTRAINT refresh_commitments_default_pkey PRIMARY KEY (rc);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_coin_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_coin_ev_key UNIQUE (coin_ev);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_h_coin_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_h_coin_ev_key UNIQUE (h_coin_ev);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_pkey PRIMARY KEY (melt_serial_id, freshcoin_index);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_rrc_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_rrc_serial_key UNIQUE (rrc_serial);
-
-
---
--- Name: refresh_transfer_keys refresh_transfer_keys_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys
- ADD CONSTRAINT refresh_transfer_keys_pkey PRIMARY KEY (melt_serial_id);
-
-
---
--- Name: refresh_transfer_keys_default refresh_transfer_keys_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys_default
- ADD CONSTRAINT refresh_transfer_keys_default_pkey PRIMARY KEY (melt_serial_id);
-
-
---
--- Name: refresh_transfer_keys_default refresh_transfer_keys_default_rtc_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys_default
- ADD CONSTRAINT refresh_transfer_keys_default_rtc_serial_key UNIQUE (rtc_serial);
-
-
---
--- Name: refunds_default refunds_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refunds_default
- ADD CONSTRAINT refunds_default_pkey PRIMARY KEY (deposit_serial_id, rtransaction_id);
-
-
---
--- Name: refunds_default refunds_default_refund_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refunds_default
- ADD CONSTRAINT refunds_default_refund_serial_id_key UNIQUE (refund_serial_id);
-
-
---
--- Name: reserves_close_default reserves_close_default_close_uuid_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_close_default
- ADD CONSTRAINT reserves_close_default_close_uuid_pkey PRIMARY KEY (close_uuid);
-
-
---
--- Name: reserves reserves_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves
- ADD CONSTRAINT reserves_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_default reserves_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_default
- ADD CONSTRAINT reserves_default_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in reserves_in_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in
- ADD CONSTRAINT reserves_in_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in_default reserves_in_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in_default
- ADD CONSTRAINT reserves_in_default_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in_default reserves_in_default_reserve_in_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in_default
- ADD CONSTRAINT reserves_in_default_reserve_in_serial_id_key UNIQUE (reserve_in_serial_id);
-
-
---
--- Name: reserves_out reserves_out_h_blind_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out
- ADD CONSTRAINT reserves_out_h_blind_ev_key UNIQUE (h_blind_ev);
-
-
---
--- Name: reserves_out_default reserves_out_default_h_blind_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out_default
- ADD CONSTRAINT reserves_out_default_h_blind_ev_key UNIQUE (h_blind_ev);
-
-
---
--- Name: reserves_out_default reserves_out_default_reserve_out_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out_default
- ADD CONSTRAINT reserves_out_default_reserve_out_serial_id_key UNIQUE (reserve_out_serial_id);
-
-
---
--- Name: revolving_work_shards revolving_work_shards_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.revolving_work_shards
- ADD CONSTRAINT revolving_work_shards_pkey PRIMARY KEY (job_name, start_row);
-
-
---
--- Name: revolving_work_shards revolving_work_shards_shard_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.revolving_work_shards
- ADD CONSTRAINT revolving_work_shards_shard_serial_id_key UNIQUE (shard_serial_id);
-
-
---
--- Name: signkey_revocations signkey_revocations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_pkey PRIMARY KEY (esk_serial);
-
-
---
--- Name: signkey_revocations signkey_revocations_signkey_revocations_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_signkey_revocations_serial_id_key UNIQUE (signkey_revocations_serial_id);
-
-
---
--- Name: wad_in_entries wad_in_entries_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries
- ADD CONSTRAINT wad_in_entries_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_in_entries_default wad_in_entries_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries_default
- ADD CONSTRAINT wad_in_entries_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_in_entries_default wad_in_entries_default_wad_in_entry_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries_default
- ADD CONSTRAINT wad_in_entries_default_wad_in_entry_serial_id_key UNIQUE (wad_in_entry_serial_id);
-
-
---
--- Name: wad_out_entries wad_out_entries_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries
- ADD CONSTRAINT wad_out_entries_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_out_entries_default wad_out_entries_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries_default
- ADD CONSTRAINT wad_out_entries_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_out_entries_default wad_out_entries_default_wad_out_entry_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries_default
- ADD CONSTRAINT wad_out_entries_default_wad_out_entry_serial_id_key UNIQUE (wad_out_entry_serial_id);
-
-
---
--- Name: wads_in wads_in_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in
- ADD CONSTRAINT wads_in_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_in_default wads_in_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_in wads_in_wad_id_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in
- ADD CONSTRAINT wads_in_wad_id_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_in_default wads_in_default_wad_id_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_id_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_in_default wads_in_default_wad_in_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_in_serial_id_key UNIQUE (wad_in_serial_id);
-
-
---
--- Name: wads_in_default wads_in_default_wad_is_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_is_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_out wads_out_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out
- ADD CONSTRAINT wads_out_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_out_default wads_out_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out_default
- ADD CONSTRAINT wads_out_default_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_out_default wads_out_default_wad_out_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out_default
- ADD CONSTRAINT wads_out_default_wad_out_serial_id_key UNIQUE (wad_out_serial_id);
-
-
---
--- Name: wire_accounts wire_accounts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_accounts
- ADD CONSTRAINT wire_accounts_pkey PRIMARY KEY (payto_uri);
-
-
---
--- Name: wire_fee wire_fee_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_fee
- ADD CONSTRAINT wire_fee_pkey PRIMARY KEY (wire_method, start_date);
-
-
---
--- Name: wire_fee wire_fee_wire_fee_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_fee
- ADD CONSTRAINT wire_fee_wire_fee_serial_key UNIQUE (wire_fee_serial);
-
-
---
--- Name: wire_out_default wire_out_default_wireout_uuid_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out_default
- ADD CONSTRAINT wire_out_default_wireout_uuid_pkey PRIMARY KEY (wireout_uuid);
-
-
---
--- Name: wire_out wire_out_wtid_raw_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out
- ADD CONSTRAINT wire_out_wtid_raw_key UNIQUE (wtid_raw);
-
-
---
--- Name: wire_out_default wire_out_default_wtid_raw_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out_default
- ADD CONSTRAINT wire_out_default_wtid_raw_key UNIQUE (wtid_raw);
-
-
---
--- Name: wire_targets wire_targets_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets
- ADD CONSTRAINT wire_targets_pkey PRIMARY KEY (wire_target_h_payto);
-
-
---
--- Name: wire_targets_default wire_targets_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets_default
- ADD CONSTRAINT wire_targets_default_pkey PRIMARY KEY (wire_target_h_payto);
-
-
---
--- Name: wire_targets_default wire_targets_default_wire_target_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets_default
- ADD CONSTRAINT wire_targets_default_wire_target_serial_id_key UNIQUE (wire_target_serial_id);
-
-
---
--- Name: work_shards work_shards_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.work_shards
- ADD CONSTRAINT work_shards_pkey PRIMARY KEY (job_name, start_row);
-
-
---
--- Name: work_shards work_shards_shard_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.work_shards
- ADD CONSTRAINT work_shards_shard_serial_id_key UNIQUE (shard_serial_id);
-
-
---
--- Name: merchant_accounts merchant_accounts_h_wire_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_h_wire_key UNIQUE (h_wire);
-
-
---
--- Name: merchant_accounts merchant_accounts_merchant_serial_payto_uri_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_merchant_serial_payto_uri_key UNIQUE (merchant_serial, payto_uri);
-
-
---
--- Name: merchant_accounts merchant_accounts_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_pkey PRIMARY KEY (account_serial);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_h_contract_terms_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_h_contract_terms_key UNIQUE (merchant_serial, h_contract_terms);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_order_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_order_id_key UNIQUE (merchant_serial, order_id);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_pkey PRIMARY KEY (order_serial);
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_deposit_serial_credit_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_deposit_serial_credit_serial_key UNIQUE (deposit_serial, credit_serial);
-
-
---
--- Name: merchant_deposits merchant_deposits_order_serial_coin_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_order_serial_coin_pub_key UNIQUE (order_serial, coin_pub);
-
-
---
--- Name: merchant_deposits merchant_deposits_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_pkey PRIMARY KEY (deposit_serial);
-
-
---
--- Name: merchant_exchange_signing_keys merchant_exchange_signing_key_exchange_pub_start_date_maste_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_signing_keys
- ADD CONSTRAINT merchant_exchange_signing_key_exchange_pub_start_date_maste_key UNIQUE (exchange_pub, start_date, master_pub);
-
-
---
--- Name: merchant_exchange_signing_keys merchant_exchange_signing_keys_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_signing_keys
- ADD CONSTRAINT merchant_exchange_signing_keys_pkey PRIMARY KEY (signkey_serial);
-
-
---
--- Name: merchant_exchange_wire_fees merchant_exchange_wire_fees_master_pub_h_wire_method_start__key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_wire_fees
- ADD CONSTRAINT merchant_exchange_wire_fees_master_pub_h_wire_method_start__key UNIQUE (master_pub, h_wire_method, start_date);
-
-
---
--- Name: merchant_exchange_wire_fees merchant_exchange_wire_fees_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_wire_fees
- ADD CONSTRAINT merchant_exchange_wire_fees_pkey PRIMARY KEY (wirefee_serial);
-
-
---
--- Name: merchant_instances merchant_instances_merchant_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_merchant_id_key UNIQUE (merchant_id);
-
-
---
--- Name: merchant_instances merchant_instances_merchant_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_merchant_pub_key UNIQUE (merchant_pub);
-
-
---
--- Name: merchant_instances merchant_instances_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_pkey PRIMARY KEY (merchant_serial);
-
-
---
--- Name: merchant_inventory merchant_inventory_merchant_serial_product_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_merchant_serial_product_id_key UNIQUE (merchant_serial, product_id);
-
-
---
--- Name: merchant_inventory merchant_inventory_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_pkey PRIMARY KEY (product_serial);
-
-
---
--- Name: merchant_keys merchant_keys_merchant_priv_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_merchant_priv_key UNIQUE (merchant_priv);
-
-
---
--- Name: merchant_keys merchant_keys_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_pkey PRIMARY KEY (merchant_serial);
-
-
---
--- Name: merchant_kyc merchant_kyc_kyc_serial_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_kyc_serial_id_key UNIQUE (kyc_serial_id);
-
-
---
--- Name: merchant_kyc merchant_kyc_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_pkey PRIMARY KEY (account_serial, exchange_url);
-
-
---
--- Name: merchant_orders merchant_orders_merchant_serial_order_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_merchant_serial_order_id_key UNIQUE (merchant_serial, order_id);
-
-
---
--- Name: merchant_orders merchant_orders_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_pkey PRIMARY KEY (order_serial);
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_pkey PRIMARY KEY (refund_serial);
-
-
---
--- Name: merchant_refunds merchant_refunds_order_serial_coin_pub_rtransaction_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_order_serial_coin_pub_rtransaction_id_key UNIQUE (order_serial, coin_pub, rtransaction_id);
-
-
---
--- Name: merchant_refunds merchant_refunds_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_pkey PRIMARY KEY (refund_serial);
-
-
---
--- Name: merchant_tip_pickup_signatures merchant_tip_pickup_signatures_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickup_signatures
- ADD CONSTRAINT merchant_tip_pickup_signatures_pkey PRIMARY KEY (pickup_serial, coin_offset);
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_pickup_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_pickup_id_key UNIQUE (pickup_id);
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_pkey PRIMARY KEY (pickup_serial);
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_priv_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_priv_key UNIQUE (reserve_priv);
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_serial_key UNIQUE (reserve_serial);
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_pkey PRIMARY KEY (reserve_serial);
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_reserve_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_reserve_pub_key UNIQUE (reserve_pub);
-
-
---
--- Name: merchant_tips merchant_tips_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_pkey PRIMARY KEY (tip_serial);
-
-
---
--- Name: merchant_tips merchant_tips_tip_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_tip_id_key UNIQUE (tip_id);
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_pkey PRIMARY KEY (credit_serial);
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_deposit_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_deposit_serial_key UNIQUE (deposit_serial);
-
-
---
--- Name: merchant_transfers merchant_transfers_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_pkey PRIMARY KEY (credit_serial);
-
-
---
--- Name: merchant_transfers merchant_transfers_wtid_exchange_url_account_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_wtid_exchange_url_account_serial_key UNIQUE (wtid, exchange_url, account_serial);
-
-
---
--- Name: auditor_historic_reserve_summary_by_master_pub_start_date; Type: INDEX; Schema: auditor; Owner: -
---
-
-CREATE INDEX auditor_historic_reserve_summary_by_master_pub_start_date ON auditor.auditor_historic_reserve_summary USING btree (master_pub, start_date);
-
-
---
--- Name: auditor_reserves_by_reserve_pub; Type: INDEX; Schema: auditor; Owner: -
---
-
-CREATE INDEX auditor_reserves_by_reserve_pub ON auditor.auditor_reserves USING btree (reserve_pub);
-
-
---
--- Name: account_merges_by_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX account_merges_by_reserve_pub ON ONLY exchange.account_merges USING btree (reserve_pub);
-
-
---
--- Name: account_merges_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX account_merges_default_reserve_pub_idx ON exchange.account_merges_default USING btree (reserve_pub);
-
-
---
--- Name: aggregation_tracking_by_wtid_raw_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX aggregation_tracking_by_wtid_raw_index ON ONLY exchange.aggregation_tracking USING btree (wtid_raw);
-
-
---
--- Name: INDEX aggregation_tracking_by_wtid_raw_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.aggregation_tracking_by_wtid_raw_index IS 'for lookup_transactions';
-
-
---
--- Name: aggregation_tracking_default_wtid_raw_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX aggregation_tracking_default_wtid_raw_idx ON exchange.aggregation_tracking_default USING btree (wtid_raw);
-
-
---
--- Name: denominations_by_expire_legal_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX denominations_by_expire_legal_index ON exchange.denominations USING btree (expire_legal);
-
-
---
--- Name: deposits_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_coin_pub_index ON ONLY exchange.deposits USING btree (coin_pub);
-
-
---
--- Name: deposits_by_ready_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_ready_main_index ON ONLY exchange.deposits_by_ready USING btree (wire_deadline, shard, coin_pub);
-
-
---
--- Name: deposits_by_ready_default_wire_deadline_shard_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_ready_default_wire_deadline_shard_coin_pub_idx ON exchange.deposits_by_ready_default USING btree (wire_deadline, shard, coin_pub);
-
-
---
--- Name: deposits_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_default_coin_pub_idx ON exchange.deposits_default USING btree (coin_pub);
-
-
---
--- Name: deposits_for_matching_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_for_matching_main_index ON ONLY exchange.deposits_for_matching USING btree (refund_deadline, merchant_pub, coin_pub);
-
-
---
--- Name: deposits_for_matching_default_refund_deadline_merchant_pub__idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_for_matching_default_refund_deadline_merchant_pub__idx ON exchange.deposits_for_matching_default USING btree (refund_deadline, merchant_pub, coin_pub);
-
-
---
--- Name: global_fee_by_end_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX global_fee_by_end_date_index ON exchange.global_fee USING btree (end_date);
-
-
---
--- Name: legitimizations_default_by_provider_and_legi_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX legitimizations_default_by_provider_and_legi_index ON exchange.legitimizations_default USING btree (provider_section, provider_legitimization_id);
-
-
---
--- Name: INDEX legitimizations_default_by_provider_and_legi_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.legitimizations_default_by_provider_and_legi_index IS 'used (rarely) in kyc_provider_account_lookup';
-
-
---
--- Name: partner_accounts_index_by_partner_and_time; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX partner_accounts_index_by_partner_and_time ON exchange.partner_accounts USING btree (partner_serial_id, last_seen);
-
-
---
--- Name: partner_by_wad_time; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX partner_by_wad_time ON exchange.partners USING btree (next_wad);
-
-
---
--- Name: prewire_by_failed_finished_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_by_failed_finished_index ON ONLY exchange.prewire USING btree (failed, finished);
-
-
---
--- Name: INDEX prewire_by_failed_finished_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.prewire_by_failed_finished_index IS 'for wire_prepare_data_get';
-
-
---
--- Name: prewire_by_finished_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_by_finished_index ON ONLY exchange.prewire USING btree (finished);
-
-
---
--- Name: INDEX prewire_by_finished_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.prewire_by_finished_index IS 'for gc_prewire';
-
-
---
--- Name: prewire_default_failed_finished_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_default_failed_finished_idx ON exchange.prewire_default USING btree (failed, finished);
-
-
---
--- Name: prewire_default_finished_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_default_finished_idx ON exchange.prewire_default USING btree (finished);
-
-
---
--- Name: purse_action_by_target; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_action_by_target ON exchange.purse_actions USING btree (partner_serial_id, action_date);
-
-
---
--- Name: purse_deposits_by_coin_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_deposits_by_coin_pub ON ONLY exchange.purse_deposits USING btree (coin_pub);
-
-
---
--- Name: purse_deposits_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_deposits_default_coin_pub_idx ON exchange.purse_deposits_default USING btree (coin_pub);
-
-
---
--- Name: purse_merges_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_merges_reserve_pub ON ONLY exchange.purse_merges USING btree (reserve_pub);
-
-
---
--- Name: INDEX purse_merges_reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.purse_merges_reserve_pub IS 'needed in reserve history computation';
-
-
---
--- Name: purse_merges_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_merges_default_reserve_pub_idx ON exchange.purse_merges_default USING btree (reserve_pub);
-
-
---
--- Name: purse_requests_merge_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_merge_pub ON ONLY exchange.purse_requests USING btree (merge_pub);
-
-
---
--- Name: purse_requests_default_merge_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_default_merge_pub_idx ON exchange.purse_requests_default USING btree (merge_pub);
-
-
---
--- Name: purse_requests_purse_expiration; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_purse_expiration ON ONLY exchange.purse_requests USING btree (purse_expiration);
-
-
---
--- Name: purse_requests_default_purse_expiration_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_default_purse_expiration_idx ON exchange.purse_requests_default USING btree (purse_expiration);
-
-
---
--- Name: recoup_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_coin_pub_index ON ONLY exchange.recoup USING btree (coin_pub);
-
-
---
--- Name: recoup_by_reserve_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_reserve_main_index ON ONLY exchange.recoup_by_reserve USING btree (reserve_out_serial_id);
-
-
---
--- Name: recoup_by_reserve_default_reserve_out_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_reserve_default_reserve_out_serial_id_idx ON exchange.recoup_by_reserve_default USING btree (reserve_out_serial_id);
-
-
---
--- Name: recoup_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_default_coin_pub_idx ON exchange.recoup_default USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_by_coin_pub_index ON ONLY exchange.recoup_refresh USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_by_rrc_serial_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_by_rrc_serial_index ON ONLY exchange.recoup_refresh USING btree (rrc_serial);
-
-
---
--- Name: recoup_refresh_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_default_coin_pub_idx ON exchange.recoup_refresh_default USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_default_rrc_serial_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_default_rrc_serial_idx ON exchange.recoup_refresh_default USING btree (rrc_serial);
-
-
---
--- Name: refresh_commitments_by_old_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_commitments_by_old_coin_pub_index ON ONLY exchange.refresh_commitments USING btree (old_coin_pub);
-
-
---
--- Name: refresh_commitments_default_old_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_commitments_default_old_coin_pub_idx ON exchange.refresh_commitments_default USING btree (old_coin_pub);
-
-
---
--- Name: refresh_revealed_coins_coins_by_melt_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_revealed_coins_coins_by_melt_serial_id_index ON ONLY exchange.refresh_revealed_coins USING btree (melt_serial_id);
-
-
---
--- Name: refresh_revealed_coins_default_melt_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_revealed_coins_default_melt_serial_id_idx ON exchange.refresh_revealed_coins_default USING btree (melt_serial_id);
-
-
---
--- Name: refunds_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refunds_by_coin_pub_index ON ONLY exchange.refunds USING btree (coin_pub);
-
-
---
--- Name: refunds_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refunds_default_coin_pub_idx ON exchange.refunds_default USING btree (coin_pub);
-
-
---
--- Name: reserves_by_expiration_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_expiration_index ON ONLY exchange.reserves USING btree (expiration_date, current_balance_val, current_balance_frac);
-
-
---
--- Name: INDEX reserves_by_expiration_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_by_expiration_index IS 'used in get_expired_reserves';
-
-
---
--- Name: reserves_by_gc_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_gc_date_index ON ONLY exchange.reserves USING btree (gc_date);
-
-
---
--- Name: INDEX reserves_by_gc_date_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_by_gc_date_index IS 'for reserve garbage collection';
-
-
---
--- Name: reserves_by_reserve_uuid_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_reserve_uuid_index ON ONLY exchange.reserves USING btree (reserve_uuid);
-
-
---
--- Name: reserves_close_by_close_uuid_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_by_close_uuid_index ON ONLY exchange.reserves_close USING btree (close_uuid);
-
-
---
--- Name: reserves_close_by_reserve_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_by_reserve_pub_index ON ONLY exchange.reserves_close USING btree (reserve_pub);
-
-
---
--- Name: reserves_close_default_close_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_default_close_uuid_idx ON exchange.reserves_close_default USING btree (close_uuid);
-
-
---
--- Name: reserves_close_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_default_reserve_pub_idx ON exchange.reserves_close_default USING btree (reserve_pub);
-
-
---
--- Name: reserves_default_expiration_date_current_balance_val_curren_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_expiration_date_current_balance_val_curren_idx ON exchange.reserves_default USING btree (expiration_date, current_balance_val, current_balance_frac);
-
-
---
--- Name: reserves_default_gc_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_gc_date_idx ON exchange.reserves_default USING btree (gc_date);
-
-
---
--- Name: reserves_default_reserve_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_reserve_uuid_idx ON exchange.reserves_default USING btree (reserve_uuid);
-
-
---
--- Name: reserves_in_by_exch_accnt_reserve_in_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_exch_accnt_reserve_in_serial_id_idx ON ONLY exchange.reserves_in USING btree (exchange_account_section, reserve_in_serial_id DESC);
-
-
---
--- Name: reserves_in_by_exch_accnt_section_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_exch_accnt_section_execution_date_idx ON ONLY exchange.reserves_in USING btree (exchange_account_section, execution_date);
-
-
---
--- Name: reserves_in_by_reserve_in_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_reserve_in_serial_id_index ON ONLY exchange.reserves_in USING btree (reserve_in_serial_id);
-
-
---
--- Name: reserves_in_default_exchange_account_section_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_exchange_account_section_execution_date_idx ON exchange.reserves_in_default USING btree (exchange_account_section, execution_date);
-
-
---
--- Name: reserves_in_default_exchange_account_section_reserve_in_ser_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_exchange_account_section_reserve_in_ser_idx ON exchange.reserves_in_default USING btree (exchange_account_section, reserve_in_serial_id DESC);
-
-
---
--- Name: reserves_in_default_reserve_in_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_reserve_in_serial_id_idx ON exchange.reserves_in_default USING btree (reserve_in_serial_id);
-
-
---
--- Name: reserves_out_by_reserve_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_main_index ON ONLY exchange.reserves_out_by_reserve USING btree (reserve_uuid);
-
-
---
--- Name: reserves_out_by_reserve_default_reserve_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_default_reserve_uuid_idx ON exchange.reserves_out_by_reserve_default USING btree (reserve_uuid);
-
-
---
--- Name: reserves_out_by_reserve_out_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_out_serial_id_index ON ONLY exchange.reserves_out USING btree (reserve_out_serial_id);
-
-
---
--- Name: reserves_out_by_reserve_uuid_and_execution_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_uuid_and_execution_date_index ON ONLY exchange.reserves_out USING btree (reserve_uuid, execution_date);
-
-
---
--- Name: INDEX reserves_out_by_reserve_uuid_and_execution_date_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_out_by_reserve_uuid_and_execution_date_index IS 'for get_reserves_out and exchange_do_withdraw_limit_check';
-
-
---
--- Name: reserves_out_default_reserve_out_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_default_reserve_out_serial_id_idx ON exchange.reserves_out_default USING btree (reserve_out_serial_id);
-
-
---
--- Name: reserves_out_default_reserve_uuid_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_default_reserve_uuid_execution_date_idx ON exchange.reserves_out_default USING btree (reserve_uuid, execution_date);
-
-
---
--- Name: revolving_work_shards_by_job_name_active_last_attempt_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX revolving_work_shards_by_job_name_active_last_attempt_index ON exchange.revolving_work_shards USING btree (job_name, active, last_attempt);
-
-
---
--- Name: wad_in_entries_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_in_entries_reserve_pub ON ONLY exchange.wad_in_entries USING btree (reserve_pub);
-
-
---
--- Name: INDEX wad_in_entries_reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.wad_in_entries_reserve_pub IS 'needed in reserve history computation';
-
-
---
--- Name: wad_in_entries_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_in_entries_default_reserve_pub_idx ON exchange.wad_in_entries_default USING btree (reserve_pub);
-
-
---
--- Name: wad_out_entries_by_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_out_entries_by_reserve_pub ON ONLY exchange.wad_out_entries USING btree (reserve_pub);
-
-
---
--- Name: wad_out_entries_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_out_entries_default_reserve_pub_idx ON exchange.wad_out_entries_default USING btree (reserve_pub);
-
-
---
--- Name: wire_fee_by_end_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_fee_by_end_date_index ON exchange.wire_fee USING btree (end_date);
-
-
---
--- Name: wire_out_by_wire_target_h_payto_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_out_by_wire_target_h_payto_index ON ONLY exchange.wire_out USING btree (wire_target_h_payto);
-
-
---
--- Name: wire_out_default_wire_target_h_payto_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_out_default_wire_target_h_payto_idx ON exchange.wire_out_default USING btree (wire_target_h_payto);
-
-
---
--- Name: work_shards_by_job_name_completed_last_attempt_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX work_shards_by_job_name_completed_last_attempt_index ON exchange.work_shards USING btree (job_name, completed, last_attempt);
-
-
---
--- Name: merchant_contract_terms_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_expiration ON merchant.merchant_contract_terms USING btree (paid, pay_deadline);
-
-
---
--- Name: INDEX merchant_contract_terms_by_expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON INDEX merchant.merchant_contract_terms_by_expiration IS 'for unlock_contracts';
-
-
---
--- Name: merchant_contract_terms_by_merchant_and_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_and_expiration ON merchant.merchant_contract_terms USING btree (merchant_serial, pay_deadline);
-
-
---
--- Name: INDEX merchant_contract_terms_by_merchant_and_expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON INDEX merchant.merchant_contract_terms_by_merchant_and_expiration IS 'for delete_contract_terms';
-
-
---
--- Name: merchant_contract_terms_by_merchant_and_payment; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_and_payment ON merchant.merchant_contract_terms USING btree (merchant_serial, paid);
-
-
---
--- Name: merchant_contract_terms_by_merchant_session_and_fulfillment; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_session_and_fulfillment ON merchant.merchant_contract_terms USING btree (merchant_serial, fulfillment_url, session_id);
-
-
---
--- Name: merchant_inventory_locks_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_inventory_locks_by_expiration ON merchant.merchant_inventory_locks USING btree (expiration);
-
-
---
--- Name: merchant_inventory_locks_by_uuid; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_inventory_locks_by_uuid ON merchant.merchant_inventory_locks USING btree (lock_uuid);
-
-
---
--- Name: merchant_orders_by_creation_time; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_by_creation_time ON merchant.merchant_orders USING btree (creation_time);
-
-
---
--- Name: merchant_orders_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_by_expiration ON merchant.merchant_orders USING btree (pay_deadline);
-
-
---
--- Name: merchant_orders_locks_by_order_and_product; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_locks_by_order_and_product ON merchant.merchant_order_locks USING btree (order_serial, product_serial);
-
-
---
--- Name: merchant_refunds_by_coin_and_order; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_refunds_by_coin_and_order ON merchant.merchant_refunds USING btree (coin_pub, order_serial);
-
-
---
--- Name: merchant_tip_reserves_by_exchange_balance; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_exchange_balance ON merchant.merchant_tip_reserves USING btree (exchange_initial_balance_val, exchange_initial_balance_frac);
-
-
---
--- Name: merchant_tip_reserves_by_merchant_serial_and_creation_time; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_merchant_serial_and_creation_time ON merchant.merchant_tip_reserves USING btree (merchant_serial, creation_time);
-
-
---
--- Name: merchant_tip_reserves_by_reserve_pub_and_merchant_serial; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_reserve_pub_and_merchant_serial ON merchant.merchant_tip_reserves USING btree (reserve_pub, merchant_serial, creation_time);
-
-
---
--- Name: merchant_tips_by_pickup_and_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tips_by_pickup_and_expiration ON merchant.merchant_tips USING btree (was_picked_up, expiration);
-
-
---
--- Name: merchant_transfers_by_credit; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_transfers_by_credit ON merchant.merchant_transfer_to_coin USING btree (credit_serial);
-
-
---
--- Name: account_merges_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.account_merges_pkey ATTACH PARTITION exchange.account_merges_default_pkey;
-
-
---
--- Name: account_merges_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.account_merges_by_reserve_pub ATTACH PARTITION exchange.account_merges_default_reserve_pub_idx;
-
-
---
--- Name: aggregation_tracking_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.aggregation_tracking_pkey ATTACH PARTITION exchange.aggregation_tracking_default_pkey;
-
-
---
--- Name: aggregation_tracking_default_wtid_raw_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.aggregation_tracking_by_wtid_raw_index ATTACH PARTITION exchange.aggregation_tracking_default_wtid_raw_idx;
-
-
---
--- Name: close_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.close_requests_pkey ATTACH PARTITION exchange.close_requests_default_pkey;
-
-
---
--- Name: contracts_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.contracts_pkey ATTACH PARTITION exchange.contracts_default_pkey;
-
-
---
--- Name: cs_nonce_locks_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.cs_nonce_locks_pkey ATTACH PARTITION exchange.cs_nonce_locks_default_pkey;
-
-
---
--- Name: deposits_by_ready_default_wire_deadline_shard_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_by_ready_main_index ATTACH PARTITION exchange.deposits_by_ready_default_wire_deadline_shard_coin_pub_idx;
-
-
---
--- Name: deposits_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_by_coin_pub_index ATTACH PARTITION exchange.deposits_default_coin_pub_idx;
-
-
---
--- Name: deposits_for_matching_default_refund_deadline_merchant_pub__idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_for_matching_main_index ATTACH PARTITION exchange.deposits_for_matching_default_refund_deadline_merchant_pub__idx;
-
-
---
--- Name: extension_details_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.extension_details_pkey ATTACH PARTITION exchange.extension_details_default_pkey;
-
-
---
--- Name: history_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.history_requests_pkey ATTACH PARTITION exchange.history_requests_default_pkey;
-
-
---
--- Name: known_coins_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.known_coins_pkey ATTACH PARTITION exchange.known_coins_default_pkey;
-
-
---
--- Name: legitimizations_default_h_payto_provider_section_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.legitimizations_h_payto_provider_section_key ATTACH PARTITION exchange.legitimizations_default_h_payto_provider_section_key;
-
-
---
--- Name: prewire_default_failed_finished_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_by_failed_finished_index ATTACH PARTITION exchange.prewire_default_failed_finished_idx;
-
-
---
--- Name: prewire_default_finished_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_by_finished_index ATTACH PARTITION exchange.prewire_default_finished_idx;
-
-
---
--- Name: prewire_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_pkey ATTACH PARTITION exchange.prewire_default_pkey;
-
-
---
--- Name: purse_deposits_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_deposits_by_coin_pub ATTACH PARTITION exchange.purse_deposits_default_coin_pub_idx;
-
-
---
--- Name: purse_deposits_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_deposits_pkey ATTACH PARTITION exchange.purse_deposits_default_pkey;
-
-
---
--- Name: purse_merges_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_merges_pkey ATTACH PARTITION exchange.purse_merges_default_pkey;
-
-
---
--- Name: purse_merges_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_merges_reserve_pub ATTACH PARTITION exchange.purse_merges_default_reserve_pub_idx;
-
-
---
--- Name: purse_refunds_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_refunds_pkey ATTACH PARTITION exchange.purse_refunds_default_pkey;
-
-
---
--- Name: purse_requests_default_merge_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_merge_pub ATTACH PARTITION exchange.purse_requests_default_merge_pub_idx;
-
-
---
--- Name: purse_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_pkey ATTACH PARTITION exchange.purse_requests_default_pkey;
-
-
---
--- Name: purse_requests_default_purse_expiration_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_purse_expiration ATTACH PARTITION exchange.purse_requests_default_purse_expiration_idx;
-
-
---
--- Name: recoup_by_reserve_default_reserve_out_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_by_reserve_main_index ATTACH PARTITION exchange.recoup_by_reserve_default_reserve_out_serial_id_idx;
-
-
---
--- Name: recoup_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_by_coin_pub_index ATTACH PARTITION exchange.recoup_default_coin_pub_idx;
-
-
---
--- Name: recoup_refresh_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_refresh_by_coin_pub_index ATTACH PARTITION exchange.recoup_refresh_default_coin_pub_idx;
-
-
---
--- Name: recoup_refresh_default_rrc_serial_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_refresh_by_rrc_serial_index ATTACH PARTITION exchange.recoup_refresh_default_rrc_serial_idx;
-
-
---
--- Name: refresh_commitments_default_old_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_commitments_by_old_coin_pub_index ATTACH PARTITION exchange.refresh_commitments_default_old_coin_pub_idx;
-
-
---
--- Name: refresh_commitments_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_commitments_pkey ATTACH PARTITION exchange.refresh_commitments_default_pkey;
-
-
---
--- Name: refresh_revealed_coins_default_melt_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_revealed_coins_coins_by_melt_serial_id_index ATTACH PARTITION exchange.refresh_revealed_coins_default_melt_serial_id_idx;
-
-
---
--- Name: refresh_transfer_keys_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_transfer_keys_pkey ATTACH PARTITION exchange.refresh_transfer_keys_default_pkey;
-
-
---
--- Name: refunds_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refunds_by_coin_pub_index ATTACH PARTITION exchange.refunds_default_coin_pub_idx;
-
-
---
--- Name: reserves_close_default_close_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_close_by_close_uuid_index ATTACH PARTITION exchange.reserves_close_default_close_uuid_idx;
-
-
---
--- Name: reserves_close_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_close_by_reserve_pub_index ATTACH PARTITION exchange.reserves_close_default_reserve_pub_idx;
-
-
---
--- Name: reserves_default_expiration_date_current_balance_val_curren_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_expiration_index ATTACH PARTITION exchange.reserves_default_expiration_date_current_balance_val_curren_idx;
-
-
---
--- Name: reserves_default_gc_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_gc_date_index ATTACH PARTITION exchange.reserves_default_gc_date_idx;
-
-
---
--- Name: reserves_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_pkey ATTACH PARTITION exchange.reserves_default_pkey;
-
-
---
--- Name: reserves_default_reserve_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_reserve_uuid_index ATTACH PARTITION exchange.reserves_default_reserve_uuid_idx;
-
-
---
--- Name: reserves_in_default_exchange_account_section_execution_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_exch_accnt_section_execution_date_idx ATTACH PARTITION exchange.reserves_in_default_exchange_account_section_execution_date_idx;
-
-
---
--- Name: reserves_in_default_exchange_account_section_reserve_in_ser_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_exch_accnt_reserve_in_serial_id_idx ATTACH PARTITION exchange.reserves_in_default_exchange_account_section_reserve_in_ser_idx;
-
-
---
--- Name: reserves_in_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_pkey ATTACH PARTITION exchange.reserves_in_default_pkey;
-
-
---
--- Name: reserves_in_default_reserve_in_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_reserve_in_serial_id_index ATTACH PARTITION exchange.reserves_in_default_reserve_in_serial_id_idx;
-
-
---
--- Name: reserves_out_by_reserve_default_reserve_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_main_index ATTACH PARTITION exchange.reserves_out_by_reserve_default_reserve_uuid_idx;
-
-
---
--- Name: reserves_out_default_h_blind_ev_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_h_blind_ev_key ATTACH PARTITION exchange.reserves_out_default_h_blind_ev_key;
-
-
---
--- Name: reserves_out_default_reserve_out_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_out_serial_id_index ATTACH PARTITION exchange.reserves_out_default_reserve_out_serial_id_idx;
-
-
---
--- Name: reserves_out_default_reserve_uuid_execution_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_uuid_and_execution_date_index ATTACH PARTITION exchange.reserves_out_default_reserve_uuid_execution_date_idx;
-
-
---
--- Name: wad_in_entries_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_in_entries_pkey ATTACH PARTITION exchange.wad_in_entries_default_pkey;
-
-
---
--- Name: wad_in_entries_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_in_entries_reserve_pub ATTACH PARTITION exchange.wad_in_entries_default_reserve_pub_idx;
-
-
---
--- Name: wad_out_entries_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_out_entries_pkey ATTACH PARTITION exchange.wad_out_entries_default_pkey;
-
-
---
--- Name: wad_out_entries_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_out_entries_by_reserve_pub ATTACH PARTITION exchange.wad_out_entries_default_reserve_pub_idx;
-
-
---
--- Name: wads_in_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_in_pkey ATTACH PARTITION exchange.wads_in_default_pkey;
-
-
---
--- Name: wads_in_default_wad_id_origin_exchange_url_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_in_wad_id_origin_exchange_url_key ATTACH PARTITION exchange.wads_in_default_wad_id_origin_exchange_url_key;
-
-
---
--- Name: wads_out_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_out_pkey ATTACH PARTITION exchange.wads_out_default_pkey;
-
-
---
--- Name: wire_out_default_wire_target_h_payto_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_out_by_wire_target_h_payto_index ATTACH PARTITION exchange.wire_out_default_wire_target_h_payto_idx;
-
-
---
--- Name: wire_out_default_wtid_raw_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_out_wtid_raw_key ATTACH PARTITION exchange.wire_out_default_wtid_raw_key;
-
-
---
--- Name: wire_targets_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_targets_pkey ATTACH PARTITION exchange.wire_targets_default_pkey;
-
-
---
--- Name: deposits deposits_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_delete AFTER DELETE ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_delete_trigger();
-
-
---
--- Name: deposits deposits_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_insert AFTER INSERT ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_insert_trigger();
-
-
---
--- Name: deposits deposits_on_update; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_update AFTER UPDATE ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_update_trigger();
-
-
---
--- Name: purse_requests purse_requests_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER purse_requests_on_insert AFTER INSERT ON exchange.purse_requests FOR EACH ROW EXECUTE FUNCTION exchange.purse_requests_insert_trigger();
-
-
---
--- Name: TRIGGER purse_requests_on_insert ON purse_requests; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TRIGGER purse_requests_on_insert ON exchange.purse_requests IS 'Here we install an entry for the purse expiration.';
-
-
---
--- Name: purse_requests purse_requests_on_update; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER purse_requests_on_update BEFORE UPDATE ON exchange.purse_requests FOR EACH ROW EXECUTE FUNCTION exchange.purse_requests_on_update_trigger();
-
-
---
--- Name: TRIGGER purse_requests_on_update ON purse_requests; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TRIGGER purse_requests_on_update ON exchange.purse_requests IS 'This covers the case where a deposit is made into a purse, which inherently then changes the purse balance via an UPDATE. If the merge is already present and the balance matches the total, we trigger the router. Once the router sets the purse to finished, the trigger will remove the purse from the watchlist of the router.';
-
-
---
--- Name: recoup recoup_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER recoup_on_delete AFTER DELETE ON exchange.recoup FOR EACH ROW EXECUTE FUNCTION exchange.recoup_delete_trigger();
-
-
---
--- Name: recoup recoup_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER recoup_on_insert AFTER INSERT ON exchange.recoup FOR EACH ROW EXECUTE FUNCTION exchange.recoup_insert_trigger();
-
-
---
--- Name: reserves_out reserves_out_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER reserves_out_on_delete AFTER DELETE ON exchange.reserves_out FOR EACH ROW EXECUTE FUNCTION exchange.reserves_out_by_reserve_delete_trigger();
-
-
---
--- Name: reserves_out reserves_out_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER reserves_out_on_insert AFTER INSERT ON exchange.reserves_out FOR EACH ROW EXECUTE FUNCTION exchange.reserves_out_by_reserve_insert_trigger();
-
-
---
--- Name: wire_out wire_out_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER wire_out_on_delete AFTER DELETE ON exchange.wire_out FOR EACH ROW EXECUTE FUNCTION exchange.wire_out_delete_trigger();
-
-
---
--- Name: auditor_exchange_signkeys master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_exchange_signkeys
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_reserve master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_reserve
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_aggregation master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_aggregation
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_deposit_confirmation master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_deposit_confirmation
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_coin master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_coin
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: wire_auditor_account_progress master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_account_progress
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: wire_auditor_progress master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_progress
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_reserves master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_reserve_balance master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserve_balance
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_wire_fee_balance master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_wire_fee_balance
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_balance_summary master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_balance_summary
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_historic_denomination_revenue master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_denomination_revenue
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_historic_reserve_summary master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_reserve_summary
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: deposit_confirmations master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_predicted_result master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_predicted_result
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_auditor_uuid_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_auditor_uuid_fkey FOREIGN KEY (auditor_uuid) REFERENCES exchange.auditors(auditor_uuid) ON DELETE CASCADE;
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_denominations_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_denominations_serial_fkey FOREIGN KEY (denominations_serial) REFERENCES exchange.denominations(denominations_serial) ON DELETE CASCADE;
-
-
---
--- Name: denomination_revocations denomination_revocations_denominations_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_denominations_serial_fkey FOREIGN KEY (denominations_serial) REFERENCES exchange.denominations(denominations_serial) ON DELETE CASCADE;
-
-
---
--- Name: partner_accounts partner_accounts_partner_serial_id_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partner_accounts
- ADD CONSTRAINT partner_accounts_partner_serial_id_fkey FOREIGN KEY (partner_serial_id) REFERENCES exchange.partners(partner_serial_id) ON DELETE CASCADE;
-
-
---
--- Name: signkey_revocations signkey_revocations_esk_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_esk_serial_fkey FOREIGN KEY (esk_serial) REFERENCES exchange.exchange_sign_keys(esk_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_accounts merchant_accounts_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial);
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_deposit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_deposit_serial_fkey FOREIGN KEY (deposit_serial) REFERENCES merchant.merchant_deposits(deposit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_contract_terms(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_inventory_locks merchant_inventory_locks_product_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory_locks
- ADD CONSTRAINT merchant_inventory_locks_product_serial_fkey FOREIGN KEY (product_serial) REFERENCES merchant.merchant_inventory(product_serial);
-
-
---
--- Name: merchant_inventory merchant_inventory_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_keys merchant_keys_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_kyc merchant_kyc_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_order_locks merchant_order_locks_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_order_locks
- ADD CONSTRAINT merchant_order_locks_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_orders(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_order_locks merchant_order_locks_product_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_order_locks
- ADD CONSTRAINT merchant_order_locks_product_serial_fkey FOREIGN KEY (product_serial) REFERENCES merchant.merchant_inventory(product_serial);
-
-
---
--- Name: merchant_orders merchant_orders_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_refund_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_refund_serial_fkey FOREIGN KEY (refund_serial) REFERENCES merchant.merchant_refunds(refund_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refunds merchant_refunds_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_contract_terms(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_pickup_signatures merchant_tip_pickup_signatures_pickup_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickup_signatures
- ADD CONSTRAINT merchant_tip_pickup_signatures_pickup_serial_fkey FOREIGN KEY (pickup_serial) REFERENCES merchant.merchant_tip_pickups(pickup_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_tip_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_tip_serial_fkey FOREIGN KEY (tip_serial) REFERENCES merchant.merchant_tips(tip_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_serial_fkey FOREIGN KEY (reserve_serial) REFERENCES merchant.merchant_tip_reserves(reserve_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tips merchant_tips_reserve_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_reserve_serial_fkey FOREIGN KEY (reserve_serial) REFERENCES merchant.merchant_tip_reserves(reserve_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_deposit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_deposit_serial_fkey FOREIGN KEY (deposit_serial) REFERENCES merchant.merchant_deposits(deposit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfers merchant_transfers_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- PostgreSQL database dump complete
---
-
diff --git a/src/auditor/auditor.conf b/src/auditor/auditor.conf
index 270836283..3c04d196f 100644
--- a/src/auditor/auditor.conf
+++ b/src/auditor/auditor.conf
@@ -9,7 +9,7 @@ DB = postgres
#TINY_AMOUNT = KUDOS:0.01
# Where do we store the auditor's private key?
-AUDITOR_PRIV_FILE = ${TALER_DATA_HOME}/auditor/offline-keys/auditor.priv
+AUDITOR_PRIV_FILE = ${TALER_DATA_HOME}auditor/offline-keys/auditor.priv
# What is the public key of this auditor? Used for processes that
# verify auditor's signatures but have no access to the private key.
@@ -17,7 +17,7 @@ AUDITOR_PRIV_FILE = ${TALER_DATA_HOME}/auditor/offline-keys/auditor.priv
# What is the Web site of the auditor (i.e. to file complaints about
# a misbehaving exchange)?
-# BASE_URL = https://auditor.taler.net/
+BASE_URL = http://localhost:8083/
# Network configuration for the normal API/service HTTP server
@@ -26,7 +26,7 @@ SERVE = tcp
# Unix domain socket to listen on,
# only effective with "SERVE = unix"
-UNIXPATH = ${TALER_RUNTIME_DIR}/exchange.http
+UNIXPATH = ${TALER_RUNTIME_DIR}exchange.http
UNIXPATH_MODE = 660
# HTTP port the auditor listens to
diff --git a/src/auditor/batch.conf b/src/auditor/batch.conf
index bdbef4b19..cd8c64b8e 100644
--- a/src/auditor/batch.conf
+++ b/src/auditor/batch.conf
@@ -121,7 +121,7 @@ PAYTO_URI = payto://x-taler-bank/localhost/42
PASSWORD = x
USERNAME = Exchange
WIRE_GATEWAY_AUTH_METHOD = basic
-WIRE_GATEWAY_URL = http://localhost:8082/taler-wire-gateway/Exchange/
+WIRE_GATEWAY_URL = http://localhost:8082/accounts/Exchange/taler-wire-gateway/
[exchange-account-1]
enable_credit = yes
diff --git a/src/auditor/batch.sh b/src/auditor/batch.sh
index 4bac28ece..bbe1be0ba 100755
--- a/src/auditor/batch.sh
+++ b/src/auditor/batch.sh
@@ -64,22 +64,22 @@ createdb $TARGET_DB || exit_skip "Could not create database $TARGET_DB"
# obtain key configuration data
-MASTER_PRIV_FILE=`taler-config -f -c $CONF -s exchange-offline -o MASTER_PRIV_FILE`
-MASTER_PRIV_DIR=`dirname $MASTER_PRIV_FILE`
+MASTER_PRIV_FILE=$(taler-config -f -c $CONF -s exchange-offline -o MASTER_PRIV_FILE)
+MASTER_PRIV_DIR=$(dirname $MASTER_PRIV_FILE)
mkdir -p $MASTER_PRIV_DIR
gnunet-ecc -g1 $MASTER_PRIV_FILE > /dev/null
-MASTER_PUB=`gnunet-ecc -p $MASTER_PRIV_FILE`
-EXCHANGE_URL=`taler-config -c $CONF -s EXCHANGE -o BASE_URL`
-MERCHANT_PORT=`taler-config -c $CONF -s MERCHANT -o PORT`
+MASTER_PUB=$(gnunet-ecc -p $MASTER_PRIV_FILE)
+EXCHANGE_URL=$(taler-config -c $CONF -s EXCHANGE -o BASE_URL)
+MERCHANT_PORT=$(taler-config -c $CONF -s MERCHANT -o PORT)
MERCHANT_URL=http://localhost:${MERCHANT_PORT}/
-BANK_PORT=`taler-config -c $CONF -s BANK -o HTTP_PORT`
+BANK_PORT=$(taler-config -c $CONF -s BANK -o HTTP_PORT)
BANK_URL=http://localhost:${BANK_PORT}/
AUDITOR_URL=http://localhost:8083/
-AUDITOR_PRIV_FILE=`taler-config -f -c $CONF -s AUDITOR -o AUDITOR_PRIV_FILE`
-AUDITOR_PRIV_DIR=`dirname $AUDITOR_PRIV_FILE`
+AUDITOR_PRIV_FILE=$(taler-config -f -c $CONF -s AUDITOR -o AUDITOR_PRIV_FILE)
+AUDITOR_PRIV_DIR=$(dirname $AUDITOR_PRIV_FILE)
mkdir -p $AUDITOR_PRIV_DIR
gnunet-ecc -g1 $AUDITOR_PRIV_FILE > /dev/null
-AUDITOR_PUB=`gnunet-ecc -p $AUDITOR_PRIV_FILE`
+AUDITOR_PUB=$(gnunet-ecc -p $AUDITOR_PRIV_FILE)
echo "AUDITOR PUB is $AUDITOR_PUB using file $AUDITOR_PRIV_FILE"
@@ -193,7 +193,7 @@ echo " DONE"
echo -n "Setting up merchant"
-curl -H "Content-Type: application/json" -X POST -d '{"auth":{"method":"external"},"payto_uris":["payto://x-taler-bank/localhost/43"],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000}}' http://localhost:9966/management/instances
+curl -H "Content-Type: application/json" -X POST -d '{"auth":{"method":"external"},"accounts":[{"payto_uri":"payto://x-taler-bank/localhost/43"}],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000}}' http://localhost:9966/management/instances
echo " DONE"
@@ -214,7 +214,7 @@ bash
# {
# amountToSpend: "TESTKUDOS:4",
# amountToWithdraw: "TESTKUDOS:10",
-# bankBaseUrl: $BANK_URL,
+# corebankApiBaseUrl: $BANK_URL,
# exchangeBaseUrl: $EXCHANGE_URL,
# merchantBaseUrl: $MERCHANT_URL,
# }' \
diff --git a/src/auditor/generate-auditor-basedb-template.conf b/src/auditor/generate-auditor-basedb-template.conf
deleted file mode 100644
index 1d18740c7..000000000
--- a/src/auditor/generate-auditor-basedb-template.conf
+++ /dev/null
@@ -1 +0,0 @@
-@INLINE@ generate-auditor-basedb.conf
diff --git a/src/auditor/generate-auditor-basedb.conf b/src/auditor/generate-auditor-basedb.conf
index af3c28eda..8cf63fbba 100644
--- a/src/auditor/generate-auditor-basedb.conf
+++ b/src/auditor/generate-auditor-basedb.conf
@@ -1,101 +1,123 @@
+[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/
+[taler]
+CURRENCY = TESTKUDOS
+CURRENCY_ROUND_UNIT = TESTKUDOS:0.01
+
[exchange]
-MAX_KEYS_CACHING = forever
-DB = postgres
-SERVE = tcp
-UNIXPATH = ${TALER_RUNTIME_DIR}/exchange.http
-UNIXPATH_MODE = 660
-PORT = 8081
-BASE_URL = http://localhost:8081/
+MASTER_PUBLIC_KEY = M4FGP18EQFXFGGFQ1AWXHACN2JX0SMVK9CNF6459Z1WG18JSN0BG
SIGNKEY_DURATION = 4 weeks
-SIGNKEY_LEGAL_DURATION = 4 weeks
LOOKAHEAD_SIGN = 32 weeks 1 day
+SIGNKEY_LEGAL_DURATION = 4 weeks
+AML_THRESHOLD = TESTKUDOS:1000000
+db = postgres
+BASE_URL = http://localhost:8081/
+IDLE_RESERVE_EXPIRATION_TIME = 4 weeks
+LEGAL_RESERVE_EXPIRATION_TIME = 4 weeks
-[merchant]
-SERVE = tcp
-PORT = 9966
-UNIXPATH = ${TALER_RUNTIME_DIR}/merchant.http
-UNIXPATH_MODE = 660
-DEFAULT_WIRE_FEE_AMORTIZATION = 1
-DB = postgres
-WIREFORMAT = default
-# Set very low, so we can be sure that the database generated
-# will contain wire transfers "ready" for the aggregator.
-WIRE_TRANSFER_DELAY = 1 minute
-DEFAULT_PAY_DEADLINE = 1 day
-DEFAULT_MAX_DEPOSIT_FEE = TESTKUDOS:0.1
-KEYFILE = ${TALER_DATA_HOME}/merchant/merchant.priv
-DEFAULT_MAX_WIRE_FEE = TESTKUDOS:0.10
-
-# Ensure that merchant reports EVERY deposit confirmation to auditor
-FORCE_AUDIT = YES
-
-[instance-default]
-KEYFILE = ${TALER_DATA_HOME}/merchant/default.priv
-NAME = Merchant Inc.
+[exchangedb]
+IDLE_RESERVE_EXPIRATION_TIME = 4 weeks
+LEGAL_RESERVE_EXPIRATION_TIME = 4 weeks
+AGGREGATOR_SHIFT = 1 s
+DEFAULT_PURSE_LIMIT = 1
-[auditor]
-DB = postgres
-AUDITOR_PRIV_FILE = ${TALER_DATA_HOME}/auditor/offline-keys/auditor.priv
+[libeufin-bank]
+CURRENCY = TESTKUDOS
+DEFAULT_CUSTOMER_DEBT_LIMIT = TESTKUDOS:200
+DEFAULT_ADMIN_DEBT_LIMIT = TESTKUDOS:2000
+ALLOW_REGISTRATION = yes
+REGISTRATION_BONUS_ENABLED = yes
+REGISTRATION_BONUS = TESTKUDOS:100
+SUGGESTED_WITHDRAWAL_EXCHANGE = http://localhost:8081/
+WIRE_TYPE = iban
+IBAN_PAYTO_BIC = SANDBOXX
SERVE = tcp
-UNIXPATH = ${TALER_RUNTIME_DIR}/exchange.http
-UNIXPATH_MODE = 660
-PORT = 8083
-BASE_URL = http://localhost:8083/
-TINY_AMOUNT = TESTKUDOS:0.01
+PORT = 8082
-[PATHS]
-TALER_HOME = ${PWD}/generate_auditordb_home/
-TALER_DATA_HOME = $TALER_HOME/.local/share/taler/
-TALER_CONFIG_HOME = $TALER_HOME/.config/taler/
-TALER_CACHE_HOME = $TALER_HOME/.cache/taler/
-TALER_RUNTIME_DIR = ${TMPDIR:-${TMP:-/tmp}}/taler-system-runtime/
-
-[bank]
-DATABASE = postgres:///taler-auditor-basedb
-MAX_DEBT = TESTKUDOS:50.0
-MAX_DEBT_BANK = TESTKUDOS:100000.0
-HTTP_PORT = 8082
-SUGGESTED_EXCHANGE = http://localhost:8081/
-SUGGESTED_EXCHANGE_PAYTO = payto://x-taler-bank/localhost/2
-ALLOW_REGISTRATIONS = YES
-SERVE = http
+[libeufin-bankdb-postgres]
+CONFIG = postgresql:///auditor-basedb
-[exchangedb]
+[exchangedb-postgres]
+CONFIG = postgres:///auditor-basedb
+SQL_DIR = $DATADIR/sql/exchange/
IDLE_RESERVE_EXPIRATION_TIME = 4 weeks
-LEGAL_RESERVE_EXPIRATION_TIME = 7 years
-
-[taler]
-CURRENCY = TESTKUDOS
-CURRENCY_ROUND_UNIT = TESTKUDOS:0.01
+LEGAL_RESERVE_EXPIRATION_TIME = 4 weeks
[exchange-account-1]
-PAYTO_URI = payto://x-taler-bank/localhost/Exchange
-enable_debit = yes
-enable_credit = yes
+PAYTO_URI = payto://iban/SANDBOXX/DE989651?receiver-name=Exchange+Company
+ENABLE_DEBIT = YES
+ENABLE_CREDIT = YES
[exchange-accountcredentials-1]
-WIRE_GATEWAY_URL = http://localhost:8082/facades/test-facade/taler-wire-gateway/
+WIRE_GATEWAY_URL = http://localhost:8082/accounts/exchange/taler-wire-gateway/
WIRE_GATEWAY_AUTH_METHOD = basic
USERNAME = exchange
PASSWORD = x
-[merchant-account-merchant]
-PAYTO_URI = payto://x-taler-bank/localhost/42
-HONOR_default = YES
-ACTIVE_default = YES
+[exchange-account-2]
+PAYTO_URI = "payto://x-taler-bank/localhost/2?receiver-name=2"
+ENABLE_DEBIT = YES
+ENABLE_CREDIT = YES
+
+[exchange-accountcredentials-2]
+WIRE_GATEWAY_AUTH_METHOD = basic
+USERNAME = Exchange
+PASSWORD = x
+WIRE_GATEWAY_URL = "http://localhost:8082/accounts/2/taler-wire-gateway/"
+
+[admin-accountcredentials-2]
+WIRE_GATEWAY_AUTH_METHOD = basic
+# For now, fakebank still checks against the Exchange account...
+USERNAME = Exchange
+PASSWORD = x
+WIRE_GATEWAY_URL = "http://localhost:8082/accounts/2/taler-wire-gateway/"
+
+
+[merchant]
+FORCE_AUDIT = YES
+SERVE = TCP
+PORT = 8888
+
+[merchantdb-postgres]
+CONFIG = postgres:///auditor-basedb
+SQL_DIR = $DATADIR/sql/merchant/
[merchant-exchange-default]
+MASTER_KEY = M4FGP18EQFXFGGFQ1AWXHACN2JX0SMVK9CNF6459Z1WG18JSN0BG
EXCHANGE_BASE_URL = http://localhost:8081/
CURRENCY = TESTKUDOS
-[payments-generator]
-currency = TESTKUDOS
-instance = default
-bank = http://localhost:8082/
-merchant = http://localhost:9966/
-exchange_admin = http://localhost:18080/
-exchange-admin = http://localhost:18080/
-exchange = http://localhost:8081/
+[bank]
+HTTP_PORT = 8082
+
+[libeufin-nexus]
+DB_CONNECTION="postgresql:///auditor-basedb"
+
+[libeufin-sandbox]
+DB_CONNECTION="postgresql:///auditor-basedb"
+
+[libeufin-bank]
+CURRENCY = TESTKUDOS
+DEFAULT_CUSTOMER_DEBT_LIMIT = TESTKUDOS:200 # dead
+DEFAULT_ADMIN_DEBT_LIMIT = TESTKUDOS:2000
+REGISTRATION_BONUS_ENABLED = yes
+REGISTRATION_BONUS = TESTKUDOS:100
+SUGGESTED_WITHDRAWAL_EXCHANGE = http://localhost:8081/
+SERVE = tcp
+PORT = 8082
+
+[auditor]
+BASE_URL = http://localhost:8083/
+TINY_AMOUNT = TESTKUDOS:0.01
+PUBLIC_KEY = 0EHPW5WEKHXPPN4MPJNGA7Z6D29JP21GKVNV8ARFB1YW7WWJX20G
+db = postgres
+
+[auditordb-postgres]
+CONFIG = postgres:///auditor-basedb
+SQL_DIR = $DATADIR/sql/auditor/
[coin_kudos_ct_1]
value = TESTKUDOS:0.01
@@ -192,31 +214,3 @@ fee_refresh = TESTKUDOS:0.03
fee_refund = TESTKUDOS:0.01
CIPHER = RSA
rsa_keysize = 1024
-
-[coin_kudos_ct_1]
-value = TESTKUDOS:0.01
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.01
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[coin_kudos_ct_10]
-value = TESTKUDOS:0.10
-duration_withdraw = 7 days
-duration_spend = 2 years
-duration_legal = 3 years
-fee_withdraw = TESTKUDOS:0.01
-fee_deposit = TESTKUDOS:0.01
-fee_refresh = TESTKUDOS:0.03
-fee_refund = TESTKUDOS:0.01
-CIPHER = RSA
-rsa_keysize = 1024
-
-[benchmark]
-BANK_DETAILS = bank_details.json
-MERCHANT_DETAILS = merchant_details.json
diff --git a/src/auditor/generate-auditor-basedb.sh b/src/auditor/generate-auditor-basedb.sh
index 69c2e315d..bbce37cdc 100755
--- a/src/auditor/generate-auditor-basedb.sh
+++ b/src/auditor/generate-auditor-basedb.sh
@@ -1,267 +1,143 @@
#!/bin/bash
-# Script to generate the basic database for auditor
-# testing from a 'correct' interaction between exchange,
-# wallet and merchant.
+# This file is in the public domain.
#
-# Creates $BASEDB.sql, $BASEDB.fees, $BASEDB.mpub and
-# $BASEDB.age.
-# Default $BASEDB is "auditor-basedb", override via $1.
+# Script to generate the basic database for auditor testing from a 'correct'
+# interaction between exchange, wallet and merchant.
#
-# Currently must be run online as it interacts with
-# bank.test.taler.net; also requires the wallet CLI
-# to be installed and in the path. Furthermore, the
-# user running this script must be Postgres superuser
-# and be allowed to create/drop databases.
+# Creates "$1.sql".
+#
+# Requires the wallet CLI to be installed and in the path. Furthermore, the
+# user running this script must be Postgres superuser and be allowed to
+# create/drop databases.
#
set -eu
-function get_iban() {
- export LIBEUFIN_SANDBOX_USERNAME=$1
- export LIBEUFIN_SANDBOX_PASSWORD=$2
- export LIBEUFIN_SANDBOX_URL=$BANK_URL
- libeufin-cli sandbox demobank info --bank-account $1 | jq --raw-output '.iban'
-}
-
-function get_payto_uri() {
- export LIBEUFIN_SANDBOX_USERNAME=$1
- export LIBEUFIN_SANDBOX_PASSWORD=$2
- export LIBEUFIN_SANDBOX_URL=$BANK_URL
- libeufin-cli sandbox demobank info --bank-account $1 | jq --raw-output '.paytoUri'
-}
-
-# Cleanup to run whenever we exit
-function cleanup()
-{
- for n in `jobs -p`
- do
- kill $n 2> /dev/null || true
- done
- echo Killing euFin..
- kill `cat libeufin-sandbox.pid 2> /dev/null` &> /dev/null || true
- kill `cat libeufin-nexus.pid 2> /dev/null` &> /dev/null || true
- wait
-}
-
-# Install cleanup handler (except for kill -9)
-trap cleanup EXIT
-
+. setup.sh
+
+CONF="generate-auditor-basedb.conf"
+# Parse command-line options
+while getopts ':c:d:h' OPTION; do
+ case "$OPTION" in
+ c)
+ CONF="$OPTARG"
+ ;;
+ d)
+ BASEDB="$OPTARG"
+ ;;
+ h)
+ echo 'Supported options:'
+# shellcheck disable=SC2016
+ echo ' -c $CONF -- set configuration'
+# shellcheck disable=SC2016
+ echo ' -d $DB -- set database name'
+ ;;
+ ?)
+ exit_fail "Unrecognized command line option"
+ ;;
+ esac
+done
-# Exit, with status code "skip" (no 'real' failure)
-function exit_skip() {
- echo $1
- exit 77
-}
# Where do we write the result?
-BASEDB=${1:-"auditor-basedb"}
-# Name of the Postgres database we will use for the script.
-# Will be dropped, do NOT use anything that might be used
-# elsewhere
-export TARGET_DB=`basename ${BASEDB}`
-
-export WALLET_DB=${BASEDB:-"wallet"}.wdb
-
-# delete existing wallet database
-rm -f $WALLET_DB
-# delete libeufin database
-rm -f $TARGET_DB
+if [ ! -v BASEDB ]
+then
+ exit_fail "-d option required"
+fi
-# Configuration file will be edited, so we create one
-# from the template.
-CONF_ONCE=${BASEDB}.conf
-cp generate-auditor-basedb.conf $CONF_ONCE
-echo -n "Testing for libeufin"
-libeufin-cli --help >/dev/null </dev/null || exit_skip " MISSING"
-echo " FOUND"
-echo -n "Testing for taler-wallet-cli"
-taler-wallet-cli -v >/dev/null </dev/null || exit_skip " MISSING"
-echo " FOUND"
-echo -n "Testing for curl"
+echo -n "Testing for curl ..."
curl --help >/dev/null </dev/null || exit_skip " MISSING"
echo " FOUND"
-
-pwd
-# Clean up
-
-DATA_DIR=`taler-config -f -c $CONF_ONCE -s PATHS -o TALER_HOME`
-rm -rf $DATA_DIR || true
-
# reset database
-dropdb $TARGET_DB >/dev/null 2>/dev/null || true
-createdb $TARGET_DB || exit_skip "Could not create database $TARGET_DB"
+echo -n "Reset 'auditor-basedb' database at $PGHOST ..."
+dropdb "auditor-basedb" >/dev/null 2>/dev/null || true
+createdb "auditor-basedb" || exit_skip "Could not create database '$BASEDB' at $PGHOST"
+echo " DONE"
+# Launch exchange, merchant and bank.
+setup -c "$CONF" \
+ -abemw \
+ -d "iban"
# obtain key configuration data
-MASTER_PRIV_FILE=`taler-config -f -c $CONF_ONCE -s exchange-offline -o MASTER_PRIV_FILE`
-MASTER_PRIV_DIR=`dirname $MASTER_PRIV_FILE`
-mkdir -p $MASTER_PRIV_DIR
-gnunet-ecc -g1 $MASTER_PRIV_FILE > /dev/null
-MASTER_PUB=`gnunet-ecc -p $MASTER_PRIV_FILE`
-MERCHANT_PORT=`taler-config -c $CONF_ONCE -s MERCHANT -o PORT`
-MERCHANT_URL=http://localhost:${MERCHANT_PORT}/
-AUDITOR_URL=http://localhost:8083/
-AUDITOR_PRIV_FILE=`taler-config -f -c $CONF_ONCE -s AUDITOR -o AUDITOR_PRIV_FILE`
-AUDITOR_PRIV_DIR=`dirname $AUDITOR_PRIV_FILE`
-mkdir -p $AUDITOR_PRIV_DIR
-gnunet-ecc -g1 $AUDITOR_PRIV_FILE > /dev/null
-AUDITOR_PUB=`gnunet-ecc -p $AUDITOR_PRIV_FILE`
-EXCHANGE_URL=`taler-config -c $CONF_ONCE -s EXCHANGE -o BASE_URL`
-BANK_PORT=`taler-config -c $CONF_ONCE -s BANK -o HTTP_PORT`
-BANK_URL="http://localhost:1${BANK_PORT}/demobanks/default"
-
-echo "AUDITOR PUB is $AUDITOR_PUB using file $AUDITOR_PRIV_FILE"
-
-# patch configuration
-taler-config -c $CONF_ONCE -s exchange -o MASTER_PUBLIC_KEY -V $MASTER_PUB
-taler-config -c $CONF_ONCE -s auditor -o PUBLIC_KEY -V $AUDITOR_PUB
-taler-config -c $CONF_ONCE -s merchant-exchange-default -o MASTER_KEY -V $MASTER_PUB
-taler-config -c $CONF_ONCE -s exchangedb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF_ONCE -s auditordb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF_ONCE -s merchantdb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF_ONCE -s bank -o database -V postgres:///$TARGET_DB
-
-# setup exchange
-echo "Setting up exchange"
-taler-exchange-dbinit -c $CONF_ONCE
-
-echo "Setting up merchant"
-taler-merchant-dbinit -c $CONF_ONCE
-
-# setup auditor
-echo "Setting up auditor"
-taler-auditor-dbinit -c $CONF_ONCE || exit_skip "Failed to initialize auditor DB"
-taler-auditor-exchange -c $CONF_ONCE -m $MASTER_PUB -u $EXCHANGE_URL || exit_skip "Failed to add exchange to auditor"
-
-# Launch services
-echo "Launching services (pre audit DB: $TARGET_DB)"
-taler-bank-manage-testing $BANK_PORT $TARGET_DB $EXCHANGE_URL $CONF_ONCE
-TFN=`which taler-exchange-httpd`
-TBINPFX=`dirname $TFN`
-TLIBEXEC=${TBINPFX}/../lib/taler/libexec/
-taler-exchange-secmod-eddsa -c $CONF_ONCE 2> taler-exchange-secmod-eddsa.log &
-taler-exchange-secmod-rsa -c $CONF_ONCE 2> taler-exchange-secmod-rsa.log &
-taler-exchange-secmod-cs -c $CONF_ONCE 2> taler-exchange-secmod-cs.log &
-taler-exchange-httpd -c $CONF_ONCE 2> taler-exchange-httpd.log &
-taler-merchant-httpd -c $CONF_ONCE -L INFO 2> taler-merchant-httpd.log &
-taler-exchange-wirewatch -c $CONF_ONCE 2> taler-exchange-wirewatch.log &
-taler-auditor-httpd -L INFO -c $CONF_ONCE 2> taler-auditor-httpd.log &
-
-# Wait for all bank to be available (usually the slowest)
-for n in `seq 1 50`
-do
- echo -n "."
- sleep 0.2
- OK=0
- # bank
- wget http://localhost:8082/ -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
-
-if [ 1 != $OK ]
-then
- exit_skip "Failed to launch services"
-fi
-
-# Wait for all services to be available
-for n in `seq 1 50`
-do
- echo -n "."
- sleep 0.1
- OK=0
- # exchange
- wget http://localhost:8081/seed -o /dev/null -O /dev/null >/dev/null || continue
- # merchant
- wget http://localhost:9966/ -o /dev/null -O /dev/null >/dev/null || continue
- # Auditor
- wget http://localhost:8083/ -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
-
-if [ 1 != $OK ]
-then
- exit_skip "Failed to launch services"
-fi
-echo -n "Setting up keys"
-taler-exchange-offline -c $CONF_ONCE \
- download sign \
- enable-account `taler-config -c $CONF_ONCE -s exchange-account-1 -o PAYTO_URI` \
- enable-auditor $AUDITOR_PUB $AUDITOR_URL "TESTKUDOS Auditor" \
- wire-fee now iban TESTKUDOS:0.07 TESTKUDOS:0.01 TESTKUDOS:0.01 \
- global-fee now TESTKUDOS:0.01 TESTKUDOS:0.01 TESTKUDOS:0.01 TESTKUDOS:0.01 1h 1h 1year 5 \
- upload &> taler-exchange-offline.log
-
-echo -n "."
+EXCHANGE_URL=$(taler-config -c "$CONF" -s EXCHANGE -o BASE_URL)
+MERCHANT_PORT=$(taler-config -c "$CONF" -s MERCHANT -o PORT)
+MERCHANT_URL="http://localhost:${MERCHANT_PORT}/"
+BANK_PORT=$(taler-config -c "$CONF" -s BANK -o HTTP_PORT)
+BANK_URL="http://localhost:${BANK_PORT}"
+
+echo -n "Checking setup worked ..."
+wget \
+ --tries=1 \
+ --timeout=1 \
+ "${EXCHANGE_URL}config" \
+ -o /dev/null \
+ -O /dev/null >/dev/null
+echo "DONE"
+
+export MERCHANT_URL
+echo -n "Setting up merchant ..."
+
+curl -H "Content-Type: application/json" -X POST -d '{"auth":{"method":"external"},"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000},"use_stefan":false}' "${MERCHANT_URL}management/instances"
+echo " DONE"
-for n in `seq 1 2`
-do
- echo -n "."
- OK=0
- wget --timeout=1 http://localhost:8081/keys -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
+echo -n "Setting up merchant account ..."
+FORTYTHREE="payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43"
+STATUS=$(curl -H "Content-Type: application/json" -X POST \
+ "${MERCHANT_URL}private/accounts" \
+ -d '{"payto_uri":"'"$FORTYTHREE"'"}' \
+ -w "%{http_code}" -s -o /dev/null)
-if [ 1 != $OK ]
+if [ "$STATUS" != "200" ]
then
- exit_skip "Failed to setup keys"
+ exit_fail "Expected 200 OK. Got: $STATUS"
fi
-
echo " DONE"
-echo -n "Adding auditor signatures ..."
-
-taler-auditor-offline -c $CONF_ONCE \
- download sign upload &> taler-auditor-offline.log
-echo " DONE"
-# Setup merchant
-
-echo -n "Setting up merchant"
-
-curl -H "Content-Type: application/json" -X POST -d '{"auth":{"method":"external"},"payto_uris":["payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43"],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000}}' http://localhost:9966/management/instances
-
-
-echo " DONE"
-
-# run wallet CLI
-echo "Running wallet"
-
-
-taler-wallet-cli --no-throttle --wallet-db=$WALLET_DB api 'runIntegrationTest' \
+# delete existing wallet database
+export WALLET_DB="wallet.wdb"
+rm -f "$WALLET_DB"
+
+echo -n "Running wallet ..."
+taler-wallet-cli \
+ --no-throttle \
+ --wallet-db="$WALLET_DB" \
+ api \
+ --expect-success \
+ 'runIntegrationTest' \
"$(jq -n '
{
amountToSpend: "TESTKUDOS:4",
amountToWithdraw: "TESTKUDOS:10",
- bankBaseUrl: $BANK_URL,
+ corebankApiBaseUrl: $BANK_URL,
exchangeBaseUrl: $EXCHANGE_URL,
merchantBaseUrl: $MERCHANT_URL,
}' \
--arg MERCHANT_URL "$MERCHANT_URL" \
--arg EXCHANGE_URL "$EXCHANGE_URL" \
- --arg BANK_URL "$BANK_URL/access-api/"
+ --arg BANK_URL "$BANK_URL"
)" &> taler-wallet-cli.log
+echo " DONE"
-echo "Shutting down services"
-cleanup
+taler-wallet-cli --wallet-db="$WALLET_DB" run-until-done
# Dump database
-echo "Dumping database ${BASEDB}(-libeufin).sql"
-pg_dump -O $TARGET_DB | sed -e '/AS integer/d' > ${BASEDB}.sql
-sqlite3 $TARGET_DB ".dump" > ${BASEDB}-libeufin.sql
-
-echo $MASTER_PUB > ${BASEDB}.mpub
+mkdir -p "$(dirname "$BASEDB")"
-date +%s > ${BASEDB}.age
+echo "Dumping database ${BASEDB}.sql"
+pg_dump -O "auditor-basedb" | sed -e '/AS integer/d' > "${BASEDB}.sql"
+cp "${CONF}.edited" "${BASEDB}.conf"
+cp "$(taler-config -c "${CONF}.edited" -s exchange-offline -o MASTER_PRIV_FILE -f)" "${BASEDB}.mpriv"
# clean up
-echo "Final clean up"
-dropdb $TARGET_DB
-rm $TARGET_DB # libeufin DB
-rm -rf $DATA_DIR || true
+echo -n "Final clean up ..."
+kill -TERM "$SETUP_PID"
+wait
+unset SETUP_PID
+dropdb "auditor-basedb"
+echo " DONE"
echo "====================================="
-echo " Finished generation of $BASEDB"
+echo "Finished generation of ${BASEDB}.sql"
echo "====================================="
exit 0
diff --git a/src/auditor/generate-kyc-basedb.conf b/src/auditor/generate-kyc-basedb.conf
new file mode 100644
index 000000000..7f4a55cee
--- /dev/null
+++ b/src/auditor/generate-kyc-basedb.conf
@@ -0,0 +1,4 @@
+# This file is in the public domain.
+@INLINE@ generate-auditor-basedb.conf
+
+# FIXME: add options for KYC here! \ No newline at end of file
diff --git a/src/auditor/generate-revoke-basedb.sh b/src/auditor/generate-revoke-basedb.sh
index 4c83d2ecf..29aa74b27 100755
--- a/src/auditor/generate-revoke-basedb.sh
+++ b/src/auditor/generate-revoke-basedb.sh
@@ -6,272 +6,138 @@
# create/drop databases.
#
set -eu
+# set -x
-# Cleanup to run whenever we exit
-function cleanup()
-{
- for n in `jobs -p`
- do
- kill $n 2> /dev/null || true
- done
- echo Killing euFin..
- kill `cat libeufin-sandbox.pid 2> /dev/null` &> /dev/null || true
- kill `cat libeufin-nexus.pid 2> /dev/null` &> /dev/null || true
- wait
-}
-
-function get_payto_uri() {
- export LIBEUFIN_SANDBOX_USERNAME=$1
- export LIBEUFIN_SANDBOX_PASSWORD=$2
- export LIBEUFIN_SANDBOX_URL=$BANK_URL
- libeufin-cli sandbox demobank info --bank-account $1 | jq --raw-output '.paytoUri'
-}
-
-# Install cleanup handler (except for kill -9)
-trap cleanup EXIT
-
-# Exit, with status code "skip" (no 'real' failure)
-function exit_skip() {
- echo $1
- exit 77
-}
+. setup.sh
-# Where do we write the result?
-export BASEDB=${1:-"revoke-basedb"}
-
-# Name of the Postgres database we will use for the script.
-# Will be dropped, do NOT use anything that might be used
-# elsewhere
-export TARGET_DB=`basename ${BASEDB}`
-TMP_DIR=`mktemp -d revocation-tmp-XXXXXX`
-export WALLET_DB=wallet-revocation.json
-rm -f $WALLET_DB
-
-# Configuration file will be edited, so we create one
-# from the template.
-export CONF=generate-auditor-basedb-revocation.conf
-cp generate-auditor-basedb.conf $CONF
-
-
-echo -n "Testing for libeufin(-cli)"
-libeufin-cli --help >/dev/null </dev/null || exit_skip " MISSING"
-echo " FOUND"
-echo -n "Testing for taler-wallet-cli"
-taler-wallet-cli -v >/dev/null </dev/null || exit_skip " MISSING"
-echo " FOUND"
-echo -n "Testing for curl"
+echo -n "Testing for curl ..."
curl --help >/dev/null </dev/null || exit_skip " MISSING"
echo " FOUND"
-# Clean up
-DATA_DIR=`taler-config -f -c $CONF -s PATHS -o TALER_HOME`
-rm -rf $DATA_DIR || true
+CONF="generate-auditor-basedb.conf"
# reset database
-dropdb $TARGET_DB >/dev/null 2>/dev/null || true
-createdb $TARGET_DB || exit_skip "Could not create database $TARGET_DB"
-rm $TARGET_DB >/dev/null 2>/dev/null || true # libeufin
-
-# obtain key configuration data
-MASTER_PRIV_FILE=`taler-config -f -c $CONF -s exchange-offline -o MASTER_PRIV_FILE`
-MASTER_PRIV_DIR=`dirname $MASTER_PRIV_FILE`
-mkdir -p $MASTER_PRIV_DIR
-gnunet-ecc -g1 $MASTER_PRIV_FILE > /dev/null
-export MASTER_PUB=`gnunet-ecc -p $MASTER_PRIV_FILE`
-export EXCHANGE_URL=`taler-config -c $CONF -s EXCHANGE -o BASE_URL`
-MERCHANT_PORT=`taler-config -c $CONF -s MERCHANT -o PORT`
-export MERCHANT_URL=http://localhost:${MERCHANT_PORT}/
-BANK_PORT=`taler-config -c $CONF -s BANK -o HTTP_PORT`
-export BANK_URL=http://localhost:1${BANK_PORT}/demobanks/default
-export AUDITOR_URL=http://localhost:8083/
-AUDITOR_PRIV_FILE=`taler-config -f -c $CONF -s AUDITOR -o AUDITOR_PRIV_FILE`
-AUDITOR_PRIV_DIR=`dirname $AUDITOR_PRIV_FILE`
-mkdir -p $AUDITOR_PRIV_DIR
-gnunet-ecc -g1 $AUDITOR_PRIV_FILE > /dev/null
-AUDITOR_PUB=`gnunet-ecc -p $AUDITOR_PRIV_FILE`
-
-# patch configuration
-taler-config -c $CONF -s exchange -o MASTER_PUBLIC_KEY -V $MASTER_PUB
-taler-config -c $CONF -s merchant-exchange-default -o MASTER_KEY -V $MASTER_PUB
-taler-config -c $CONF -s exchangedb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF -s auditordb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF -s merchantdb-postgres -o CONFIG -V postgres:///$TARGET_DB
-taler-config -c $CONF -s bank -o database -V postgres:///$TARGET_DB
-taler-config -c $CONF -s exchange -o KEYDIR -V "${TMP_DIR}/keydir/"
-taler-config -c $CONF -s exchange -o REVOCATION_DIR -V "${TMP_DIR}/revdir/"
-
-# setup exchange
-echo "Setting up exchange"
-taler-exchange-dbinit -c $CONF
-
-echo "Setting up merchant"
-taler-merchant-dbinit -c $CONF
-
-# setup auditor
-echo "Setting up auditor"
-taler-auditor-dbinit -c $CONF
-taler-auditor-exchange -c $CONF -m $MASTER_PUB -u $EXCHANGE_URL
-
-# Launch services
-echo "Launching services"
-taler-bank-manage-testing $BANK_PORT $TARGET_DB $EXCHANGE_URL $CONF
-TFN=`which taler-exchange-httpd`
-TBINPFX=`dirname $TFN`
-TLIBEXEC=${TBINPFX}/../lib/taler/libexec/
-taler-exchange-secmod-eddsa -c $CONF 2> taler-exchange-secmod-eddsa.log &
-SIGNKEY_HELPER_PID=$!
-taler-exchange-secmod-rsa -c $CONF 2> taler-exchange-secmod-rsa.log &
-RSA_DENOM_HELPER_PID=$!
-taler-exchange-secmod-cs -c $CONF 2> taler-exchange-secmod-cs.log &
-CS_DENOM_HELPER_PID=$!
-taler-exchange-httpd -c $CONF 2> taler-exchange-httpd.log &
-EXCHANGE_PID=$!
-taler-merchant-httpd -c $CONF -L INFO 2> taler-merchant-httpd.log &
-MERCHANT_PID=$!
-taler-exchange-wirewatch -c $CONF 2> taler-exchange-wirewatch.log &
-taler-auditor-httpd -c $CONF 2> taler-auditor-httpd.log &
-
-# Wait for all bank to be available (usually the slowest)
-for n in `seq 1 50`
-do
- echo -n "."
- sleep 0.2
- OK=0
- # bank
- wget http://localhost:8082/ -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
-
-if [ 1 != $OK ]
-then
- exit_skip "Failed to launch Bank services"
-fi
-
-# Wait for all other services to be available
-for n in `seq 1 50`
-do
- echo -n "."
- sleep 0.1
- OK=0
- # exchange
- wget http://localhost:8081/seed -o /dev/null -O /dev/null >/dev/null || continue
- # merchant
- wget http://localhost:9966/ -o /dev/null -O /dev/null >/dev/null || continue
- # Auditor
- wget http://localhost:8083/ -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
-
-if [ 1 != $OK ]
-then
- cleanup
- exit_skip "Failed to launch Taler services"
-fi
+echo -n "Reset 'auditor-basedb' database ..."
+dropdb "auditor-basedb" >/dev/null 2>/dev/null || true
+createdb "auditor-basedb" || exit_skip "Could not create database '$BASEDB'"
echo " DONE"
-echo -n "Setting up keys"
-
-taler-exchange-offline -c $CONF \
- download sign \
- enable-account `taler-config -c $CONF -s exchange-account-1 -o PAYTO_URI` \
- enable-auditor $AUDITOR_PUB $AUDITOR_URL "TESTKUDOS Auditor" \
- wire-fee now iban TESTKUDOS:0.01 TESTKUDOS:0.01 TESTKUDOS:0.01 \
- global-fee now TESTKUDOS:0.01 TESTKUDOS:0.01 TESTKUDOS:0.01 TESTKUDOS:0.01 1h 1h 1year 5 \
- upload &> taler-exchange-offline.log
-
-echo -n "."
-
-for n in `seq 1 2`
-do
- echo -n "."
- OK=0
- # bank
- wget --timeout=1 http://localhost:8081/keys -o /dev/null -O /dev/null >/dev/null || continue
- OK=1
- break
-done
-
-if [ 1 != $OK ]
-then
- exit_skip "Failed to setup keys"
-fi
+# Launch exchange, merchant and bank.
+setup -c "$CONF" \
+ -abemw \
+ -d "iban"
+# obtain key configuration data
+EXCHANGE_URL=$(taler-config -c "$CONF" -s EXCHANGE -o BASE_URL)
+MERCHANT_PORT=$(taler-config -c "$CONF" -s MERCHANT -o PORT)
+MERCHANT_URL="http://localhost:${MERCHANT_PORT}/"
+BANK_PORT=$(taler-config -c "$CONF" -s BANK -o HTTP_PORT)
+BANK_URL="http://localhost:${BANK_PORT}"
-taler-auditor-offline -c $CONF \
- download sign upload &> taler-auditor-offline.log
-
-echo " DONE"
# Setup merchant
-echo -n "Setting up merchant"
-
-curl -H "Content-Type: application/json" -X POST -d '{"auth": {"method": "external"}, "payto_uris":["payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43"],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000}}' http://localhost:9966/management/instances
+echo -n "Setting up merchant ..."
+curl -H "Content-Type: application/json" -X POST -d '{"auth": {"method": "external"}, "accounts":[{"payto_uri":"payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43"}],"id":"default","name":"default","address":{},"jurisdiction":{},"default_max_wire_fee":"TESTKUDOS:1", "default_max_deposit_fee":"TESTKUDOS:1","default_wire_fee_amortization":1,"default_wire_transfer_delay":{"d_us" : 3600000000},"default_pay_delay":{"d_us": 3600000000},"use_stefan":true}' "${MERCHANT_URL}management/instances"
+echo " DONE"
# run wallet CLI
echo "Running wallet"
-taler-wallet-cli --no-throttle --wallet-db=$WALLET_DB api 'withdrawTestBalance' \
+export WALLET_DB="wallet.wdb"
+rm -f "$WALLET_DB"
+
+taler-wallet-cli \
+ --no-throttle \
+ --wallet-db="$WALLET_DB" \
+ api \
+ --expect-success 'withdrawTestBalance' \
"$(jq -n '
{
amount: "TESTKUDOS:8",
- bankBaseUrl: $BANK_URL,
+ corebankApiBaseUrl: $BANK_URL,
exchangeBaseUrl: $EXCHANGE_URL,
}' \
- --arg BANK_URL "$BANK_URL/access-api/" \
- --arg EXCHANGE_URL $EXCHANGE_URL
- )"
+ --arg BANK_URL "$BANK_URL" \
+ --arg EXCHANGE_URL "$EXCHANGE_URL"
+ )" &> taler-wallet-cli-withdraw.log
-taler-wallet-cli --no-throttle --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ --no-throttle \
+ --wallet-db="$WALLET_DB" \
+ run-until-done \
+ &> taler-wallet-cli-withdraw-finish.log
-export coins=$(taler-wallet-cli --wallet-db=$WALLET_DB advanced dump-coins)
+export COINS=$(taler-wallet-cli --wallet-db="$WALLET_DB" advanced dump-coins)
echo -n "COINS are:"
-echo $coins
+echo "$COINS"
# Find coin we want to revoke
-export rc=$(echo "$coins" | jq -r '[.coins[] | select((.denom_value == "TESTKUDOS:2"))][0] | .coin_pub')
+export rc=$(echo "$COINS" | jq -r '[.coins[] | select((.denom_value == "TESTKUDOS:2"))][0] | .coin_pub')
# Find the denom
-export rd=$(echo "$coins" | jq -r '[.coins[] | select((.denom_value == "TESTKUDOS:2"))][0] | .denom_pub_hash')
-echo "Revoking denomination ${rd} (to affect coin ${rc})"
+export rd=$(echo "$COINS" | jq -r '[.coins[] | select((.denom_value == "TESTKUDOS:2"))][0] | .denom_pub_hash')
+echo -n "Revoking denomination ${rd} (to affect coin ${rc}) ..."
# Find all other coins, which will be suspended
-export susp=$(echo "$coins" | jq --arg rc "$rc" '[.coins[] | select(.coin_pub != $rc) | .coin_pub]')
+export susp=$(echo "$COINS" | jq --arg rc "$rc" '[.coins[] | select(.coin_pub != $rc) | .coin_pub]')
# Do the revocation
-taler-exchange-offline -c $CONF \
- revoke-denomination "${rd}" upload &> taler-exchange-offline-revoke.log
-
+taler-exchange-offline \
+ -c $CONF \
+ revoke-denomination "${rd}" \
+ upload \
+ &> taler-exchange-offline-revoke.log
+echo "DONE"
+
+echo -n "Signing replacement keys ..."
sleep 1 # Give exchange time to create replacmenent key
# Re-sign replacement keys
-taler-auditor-offline -c $CONF \
- download sign upload &> taler-auditor-offline.log
+taler-auditor-offline \
+ -c $CONF \
+ download \
+ sign \
+ upload \
+ &> taler-auditor-offline-reinit.log
+echo " DONE"
# Now we suspend the other coins, so later we will pay with the recouped coin
-taler-wallet-cli --wallet-db=$WALLET_DB advanced suspend-coins "$susp"
+taler-wallet-cli \
+ --wallet-db="$WALLET_DB" \
+ advanced \
+ suspend-coins "$susp"
# Update exchange /keys so recoup gets scheduled
-taler-wallet-cli --wallet-db=$WALLET_DB exchanges update \
- -f $EXCHANGE_URL
+taler-wallet-cli \
+ --wallet-db="$WALLET_DB" \
+ exchanges \
+ update \
+ -f "$EXCHANGE_URL"
# Block until scheduled operations are done
-taler-wallet-cli --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ --wallet-db="$WALLET_DB"\
+ run-until-done
-# Now we buy something, only the coins resulting from recouped will be
+# Now we buy something, only the coins resulting from recoup will be
# used, as other ones are suspended
-taler-wallet-cli --no-throttle --wallet-db=$WALLET_DB api 'testPay' \
+taler-wallet-cli \
+ --no-throttle \
+ --wallet-db="$WALLET_DB" \
+ api \
+ 'testPay' \
"$(jq -n '
{
amount: "TESTKUDOS:1",
merchantBaseUrl: $MERCHANT_URL,
summary: "foo",
}' \
- --arg MERCHANT_URL $MERCHANT_URL
+ --arg MERCHANT_URL "$MERCHANT_URL"
)"
-taler-wallet-cli --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ --wallet-db="$WALLET_DB" \
+ run-until-done
echo "Purchase with recoup'ed coin (via reserve) done"
@@ -284,9 +150,6 @@ echo "Will refresh coin ${rrc} of denomination ${zombie_denom}"
# Find all other coins, which will be suspended
export susp=$(echo "$coins" | jq --arg rrc "$rrc" '[.coins[] | select(.coin_pub != $rrc) | .coin_pub]')
-export rrc
-export zombie_denom
-
# Travel into the future! (must match DURATION_WITHDRAW option)
export TIMETRAVEL="--timetravel=604800000000"
@@ -295,13 +158,13 @@ kill -TERM $EXCHANGE_PID
kill -TERM $RSA_DENOM_HELPER_PID
kill -TERM $CS_DENOM_HELPER_PID
kill -TERM $SIGNKEY_HELPER_PID
-taler-exchange-secmod-eddsa $TIMETRAVEL -c $CONF 2> taler-exchange-secmod-eddsa.log &
+taler-exchange-secmod-eddsa $TIMETRAVEL -c $CONF 2> ${MY_TMP_DIR}/taler-exchange-secmod-eddsa.log &
SIGNKEY_HELPER_PID=$!
-taler-exchange-secmod-rsa $TIMETRAVEL -c $CONF 2> taler-exchange-secmod-rsa.log &
+taler-exchange-secmod-rsa $TIMETRAVEL -c $CONF 2> ${MY_TMP_DIR}/taler-exchange-secmod-rsa.log &
RSA_DENOM_HELPER_PID=$!
-taler-exchange-secmod-cs $TIMETRAVEL -c $CONF 2> taler-exchange-secmod-cs.log &
+taler-exchange-secmod-cs $TIMETRAVEL -c $CONF 2> ${MY_TMP_DIR}/taler-exchange-secmod-cs.log &
CS_DENOM_HELPER_PID=$!
-taler-exchange-httpd $TIMETRAVEL -c $CONF 2> taler-exchange-httpd.log &
+taler-exchange-httpd $TIMETRAVEL -c $CONF 2> ${MY_TMP_DIR}/taler-exchange-httpd.log &
export EXCHANGE_PID=$!
# Wait for exchange to be available
@@ -317,8 +180,15 @@ do
done
echo "Refreshing coin $rrc"
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB advanced force-refresh "$rrc"
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ "$TIMETRAVEL" \
+ --wallet-db="$WALLET_DB" \
+ advanced force-refresh \
+ "$rrc"
+taler-wallet-cli \
+ "$TIMETRAVEL" \
+ --wallet-db="$WALLET_DB" \
+ run-until-done
# Update our list of the coins
export coins=$(taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB advanced dump-coins)
@@ -341,29 +211,49 @@ export susp=$(echo "$coins" | jq --arg freshc "$freshc" '[.coins[] | select(.coi
# Do the revocation of freshc
echo "Revoking ${fresh_denom} (to affect coin ${freshc})"
-taler-exchange-offline -c $CONF \
- revoke-denomination "${fresh_denom}" upload &> taler-exchange-offline-revoke-2.log
+taler-exchange-offline \
+ -c "$CONF" \
+ revoke-denomination \
+ "${fresh_denom}" \
+ upload &> taler-exchange-offline-revoke-2.log
sleep 1 # Give exchange time to create replacmenent key
# Re-sign replacement keys
-taler-auditor-offline -c $CONF \
- download sign upload &> taler-auditor-offline.log
+taler-auditor-offline \
+ -c "$CONF" \
+ download \
+ sign \
+ upload &> taler-auditor-offline.log
# Now we suspend the other coins, so later we will pay with the recouped coin
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB advanced suspend-coins "$susp"
+taler-wallet-cli \
+ "$TIMETRAVEL" \
+ --wallet-db="$WALLET_DB" \
+ advanced \
+ suspend-coins "$susp"
# Update exchange /keys so recoup gets scheduled
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB exchanges update \
- -f $EXCHANGE_URL
+taler-wallet-cli \
+ "$TIMETRAVEL"\
+ --wallet-db="$WALLET_DB" \
+ exchanges update \
+ -f "$EXCHANGE_URL"
# Block until scheduled operations are done
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ "$TIMETRAVEL" \
+ --wallet-db="$WALLET_DB" \
+ run-until-done
echo "Restarting merchant (so new keys are known)"
kill -TERM $MERCHANT_PID
-taler-merchant-httpd -c $CONF -L INFO 2> taler-merchant-httpd.log &
+taler-merchant-httpd \
+ -c "$CONF" \
+ -L INFO \
+ 2> ${MY_TMP_DIR}/taler-merchant-httpd.log &
MERCHANT_PID=$!
+
# Wait for merchant to be again available
for n in `seq 1 50`
do
@@ -387,34 +277,35 @@ taler-wallet-cli $TIMETRAVEL --no-throttle --wallet-db=$WALLET_DB api 'testPay'
}' \
--arg MERCHANT_URL $MERCHANT_URL
)"
-taler-wallet-cli $TIMETRAVEL --wallet-db=$WALLET_DB run-until-done
+taler-wallet-cli \
+ "$TIMETRAVEL" \
+ --wallet-db="$WALLET_DB" \
+ run-until-done
echo "Bought something with refresh-recouped coin"
echo "Shutting down services"
-cleanup
+exit_cleanup
-# Dump database
-echo "Dumping database"
-echo "Dumping PostgreSQL database: ${BASEDB}.sql"
-pg_dump -O $TARGET_DB | sed -e '/AS integer/d' > ${BASEDB}.sql
-echo "Dumping libeufin database: ${BASEDB}-libeufin.sql"
-sqlite3 $TARGET_DB ".dump" > ${BASEDB}-libeufin.sql
+# Where do we write the result?
+export BASEDB=${1:-"revoke-basedb"}
+
-echo $MASTER_PUB > ${BASEDB}.mpub
-date +%s > ${BASEDB}.age
+# Dump database
+echo "Dumping database ${BASEDB}.sql"
+pg_dump -O "auditor-basedb" | sed -e '/AS integer/d' > "${BASEDB}.sql"
# clean up
-echo "Final clean up"
-dropdb $TARGET_DB
-rm $TARGET_DB # libeufin
-rm -rf $DATA_DIR || true
-rm -f $CONF
-rm -r $TMP_DIR
+echo -n "Final clean up ..."
+kill -TERM "$SETUP_PID"
+wait
+unset SETUP_PID
+dropdb "auditor-basedb"
+echo " DONE"
echo "====================================="
-echo " Finished revocation DB generation "
+echo "Finished generation of ${BASEDB}.sql"
echo "====================================="
exit 0
diff --git a/src/auditor/generate_auditordb_home/.local/share/taler/exchange-offline/master.priv b/src/auditor/generate_auditordb_home/.local/share/taler/exchange-offline/master.priv
new file mode 100644
index 000000000..85195dd8f
--- /dev/null
+++ b/src/auditor/generate_auditordb_home/.local/share/taler/exchange-offline/master.priv
@@ -0,0 +1 @@
+%I7qYÿ®ÜX˜2@–šò%'1†”ÂOàÔæJ³Ô¦‘ \ No newline at end of file
diff --git a/src/auditor/report-lib.c b/src/auditor/report-lib.c
index e4f66b31c..d0e1325ea 100644
--- a/src/auditor/report-lib.c
+++ b/src/auditor/report-lib.c
@@ -260,7 +260,7 @@ TALER_ARL_get_denomination_info (
*
* @param analysis analysis to run
* @param analysis_cls closure for @a analysis
- * @return #GNUNET_OK if @a analysis succeessfully committed,
+ * @return #GNUNET_OK if @a analysis successfully committed,
* #GNUNET_NO if we had an error on commit (retry may help)
* #GNUNET_SYSERR on hard errors
*/
@@ -361,31 +361,6 @@ TALER_ARL_setup_sessions_and_run (TALER_ARL_Analysis ana,
}
-/**
- * Test if the given @a mpub matches the #TALER_ARL_master_pub.
- * If so, set "found" to GNUNET_YES.
- *
- * @param cls a `int *` pointing to "found"
- * @param mpub exchange master public key to compare
- * @param exchange_url URL of the exchange (ignored)
- */
-static void
-test_master_present (void *cls,
- const struct TALER_MasterPublicKeyP *mpub,
- const char *exchange_url)
-{
- int *found = cls;
-
- if (0 == GNUNET_memcmp (mpub,
- &TALER_ARL_master_pub))
- {
- *found = GNUNET_YES;
- GNUNET_free (TALER_ARL_exchange_url);
- TALER_ARL_exchange_url = GNUNET_strdup (exchange_url);
- }
-}
-
-
void
TALER_ARL_amount_add_ (struct TALER_Amount *sum,
const struct TALER_Amount *a1,
@@ -557,6 +532,18 @@ TALER_ARL_init (const struct GNUNET_CONFIGURATION_Handle *c)
"BASE_URL");
return GNUNET_SYSERR;
}
+ if (GNUNET_OK !=
+ GNUNET_CONFIGURATION_get_value_string (TALER_ARL_cfg,
+ "exchange",
+ "BASE_URL",
+ &TALER_ARL_exchange_url))
+ {
+ GNUNET_log_config_missing (GNUNET_ERROR_TYPE_ERROR,
+ "exchange",
+ "BASE_URL");
+ return GNUNET_SYSERR;
+ }
+
if (GNUNET_is_zero (&TALER_ARL_master_pub))
{
/* -m option not given, try configuration */
@@ -588,6 +575,9 @@ TALER_ARL_init (const struct GNUNET_CONFIGURATION_Handle *c)
GNUNET_free (master_public_key_str);
return GNUNET_SYSERR;
}
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Running auditor against exchange master public key `%s'\n",
+ master_public_key_str);
GNUNET_free (master_public_key_str);
} /* end of -m not given */
@@ -713,29 +703,13 @@ TALER_ARL_init (const struct GNUNET_CONFIGURATION_Handle *c)
TALER_ARL_done (NULL);
return GNUNET_SYSERR;
}
+ if (GNUNET_SYSERR ==
+ TALER_ARL_adb->preflight (TALER_ARL_adb->cls))
{
- int found;
-
- if (GNUNET_SYSERR ==
- TALER_ARL_adb->preflight (TALER_ARL_adb->cls))
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Failed to start session with auditor database.\n");
- TALER_ARL_done (NULL);
- return GNUNET_SYSERR;
- }
- found = GNUNET_NO;
- (void) TALER_ARL_adb->list_exchanges (TALER_ARL_adb->cls,
- &test_master_present,
- &found);
- if (GNUNET_NO == found)
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Exchange's master public key `%s' not known to auditor DB. Did you forget to run `taler-auditor-exchange`?\n",
- GNUNET_p2s (&TALER_ARL_master_pub.eddsa_pub));
- TALER_ARL_done (NULL);
- return GNUNET_SYSERR;
- }
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Failed to start session with auditor database.\n");
+ TALER_ARL_done (NULL);
+ return GNUNET_SYSERR;
}
return GNUNET_OK;
}
diff --git a/src/auditor/report-lib.h b/src/auditor/report-lib.h
index db15494cd..db29abc3a 100644
--- a/src/auditor/report-lib.h
+++ b/src/auditor/report-lib.h
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2016-2020 Taler Systems SA
+ Copyright (C) 2016-2024 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero Public License as published by the Free Software
@@ -28,6 +28,52 @@
#include "taler_bank_service.h"
#include "taler_signatures.h"
+/**
+ * Macro to use to access progress point value @a name.
+ */
+#define TALER_ARL_USE_PP(name) TAC_ ## name
+
+/**
+ * Macro to use to declare progress point value @a name.
+ */
+#define TALER_ARL_DEF_PP(name) \
+ uint64_t TALER_ARL_USE_PP (name) = 0
+
+/**
+ * Macro to use to GET progress point value @a name from DB.
+ */
+#define TALER_ARL_GET_PP(name) \
+ TALER_S (name), &TALER_ARL_USE_PP (name)
+
+/**
+ * Macro to use to SET progress point value @a name in DB.
+ */
+#define TALER_ARL_SET_PP(name) \
+ TALER_S (name), TALER_ARL_USE_PP (name)
+
+/**
+ * Macro to use to access amount balance @a name.
+ */
+#define TALER_ARL_USE_AB(name) TAC_ ## name
+
+/**
+ * Macro to use to declare amount balance @a name.
+ */
+#define TALER_ARL_DEF_AB(name) \
+ struct TALER_Amount TALER_ARL_USE_AB (name)
+
+/**
+ * Macro to use to GET amount balance @a name from DB.
+ */
+#define TALER_ARL_GET_AB(name) \
+ TALER_S (name), &TALER_ARL_USE_AB (name)
+
+/**
+ * Macro to use to SET amount balance @a name in DB.
+ */
+#define TALER_ARL_SET_AB(name) \
+ TALER_S (name), &TALER_ARL_USE_AB (name)
+
/**
* Command-line option "-r": restart audit from scratch
diff --git a/src/auditor/revoke-basedb-libeufin.sql b/src/auditor/revoke-basedb-libeufin.sql
deleted file mode 100644
index 50428d562..000000000
--- a/src/auditor/revoke-basedb-libeufin.sql
+++ /dev/null
@@ -1,161 +0,0 @@
-PRAGMA foreign_keys=OFF;
-BEGIN TRANSACTION;
-CREATE TABLE DemobankConfigs (id INTEGER PRIMARY KEY AUTOINCREMENT, currency TEXT NOT NULL, allowRegistrations BOOLEAN NOT NULL, withSignupBonus BOOLEAN NOT NULL, bankDebtLimit INT NOT NULL, usersDebtLimit INT NOT NULL, hostname TEXT NOT NULL, suggestedExchangeBaseUrl TEXT NULL, suggestedExchangePayto TEXT NULL, uiTitle TEXT NOT NULL);
-INSERT INTO DemobankConfigs VALUES(1,'TESTKUDOS',1,0,1000000,1000,'default','http://localhost:8081/','payto://iban/SANDBOXX/DE064129?receiver-name=Exchange+Company','Demo Bank');
-CREATE TABLE EbicsSubscriberPublicKeys (id INTEGER PRIMARY KEY AUTOINCREMENT, rsaPublicKey BLOB NOT NULL, "state" INT NOT NULL);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(1,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100bbb5f6d9010223796047d129b97dd2ec8a3efffde972e3b0d0bb1ac73b229404715a04d9005bff9130c25b2a1badd7f7d5d847aea43a6436259ec6ba59de6416fcc5eb0b3df939fa5fbe3f327061450c6e9e9329d92e393eda311984fae771d3110f7fb6536fc6dec6c60561232815fc9f752af9b0cb5453a3a79db648537875648d8c5dc3f09f2b8c0ea2fdb2f178fb6fcb327ac279afb43b0236e6fca7fa4d711f895c3385e4b406e6ddeabbca99673de51bf33fd4b7e4406d61fbf3fd31cf1532233064a8376049adffaed07a54c42de502d9c630cbbd77b17b8b3d44f1baf4a9c2495f17cb780b07cdcf8f4be84b9911994758a22eb623ad88edac5b18b90203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(2,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100998d7bef44b3642dcb7bd17ca5903e090da9ca3cfbda972dbaab97c0d63aa6f8b9ad5f203f517ba654894a14a629194462e62657fbc46212bc6aa3f215e90604047f683307772c4e512a82539a534774395368bf23997b29ad4091454c1c880682d140396f49808bbe924c23629d14b01678a16f0211d7c38e15192d6e9df26bc20e311868bde1972bd7391749798ae4c470a03cc75c338f369fd8894b5946a1c20860aed64a408e53248ab56e240bc95cc2ced2aef4fcef469529bd1df45ddb18073e7fc9cabc637cf141f5fc1e8d9af5d2bd23b5e0cb558de1df628c3a88d48230e43565483adc85657045d5fbe9ba9c4299cad0482f0fe02bd86caf1483950203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(3,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100d037ad2bcea58add86b77a7c1073bb5732006a7154b5b2e93a3798c49d6e4ed8df7e013ea665b8dea0a90adc1ba54d661b83487300d452bf3fce101738404edd057689f096ff554011aba727e986a635706e10d0c78efd71493d62a21c0f6181979dbe8ef49e0506d6e4f6f4d9163db01873457140ca60e3d56bba1a18b188c4cb92cd5282d1154bf91f878110d6c6e3affbfb3478791a2d9431455cef9e0a8d2eb7af155a5ff16e0ae0937f4212acf61aaaed08ffd5c987b7862b64c01bda71ad91d9341111de96ff15138685d2bb07c199e3cbe4d80c35db4d889b7d0a6c8bad1b09281a6c866a6d77a50610547339126e03acd09d9b1939f858d97270cb9d0203010001',1);
-CREATE TABLE BankAccountTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, creditorIban TEXT NOT NULL, creditorBic TEXT NULL, creditorName TEXT NOT NULL, debtorIban TEXT NOT NULL, debtorBic TEXT NULL, debtorName TEXT NOT NULL, subject TEXT NOT NULL, amount TEXT NOT NULL, currency TEXT NOT NULL, "date" BIGINT NOT NULL, accountServicerReference TEXT NOT NULL, pmtInfId TEXT NULL, direction TEXT NOT NULL, account INT NOT NULL, demobank BIGINT NOT NULL, CONSTRAINT fk_BankAccountTransactions_account_id FOREIGN KEY (account) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_BankAccountTransactions_demobank_id FOREIGN KEY (demobank) REFERENCES DemobankConfigs(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccountTransactions VALUES(1,'DE064129','SANDBOXX','Exchange Company','DE496362','SANDBOXX','Name unknown','Q85DYPJ1ZKMMQ6066DB77KMJGERNNSEV6T7EVF3TXMJ349FGTFGG','8','TESTKUDOS',1660251987254,'3OCNEK2S',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(2,'DE064129','SANDBOXX','Exchange Company','DE496362','SANDBOXX','Name unknown','Q85DYPJ1ZKMMQ6066DB77KMJGERNNSEV6T7EVF3TXMJ349FGTFGG','8','TESTKUDOS',1660251987254,'3OCNEK2S',NULL,'DBIT',9,1);
-CREATE TABLE BankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, iban TEXT NOT NULL, bic TEXT DEFAULT 'SANDBOXX' NOT NULL, label TEXT NOT NULL, owner TEXT NOT NULL, isPublic BOOLEAN DEFAULT 0 NOT NULL, demoBank BIGINT NOT NULL, lastTransaction BIGINT NULL, CONSTRAINT fk_BankAccounts_demoBank_id FOREIGN KEY (demoBank) REFERENCES DemobankConfigs(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_BankAccounts_lastTransaction_id FOREIGN KEY (lastTransaction) REFERENCES BankAccountTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccounts VALUES(1,'DE746397','SANDBOXX','bank','bank',0,1,NULL);
-INSERT INTO BankAccounts VALUES(2,'DE146604','SANDBOXX','fortytwo','fortytwo',0,1,NULL);
-INSERT INTO BankAccounts VALUES(3,'DE599383','SANDBOXX','fortythree','fortythree',0,1,NULL);
-INSERT INTO BankAccounts VALUES(4,'DE064129','SANDBOXX','exchange','exchange',0,1,1);
-INSERT INTO BankAccounts VALUES(5,'DE711892','SANDBOXX','tor','tor',0,1,NULL);
-INSERT INTO BankAccounts VALUES(6,'DE847769','SANDBOXX','gnunet','gnunet',0,1,NULL);
-INSERT INTO BankAccounts VALUES(7,'DE558679','SANDBOXX','tutorial','tutorial',0,1,NULL);
-INSERT INTO BankAccounts VALUES(8,'DE695032','SANDBOXX','survey','survey',0,1,NULL);
-INSERT INTO BankAccounts VALUES(9,'DE496362','SANDBOXX','testuser-9oiyqxiw','testuser-9oiyqxiw',0,1,2);
-CREATE TABLE EbicsSubscribers (id INTEGER PRIMARY KEY AUTOINCREMENT, userID TEXT NOT NULL, partnerID TEXT NOT NULL, systemID TEXT NULL, hostID TEXT NOT NULL, signatureKey INT NULL, encryptionKey INT NULL, authorizationKey INT NULL, nextOrderID INT NOT NULL, "state" INT NOT NULL, bankAccount INT NULL, CONSTRAINT fk_EbicsSubscribers_signatureKey_id FOREIGN KEY (signatureKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_encryptionKey_id FOREIGN KEY (encryptionKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_authorizationKey_id FOREIGN KEY (authorizationKey) REFERENCES EbicsSubscriberPublicKeys(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsSubscribers_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO EbicsSubscribers VALUES(1,'exchangeebics','talerpartner',NULL,'talerebics',1,3,2,1,3,4);
-CREATE TABLE EbicsHosts (id INTEGER PRIMARY KEY AUTOINCREMENT, hostID TEXT NOT NULL, ebicsVersion TEXT NOT NULL, signaturePrivateKey BLOB NOT NULL, encryptionPrivateKey BLOB NOT NULL, authenticationPrivateKey BLOB NOT NULL);
-INSERT INTO EbicsHosts VALUES(1,'talerebics','2.5',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100b7f61ae60a40b67cfc214a9fe94e7f0e96fcfc55a29d529248ff30660fdcb1ef4c6e6a0ae849f934aa369098fa2fca8fbc181b26f66a3eea9c875162c627559b41176d22c6df4033f11dde68daee96daa4283f31e00f8947ff50d73a809b3c3da85827bb57960b0e04d23d24ba6af1541aef0051fce338f8816fb8a7506aa9b600252a8fa976e6f32b926e8b3f7bac979ff4d87e2a84d1fc73f478600f6fc3959732dc7e2c07dcf54f2d114c45e4b3531204bb640aa40dce683ab1fa7ee21d8c13c5d16b9007478e8706075c0cc960936b88ec0bbf145437401332dcff8bda62e6abb3198580e9348dda4821e77af9363456f9cf047e47b9e88a6c38561de6510203010001028201003d7ed3b71aae4f52b0a620601c89d5077789d2807dffc15e8d7061297d1bf58f5d297be1718d68f526015f8d03f57ded569f68543a03824cc34ea8f22ff36e369c27cc9fd78341df1b3734e63069999c354c0ef40946a8499d1bd517056edf506d3a2aee017572f498bfff188c08bbebb5a537a230bb748bfe18eecd5fa0886270881b5bc6f934f12c59a0ece6ae112f682eccd9fdf724a91c64886eb625be975562da6a72cc2e8a8831a790995aabb85f069689418735c383ede28f3dc734bdf8b801ab055ab2b2e8bc67e16cb3da7d690c092221284e6703c88aa05f38340a0862f533da4ca0ad89ab0a9ba55245ca17f5b843faf04612d0ca0810c0e0e50102818100f79414f328957cfa615f5b5812908aee3f8aa8d7f699a5b6cc2216ac5e8eb15f1ad8664b73430292f8b8b946576af057e7e6c09f6bdad139ada1522b7264de3361b0033966d2bfc09dc3f2a271d7a8573f778693dddd507a3a230e62fda687accf44b5963492ab1cf3796da05b50f1f34bdc3fbf581a361a8f2dd8bab6644e4902818100be380b5466d596e8a62d1fbe5fe0cda6a6503b9b0ba954bf2b6ccdd28e78f8722c967ab77f9eee37a19c9730c8400628b46f8632b1c1e8169a2501ccb532030973e58a7acec9c60b61cf9af18c1cc70982a9774053240afdbbdbe0217562c8cca98cb10f07d27d8a82f451622f6864219bafae7f10f970e41e456decdb34f7c90281810092efe03f30a70835d1f4b651df32ca41fc945f014dea82dfaae7d06d1cf1b373ae8b20ab470d4e49cc345641d9402ec4fd6d8685178e16ff147dda36cefdeea2b027b6c22ab489f9d7a8a428a5484930ff0a0165611828db6205cc541416f20f2e34a9512c829febded502ab5987011254c3b351ed08217441e603eb4cb4db810281804e57e6d2ac47ec0f85e1afe148bbddf7752836647539189e63d43c312c5cc676bfc67a64793b8c017d9e70e6b69327f63bda72fb0e1b3eeb90310dbcb22416fc1dafbc893802027f4d99a3c7385de1dc18e49328fb152d31b3ddab421c86c30d0807da24c6a3faf0c15ebee621806d3d2a52011c747147fdac3a0c3c314c6f8102818100b13dabf4b5629fab358b11a73bcbff732ec686dd130d088c5b04a44f04fd0c693ffeff22ce6ffca4f3455534321f6c335f5dce757ba62cd0094e1e9284f7622058e6a4eff159f44bd17179497249a6f5e83f3cb8cb2bacc30618dfe7fd7b2fd81c33fcf0d802344fd9fa55dcde7db5b946d5de1e703948622395e8babc6bf151',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100df078e3d7cf57ef95d249b74ae45fbbb95b84d28ac454d97e7acfb6015f0b974a5aa770a31c77045c480676218de2b96a6dd167cac16f67d41d4e35dd73c1d09cb60b651e18bb6e755273b8b15025491bfd8271e1be6cb4d43702688258fe59b698e1dc172383d13271b4e6e4502b292267e4fe1108cb982d64e882f8c797c537f77c0500ad1683319ee9f8e228ac64ac6499cca275a3c03811b201e8a2bcc3c69a48dcf9efabc8c364b4e585201e15dae4ceda5912d523bc6df83f21bcffb26626aca844e89b0b025ed2110dd07b9992c20cf989ed1f0cd687d355bc9027e113857b52fa1263162855b20483a389bb0da6e5d90f4f38b6536d8450680cdf7a502030100010282010100b3d814e41252a84c0ec6c93082a35e45ba8a7e75b0ccc5b01b9a8aadc5a372f8d3ea2cc9a4b06d21653e219fa1ebed7c331c0ed903b0149d96ab4398d549dd249bc265e28b1cada5c72db6bf0576f698fcf9213a0f47c1629161eb405801bc25e12d3f63516676216ea47f4f3e08d9d42e842687975fd2ebe542386117469370034feafaa30f4fabcc18bea95cf42b70d11cdf2bc8e1d3d4ae2710f3f87b72eaebcfe1735c7c070f24ef1dc997a0a539aee329ab84c529f1330a6850bd830c808f8f186b100f10ac81539994340e2de894a32fcea2048fd69232094065a68e6909476f2b6638307f73f748f003dec1854c914b8380a632b4d2510d34f2e40e0102818100fd5defa1bd4d42c4116c97692f52ff42348f9a010bb386bb9dced3ff18b7515cbdf66d629495fa58eb51eac5b920a0ad81e78c64efe462a09ef4af246f53c5664f0a5d174c4264c246c124b3b36c1eeb3ab4b5045756e159698c1ccbc552aae5ac061d43875f432a629f50b70faf33eebd48b6238c21f7d78555232824d9952502818100e158e8bac08bd2195114a947c6d53ebe24046cf9f25b4430ee7219cbe9ba9b6cbd351584044eb3503a262b7a814e975a8adcebf3cddcce4447d6645860b7f044727f9e82d45fdf546b05c7bf59d0afd48da5e209f5a5ab9fae323805faec86e411aab5a3218b5584a5ab0578b7f2edca99b50f7daa6b7e4fcb6177b513a190810281807b7412f82f21ff3f43f2329089039ae6ea6f722dc242d68a82692df8e555256ad810c3d9bde69a164b8b1da6fbfe7eec2c18e3daa6dd1485890e566c9d66271023c13bfcc726aeabcf07fb57283cad901689c88df5f49a5713cbb6983f6c7962f18005304b3ccaa0536fa7479b77d60924e7d1ffde1f0b0153b159310d4b8b9502818063e09b2e029f361ca0722ee130405d91bab6f77204b7ecce5f30d53c2ab8d9a0656ffcbc498874334fc2912cb7d9147e3de3d2f4793eaf715601b0f1f6d42fbab6a0d7a996e5733fa03bac9fa3f839a654adbc34bbda94e9ae3475de38abd2d18cff03886d1aab69a25fdd89f6c5c61d30e92e177d8c2d2cc2b0cd74c561ab8102818100b68fd965042602d3947422d8f2413378ac44ad304e45d980850f2e14241bed5ddc3405c3b587a013eaa1dd7d317a2c86c971b46b278eb7ccf68d5595b199a58a42b71f94a4a0592f428322c5ecb80ee3294e71dbe8227151d650d7f391aa97bc520765480af3f4c9b1ad8c7d6f1e6018297633c5b8c05b7ac6f1c87d86bb42d9',X'308204bd020100300d06092a864886f70d0101010500048204a7308204a30201000282010100cd3484cbdd418f6bcf52207824a6af5750333f1ca7d924ba3143474385e69bb98d8fd20a8dd98012cdeec6570134bb0477d3338ff657c5a7af4312a869fa4a5e9d2a37f41c0d4a5cb1719eee25d2e22ee79533461eaee44fe8e6384a55ea7b33c438bb6d8b599c793bdcf3e6177b5fc1ab44cc2eaf9bcd8d2fa7b115a84d5b81bceb20ec053aa2d58c0e5363f941509dd7bf7d2a1412ded0bf1c977bc8d6d85b315cbd7ccf845d74512ea88e61da3f4f772001f7d64d90871ca803c0b29e64d66aa986aa4334cf5a65b0923f7ab49591c00cc0b7ca62f9d32fffb8066fa08ec873df7fcbd501019bfcec1cc6740f5ef60618f6c35351372e14af90a97c4ed333020301000102820101009d57b6b74668bd9ad1b5cc35b30ca8078ff42b6142862a36260dcb37c81501b4ae09e7e8b5c95efd8c2f989f1fca99d79c35322521a33d680ce7a607c272ead14f3b0efa3b0429cf973362c481f607fe250deee9c61f1deaf3ce8abcdcd1d533e53206ecc0dbae31fb27b94fe5137161e37bf5ff9a2121e42ef52ac04b733d448639109e0152de472028057d0e97ca5a14fdfc478fe9f45b200ba758aa6020b703e3919a342c1c5e8b285a1d6b822543eaf2ce7d7d4ca2bd8a41d02171a61744d86bdf13c13a4f241243c9ebdcaca2832e2e8efd5de2b2afbe0930491264b59e886c3a4b38c18f0546f267292397200bce3cd6b0d70f10881f17b1c38616038902818100f3d30818b5903bd84313da3051b1b09fd32cc505d82db0899462f2c8bd4ae389dfaa2d03bee67c24025ba4fe9c064f1173aa1e7118ee61ecba044386593d7001f7d0cf0c456744b59064412441aeac30e4cfd46c3f4bff285cc517ff25fefd93d548926639c07b445c3e68ef1810fba845c8a0335781549371a42ef7514c7ca502818100d773cad83e2ea53badec787e45ad71639bf186729da6489b077f933950b1c445aaeb16efb47e1bc8c0b3548dd03668e5f728ab9a7230086dfcc659aa66f3e149b950688347a03ad913104b18c106c58a3d6f32f4855e4ef3cb42fd0fc195e93db7c9adf03da5ef8094f7d36b38a315159185f8fd5a202a4c0589330b922350f7028180357562841062e44c2140dc08d610907a2a51d98cd37e0903d12df4af409987d3f5df18e986548089609ef948fdaa8071821b9d7b0c8d4f99189bd0b64720aa4b342b6b09f4b9949dfe5f8cccc73de5f0fe69f6d818f4afa808d709d0de62cef437c2269f1530779660672a98a97d27c01834c9b3180f7a1cadc0e2af44faf12502818043766d78a297e68336658a2137de245825574e5b0b442b0de81e2952541325bb0ed6c7faccd08410ab4e3bd69ff0b98df0835aa064cae788d112a6b6f5bfbdb661016d8855e0352d0d8c1787abc15c0f7a471c7476625e64762c06a36d616c8437cd3ddab0e30988809ccd2590b977fba5f28651866bf5f291f530f7998dd7670281800ab0d4918da65572ea4da46fd36e57dec795b78389cdaebc7d01b807d32d7a0785b0c9b067e17b256cd23932477890a23a0f6f66b1f139d2a1b1afc0e921fd7fd1d0363cd7dd6f90f76ebce63fc37888393376f6177ab267e3bb1bdf0b17abfaff416be0eebb1683fad1140be2bcd7358d449153ae5d9f951ea00ca50dd8d0d1');
-CREATE TABLE EbicsDownloadTransactions (transactionID TEXT NOT NULL, orderType TEXT NOT NULL, host INT NOT NULL, subscriber INT NOT NULL, encodedResponse TEXT NOT NULL, transactionKeyEnc BLOB NOT NULL, numSegments INT NOT NULL, segmentSize INT NOT NULL, receiptReceived BOOLEAN NOT NULL, CONSTRAINT fk_EbicsDownloadTransactions_host_id FOREIGN KEY (host) REFERENCES EbicsHosts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsDownloadTransactions_subscriber_id FOREIGN KEY (subscriber) REFERENCES EbicsSubscribers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO EbicsDownloadTransactions VALUES('0A31DB3F8D19700AC6A3AB56CC6E9EE8','HTD',1,1,'WwMNEK5syYXL2Vyty2jBAGrF0lDftrxDuqhXDHv3WK19lp9rbnZ5tdXNiYutiClD0YOF65rJdJtB9NrRm/2CB8Tcchc/tqbM4TNyxTql3iB3o1AIRE+Pr5tiIHbA+sqBPpCnRyDcP69glDrHTVyZmwEykliVdFsieXXICmlTlvEOZu7vHY3SpkTQXEKjImsSxlyGpDFahPniKqw2rjODzhhwzF52RYJjfotlp5dCqg4E+sX4NhX9RYS4V9zADgjDZHvvqT0r0uWY1EEtZJRhxaajF5P+M1HNhvy4osqWrUkl3iqhfaTl1TZLIsN7t1EtCpXTH1IvVnTdKTsJWzlCj1h0sbg9YjmOKsIiHbpSa43kyq6kLPlIIhNg+f17eQOWVt9YPvcs3pHFugau6cZkpNidQxAgQS6sftabk2CCbhHXUlVsmEOB0AuxQLf0dDG3ZSJHli8r3l0OM5sYR/QvmDac9DB6ymc6gdDAoo9O7Xnqltskz3EiSzcfu6kPEgvxlDZX8gmnWAfGyTz7XwA71t9hTaLy1VLLeOipDVm6FgGqOagr96rDTTViDiSkMteq+v2gW6SdDBrK8zR4n1K9CYTVZ49d85IGmYkbvc87FVb7xF/QBdCw9M4Cver7nWpQgyJnk0+AjY+SNqdPu7uerV1Xmv6kGLhbQr7m7gzhDsBpTW1K5qS5Dw9zIx1e6f3cOD3jlf6HM6QI2Egtu75xyQ==',X'aee8bc15a1bddce56612ce272e95b07a0365a7ce77e559611393ccb1f14c4d502f54e82cb4a9e62fc50d6d35794e9c7577c27d850247715f5a946490db7567a71d86152b8e6f6c41c892edd04d092ffa4abb6864081d44cc4d6e87cb8a7deeecf5d54e364b91ca530377478b412ea85b35f50b7090b0f837727a9cd90a4d45b2fa987a0591e6c3a8821eed472679d7774b59dc567458e93834e0e3cde039412d45375c2b658efcee96c0990f7723c7456ab8b68b79a3062b690d9553f023f3fafd421cbd94b36e4c41d795e66ad1c763ee24186fc31a1b7c60d5f2b86b6fc7db4bc9d033234c51b1c24f549b9f49ea4975e80bb21072c0c5da603a28b7922773',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('FB35F936A4CCB644D7D76D660D44A5E2','C52',1,1,'FkSwr4TWQq4aHij6nAEykNQTZl4bJl9a3D5XKLHIYk8GZBnsbBVJf2H4YwddAjjyQ3GKn6Aj0X9YCdpdfOFM+aM0my1VJ6g8Q9PFsYgROIL8+3Yu2ksC4On+svlhRGQdb2lH//aYqE5uDzyuvp42IemkN3AoP4u+HyyjHrV7l7d4gro9feCs42vPWvSz/53eQYyRpstOIMQJnHRumKjD6dv9ZUunl8uK9M27G2VXp9kV33WOwTsGvHMXnCxYTjeKAyojdZ5G4D45QzoEl6sGLPuGSrPKdH0LAOer/qV/n+rVALh5auwpk439iKz1xISmFsqLbJCKUQiivXGjVAAEWc0WBQ7MD27IBDeAzzlFTS58FWbVwlV4n65F7NpAhRX+4oxJTea4PrbgCewt5zBaktnAvJl7Vgxp9EFxs+x7Eg/pbXhdg379CeSe0VaQXx6FvXdXtsTRHu+0gqLadg6eoXSyTUtPx5sROT1MGsLop2fHih6chNMMPt3FihTQw42Re/erFdeZLEsKD3CP8mjNB2Oi16AnTTEWkiFVsD+rxSTmgLf0RNv1/64fkTXbqt9VmiGDnLRSwNsHeLSCYZxnoj8z3sCYlCLC+FuxcsLjERbNjFt1mlKEq3VsiuQzywELw2NSJ1Dr8mY0uOX7q9nisSbxyjHl4CHS1AAatOKbXulr5AGn14tbnSwtQGhuPBg0kSZsM3NUwdJlOP4aJsDEizTKp9lI4sOGAwkyXoK6VH6mTo8DrJGqru7sIcrTkOi45srCD0QgCytoVdHpgtTXR+wOw13FFXImqZstwPVKH9eTRsmL/PDYYBFTTAViTrvPgy3UWeiUhnU69mxwCPK6GVHaOlHpbySjKgWvBpmdRwE=',X'06d231884f41be0e102641f7641b16c1835d41d4f19a4839f4c597aa0ed34c5cdd14538a4961578125faab3d7c36ebe48b1ade7e6a65af47b46147db0404b3c318a6c4ac293d750c56038a08792855374553050c518bfb5c15d26699633e9920e937f2433c0fce63acd078e05a3ce387c960cfe41530d37791c35540564e913784af708039f6554e9003d35c7a4e13789d061f5c98305ab319fc86a7f12947311b5b613646d5d526d9df820c2bf3540575a7fad89daa0fcef615402f8c03a31fd433accd0c5384096bcb976eee7054ca9a2331ea8bb62879d7847b2dddf035c60c32139ff66e953b2cc825a02337f026058c352651be027ebc209383574e54a8',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('7694B8E9D3E701DC3D9B5ED97C167204','C52',1,1,'Bg70zZWLrEVG3dKomaGfePCeyWqWkPtLjZ64puX85CX8b6+2c1msIsbxG2Jj2JWnTY9lMlN8LPy4QJPvvwja4sflQBEhGZELIt1hkXj/MkqsYrTmFBEVui2so0uovkyf0cU1KJTqQY4nyLqsrPfgquFX8TcJRALGEIdZl94gr1/w5RaVZOQe/Lv6OOQdgqUPOE4h0hkv80GlmaiJU2XM2G4x9YeBm4QWZG07P8HYAnnlBaYhA0QtNmT8765Tx8II00EUZ6ytuGRvr9b19atFzOmtoCq99Fn48/eFSf7FU9oa1Ets8axLBoqPO6fR76QLLRDcrhv7jR0gAD9PHewfPYXRLACz0PH6GBGY12t44frLzNwVAZjY8dxLs9562k9mC2PXCY3Hv+lThAh6GAMR93auPTQHLf/QEzO2EF9UvKwJl7MlhGFF90uKo3GRZ45w7gOWTPhAGo7Qeb6s/incVNRYYPB4Rc5vcih+SI6xei0NSvR09e4Jwgoo2SSB/wApkKUorD88atFfL9mcPimaZnOLHYFwTtet+qU9tcB/pA6n2IY+PXsXAWGy/II82h1cOMYtvhCXlTDxV2oys9iH6JihAPd8sA9gYXs5OmEG1m2NM9rqdlMTIQKy2yTgvHAU2hozSXzuJ97miZ68baxAS+j7n3Z3AeY3JpP8QYOUH38YqQbXpZghZG/m9NgCN/ftlIPvlKGCkjhlmjO/bcyTaTmsYarcB4/rgOIfMzRStXs0WzHT6X0wn1CfN11guMwflhw+d31qTQRd5We3At/kOEaQ2mqGI6Fd6EgnaZf65S+Un3Uq5IU9gRLqxw/oWI8dQnJr+nLKVGFIxJmnXnUJPekUBXp0L9srfbov8IM/SAE=',X'26c4a31290490726ca9833dc1ab125b4eff613bfd6232142d6ee800208a1944e25fb7b3913e65fa68f51b84dedc2455ccae38bc871a1c7d16f877c1925f61088e46099b2263f3175de0b08f85c262f0b8d8d3a341f048c65ea488b4a6ba8547f2f76c8108d6f8efb5ea28df2fbd31f23745ea24b078ef2c27af3033d8090a667a7f21d686c1488dca51af59234a4afe6d771948dc50828070ac80fa527a520eb5c68fcf19691b3ba47edaf8e48d274e7771443789dcab3423b26236f1c676d1fb2227fa6cacf79e4cc01288787549a90fd3484c7dda5861bb459f055816202233949de4b1fdef30416a764ba1c3971fcf8d7f7a5e215eac3827476dd45f05a51',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('BE0964BB33080BFD13DD5A29E3EF32F7','C52',1,1,'0hsR8H8jvtHNfZK5lLqSXChRkbBGm/d50UopSxfW0pGwTYMb7DQVF2rdhfnScfFj+8T9RIOiFp4nGU1UMt5qrZjnhN8bZNpR3TVnieOoQRjg4rpzWDIOBLLertvzY5BO5TOaMo6OiS1AFWhOn/lRLEyrPfmNz98eesnlRFl4iaM64FGNSZRQsjShSFVJM7FIz2+OR0O8pvSbzfNcVizIC5hR9Ld6uFOCESMs316GJhiUzzxUbp3bQ4UwLugvt00ccHGZQLe7dg4KsrRcx6NuOC/7Nas2X4rR17jpEFpKFTC6nHcDjTSf5R/NcNFdYi4W9d9qZLvPlYxPRv9qI0s0x/KGTggYNcJQ5RPU71B6NZOsykj2BbUf/vuVqCwQVBveD6FI//CQp+ifZHq3oqN0GGlF6KHKvysVwJ9/gagvusQOrQqN0cVSY59ymqtbRQL9fUKGePuqSViEktbxSXlZHY8qmUwMh2s89xwz+y/3iOunTU1TYm8ASuKyvdE9cv9Y0VhfUAFjyhmphD3fBUsbKOIcQsEmsYXbU4asWi+/1LzCDVKhsP93Pl+A45meYoVNzTuSKRJBM9cNwTHf8qQlASHPsXXO0syJLzzzrMfSOdy8Y7RnfEzp523CVNXS7lRVYLUgau8Oy0xs5Necx0r2cYRl3Hb2V9/+BwTxC9AgEXnXOgZT1Kq+2o1gI+UYY6JzqL2np/qIjFdFg2NhH8R/3fJ6CmWtOVGiLDHDTQNtLi+yFZPPilZgxsO5kyhPs18MLDrG/kWbjdoXaPuk5T/i1UPU+8h4qT2+nEN5MmQ1a9sb1kPOXByclKuEWhJQfn5HYoVFku1UAms0auYDvluCHD5PDeLVKT/LNWeQPZ2m3OI=',X'2a005491a0e5eb694ba381693799706d3dc0c4e246e100425339b81ff1ff211f7c1e41d49e8da9ad3c299b455c6ea69d7237cba6c61558285bb5f91803edc062a29ee99d01c8d875196e52314e1fb92087bfc1d434db7c7707d9349cbdd2c7ddb8578b98b0b2c8f78c79b13413cb37083746a25c0f47f0f723129ff90a6b4e67b5e1d5a9232565ef91456472557bc5e0e2e8332e722a73612065eeb11c12ffe01b9524af4db49a8663501383b93dd02bfdc18ded6948ef80c11275ccf2851399be195e7a45d9b55dc902fcbc6bc6102e706e6b0e8d88ba1ff627d61cef316baec5758998b913f5201bada9217eacd914ebf8ee4ad67e711a9548210004183667',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('5674506402676A8A0F74CE18354E7285','C52',1,1,'EEB/3CxCzYTXxqqc2x/T3X/fXwY3Gaf6nXVdWH+XiDG3HZRq3ktJvFBmm4paf5Atf3rBpE+qnrp0J//IDPya8WknDKB2kxvxdENx3p4+RJEdHnKdogAfUo8AsO1FBwRx6guan+MlxJ0obncRP+O2A5VyIYBROJnqViOsi3luzE4+wSYr4Xv0Zstl68Z7kNAnMsm3O8e9fsaYfUnpuQ6oa5TyRuVpquAZLkPdUgZDhjokDiXHGQ31LgLbKOUQu/prbtMC7yW5xbEHFgQ1NCcW5Ho5nakEw0BIJSOIKt6C6G3LGEZfIPww9/8hMNqcou+q/je2gufKKiQ9fIVQ/O4xzkrUq489dfhQHVsYZ6mBl2ACNY3BXek2+6cQ4Iz2eme6emdWoL4ibh1X3CAFkRro9+p8orm6W0f8//ftOloCMMlBAm85Si4sHFkq2cRtsrFaWSV/KfktTFbPSmvghvzCkGhDIRlMiRltDmSavCuJm+Dr+aq6aaw3kHSIrOef0tgk5Cu2DfD1cpAaLEcpoeRAwR/s1X3xUmDL562nrQDvl4/+0sDXMq7Fc3FOA1OtoU3GXms3dXo/VfedR+Jn6aGCSTP9hv4iPuwe9GNkvkVNB0XQ1urM7KS4/jOdWOg2dn15g2YxCAEk4NH5ikyG7hag+Yay0/U0vwyjHEgfdykxzzcmxLg//F1NQd8d47RRciqb1SD3OnnthKxGMkFyEORXWiXsT7jFJzS3wKgmdeeG8TE7fF5MPnRFaiCnhkKMK4ssas9DDJmpy5zdDZGh5mwWkwZYD6lO+7pO1vKbeq38Ok2K9InaNEX45EMIrtktYuMNHymaAFB5IwyrT1btq6FhOPUAmm3VmtRc0XkC8kwW8cQ=',X'0b46bc977e7de8596d51fb4484f07f58b19570d865c96e57ecbf536a6386f0b61919e761499424aa875dda9d38a02a3c324f63abdce25270aae45fbb5892f4ad592729607543dcca9c8b9201e243168654ce89a868e82d27b558f03f32edcce4f7cd232a652c0e148572669fae7d677bc19ace9030099f829abc184c697cc128c842f45df87f7eb4ff017d315b2bfcd7ee01ad517f5b85df60b3e90c667d4db4fae274335d0282608bd162cd3c920291976678449529af4be19d61cc02b6452715fd21d81601cc95990e505582c38158b620819af322c57553f5aab594d3ab092ec8785fce4b66ef796e0b88933e7f36edffc58946776cae7c435ef2169e8965',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('E9A1FA5889B193DAA06BE84D366EEAE6','C52',1,1,'elLRsPo4Xi/Fc2xFkYHEg9a4OVyQszRSakktC+a1J7TbxsWdLA78nfiKOmpxYmwIAjL86qFDaMcwy1Mq2Y+DH6tzWQfv0dWAm9/1/IhamlAk7JBJlnaeCAdyq1kguF9+IBXmc879gPjYaS0zb8a8XDcJFs+S2SE8PrU/4MAlJrXBFhGn+HRH3mrKSexESd6d1YpNJIzPJ+CedvZoHL7lhbgcMinZVdd6CBJDoSFcLLjx6LU83SkMojXZMFvF0Fe0wuP2QROHsY7eQ0eJ2Z25HbkSFHIQg9QjqlnvTVBagbSnMe7+Nbs2eWWjDvARFIC+FsLxU0ExIz6OyO3ceBppvbeJ36X1UXSX2iC9hInKCs1gWuxoAF7ZrjcmyfGWCcnbLSD65KabPwIZtn9tPweIBddYPoTuothLoDca8yo4yRzgT9rHe9HeFQb81AKZ4OIz7BmcIWh3tJorsd5jdIsrkOX2TpWqFxlOn9e2ZTzK6XGuBoHWnK9Rt2p1pVN2Gl8eJpf8y45BuIaAVZUXzG5f3wZNn/rGAn0cmygFLtIgy7HxIfSKocVljxLqs8dKk2s1mvi5lZeVHB/IgW1+ndQzR/ymbV0Uw1v3tjN6cLeBb5gJQwDYM194K5jp42Xuto5r4+2XL00l7LqMEY5ccV7eiGktvzbymJaRK/7E/+jeZF1gz8Mvb8lYJM+PXlj0bgHxJSPdEHfwbeNVu04EM/BwigMguKCBT7LR4cOl3gbTAwOfv98C4rzzz69HM358SKUZiDj7vbgwZMH+p4u2/g/kWTPu36dPTM2ae+8ynAXyovCB3v4eR4IhdU7nn3oorBdvyKDYNaHT9KuGbcmHKe7jgBHNROv6ewsWj16+Gmu8k3I=',X'c4db8e0ae23d390cfdd5cc3b3649e5ce827bfce77b97f182bafee960301327f8d62b26119bd5c58753eb19b2ff9a9417e17624543851112060b6bf7e379f30ae9f4c1734abeaa6438ca31562d176552c2749729b700305b4549c498818e8f31cbb2fa5970848fdab169f3bb4d950c65585185a3c7c93b8417bb23e03c9c705a86a9632c41ed68b574d5f69a3311a1268a328f120e67a362653535a2b5470a1497d8d69ddeb92204f7a19154e156ccbba927db93011268d76d55acb73f4943b57716e99ef87cee932de8cd01ef19a73f6e1a7746bdd9ae3000881bf12a4c8434f958911fdf8dc934b75637d52ce02fe1a810ba323c6933a4f2c7065f992771555',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('4ECDE9D9F7870F6D7D116D986B438E38','C52',1,1,'x026XquBAxfT6n9+WHgesdy97M0QXVDVRKnTN59qLL9qgGOQCaR7/UAq8GPh97iMmDyhUDibPsgaxPFhnD3W2u4yzrnKVqZQpSpikjfaYlPwf3stKXN92XdBwryjZDRBCQ51GVQb0//bT8IXDqEljIJfTdOpJUXIMdCYQqvhuA+Wh+JkZeel1EM/EhkyF9AYMmU6AYSfISN5Yf8LXXzIToJ/7tQFdsGw4j8419ZQdEeIURhQKT911QMa3IsSdwm5i4kAidEwyCoWjXl7Cl6kF/2llbMH9euvNrkOTk8TUEoDGP+Z7tQ8ADL0DNN5tNlrk/+K3SoPFIKKETotzsW5hwwpcwNudtgVYz99xHrAE3H1NWO35WfOUqb49/dfB2jtyMvV77R+O6FkJfLZrhC2vheY9rlYk4vYLj+edquH5N3NhyIkdBRsB5sZVqBKiY7UFtboyE9UWrXlztBTy1lFbb45ZZ/JzUsPPj8Ej/EUHXeXz6my493EAI5ZCTm0XBQbcVfdMq2bNMLkifS9enamSZnOpew1h8l/BoSW8SGKv7eF7jwMqx0DEJ/N5TXzGgBtgUYLWKpOhTDM6Af9NOJOlaFz7GtUEaYwXFg8L4zjKURGZaDIlh+y3DXjfVTu5MssHpB751Bffdi8nkkpMhB93Myh01i6CluZL8lAIBLSHKH/F3827U3CC+Z5l+lFwH5HWoXJUgi7aNSCDRxaaEMN/yleFOA7juUCdfGnj8HeeVJZks3O09lfTA4udT+5bLjLCusNNXOJ0adBT7W8JMg4gOX7pP5RuE5KpqSMOBmUIhdMg0YWdBJsUl+soUGhNPqPTx8d6RCis1k1i5NN39XNxmJAEnIq44tEZfTMqcmCCMDR95OctgFkTgNd2+HkfSR/SDrGhvwa23q4CVJcMoDBcvj6wuqyFEiaAvR2+LSriS6PS/SZNtL/uh/VFtQAVm5yLdlgLio3oLAUl4dJx9C3dxUd56F0P4I3ExEUt/HZPFZZcioV6c0uTtT8kn7OhD346txzkU/wenpNc3SI5P7sN22dLWD67x5io86TFSpv/cBsD2ZmYS9v9N9gBry6AYa0stXuQmLmxRAvIAAAwmIEemu//0PmL0VftSzFIuy8fZNWXS30M0NWFRiA40tpLZHAsKxKyaoVVacxJAz0E3FXWmMZg18GMY8jbB7YpWi88DYQVKjCdns/y62+9fCe+6Rt9d2llFLsK6vpvtjKJi5NPe60sWTpgK3jHcbMpEiFvuYDfAC3BunJ3A+ZfVCK30Ih2813NQSgLrwECDgnoVUl+HOANupQfbV9uNxZxNtd+gqYtF0tEa3gTTcPwQHCGKaptHFwvDhJJpAQd19SCFRKPM6uS6uaYVnVBVen3gDRySi7U8sCo7r5YC+B4/+6XZpb49u4HruDw/lEBC07MwLeOckhrch5Tqw7vaQI2nz2DmtHsCgS4l8kDt1pakBJLZa2QpG0P1EXOH3C8kG6V0myFw==',X'1eebfe88b1697bd602ae11ba38029c4f3f8f3edf20036cca8adcc9cefe242f441145403d960649ca60090a66ac58fc1f21253b38aa8f25284ba730b8c0656f8fead31fd083f0867a55c6fb87c42d4294dd29fd0d7a8610005a08a1c0ae8a5c04e3f51433337d516023240032e062682d63b2e6a32dc63fb0bfa6c66b3188e0db9164419cf9788f075b384db615857da0332950cdfc727c67c9eecb2b01bdf3bdde564384dccc0d55049d75b416ef2e52a57eb0871204977269983f21f9c4ce049ed196756a99bf396a14b95daef43cfa9e255a50f4c01fa065500733c934d1d2def427de58d0ce7ff3758b0b74f632e4e5c006dd25dd678fd75aa6fd189124b4',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('40BBFDB7B31CA5744A494970446D6088','C52',1,1,'I+qNRUpW/ta+ICtcvnmPj/rn7c4QeyVZLvWlLMU3AegWimMWh7+Fo0hDFO6ZsA8Ud7tLiCkL6L/ROXj4fB0tS1EsvhK90f5w+2Lm8r+Ci+ztoyirScnI7zok1si0+0H7xwqv+hTnSbErI8OcnGDT39kWYywBtigajCQAh8sZaXdWbOSJntJs7i9C/bSMnivA87zEsvKKkhP+jWr/N+VJwo30M3MkYnziWEO/IKhQuWgyrG3fxRHqW4U02v2W1sEKGMQBzH5+KxOzjAHcXfgSXKbbJDmKRL6EoEQpI1I30ZtTJiUcNyidvs7n0OuA5dCX9iWU5oaIaYkt00FX4C4Il/QqwH+IAGe8c8UiQ+kYbF+PsXM6Q/VeYjXwerbv2KviqtmbS8bO9ZKEgdaCrrKJLormR1NacHd2Ilieqtg5jnuEz+2ijql6viL4nXE4M5sNfyrE2cZ85cNjliEg9nHpjiNR2rOCK3HmuGRG4dq1fPMkkdpQgtYVjmfS+dEK4d0SIBcS9pPt5tSShql8qgJHTCBXkyGm/SUzWj2OVITXf0DcpsmSFo0560K7uCAX+Khrl/snkRmClzgp6w8k+geFUJNS0jJ13peWIDybsP9v2Rexh3B8/7Jk02RoGL1EFz2QJzRr/DLjP4jW9JZ4xBu8S8aHQAadIdblDpJGx7PgKNDXMYbg1Hh7XkJWKxuQoRie4MwO3BOew+1tOjekTmJJaRukCDApfHFJZp8qXeF6KDtJj8e7vQtAn5INOzkF5k3wQokybxKsrOlamzRWPaP53fAeOIzZieT8jRjngjEDgvqIYtaClvKzxXngVyiZf9HHkvTfiFgOMzjgJcjZsAa3MMXywBjmXoxPZaB+cFF1Z3JYLhZllzaOwzlhFnVWSl6tPdo/0PnTT/+ArVu8IMegpWhg6c6BwDYhbEKsIDGRMJ8IyzhpK8yQ8PiDohvbCbdaCAPlztjA5Yj05+x/T5s6gK+jK1D8C3Lg+sU4+1rJzyNBCpoSffW4+VUyNhZdhFQR8vhBOF8H+PtPksPX3DdFMmZr0iBzfAbkDZlWSIufgbQFl0WY6VarFY8Qb9+Iv7hkwY2xgGePSw5LBhDZ7S6MMVpu4jLA5SfBGntU7QwjCTvUfNamvWagtxyto9/m8A6qZ1xqxInDq6M0sVocTyz61aY/o7klSlPvw7UJ3RniY0h+5jfGXXUhIXQwVY/jev3bH0qzio7uZn5O7d1HbMyQurgwxjB3CCtTBlz7yS/TaCGJxgLh+7SKSvnNKB+1BBVBxb0mW3CReGWson3uidYIESEUuzf0+Wj5gn2BD4YuJunBWeTu7UIBp2xuZgTqbG9d36xiOp23qrIjLi+w0YC4O/BsRQywDyeCpIepEeMC6egrjM0IJgv5QKZ2svG9xYyXRYP2bKjYaCkYpd4reuNX1Dso5ZOqzBujIuABJNFMSi25QYh6HG9yoGZ7CnEzZsUWoA6YE9pkZu3NoL320Ai5hA==',X'4f3f1abb5fc107333d2062b2c74c45af2de1df7635c4ed22cefbd16199281d7441d49991c82e5ca8ca44f2dc3bc5b3a586384fdeb3a9b508b2cd05908a1d0fb1ecf99030861b43f3a51824dd73f54d4efcdcc22acd440c2e6c11d9006afe94d64f1a8850bf6a0cb22b3002dd5daa750acd41c59344f0bb1b669d7257de8c225cb887ee1af0ef0eb686dcc0e982415993f41a2b53326725eed3fd880af9729798739ea96b9a71f6129fd2b2ec1ae94f820ea2c3e05a28d9fd32ffb06c460de67bd7338e757a2fdd0b1650b1b25a23bafe5473ebb417b1fcacb606898368da051b77d8178a0bb66fc25598ab161184a1440af44396feead54bcc13553e7fbc8dfb',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('378C8F1FFC72C878AE5ECF7F2AAAB928','C52',1,1,'Qp8kIB6bXtoJ+X897N/zpS8QGMPy/hTWKxHqkdUhflXP9WT2/UMqtTj01MOtOqYcNBs4wBlNiEma11Yrl21plqi/7tAXZflQU3x6awix+qv3ON1qR4eZ8UNZuVFBq7od723YMBI/WsYlhCS7qbWBDV6BQBtmYjleU5WFPaE60NJ6pzQ5lWhLP9tRCJ9JUND8IhLleEsnplHCKs59JfmkQTH1yg6BFZwDxa2hhnHCNp5/ingTi3D+o8nKXBmu7NWxZcesyScOQYU2kcuIoEME81M7HPvlstPlN0B6hJKtjQiEmW9EXiN1J1IfYTaQIlFdXmB8gHksn6mI7gFgWtG/DIb1qgGf/PWxFvaNgh8C0TbF3TZP4qDYjaqt5Cx1p6hLdBadetMBOcyiUO1UHRNoF0z671u/utF7l0jaHOHg2N+N/9JWegNc/xCe1GeZkiTv3SQSuMRZXKs1AlsOBM24CwGgeGWyCal3GXxTORLvnGhK1VYdsG7W612ioZb2pfy/2ki0GzPIyYQ0HaV566DeYt66lDBRJlfQGZ9wjwposlZ8IDKJ79nfdwMlvqxwVV/MbFh4WC6UtNpN4qhSL9yky/joUkCGhGBKaNTlbeSkkpmzaLEFJKboewz5hBMMOuW0nXrvnSHGHm+SQ8PObwyvtcGaSo302NJdj+WxYolAGnegqK6UkQPvx3eGTPPNVPWc0ikWMES1agEZ+WRJh5u2D7mi2MB5LBSYk13S+pF5A5iTSs6aFlSm3I177apyLZ+PpJOLY9XpOnWG4zRYrmNUYkbtalRXW3dUQGNOxYRWUJuFk2dOiuuaKfstj5RrBJkclgw0X5FYENs4gfTTNVnYA4eRQnSdkbYpSX6PGjuV1JS+VTuoIUb4VCi1+WuDOYPzfY8f89QabrEsNGddrLksLnCQ28rRv42dAfyGqaQ9n8C3l/wVONBBxssfas723nYWaOkitS1TopRaLMe6Clk//zfE/89G5aopnZnaJY1nE2v3iCIvbKPLFiSSn6Z1GpZDcR/rjLu4iUqfeyywMXrcKuuYVxOgI/FQIYdG5pbprQLzOF26+fvToQiPDHB9g5nH7aglsKgV738G+fUt+ubTriBcq/Y0ABhEA8BKywsGozb8LXfpqR/WVGotqP51WedRurGZTXoVx39ajFGWJb6aGpGr1asvohZ9Bvl40OMUShkViPRGwsWxlAfoFv/fxbXFzKC/WXTfhJuiJjL+ULY3+cohsaJNeZ+y6P6Xms9FWT+ZzTpn86Yj5uzLiVkBGMQxXpJUMhDHLcACfCd2ty9hqkLLp4QbJgvxwZx/BxsAb2AeP1HfVEdj6/K8rkLWCeOfrR6+anCbQezu3Upidhw2aWKDC38wK660q6f4kBsR/YK8rTXjZRTbJX7F1O4zGQeWbkymUv04z0W+F5vCKsNxrH8gdgBe/M4UPcVBBjI5B/02mUbI0dEdbr962nOpl6sVkpiK0qbnO1ADd/d/+k5+zA==',X'cc58bce1362ab1d4af8eaf666acd6585bbef59288ed15d11ed0e26817dee455054d1b111a49711a1f7792faf087de49046d13cc0f8a8a5196df40330e16dc921d681fd5d89b8a2acbbd26672280470cf2214db758dadaf7fca420d60607d1534603176166a86a6e44ada9dd99ea55f9f39bae6ce2b734b1de4a5781a3ae1924d8a1fa64c30761d2a80e5e1ca8c3edcde22b35894113e1289f8a1c2219b88a5220efbad89347403b9bd6a3598f310534bb9349fcdb5df7cae4f68c46fe31a1efefc50afe7a3eab85f7d775bbca215d4a21e02f2cb43270f3b9154d961a27ad95fa94ab325b3982f42d04332bc65f7ead801a721bcee055618960efc704c351aaf',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0364AA00BB9C4424F96639627A8AF691','C52',1,1,'S8p3og2EtpjLGYYRwqbXg6YDIp7oOG6qH0xEoL+ZQOMryJj4wMXAm4e9XzFYcUa5V0W3cIE6gDDVMgSBCJuKAX2iEHkg86y2p+sNcw/R3qTRNk09YGv9xgrHpIqGaIG1FVQI7emIJdiXkmtsVjmeQ7OKxhqBahSyGY5H/KUMKKjO18EDZyqZgaDcG+T3IH7MM+oeFrj5240GyxNzCRD2DAywzjK3adfiGVBqBQQfYqYehXk1vrTN6P+tKFjUwEBx51VRhgtcCLyuM8UxGYH73yZxvSpsWC1tk6fKfxDDAVZMRKyqbCADVlmLhpWb8WYjC9eaIrpR/TwA3mPyTffWbVn/jZNFCYCdgDDL8n0wOwa6a8SBpBPdREfNUEZkezzQSikHQr4Ux/YgdRbrGjp4V1jN6gJrQC5aWAbeRu54M8Su0i1ReYXHyCR/3elmn85uL/0QMtQU1J0txsbl4i/MiIZGkxElFUSAG0986yN5G+1Gi1SHjs5FdZbLqgbyb+VgyMNjQQ+iKkxgrHMM5thOfB8zBlw+wwWUZIyZYY4ERfTMLEMmUYKeUT/zulCMc9jGFjVZva3h2kC5cuasK1AZhsQ8DaHDFwdzQIO/a3LRPXtPfOccgDSHjtuLNoP1GgZcon04H9JpmzIYTvLsXo73G3oSitwsqRvQRWW7moZ2kH+537ne0/ll4uB/TBptjbDlGblQNfVXHymgm0z7dgO5DSm7cx8sGJE6e4N9nhdT+k6gxKAPJwpY4Vy0gJBgC6fcF1qK3DrCE8jXdDgtFq6R+RgnFZ12JAsd3HqLGKuPjm0EcZQI2+7dsCR2EthXBt+AGP9SQcLYybBXqu76KisCpzHVH9EdRVj5lu7kQhBTBX1ll9X6VSK7D3Z9ICaHkrMVG2weAyAiQP9g8qf7fvqAygf4QshbU423zDTwI2fybx4OU/6dK4R8+wQwz4C+Obp6UAw1Bq1FiZE7HvSsfsngnCfFHjFBIuK9QnUGZ8WVNNlmg67wvmP0wSFgiLNUCdbyv6uOTHxVYo3wsqtVdZ7MArItecDcavmaWCUMqZL9kWhKXUhlWdWVMxZ2vMa/05p084AwERNH9iSvu1iXCX0kqo+at2yw1RgrJB+KxWoGm2HGOlHvo/tQhi18z2d+vtbdgPjawEhcLmXZnBRo8Z4zedD2U7QGEbX01cF69wfuSRoQ8gUfcx0JXs0qO2+lAUVJTiyIQqk9Y7J/bo8zkOKxTSZLmao9dBH1n4n0ah3imMeCy/ZBeQHYgn80YHeV2vy8yQmt9MsOQmDOnWI+hCH2LUVaZ8noZWBWgBMfuRqTQzNkMZef3Zg/EeP4nzcHvBibutiaWe6rxJacEBiPb0X1M0/2E5iL6B7+VL5tMv1OudJ67kXGwyOWPYZi4NupGObLxXuGzjRiPfL+BTRMPyjpyGjs0tbv9WZPKPAdFoCxMbDVAeOLo+Uh24KuEXcoS2NeqMPpYeRqg4x9Jt+5fgVmwQ==',X'59ee464c47b9f0987ddbe5b92782aa8b62d7982e90892784be837299a81777095ab2673a98e621d4a0b8dc20720bb758fbc05cb88b7272c51290b598ca9712c6b5d24c4008c2c3352ffb082c0c4c051e038672a25178dad14fb3fad9b12bf3de02e4a4de11afffba7372da1de57870f9081ffa56b6c695c1c17f4cecd539e7716f808e6c2cf41bbbf65834d2ed2cc2ea777a6b3810baf9d3a76f005a25d8aeede4cef4f897f14b4a05fbd0273161ad0151f61bb82c849e7b1bbad2e22a08180b41bce26456f09fa2082819efac6c6cce43160c785b022400834b2137dd27c09776880338c69a0c46ab2bb1b7f6fe5159d4e7950ae5963e823b7f0f51db4f301c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('3D1298725609EADB27794CF31096A77D','C52',1,1,'NSKNSfAqE2wtZrM+s1yd+3alY0BWus004T1rbxzrLeddaijJbbCjXTrJmHT3QqKfm3P3Nh4OvzWTewChw3uBe29V5HkF21wV4riaA2E+b4/gP+0ngTbnZ4TLuqAi//c3CwgyJKT1pjltbGa/EoebCZXr9dAHmUPQ9j1RcS78QcQv5/HRq+uXjslb3dB4B07uegVbZmSfZVDy1ELKGOMArxqAjpgIOXTb0UR0s6vCJUzy3Jsw80JGQp5UbUqmR5+9xOJMzgCJfp/Dl5vg8FA4WSuqYPsIrhr5GSbr3dtT91xJ8stJMi/ygKv/wJHlsFdU+0JcjGS9eelMunGCjlHvpanfvwcVianHiSV2/56RX/67AWZwWxdYz2iarIo3Jf1N1FLakPpVZ+PbdLvUF4AGQs3sOFrWS6Nc91y7PXdPfcDdM1vQSP++qbv0NeisackZ/9jsf3sDLqUMcF8O825/uzxTgEfr0TzUI7Q9VLGGn16E3bOzRkq3HRYJtKP3DWmdWgeYJ5cXS5EvvNxj12AD+sAW6kjxTgUVf9kIK2pX84++Zqp5LjQfiDoEDDg5jWMk2A3U4byG5ETwa1m/EkrRm5dQ/KKcEdXwLGJAMWjmVhdYJAiSvCxneig06r+buTzViEExVg/enVPwy/t9hzwuLnr38aP8PmNQCJ9QaG7K3G72x4yZTxgOcyVu98cA3/B0+Hur7ry+dvKVEn3gTKvsBjgMFK2jHFDh3jOu3QfNtfdMhiMabdi862CFFe7/fm8hWTb7fJg3yEWK9UT69FkhR35KfBhzJX66H52JthTnsFi028y9Kdw5czutps6WbXdhPSEvXaf41PdNMCXvSenkGDT7GDOaB/1xDRSekTJDY71pLfBs1kQwoVAydwk1HHMdoUcxJlzEjzSnXYwdFE9LNPAZAB+9cl6bAzQG50zaCByAWrwanPseIoaDb8nz5n6uaOrrKSqI6F58NvOtoi0+x/8hO7+CYk4BTEvvmm/CafqAnuZdMZujnSMTveuBZS2xSXdqFCa+CxkbngaEjQPfCFfD264f3Ke8o0qmA2xDlkADWSDy8RtrfvhoKUsCBU8QlEgjXI5k8Jad36kLqjWjQNS7sCBvAZdV6PRiztiE+6bv8p5UJa31nHnSXKxXWC0A8ODjLgS3tdgz6+3aSJtZvxFwrGwUmOhNtaD9WyCoPnJ6FOcVGwALbygvPKJHbvuZ3VdQEnMF9BLVlAPaxsuR5yUMLaUvGNo4uwpYSLCa9hK9MLh9LpGt1BLROFRUyYUKEbm43Dr2cgmYSonrbStJQvrMDmkw9WrwqJX3yK7o14zi11eDB3VM6AR608Y0SCjWkdsYG1pYLFfWFXOIWs+5duQa9gq6H8/6/mBLC9Kdc4x/2FRkbSk2pkNj8AgHR6/SyYZK7sb59yB3z65z8etYLtFwJS+vv/0lTOhFbIR3YyXGyEJZ140Ca/tr9rEojfaG7NwzVdN+nE4MVCOXKJqbQg==',X'01bb38c8e2f18828f7a6823cbd82f1eba9c4d01a5bfcaab1076844abd7c8779649364bf6e758be5a6e2c39a1e44edd165b7e21034f3edc13f6185b4e50cf087f3ba736ba97d6efb96a1e8745c10d60227f15e8961220ad54a634aaf9859dfcd1dafeae0cce3040357ed1932d96b965d957688ac6acbd3a7d51762b6b012063c754d7fd04ed542157673620b1f36412e91a365cf9abe13171a4df45b1544754579eeaf31b2bd0f65f54161fd4bc250de58820d5233d567d9bac11704a5712a558f2618b0e343aff9791c83b071f5e8cc61b28727a974f74254e142be8073da1b112960899f4516da937351f8a3673d5a139718259f347ee6b11975b41dd33aeb0',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0D20124FCD6EB95633590CF1DBBCC3BF','C52',1,1,'Rd0VosahjGc0ZZnJgHBy4hL9EUJbGfSqmEuTfLgNVSkwGBpop+1jX7ie3+v5OQz4Jnkkr67p+qz+JCyHp1l6N0FmyO5hj+9mWutjiZbg9B73k0xBv9jyHJyYVkn0sjub3o8T5LuJtmQ+k9o6IlW8Skzy3K1ChDOiAb3BJZv9wWKyb5uy1u1gq5da+rqtuwHMrGHEErOzXa0W/FbPFWuUbAzNk9Uljl2iC4SimBUBIe4+7JaUxAgDw+rrxUH/rmyM+y0oGllxErxEIcVe4AszBARZ8MEz8UZo6J8HNCWqyMg0Uo/882UDO1IE6Cuyk1ZJNje2e+DuPwF5aNeottBLlDBcP1oFrpifo7qUWEexpobfLW3h6ueQounCMjHA65JXiBepQZCFNUk/eGnDXH4t9MWRNqqZc19Naq/iTpoTLXPgSnXDkyJzbZDukrwh38CRHUGyGMbx6aNaZMTFWroR7re/FcwtsXinZR69qXhuAhKECRclSqCYDT3/a3HbhG6GzJkpTrlWhI6UMCpcOUabxdWvqE/XolAGxMFWS8OczUC6yoSGi0nr/bKEauDUBhPN/4hdwDt5zXboi7h5BVrs/wy/Yw4T0XLvIjRrJoqj+78GHTdxkLUP/w4jwBfKWiDx+sXiojLqgTVYRfAG8/1EP+mo/UorKJqyWypbinQXMrVRhgbPjbWo5zVFE1da+hJVta8yDjPPw0BkNFjoOJoueuHCkl5JBq3dFdAWdgE3KJIWLZOuyhTdriGYtorJg/1JEC0E+DxW1MVMAniEUp/38+8NMu1RnLrmrjimN4xcctQOiLj9s1MFyAHMjfU34baK4Wfi08RBqGU31LCyfFX3Y3nwjC6TAlCG6RNZs7UogZkW1sqUwm4u4YPqDkp1uAWYprqMl24I22s/qIi0avtRaT8JCaST0anZY976K0LKhVcFHBXbNoA1AzKrwgmE532atCvE6eEo2xptsj5+K3ipujTMs/jg46G+fN3P7g2J8RhRPxRX7GxJhfC3rCv+RfleQYiYdrpzKTx1LimlJhMGONeaLpRtWprjyzGnsnepoUkxSbgKWWl0TU+/ZuestcXyafVdoXaSzNWmmEmBdsVIOOeqyb5PlTltYc0NwIO45PXyiDGcqr1Y9dgkr4wMUHok8I5Jeu4FBKJV3umj2bmecLdwoNwgATSePc5d0BgfLFsLnq4j5dXoue1lrhJ6cUmDiRspSqdMxg5JE+KlhqW3H9JM6xofUIoCyWHhaeh3QyeTWFF5pQOqnh94wB2oQP8TxlDSF9HkIk61snS+pzfNEPIsqCcASYDyNOWpuIFn7nyOcpRsFm6ma2qM+fs6s+N6dSUmcNhOJZwYYKOHBP2Qf9trqBC9gICNzhy3gDwA9LYBohVRBV5tQCIK86um4vlEQL+vqL6WxzUk9aM807qK6Thuv8ScpZjuablw1kPme4x0pV6FE8dV9sEJp5mWgsdq6TR8Z/oyKr9sy2S/72oweA==',X'8270357e9e41c96db341ade4bf08d510b3dd5a64f874313983ff85920e3c6405101b6ae582fd7ac2dda9d32862b0cf8d021c1df75612370e573f035810e21708a0b7f6ca7965cbdddc82cca73547bd2a7dc3925869dac612ed5098b896bd335a41515453265593c03b87031a3739f7ee8121d77c1fcccef56718b31ab8a7517481d6201373abde4adebf4636ca21823d494f95d96b70997fc8aae191a69043ea2f94e0361d801afa6f2c5ac9bd9569ce7381b81e669484042dbc56ffa58838dbaa08950bbdf73e7917f0a9cc592a489a21379beac14fd534ce7c6c49d6182a347f4dcb6cee5885b25a7867ed15eafab1f8b7b5e61a512ada1ab1c03da71c276f',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0550925003A95748D712D63D7551E464','C52',1,1,'d9TLnmpGgeeg41tUZ3m2oBAFfdz2xkJSoS1mVVQVyWneZ7OC5uCMLvtNf4+jStRv7n3LEdaZnZQAl/KCyDVUsLForOjOMeqtSVAbfyS2YHbLnQLjhM6BWBgkI/sCABu/CCxqt4Rx4Fpj+SToInMAdnQFbVcAx+BT0SPlGISJQuVbSi0U4pyxvkvjrT07iAoe56kGJFHjODt/Ss3IBW6NtRxNfObXQi2MKLD3AG2YmR8hLj2E+h//TZImOXjW/HjZPd4MCNEwt8TyJusPxN1/xETBcAAATuZsNGYpJTT80p3vKpjXjuRn7T7PAJ1rif/mBnDNdmgORkpdmG/6CveuY0LMOuVn/Oyl8bbGEVhAaGL+I3DhEZquBI5dYNX97u4BKOnkftzBk7Wuxn+4W5VwT1Z9x7DOLotwi8gkfU8Is4RMThy0RQiXLJo5G0MPYQnXzIWK4e563/l3LOD1ZNOgWvbHxnktbDuTQF/8x9e9yxuqwK5IPOFK3jK4a9QWeKY8fAWhjWYtHkZ+32Cl6xbJ522d5W/ZCZDNagz6bVghbKtPih/fdW0HKL+tTPT7TOIKVuwIM199fDQMOO1tz3uzJy2AI50vbjpacf4kDdBIgIG6yC++gz59U3OjKmVM7vaFZX9AoKm15ostCbsq8ptkmQltoDRTIh068Fq1c4duy7uFzbo+KWpKzRfpKFmp/uex3Van0uRUZX0pQsBh9+qlXyVuMpVDrUTTmlgSkeg0UG8RV/7sSfaRloPiGXwm/5roMRVVcMY5TLDrFtN7t0TOAsX6fLBrGx2394/6jdL+VBomO+GY+qFeEVkTw3pzm8wJEOPHiKn5nOFB2kBlpBiiXl3Edar0ylhAu9PjCIZ2fbVkEpXlGcKajPAGBKQftmEm1GEFvW8vOGZYgxPuEC1S4qrX2Frj3g11KYiSCZ+Jl4P4fnT5TCmN0qupONeFUbgwAE3wG1RL57uLcXTmdeZI9BgfXLdFB5sUYjNZ6Z/bz6ncqg/DLCgHW3SOFf9r/UYCNrGDwQa3wMqqvETgFEIinJwvpavCwa/+AmbqXck8f3eUqG1u3tiJv8Q6iWdlxg4OuBePkIMjZ6MeM8JaIsYOxjc4Uvffn+uzYiPaTq4HzD92vxX0hv4IvUK+W/fCiS37+VL8qHLKlkuAhZRrBYUwyubJ6GDry4ds6envDwLcfdFzZb25IR0iBcsW5mtRbm7ROWilYhPEAlH76onMqIMBqwGEj9t8+FC8UN6+QlLULxcjg81FJvp89fJ8QpPy4X751SUbp7+8Rew+deJ60etz2XWT7zuSjHLSK5W5WRf4577vxb6tO420+Iw+2p+44sQTX10uhmig8jjpG9V83PdR5GEkWcNo3GdLhnRWE1KlSVFT0rY2sOVD5HkfCg6c54gbh4xmaMxeJS4rrfgUomLGD7UH/onrhGvhbSrgnn/L+MM/OIc9Nw6bw8KZ0VwEL/orxJPENNq4IOaYEcBNfZzFEA==',X'157b6646d8c6930aba9bd53b19563bead0c6a67e167c268b4882104f34a19c0bcd8e79e8cecfacd1f756aed42c23d2daf9d8eecdbc97c25ea051ef618605bfed2d9ef04309729d4ec2d0fde47f3931720f09a76656b2ae754de4d5c10269425ecfdac74d89290ff4bd2429e8f1eadbaefa004f7ed17320ad8a2d262a019ae4500de7991d55e196ef745c76bb91b082ce2f0e847436ca22a6f6d02afa5280e762de341258fccea7539a6eeb0fb2d16d8b5df96cdb70e247ad3e9c1ddf477a2661d730eefc14b6bb9102992522d5a5daeaa121406e054c5ce59faa16c4ed1e70cd56e4db9b1c79084c884721a891fcf667505df3456a65e044b57de8950335957e',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('9402017A391CBEBF3D8D59DFA9F8A471','C52',1,1,'zFHXBV8U8fbVmjgw0WJhDHGjtXPOzUZPnDoBlvJXxt0UV6QVBJRU9jOXXMBXwGLL3bhVlR4mOBCdoPjeyyhr+FPs5YmHzwc62eaB6lc6Rg+x/xEf3o+b8eV4KyzVwLuUSezwweFZiRYYisY+7ZicGtdPjoEAhpWWFNKDBGq8CMmwrL2CmqQPqYZvheUmTdExOrV6Z197JaJJtYNkT52YDE3renBxMtZihofJ2woAnRRoE0TnFvhjMuuvIXIf/uXkowpP6gBpdkTqVyBFrX/efFf4NXmRd5GkI1SVOQjv9fOPOy6sFCmJFJga/jJjVPGpXhga5n8peNufw4ZCKJlWsDw1gKsqh+bAma6DEP2WppOQiUfhfpPrEGxFe/vE8A0Sb3HxHy5HAEuK6APui3h1NrzDdbJsM26LfiohTyaIFMCVNx+mhIWprSlFa/YqiJZCzGCuTyhIX6ye35rrensCuUbMONhZiLUZDX4npjGe9Wl8lrtjl6qF8MafiLPMAYZjx2tL5VlEdp+hAhpSk0jawZbVOcwJ8EAMakRoBim05S5O47F1ug89KLVeD8NUYRFr044E3ya0UPmhHi6rXCj9kAp17xcokmBemrYi8R5Gy2YHQvmqhIa7q4uGhjVqYl28uSm6elR7EpbK0NeWNABVe+OD8Jvy5Mw6uE1Mu6kFLt4jaQkOBS4Uqd0PTvwSLZMV1U+JoN6nb3b8xQxUfFm/k49WNoTX9EcVSe9iPMCdKIZV7F6fPr5RGvhd2a7Y0TWndv4zzgWT+pOrPeAF1octn+aUMZaeMEvWAdD7qJIvKdlsJlhlqClq7xISqvXYCzaMybR6dXcKIlWNk7xlpofQYvlp5a50vzsEltX84RIDRQkx75E6DG2QZfAUEj4desl/J/K80mINnVm4zYs4LpOzCG0ioktYui/doAEgrcSgC3fOyQV+WTGBO7M+T1K6JTM+++sI/zjqOT75ZoETLv4ynna/MksS3eqfG0zuT+UStXTn7y/AOGDKwB36FKeE/F79W17j5X1wPDw0ZaRcHXYymTIUe7irCQWwaJlP1XiaX+uR+A4yawaYgOSqDtqaHSNa8NuhY07QCSylKXxsPzr4DJNbMv4LBLUviScOL6Po1DYycOOlZ8oRSFpUiUoieBHfvllNLa9mJDNRUFhFKpnl0YK8Wl4/gPMArY7J7MHq1eHk8qqWS1u7A/0NEYtbPIzol8Xdu89nX7c1W2x0ddR3D3DYPfr4HKmANWIWxd/sMMwDVYkx+woe+/4am4Osl59UopIY0h9ZfqdXTb4udyN/Wyb+k0jokYg7pPmmYZyD0lKpeYuIS9eO6+9Fg2VH2HuAcTBXzbUFhXk2OIvmZmFVQBU6e1QDwfuM8X1dyjGi2Z2p8QgiTxhnNrFLWPXAa+9RceUOKGphqLvVty6cTWVISluDhcqgZQ7fMLKsBJynHgr03cc4K3IMbQe+bBQEunz00mmTg47YL3NJl8wBtNoC/Q==',X'798a3fa44dae1475360f4121e98e0b320cb132da416ed996d8d98554a52af767e02bbf848b5df885b5bcb7a1813628f362a782ff0b054873a86bd10c458dfca8889ccd278328d4142e1a802da509b8f044edc57e7b6d2f162590a9d7530651a9a284bad177598167cf117432f6a1816912ac4065d34090954b39701046cb777ff5ee038da44d5a9b11c9e21d824427fae0a27db89fba851e783ab8cec885c6741cffec4fcd9046f4097e7729617da4233a1c59b2cb56b82d6416798c9e02248877d6fbbfe7e908b621ee21431c3c020a6c06ed0cb1e1696dc456e887460488ab52f4ea9cdae641bce26dcec0d8f6935cafe10951a9467796b97d68fb4e5ab91c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('F0D1E5B33060C4F1E9CC1883B4772E01','C52',1,1,'DMJI3z1ygwO6jf+QmK1Q4DUw3/fREnFSMG5mQnLe83L3suFLpamraYOv4kUl7kZJiAz9zujEJQOatO4oNb+f+sKGmeT4j70cN9lemg+/ClEAbzbPHMp6NtLQGN1d/PVvCMsmn99b7cIZI+p8RADkIXi1glGDqGnE+TQy7T60/9AnrNtPbW3MANS/+UDqMkBjAD2g1ajhyIwCbuhhnGowXxbQgUe1FmxmrvOtkZsED6udYxlsgfxrbiisE3G5uGUy4Fp+nEMFx2YxmxwTenehqVfKMMnATsfNk21L2HlpniEEYiDPJdXyoAOvwResTcbMq9nYNcBNgxGfjm703WTjMxDEbG1rQGwYaYuJnkPB03WkGK7pADduatvSF/HqdgvB7zf5gqIqqRzKGHE1/TWHriS+3b9NP4U6FHBuovFtBW7fKtGwh2L4z3C+A+bnbHTprV9iFuIqFR15OS2lnRLdWTW9qrCG8Y2/xQJTziWqMhCpXQjEyg90wNWIvGfLjGQB83IMhSqvHBLTKkhsLzGs+RoMMZNTzAh2Fcl6nX8xc/g6bDovKxqCQWhT4KUGaNuM0lPy+3nP7al14rwAm3fQ6PY6STjFkC8P4gmsaQHIZLPVYaS0+QCYKCwnUAt7ZXgk9TuUp5ejfLWLCYj0IwEV/1INsCmxxyLq3mZHEIM61q4zWp8AfcwQnedMwXnWAIb1VJp0Yc4OFTo7ZwmI3sPFo07Xeg5Mmdis9ZKGevB9pwJjUEE9Cd3nYZuHUXoHpzRU0lCxPLwXryv68gcbL/qELAfdwNYSR++8GjjoqYigiQe70Lz99/ZEhUFNz5qNljMV8VmHPxpni7b146cB6DLzdOIxyh1MAqZ+iXd23lcFBk8WcJydbgjoNUZDp2oyUUwABZ3tjQO4Pykr94UNtBBNklHOGbSmoq36etnjd60BZhR4+sReoHNgD0npYvq+0c8yp6o0cr8zh2Vcp2Mo2ivxCrQIQGsgBujwnyutk/1S8jzqNYRVFUXMBtduQZct/rK+qYuyjRB+nUVCKUGuxaVU+Gk2RmPh1E444D8TWaWBZSf8AAgByA8yBBNlMi/R84+8YuFCV9iolcsaJEo8gXzkw6adM+IesyoBzkEX8Z5/6S1EiS0U1LHmPiqC9FrgtTKv+BSdQN7AoCo4JY+gmO2t6ZOsRQh56Ai3S21U1IYwwYo8gIHDs3pOlQLvwDSitwZrPOWgrs+sSUtThjuWcac5iqqDllm2I9ZHRBtDxrBWMITkH1ggDYsVSWR34ZGhNQbbV+CK4QhiOkaKySK1BXr9/mjyoRGMGw4pPdoOVuILYIU0O9yX3uBbB2fwv1+MOEKcADPiYo34bcD+YlmYmtdxG4fSdmGSMvgh5PxPB5ZIRR7UCGyp6xRuTwcSI09J2cAQM8tydggizvqDwUdQnGVm/W4CSWVlEq4gPrgAYMD4iG2E8vZxZnMflKAUri0XN+x9R4MNuyihnmwWfkbvGEV5bQ==',X'1e138e43a03f077c4ae44cb47cf7ca860b59f61fe44df3cac0b1ade28b1504df3c515caf86feca34877341adf68f9f1d55f056af9d35a1770c260b8d0155b209bf977221df2652d03b0a567d1017a6a0f72bc054b08b72892272e6ecb5e4e46a73252e122321286e69f5cdf8a48bb7060466056ff866a0f9e04f8c75dc0c5342ff972a8fec71a4316c8898525ba9c98dedfea001b189c881bc56d3f1b4c48141a28e585d32a7fdab8bf1912b8779208f3a1d922ba65db449b1b2e4d9fccea80e4d84f3035999350b90fb053ca566e6f418e8f99e60e2b4a4c68f3a78b2630da1a8724d7cb5ea65d8d57eb0661d77b1251573a5bb0e7732e4eaf72c5da354bb14',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('65E15330D408EC66C58A7345E07C27D0','C52',1,1,'EuHrH9NVS+MVvdEqlemNc3wER0s3sr/S+6H5jhb9m9cDGrtiDqe4VSq3zAOlxYQR+5BTCFVe+KNxd5x5N8l8MFqH/AQGdcffpUtsqlJ2YkEumWlsxYYcxn4a7w6+fsosbas5OrUpDQDFDUaAQ7V2gtEWTeX1ZxfO1/rrvHNm4T8IzYhQAC0D4R5Eu9r/UYyVcFRcdmkxcSQA1QVLuczz//21ov6X/AHQYXCPLTgtihFx1sGMLc4ZankhcOYKhMUpuCPTWq0C5keyboe5AODV+gKPRVGUJdMlJ7lV1xZu4ZAdF5TTl0NrdPIVQ5tKxPrTGe95zxFBDxc5Q4olQom0FEh8fvFytEDgP7gf58OhotxevVKnta7shspKf3PqvfHluEJHzYDm8Lh4ZrR1Tw/DDORb8LCWoi654u9+fJ02MWcHECNnL6xJ3zNmEZcgYvbvs9zP521ZV+1spNKbanWbS5wTbCF3R6pL18WOFWh1awgD7Fw0j2BMhhj6O8fXwTIitkO0RGNtGX+GF4N2VRmkv9rXvMwVzIM94kJOSxf9afsOkLhnVnBDqJx5/DxqaUQFGisHGQA4lsgU2s8qb645YgvMO5oNZcZajRA/ZhrohnL38eMfbQjd9kKo3GbdB6HuFUkNLSYr2D7OHY+jJD0Bid+d/xRC4Znng9XhGCJPlrqfH+ElcXdHBLFCzrXY8/ZaHvbK1UD9oDuDtegJqT2XBwFQz2P43d2eKNI/AlyXrE7E36p+g1A+EL/knL9H2d7Jojsa26GYF+xTEt3dyhP30HewbGQRHrhdiJp8uHHHdB8hyY/5v++3CHYHXHw1uAiNk2nGikanifTpeQEBHTIeyV03SqcoHYYccezGpitOWrnfH3Qe43OkS99QG8WvMIkIVWx/bh1KKPLbDusAr38ikA2OnaeZhptoJS4i4u43qsLegMpSr6V9nRMilPhsPRysbed8ItvVPfgDDUXcGUIJQCXgPfM423BnsZqMppBNpBsXWVZqXqyGy14Vk/h/GOlgBHpFnKwlVnj57siY7obDgnW2EWYRMusYx8cdFj7rD6YzKCEgrcjtcRXL9B8rSj8Y/KU/HpmB7hdsei6QyvQg8ghfvWzpjIe0cwyYM8jWK+WS+cwQsWRkZN/AaOQ/TEMmmSR5KU1x+0VfF8/vodTgLpotB3ccoU6KIncla42cKiHhuxZsXsFXi5nwg5QuZgjasZlIy0A1L36EMZG5baeJG57AML3DEYSrKM3wJAw5gj0RWKxssgabKZkf22W/MRpuB5BvxutdUZgfff8F8iJVb7zUAG0mP4+KsQmQgOefHJOODQUTZldm+g4H4wFqMBY0EhqLKVk9FvVmiAbnwATQ//ID5EGqtbc0W6BkWWz4DBDny5K2H9b8VCw5UncpjOPWnIU7FabFggziRcKvHFJSo7HP4NxtG1c3UdWK0TIs3pSfnqdYptJOCl/EIMFXvENvBNUyDBqhfG4ppfdtzNAkCQ==',X'7e2960f8a974dcbc5ae46f9cec2b22adfd30ab4d8745433a1ef950e1363b77178ca94f1c7bd26282ed39982190d749273c37d196e9f87b13c7e2c649dbfa876f9bd59d391afc3d42a288b2f1d32a97c6a835b9fa55243b931334aeac35de3d9c1a27196f8bf26f8e6746d0acc1137e4e460d9c98a3bf32a0c87fd8fadf06ff6d0a21190d859d79334aff2cc5d85dfa476cd1e3e644efc881e8d4f9cae53e4b2114e7d700dbe98398e354b5b911ae4ec65aa8c6a80d9920647db6a86e29a6b0d4a610b13bd59038a628a223f35031fa1ba6580bff0cc3c9ff0652bf217abbea291492f3e1a9824e1f827eb9c80ab3fecf0d478c608a4f4212f0a2f7b08a5167dc',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('9BBB74F5F4FB705B8E05A3A6E633B388','C52',1,1,'jTHNb2iKwpmAQN0CWPXSNl4/Erl50Zy8IPYrtAaKIX0aKP2kaKT05fyxNQPlbzkDfqb9eTJcTb4AqKARizejmGMj2yzPlXeiGxtX26KsfxHGA1pRkoe+TEVPK1rmx2GwDWBLk5TPT44W+mPEI8XGlQMZwuKCcR8RjxBaWMaJR7UB8XudNNJbNsYv9oLBnfK9EQIaM7OODkayrl4WWZFYItNrsXSyCMq+EHKo/EFdl9dsvqKhG33qWfu+omzljE71uoAg5qfZD0+xlOSrnvBHE+qYnpaw9Xx0Px+7+gXDa7IaaDlYcJOR75/dqhKOS4/xjm0taWXmgc7f6ZAbE6qal9oj1h9w6AkH4TsBT4leHnYUqAcCARzyaVTSjYFEyPv8X9+dcZPx3YnZsIZUC8KntmQevdCWEzn43ESeEisMmDnLGgNb0p/3QwjeLZVKCSWrUZYNvMyNMealR7feELSj2zIr2rabDnp6NzCH8pK4k1wQeDcEZ8PMVOiqrQr8813P1hC4mCDFNGPy3a20Sp2gDVI1LRhgZ7eDQppY88HT1nHZD+GRl3dS2ei6+mqwCpjwwjsOnthQBXWQWsnznMr4Hg9UGJ0ZK2bvmcTtP4T+gfI7i7RCVd5W40hzFLDqLbjVchEp5kKwIsn6p4ihPxJx07KUfe5uZcrwsyWqeaHVvxH8LRfi9U0DfR+DGMgaL9guowJNtmXER863oHLaXzWQOYyIUDidEZU+G/+yVUWErc/BOsrpwy3yjc53nTsPhgtovYbbyH4dh5AFgXsP5fTkoOP3C0TrNbT0+HIdY2usBBy9LT/YvqfjmLHbR/0OeIaQ6MYFMcS10wqurj6doM5xVx7iMteCiJqL2N4gTchW/CzTOsCyoBWIYTRUGRTgyPkpLBK/B0u/RngWx16ByUKqVvQONUrJXvyL+ilpL19RAwxbBWt6EFUEDQW7n+37g/Qoac1M7sUCLw7nqRbea/ffR97YiVkY7AGfNyK2h26GdQoN480jXJxYutV9zahP+JYmbI3PwJOD6aN045CnLP/wH5ZrGrtHYKAhA8eVF2xziYXrlZzva07Wf+KyxhykFMWHZwBuNDNgAOjGJZFSMDvXtejBv4YZqk8Qp9yZSIfkhNibW7fIkP+hOzi5OAzQBzcTHq9GfjGfYz/GUC/ApOWbrYTHiVI3fkIQNlRIb8UqwxH30syX6LJBnQ9PiNDpuECZ8l+uUw1KRdZMSukgyZwWe7EDZm0iRiqLdAVogkVMl0PNXzpfVCXpvfdKUbBk1EZ4YsidoG8cC9Vt6yjWcu7GtS6QVkrsGaDRQxPAaOcCzJQLtMe1K6KV/BxfGZA2QXxMKBxtWE6FMnhbqxL1/hXZ5Yqd9nPkGDvb9tW97Elusdq9RZgrgCmzQx3IRi666QV2GWDq+mmR8SaGxqJEV3uq2u0RQxSnmJt2sZOdHvlz9CiXOv7xPSUo2jK8obRiDKRt8JgVKW3cajIMkBU0GzIm8w==',X'bc1746a638118c6d39a64e608737fd2dbb7736498be79f70a2e66e5db12d67d7a81067d62cf0109cba312fd63d495919a40bb4c3df424dfab544c81906660aefce86ee253245dcab84e28fac1ac42f6424fcabd9ef5be8a6ad2bd349eacd6871e7e9469604107f821dcbfa228c757cf98f6012136d7d3ae91e3cddb4108200932376d903ff21873b837348c893eadbb6c3fdaef4c78a5c2ab5499390b7383909897f94abde5f82fde42de4a7c257f5941146f1c7e82a448f1fcda811a153a867d60dd8119cb5c6bb114d512580aa9124967c2a62cd44f2a83bd3cdf1420d4235f1f9872bc626b6834a2a71fde7a430d276db95785d22c24bcc45857b069e17af',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('DFD63E8347BE72516D63F4DB2165AB17','C52',1,1,'QXjHNPI13fbJJaE1nT1FIlGBrrE1P/apVLYeEbliegn8Oq3GCu4K2b961YGW1RRW0aH+Sh8iI1zal+M+ycfL+YhJ6Kn9BcWe3HBEjOO57WTUpOWqi7VhqiAzpocMzMW6g3VUOLzkkoOOgx3RAujsnITzZ1PnXZzyOuHBUff5fQ51MLdt533K5I8h8eMH8hAnQ7IM7ZQP3cZUAyrIferWyj/0tQEUJM0rI1nmmKrWDm69KmMfiYTsZa4cU2KnHAUaolN43KwJ+CnsfhK1H9/0rBhO1kLOAI09GOROf4Hli28NrA7eBcXqlAWb9r/4p0MEquxRUPfRkX/GnEaxFpHzBoufEo3+ge8fU7WJMATs4n5ILnkDlq3zcqd7fcbKvivYLBuqId0c4BdsI4/ziq75FdlRIJvFBOIWHE9ZELfBLdeWfZaQw7UHiFvfjZJvpR3dM+/JBZ+2A677/0saYvOGx4iICH0xmYOOI36xpbYd1NARU4O+rACPTy4fxScOGNHgL5XRZWrf9BYXDS/q0P1w2WeHKnIUNb4KMGyNAJ1qUZHa4BEN3a+lZl6JSuBNtN0NJ9WuCna02SDdx8c/5y8HB905+AtBHniyNQAvoCtDFAg1uafrYgFa5yBAWdcK9Bc4jWek5okSegXpkkZEwyYZI2KVaRj1uq0GdezeotHvFMTJZyXMg+sIMD3lc0T3c/I133V4d5jd/OgSrAcprh3lGTCFLmI2rK6ybf0h0UWbRpyEhjiUxD76Fjk2nvna0tRnX8WZ0m+d71WcdQwRna3jz8f2g6OToLhFI514r6QYNA9Ou1Wx0tNffTwxxheBjINL+mz3IIEk60/XE7yYQO//Fn1kaoeQRRi6l4vs5p3h43QQ9Z9mvB4+Ooj9D10KuhoBdhAPLfdtfRoSvmVYLXkSQiSfQHQ7tWvPT+oo6z7j147hBlO6Rak608AbZ7x/ByCiMCNI+EtAl9LjdJmUTg/HYl5HvbVqbnWnGCqzNs+0pSBLAkuhGLPlu7PQazNDCUbf8U0eBfTiVgDe/xC13y9AXUVrd7kKyEN3XskO08G0LWEp3iWTgzU5QkAKPE2CL/Y5rZ2+dweeBAd9c/wfpI6QdKnFkP+eFSyr4MeVxr9KDsgNwnLk33IUujLTLCJc5VFiZA7T3coXopwH10Lu9FAKhGGyLlfY8cB7H8TMQccCqdo8AcR0WK3INXhTHXBoOcbVns8VfkLE5eTFaz52RWtq2UvktE9mn66CZ5zpECsopc9KcUOHAA4/tYqE3quLWmeDu5FkJInqNISm1UucUNvH5YFkIBy7cPW4L13zsY6gQ8vGhan3qyuHwJi6J6EarXfMhOB94t71EpHAGRT/owW26A5w74kh/sgjgsZuLfc6X/Igmn2+V+OpiVQsAb0fK7EgrA6nip16x0hM6SFbbjPXO/+TSzdQfuYDa0KvtGZIc4KUTYOVMauGf2sDjI8CltjNPttV0B41ZxQmqZN8NX8Wqw==',X'109b5473b1989cae9c2e9052ffe47fabe47c97e40c6e91114e9f7bb4656ccc8762a9936862eec05a71fa35d0ca1ca5bbe86de4fb9d02cc2ef3836ec7d3cfedfb2fd6135c373390f0eac0ade781486f76e49cd2fe5bcae1326e2224269edcc959b3fa51d2eb506c6cd51ea2a83ef7580383e198314fc9e09a74305ca63f4229d05035362e76887e6b557606d9a35df8c0b04612aa4d62d33d9d3bc0e32800a22450f437241a3cd3da477fd7448cf3704ef51c7c5864ae4f42b5f192a6d0ba5e52c1f20991cb33121a11e304f4a349343adc8d6d6182d97ac1eff6268b7daaeca7e6f6c65541790af1538aa0468d0321aacd574f6c76bc6c7d79ed6a1eea284186',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('BE88378E023ECC8071215147F8BAC9C2','C52',1,1,'r7Mma+UD7G8WjnSrFDxnYF1Alc0ALhZhzItGsU0FOZs/3V3N59Q8GTu+qG/WlT90Qbw8JHDmk5ceZxES3Vwip2dOPULcipKoFkKRsiBXnbeOuNlrVHXC3BxDrOCP6WvkkN85+o6c7Z1GmjVBeWJDcQ7jYW7gerLA0+EIlA0p0kbRLW1DSDqy8LMaiw+ysbyPqqSXYJhwMuK4zY24YAt2z9T6G0fnAGg4z0p0bNVCXaUwRJvG4CnzEciLyomUgrx8FrkgKXiIUackJXXhg4ecI99YzSekFK8AOFud/GL33cDzEvQubYaP8R5mdp1uJJ3xeb/M/BK67V99GTN++fu18hggeVGRNpqUS/7qcwp2Y3++M60+n4P/XhyTiWYUvGdBjFp6n3R9DN28RhbOKaV3LuiawE0CQVNfZi4TY6RnuHyPejk1C4AFEXBpatyfIg2tGj1ZneXr3WHO0gXy0CUpEvEiGex3FqM+2Q63JCaA9k6vDy3CWOixOgWHViEFFyMvmz6kUcbvji6M+snTKbrTWo0ndG7ghHS+WhqaV2iInQ8WJ5uYP+9BuXwQL3j3aCxtRAZW3Zwro6d+Y+OMkUrqzqiAqWtDUWqMGcWL/0TG68D5bUlRZMISTWw2iAqVFEABDENLSd6/tpcbuujs+1CHelm0JdIOMq7KmqJlVjQF1VPNh20P2Ee+tbaSFGl/6B4uGSbcNBL45OKstMLTqF2DrmMYeksizrA00RWSojrTs+kGneUcbW9ULCsWOV2XnQpfjPIrx0ZdQV7edIFOtD/GNOPug6kaPNLoHwJfSkAuYOWxry7AAJ2RPSxZ2PRCT/johMllrRlUEJCqNeBYpdKnZqX+5Gv/KPRXl/VoWRYucl1T+dd6cPSHwWqlhL6uwqjq/i52tCV6ij80/x/0mMJJmg8A5TDzMCera0dSUgPgdJ911gtQIR7YqtrkQVP1ki5oC1sJPD2VEF3JYtW5EXeSxG1KGdz9y2hbBIV2myqrsyN4eeHgZZUlTvGhAt4n3MuAyBc69JQSVqgz6IEmS7ygRZwvdwmonUsAGeFATCIxC8XMWpfup4/I3ZaV8T54TsfSgT8PlhEH7SH8MR6Blutc/YGq22sp8BrAlEXr/fU1BtZ/Hht/Jfud3yjTIreTg5mh+D2x+Ejbt4GMQ7/5xXZGia+IzygChOWWUDgp+lSvoRvG2GO1jGp0f6n5KPyFwb5zvtZ6IX3+wILs7rl8pXpv4WihnzS32QHG+RxyJZZCWl6k/Zt/WYbGqq4bZOY9rX0LYhD+PY63OAF0xfZH4xXsuNhEXTSNQa62r+2QI7DckeM5/eLMgTEoEC5XGL0DsHiWBIz0ir0EIXumskN4aBaXxE6KYa19quzRBfD9aAz7bQmWCtsdKfaRKkX35Md8tYIJwC12RWbTbXXNx2m/t7bKop2FOcYljLQwlVJ3T99Pq38wxtQOAucwLdVkTtILVheu4dMr8IZxODn3Q3Tw+ICMUw==',X'af485f9017b786ba82dceb95416f3515b8ed16a54c485523dfb756ce07982f41955d09dfe86800d7ba3bb69e3588e3b1c3c9eda1b239fccdfbab1281eb298cd2e039da38a40c21dfd1c7f67819ef04443f9cdacad44c2af256a626c96e22d9da2ccc6f5ef7d433eb3e6d2e3111abcdccc892a019c7357f886990bc181cd8ae4df5a33c06deb8c344bd4d661525dec50b8df18daadc9dc25a7cd2f08f95443299f2ff8df48ce71caf8111695a647718a2117dc0b7c41acfe847359abb67ad279f7c469c2e65a3571537caa69a80015fca9927c981619fb5f9bdc6ee1d82143509219a5404524871d3a824944b00acf91da2ef46fa7c95e94ff504de278f29444a',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('91D69A758D4498490F63201BAED2C7E8','C52',1,1,'ryYnV5gHlywx4rvzhpMjYu1DKteQtkD8hT7+X6rTk3VAsjyyi3O/2R9/ikktwHoKGZ7P4unXq0v3gmpG+htGoXoABof+l2blDe4QmqvzNELC9IHOXLHslVDrp4AqMiw9155LWyHN0aK8+Q7lIU1polfgCUgjQRGjOl7thMmqXY80g361Aesd+TnGXwwEGa0d6nEOrDFECiq2rkkmngb/tAsUoi93eQx1jcz1A2bm/VW1/qbKc4wsqUwUS6xaexS0lBl1vPfnXDYAZ6AKq9P5pVdNj19JFmwmMNDsDJx5ImrbxVf8rqQd+E4z3i0koh9WifnpIjph4Stjx7TU4igFDPRjOq0zQ3Wml/C0sOsE1oTnS0KnbCq1MHVzc7PBgZ5q6ROs5LBZ/Ui6cTsz1JdNhM34ztMT9X2Y/+IytxvhjFqtOxOU1L3/qsJzla15rSNhTZLjASGulse+my8YfjnuKOrak8aeAhCmLF26JEjHykGSPNYsH0Uvw6t4RV0XslsDL930omQSR0h/x2ybG6ace4fut3zmdowUgDYcqZUL/eU5tIUqAicWD15XUTyudoKNtQ/DdpBIb61q4DhtGYv223G+2NMVF3F5MEUf/XFDGGTYxAcLPD8Elu2IV7grUtXd4CnhEdTxA1LcEGAebx6yLmk6h9MOSpU6LeFs7vBCy3aOJEoso5wp6wZoJZGqNHPIV783//zjTENnfPx7BU67xxRTyDeMGq3Tae2Dzq/Csm+FYWlyHCBKyLvs6UVg8LjhcdB5hauQxlTj1l+vPOPMGoxtx2fknbVoQk0jhPQXNYOopQfp3kJ6yX6F0f/n5zOY5xfbiSHSAd1VNqGRjvWzKEdGLk4d8prlm8z/mYXHPMCa1yr8lmlmhS6WZSj6oGzYyp2636MJNJMjgOG37xXWCVq6jgB/dFVGa22sXeTpaV2vJJbpE24oYhgn9P/rf+pTyaAqdXBPAK/uY6e/lZ63hwEH8lEvoUop0hlOV8ctvBJDhxiXgjYNpfgFu/YypV9q/y5sY1zyf0ilF+MCx9Orho7eGNNgT2Vi6e/q00ug60lnuV6czVv4BM7UAes/volRGtDjIt7eMxUiRZI3l2UN1R+a0otX8CLKTwMLgdoAQtbd5Caf/FeRw+6/ZNJsoolrcBVPSOdI0dyiaOlKxuowJ9z2J8DIXoT2KIdJmLJUl6EyAOiPmi3qvHeZ14cwC/+u4I9MQzfXRYUva0d4bBTGKu0vQDlKvscsxWGFnWvZ+HrM1wVHKE4vjKLjtxR+ISIHHId8Cag2mIXKJiLhCXSjTH5no+6fpwHXm8td2ipJCaVnJDKIixwb9/KIwK7UL+RAF5bV1uSEQ7zdkZGIStsyl87vW2kf88edvNmLG2sbqJ8TQF2o4uCTLrenTijbrTJCdNqagNqIBHfkvTGO+2nV3o7fpkHe5OagElnyRcOEJbxtfgoWj4wcICPDiAzBTAB+NCn0N+CQ8SslpGhLXrdMeA==',X'3f4176f700a12256c391615bf886d003afe2ad7d3937211a0dfece3c49dfa080643e98f2f8ff0344b0bb9133680de336338f00e12057cd37894b297582ee7bb53e1083906d46f46e8fcd43962fc85c203532cc8645a840da82429bc820e39e5863a4f352248bb35340d5fc75afbc90ee92a76a03d9ae8bb053f3a21875300de3d2146539f75a6f823dc57775498d4b522cad08271514a7c62f7ffa9c3ea769fe701c940bd2ca8896337ec95f34bb0d6ee133275c51ea7ee0d33f26fa6879136e8df086bf2ff5f5969aedc398ce55518d9dc356ebc2f6614ece4cbf7f45e8ff095908357e4f03fe1b52ddce43220ccb228fbf918df6a3f03af3ddd8e9abf0fffb',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('29764751F659C97067867AD4F501AE7D','C52',1,1,'MyUTntb5rWPwC2ICCSuc5R6oueyn9CwXqhClwOlgzVFzdMO2lzGDIpXTZi6lC87gdLgnATNJ1bCh7+R7d3Z193TvU4B8mOja6TDAcVWtk2o6wECehSYTJRJMsqADQuPaLFho7mPKeAH/E4ACerpWiraMPYSOmh+XS/PEjjkI3tfAKT1zcv/eiMnLKr4T3e5lgUIiJRPfrOtwkBsNTMmtM8qHL0D7hOpMjr3dFVr16BYOjxZoZor1QHzNfIOchav7xqmDxM31B7FGY/RGmrzMVd7iodWYKFwbXPHxuBdL7uIMLPHSIiRTytE446umDa9E5qnEBqU3P4u5yWjo7BgqkYBseDiMB5ZMh4+fWMX/357b9ZeQ2mUzZLV+uh/RaRZPJopcdXUWxjS9MDUlxfluUCcgVw/w5WkOMM2U+dIzt7qj3ZEZf2m+YqeoURenGGL4RGylENypgdUsdiDBC9KFmseVd17vJemJ/G1DAbL1kLT+X1Ou/bnLqz//Po8LafgBz6rZCpoDixy3Jh4e78OBbZU0rKk3MQcfkZsYdp8MKh6h6aHcik1Hdtm8M9G13pCIT1Ii3sG1MEKB1OgsG9DVUnY6JFfw+JiVPX1UHWrJqXlklksjTr+9ERe01f7XS6uHEZsG4dSvExRMeiYtDA/sHR9DhpNiJ7D4npT99WesgZ0hJIwQNNN45NYMPr3+7THKvPatiziMphtqALA9LzhkTJYW84Ddtc4x8V9tQndVln5aAgadFiAUt0rKaVtppxqEV0rT5hw36laE66KpLz+qpPlNe79+KMrWM0gDF2wqClTjfaCadnG1GYOPfZZ1VFvr+9lqgShSF7tz1OnaVIqDKVp5NUm13y2R7Y8y0C9Swfg0SKJPyLgG1M7HHYjEcYzDeTqkJCkw0tY2Y7L6+bX6/w1Ra6uwTa1LDGuBNBS/itks+M8c2FC5gPOY52R1AFAMce0NB2i3/HQ5bIT3mAT8wxxiiFiNPUx9NU7QknxfQhyNR3sJFUTye+h+gO14atOKLBQ0X3SKBW+jUiqLjhi9PO1AHpf/bY1H6DsnOG2W0HFML+A8C7tgtTO47yzJh7AIhcmYrcCHLjaib2/mJjtf0RFDPFAtMTB8KN77e9JyMcriKVf5UJGDcaRIwqLQ+G9i+GkN3jZzN2YQASNC4hclmbljSdITBikUfHsiPvLUa11S9OB+m+adMGmnyzs+PNt4qo7aXCL8OmJVI/owd1oCWZeGSxIgdS7o0R+t0+l0ngs5ZFlzcExV7abDDrTY+j5izmcFLagfET4LCfV008B5mjPUXPPNjQxilhkDniI9Cvzacs1+DlANRbLaxr2P4Ooc39qjgk+gJ1Qz6eCjI1gsMCkY+3YXb8B/CTf3NVA1kl5yDX37wBh2tuI1xDe5jpw0c5PCTpEb0FJuzNVOT2a+Y1rQWhkF7UFbREU9dZpWfMIQYfqdEE6XQAnSOx21Oo+ZqRDV+uI7DlyQfB5CyXHuDA==',X'52bf31e2313ca4141c94b6787ccf06157f49e253dcf154464f381afdff9766c1cbc0781034cff7e120adf5ec36253cc4997c76dcfd6d19cf5e7880893217d87fd5bd819e72e782ea5b394ce7655529ea3a64f2d8e3c441dee0cf9e7311cf90545167e13abf0f6e45f5020af8e11782d541dcdfc2b743bfae7805884ae3885bf2a881214c068f74194f3ffa287582ff70a3d8c3ff6d3cead1aec327fd6ac8ee54c2e95a51111cc72178dbff23513b562c5cbe13a9ab14437bf9ddd850f626944669db8fe4c8744f1dfb0f3e1cc35ca1b1595945b21fcc7a48c93d33cfc40d9989f00c4ac2dd53f9788b99a28dc33e106cba5bced6cd915f1f652c3e5ae1c4073c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('AF0918477A75BD4100F72271DF63E15A','C52',1,1,'awlh7qIG65Vc1reA65+4ez4RD3ydR31aW8tkydeAQyE+qyP3cl5fgCeESfAAN2Bi0XIbusZh9HLJhlKrLCNhArwPakuQBmnVXpNO6txHipcrskimRnW9+ZE6/W6erbsoD50/0SU2ij5/PPbaDfrdVh11fveqNu/VcK44gRB8yt1lC3/YdUbnIktSmYcFnxNAFGCccjkyDciSGkDwrmn1qdANpys+cP9m3fmjsj0NT2qHeH4BCsxNI+T/gCjhrJwxEfcC+uC9TzSZXhn9+OZWuX+fcF5hJ/9lhJovwuYMW0YX1pItsh5D0tpM+UV8gbFs8Tb0J689ch+qeLylk4dSV5nsXUcVbNUcMpiiL25k5qbNCJ0kh8KrH3yiyVVK5GbusiZjHGoCD2SIt7bC3C70NUaOQsc5LCnxpHYPDHhSh9I1+zBUMiW++NwZAdt1M7p5NvZ1uqgXrS94uvL6O0qHk+kSuS99DvhPx9Sz3V15dYGTfXftvGh0bLiv0qocJ4mBkOscfgMNotwa2aC5y6ibxA76xu/U3SAYlZp52mwDy/fXDxrSmKgyyjWaSCzJAY5nPLD8+z58zoVdNz6fYxlr1ONkK1g1uv8zNFUwaAPKe8K7uiZHV8wHiDspakxwIakhN+DaKKYXylzuRBexA0HMnFf2rVsgpniQSBZhOcNroAlZABVTlPNVcZfe3fMwac/U7HxO9v94Pm/YKzd3xczjAMHUZL6ssl2izCzaabHAf2G92Kmmnjj7we/+rAfRYHl3q+mxDongu5aJXNqyOC0J/F/za5An8g5WaNsOnnbt2TsOLf80HcaxGisKE3XzaTOcsBTL52zIpKQF0114wpOS9T2mWSPJ0iwEjuxr5G4lGIYr/OPZRoPDG1r8gTnCF5jUoCmCrNWCCtkhGAyClC57N5+dBUg24Fq4OA8LpaDBO6tmpG0QlKcqMOJ1I2kJwM6tERUkCP3Mngnjh3kyKuDxUbrzhDhfHObOZsl4YSd9tpuzTS4jmHsikEwWtTE3m3Pi7YySiML0xkKZ7w3anQQUoYMg8/N16OwL/GakPA2JpfKq+jYI6kMEp/EMy4txhzh1OFyVvw7XweVlHYbSkrN8SKA82DfAbkT1350SQ0YmjtQxH7c6PNdf06J5HtIIMok07V4G5AHG4N/9TUkmxFO0dY9s+v40XLTpcOps1Lc1HFASVDss0Emp0eN/gYuWnSoieeQkPwbu2dRQ8OPFUBRI60mdxNvagqFv2OB1NICI/8LG9dDk4BRD8z32v3UMm3pCUWnG8QRW6mBhz5imPFkruWh4hdQgj1hnv1LZ7M6rdWrIT85ZSLdzJRQSOJUZIJtjhsnJtcIkN6XQ0cqgeMJaa556Y+dMuobgbcU3RfywOCihbw8AxJFN+GSm3HRG310lp7g63m9ouYZojs2bSZKcrA4Uf671oGTNomifcEMFFeV34BB6AaVBDQgZi2uJKESXEUQDycHNcqr2qbuzE0zT+g==',X'7629c8f61456ee1e3eb090d0e45188330c5eb3d2139beb8afb6291c9ca7625d1c06d89de58fee79abb786d4dc60d896bf3f29f9e36145b1cb7f2872e55ef15e6f56050b5d96055ffd9ff1f4da5b70328da9a7edf061f0ae5a12a4b0ae167e63556e8ee9d337460658aad1997e382e351afc9fd9e155519aee25309ffd8aaa39047565413eae5001c6a1ea4d595218834b9689061d217500a4997bcccb841ed6566d9ce400cc6ff26b87e0932fd3183d043509d39c6e8e828870bee845128a29abdce31a79459a930f4eac134a4f98569e671960829ce7a8e58ce20b7f482f25dc316ba487233059a29988af428d91f25618cbf21d30d2aa4ca0ddfc9376a4574',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('14C01C668B98A7FADBDC1AD5AC5A3340','C52',1,1,'tujg4+YgyisR6e4YDocPGGFo//lr6u0mo3OHS3vWfmQIMkavSMiH5EeZHpUMmVb31uskmCtLkCqhNMzC4qGqz3OLMC5Lg/JZIQK6oQh/ApaLcJ2XivjKubNsp/nQPoyldDSbUD95SUZzHNwPrjKVuX/ALtTCS/tcTIWtJMHftCEr+kGVTM+5DoDuVCVGllYGrx1aeE8NML7BaIw29TmbXeWblxsHZib5nOsZlOTBmx2LpDTItsi5vWE5Q+zV9YWfujIh7GD7LOP+wHJ9Q8Bkck2j3bPqjfd4Igdy+nq61XJezyeCWNkPkdC18MzwQ9tL1YMUuG4qqr+/ibJX4kzyam/kjmkTKEdyulLME8O7BES5UR2cE9gyFXdLoHVGkfXVCO4wutvGWcys3eY9mR8iSM3OS1DBZ0RAeLPgwXAe4Mti31KMKeLzWkKbpxLYZjIggo9ZgwOgqwrOjx20PW/i5HS07a/4AlRdJhlMDbndF4h2PZYlWPTV9mSJDw6/IBrtWtO7W55fBh7Xgy7JxPoQYMJz0B+V3VnfuYG+cJBlwh1WTeMr6EhXnzvymZGR/A55OS5YzVqpgLHGRcdMJdXyLJmC1WCQ8meH656zr6XqoI7pCB/TTf6Z8Sw53R7+/dzGFYYGWtfiWnvz1UHr9IEkwgj8kd52qjBQ95Apcn+o3QAE+ZOkY77P9xtCIGCRkUHLOLT5mu3Ul2d98mYBGIqnOc3DfEOIomIidObXgGfwNvrvEpwsEHAakt4uUEfC8MnwrIIUCM8ONRxlWrackl/92tmOioCbzf4yqF5XlDCD07tkXVIuW1pLNaAMwGn3+nktzEzkcsqxrWpvL0/R/3dPHYey6kueKHD6fKQHV+Bg0rXyQcpyNhFS9yb9CiyG4DgLJKudMHt5KvVT1eJLBdYUWl7EtEuZv74QHyBGWVZ+vKwYNAEnA1DH4zUlzpSUD3w3MWUX3kbx4Sh4ZIOl5BjAjJHYfMw8ycEu55q6dmfqA16G81J/cwEdLPoJJAKqiM57i4oyGYPPJRoUFenM96QlNXo6WyXhy33ks9pu4NkEktPRU503tWLzzxs0ZIJLhq+joWEbiWBY6d9lOujEEuHtik2ov+dSxI7vLrC1bUW0xOEJvnGTY02F4QjRIB3dyXblA1ZhhVYECYDNJIzZPNyEPvBk+nTO3TC0slo6R5YBx1ycX57dA0j5LIynqXD+yxkq7N3pxLqFESeItMNZ2WhZLEy22CC9/NbFkyrij5S3yjS1PIXQ5hUcqMI5VhMuiYaI62TBg6v7MQijFS9StraPIfOlfiUYdb5xpSkecis3BvJZDCisXT7Ug3jpvL6LCSlKJ7D9Oxl442vDfIfDrs79Fy35h+aTwRkublIIeGJeiI0T0ABT709vpTc1Hkhod3vcUsgrhLK1FbJtsuYVwxKukRVoBkJIV2JttchbxYEBY/IvVMjYqVg4v+WCEn5VnLmt/PtE+nOYyJjdhL21JpcyUQ==',X'3b8662821b351c9feb863cc9b7f45d1a144e05196e98f3d2d92bff54917da37bf710f80e7765121542b8d1c4a57ee81a9c0ed3b8a5aa5b43a7e82dbce0436176a145d95acc0c0c295bdfd578cf0e4812dbc4e8c07d517f33cb406478cc36ec413e460ace3fe58a96b2040fbce16f9ff7a041fe8aeeb52dde675831b11c7e8551d637d42942bf8fd36d7bf21986dd66607c6086ea3c9e5153b465ca058674a8abcd121ec93f5c6d4bfccda91ebca9897d9b4ca7c51fb0c012baad4d89bf1ac8a7b72f61b1829c550c56011abeea9055e779eacf028333f648794963928f83b5d026981171aa33e8d7808c2b33ceb63d4aaec2aaedf58e140172e650c1eacabd43',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('BD54B9E8FC626515C202F8783F231053','C52',1,1,'QrOOAL2xMxjdD4SRNtxw00Glc2DhdBIlz9fCqthIsmyaFx0dS2rwOqsg/7qo06aDGJnstsLjZNsZFZtgod2cvm84nzzQ/IfdJbeIn9iCPy7O44iPVvQHiEMhvIlyg8vQEiHerU4eZwZmR6XzQUDMToEZRKt2JFBvTKCiXLi/nhyrmUpFhzMS3podnQi5qUecEJK9cEFjufQR0AmMyf5yceavqXv5xTG5T9xmykVXPsgCAY9UmhoesSrQWEj7vCcDd8V5fSLxGYESrrE8nF80FCkTQiHocpYdDBJPIHU8+if74vPgHQTMoMfEl7HtFp+8hqRpXZ0YNcOBMMHTKvIPnciTqeXpn7i4FFB8OXk+8OWSdHmkdLDXvKIO+xPFXsz0YGiV0YkfDfmMlDIAoKkLMGoRFJeYMDcgpk3H2pbP8yuAaVqTIi3NA5YA2hKQZrlY0tUn42WTLrnPsSdyBzUWknMf1UO3lrBynFVlVpbof0xP1FFYGX1wba/2TjcFmmpm64xMN4hj6R4OAVMbKqDQAlz5YBqGZ7XJjrOrBNSZ3pmyA+TGZc9S6Ug/NtymRyYdmckl4qD7RtgRFqFQWUzmQ7oZiSaWZrXccLNXv0pD1TRBlG3L/XwKd0gKw3oM/KLXviqxGBZFgROisCzT7Y+liGASWEz/lP3jRmCidZP5O9mkAtTRk3qQoHWkMc85vRCuAqNWmFhrkpoZ2nwKniNuJdKLdamxwz6UrvhvG8aSLqG7d6SifxiYqPHVGq+CSrd5C9lxahMN+YF6qUexAYCp/rcWUjR5vsFPt//onC1BWEKqm38rutwF/wT52NCNKKKIB61h/C1lK9VVkdD74AroYk6+3MDw3P3yCoAmPCAV8w6aDdh69v1SyUFfusd2/v3OMXbYGxxDKvK2PHinaouSAqBK1ba4B3F17xTAsBy7FD+pqpykrZdD0Hy6L7q77emkwqBKxa2bw3WDKijRv0G/kzgt6oifYoe+9o8dlvuvr9y0VNSaUu1Th2SOHMyL4nFYXAl7zcpvRMpo3p0aDSPdXamRU8Ko1Hgh8UaUEjUXrED315RHECgDec7iB2iR+ZElz1uBFZgo89AQvtPSnD+66ugBbiJ9LiN6S20sbgEt0lzCLfDJJ564swhj6MDhpLdb23HgFVQUwEM9uXGsbfO2Nh5dfL5cTcEEn29FtM/L6o6/jzKANh27npnF0NFZsLj+hidcwgiUJiO1ElRY2/WSw5AChusW49SuD3ZK8trhdiNm5HLMsPJKcTlFmkBfGtNT/+Vl22DCIOubJvEy5aGhqEbJZov/DozC0TUqVIEpskzem+JoGG8l/hGPkE/zRYuom9knzYTHjCRa3OS2SAtMztbcuqv/Ov7BvnYmLkdUuseu1DF3/pFxtEuiYy4wjiGYHCM5ueIlj18BEpJGbIOfOnIcjFzB+9/6Pqi+M8xq9EUzVmqqaiihGJ86Q36GVuJKKhITet0vQ4lmsu0D4PeSUA==',X'44e04deff641250699e0328d786074535b00a9bf962eb684b627230653101dd2fc4328212aa2669ea4dc7cb68bf76662207fb3f307441db0e9f0a59a1b1aa228ea3836095bec6cf2f65739da18744acec03bb9db4be3904a01838efe67a75ea7fe556193be8c92748e0c9b4f949c086afd18d1a8e66c0e10bb2ef5f621bb63f6a5b389c7a289a9b92ea4a2ddbd9d1ae3bea7553534498dea7cd213c367b58b042dfcfe7ff2a62f39ff34448f680d6caf1f1195ebf8db4dadced2d5d49aee2824844990e91c39461877aa23f5737f40bd9c40d90fd930b2d7e9549b6f65458623abdd8452ba5ae6d065b2ccebbb1f6e62ea6bfa14852900687f84240741fd280f',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('799A61E166F4EF428B101981452A6B1E','C52',1,1,'XS5qGtyjWTNGj+JHuqPbyLw7U1rGmb5i0GnLg9jfSSB5iCKfKNxIpCT8j4+ewDHW4xniAYeMAhN+6ylw+0ikvXIkL8IIj+8ZxraMFeHvfEJdi5C8QTmHfyShOKSI1rAyzTlHXxLr+1ErMZqk+pNwagJOALJA+kmKYq0yTaFWr3fx7rGD+rdpsDmPnRHu4G9pM2yygKamWZHLzFRX8aqKVqGsOXJX2/YY2BHLie2yOx3eoRngXOtaaJCkudrLQ+nW4zhrZb8l5ObNX0FB/AeT4FEIvEfDpz5uZ0sXwD39LD3Ecvtph5mdvFtqjabP872JI3uzUtqvE4RRAkXhYv4sqRt7nlyp4ZgnWu2VGp+2qZAZOU3tUx4iJWW9KUtvtasfyOc3XT8sMPnYYCQ9Lvt9lplp0/TPRPSa4l1BqQ/7nbuWTyzZ8tz6yR+1ScdgFVcFjCeMdNoGX0O4a0r4u2i66NHozsjTf8AeHJk9lt3at4QVGepL4+rCPnas7cf58OmrH77EgUR3XK6aVtPV8Bbv9VfFZ+6gJEvGvLK54Au/fdCqW5mYowIgHBlJtHmj5l1CTMzffExgaagM0Pb6oNupI6eJEh2vMUjSuKfsviRrLhxEFkU7S6xYI0BvQUec1DbQ2CY7R2pkNqwQsF9Q+1GkSY/pi5kgl7kot/VuYJIu1jUXh+gcawVJshmDJGp9REHNsOHsWrzFoZ1fnROPEOTP645OUrqVtF24aFbxk4fC8+7lNltVo2tINhj6WA1egan1WnKn8qOejVhhMHpPIjOvrFA7Czi8gGSMr1bhvWI8HNxxbAm1qB2gMCYb4Qd59L6XjI12ejCFgaA+i+TWyXaQ3dt7cDPfh754bIskRlT4/LNDfT8zirADtXQTZZbNIw3W5YLzMqXn5rtcYslGdK2uzKRGt5rgJmuUaMmxuMC1BGNZ9xlgCYjLa8GHkvt95OBAqFgkjb8F4sbT8LeuCO5uzrH9TstX8ySmTNzCfSD3oKhjCdQ29rwQksXADszKzpiI6UOYvI1MHLOkGTEzAG8eCRxgBh5+jJ2MijM447YHy8W1mAEOo601xHc/045jTFpsM5ATMRKGU8ubArOLAb2B8X/KsYyrFOKA3I1i64PwQH2/KDvSUSbcYxYF2pJ9vTEEL1ItGMUJ+Y8A4Tz9Or5e9NEZqjM/fdhfE6Sbbgh7T/m+iiYOU33Gco04xt5C5Gen6c8YWboaaIFullkuowPFySrJl0SY7leNUz9jOUM8rWL0XlZqi8ipvP8T2QAAKARioXw4PbZ8oATfQBMec6TsYD+N3H9rEmDgvt3CbZHMORCu9/q6Qh4P69v2AVrgM0iBhdNrvhTogBsdwRoMffVyAvwmQmiIo8HpjA3G79nq/vZgxd4a7XQYNlWBvMQm7PMrXrdEQIuMhJtQv8urjqIVRgyZaC67UhvrmFJCKjvMtY/lkQVPYeu2ytnEDBLsVnj5GdHPHrtgZ7TMhFufX++8Lw==',X'b35bba6a102c4517b7544bc12023f777f82695daf7f90f8b3116a24c10d20312423748876ff0b3a1029c5282b3a08564c20c8e902b1e05341153af0cdca230d21c7bcd614ff41fba2567dac8aa9d4af06263792e192154b0dfe2ed3b5f7463370331fe98c4e06a9fce3dc4579a963d9fb7e67ce133c39b34c7a353acc1f6aa76b23246252fc63058bc36079e0a6de9a3938b1ae6bc052799bd0d7e4bcd539228700d91651c96457cb91c0d39153521c969f24ca42a08a808c48100e844aaab8f7a373b61b1e312ac11fde591b2d3e912a1e81f8520235b8ed8128d187fe080c568f48aadd279e5693c0c8c4a094390ffcba06e7aa960c42b452bb80d635ce1d5',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('F8D940079086CA10508D7BEFEEA62A1E','C52',1,1,'1RM5Wz5cDOOtDpqq0Sm1+9UIWQQhvkzM7dKuGMEQmIIIx6rpwQUUzo+Gmq0iEYMVd6w2xeaZM90GOU6pIEItQmbsJAbSuLnUgp3TwSHDuqlJoJk+ZDcLYtSuipoW3xbMzo+Ff68NWvOlG6ltjP3snn9Ifgru8m4aRA/gTbZz4xFyYtIFhpvVRJIz/8WblBUB+DIcLRlnOlobOC+RCBSPduvo+21W7HdI2mGlSW0gJPmNbz1YVoK/QRkSzZFKoOd+lgwxRPT2DuNcH0nvi9Lzp/0anOKzQ7+GpiVrlT8TktZzILArfSYqXUAeQpomMIKGWyiHQ8NkjtFRIMRfPsUGgsARXR0kagVDBdb48K5pcvrBTZu3YLnTcwv9BF/fFN9Nr83amj8968+wBqzRLlZ6Gdnf7RI1l5dOc6/GWjTTd2WMexQ/74v8e6Mf0A4eeL8XzDV5eL16I5xZKOi0KFyw/48f55oi1Sk29BsbZg3duBu9ohWfzgUP2+Z5+mYwI+9c1/Xrbv2ICStGBRUzgq/ONGT3hWxbLemUvi9HZtBV/L/ekCU1CraCTUCCNh2cOJqNzuNhzFOD8zIIk+sQV8WwOhM+QZjr3s1yO8gRuwMBtNadbsE0EnsRWoRKPhHwh/IWcMtTHwiFi4aK3bMrqPj/vj4epzh8clSBgrD8GBjJhdMUuEuI8dnJNOZSRyNdkLtzpxcQPlvKE+2inhODknoWeYES0FslUxSgCD3HTS1WL71Sz4mvUsUouU9F73RFo+ogkK9obbWryu42youevM1banAvrG+FYfJd+zIb8y1pQ1YYtj1YCRLkj/kp4cWUlkZ0nBg/Fkz4+E+90K8OVpkgzqZV6ACxq+SbBj4QWwMTL/YHNb34gcWXmS50nAXNtZBWgcPxBT6PyCBvI1YRd4khzJfZNvep2jbZ3SDvGANpVf1DnX8NdNzzCgzhc3iuy6iDUeQvkf1qhmoTpFXxFZi4VqJmVdnFs+UWbdIE+ADaoHfy7KKoQoGwuD6LGpRXyzs86iYJsBAm+7fUzS2ud64kM5moJm7sWVX9DHYN+sqXie7ZomRWy8rauKW8guhw3+jis1tOat3Vh1VZyrf3TffiLANQ1MaqMa6f1BLQv0dDRhKTqQDw/cP9Z+qGE8mVsimhvVf1b3AvUjoRYQsMdwfyK8HmshgGU7sGSVp7R+nxYnAiB+js9Ei+1johtaVdUtpOM1ZzzswkhxHkxGXlSUa/BNKd2L6b+NwoJ0WdQchDx42xMpWhC+geMOxkC5MhXY0yUtEKT5qERezS5EZDqjQiSGVcfQCzPYp2FX3XD8GGvs+YyGJ1CahcUe3xfR3qls9cwo+9Drb7Su3lB27ehU7+2cWaCFNw0rMRzV0oNF+qQfPZ5dXnBAcU+kIxo/GYn2hjFRYJOfTDAXexI2N0IuwQVPu7P4WBBjMcHLeNxRIwxj/X38M0qPcI73utGE6POClhfMTdKcW31+c2ON8kYxc37w==',X'a9728ac79d085132c1e7f9d3237f30047e90ba4ee8d09e5810357c6425257923eababe965f02bf97dc06154d1009e1b2f0046aaef4e6deef9ee5b64c3e13c5f3f07620729f3f524dcbc5454837c68c84d23c4e25ecad883deb5d5c79b64c1632dac9603a23159b24b23ef6d921fc850a17b7bb1b807c08d07cf291537dd8b3dbfe3c45f3f52bbdb9609b63217884ca70ce7b4f409718c21e9995b60cc903c12b4e3c898a1e67d20c47a1b45d776df40f9b5ccb9d0d6ae3204abc081a04c1b1d32b468b659ca8f8e142939f9c84dbf69a6b975f124b18d5332c8aeb02e9788690b1f86fd1e508e2d3603b50533c59b0029bbf3a4bbf2317dc69152759e326ee83',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('62E4511DCE6DDD750C048E5B6D8777AF','C52',1,1,'8lsHNSGSKyQbnDMfml7AaMDPqsF2SBsbfmJ5ORNaWy5HX4kX7ZcFI5lUXQ8gOT26wipodvRZMQ6KnkE4AVxa23JKmwdptpNpz6BOZuF4xRQPdunMRShcDi93ImvDbsdkUyNED6sQTk0kLVynmSaB0znnY9X5+jA6uKRxVlzoFeKuW4IgXlO62QWzTC5XD6dJKwI6g4jFATkDF+QSPlyKFFSXginZMIw4dBxo3/B8F9J6ZdAUJi62Dkv5yj4AeRwLIqbUVyaLbz9t2fixjyfR9ul27ugMO4uTgWWVQ9+PT9u7l2mqruF6TqjR9Bgz1ibXUirDSKHaQJdIeCPJVSnFBJ68KQEoIIT+VZDfvgcfT3iET0RxTIu4fJVnsoI0max7aJKoJELmmfFw/D98dtCGoHfJcQdT/YPBt3dJbPOg0pYvQGxaaMEEFLL4Xq8pEb7yz5m29zgzsl0jhmsmKodYTIqiaDAxDM/27D+SkDaox0jtRFZV30NPSMbc/W09BPTDHCwnKrjWxAjgopTJuX3kE0YXT7lfPGn8gaL6omc40kbpyAv2QViaOjBkEkcr1ZFsFyTH2rLDMXsRX5Lh2jF6/z2DyvJD54TIPzDnQIAi5Zhnm7YlbVwVdgaDoFP6LkLNKtLHhab58D8UhRuAa/8O0CS1TfrT7jK/u4d5HBmQ70k/WvBF7TEmDNKQaubd3R4UtXP3sEPENjGuDNl/csyftupQc/tmbIe1fGP8pEQRDIZmyJcEEVLHo74n/Jt2vCRAd3KpM7C0EhdKHEs0V3HxHmAr42JTO4cHdg8RkHCAJvSr/Y46LfCzMZb3Q1Mryrgz9BshRfuhcs7WT5Agpq8STP2NFFcssPAOq5sfHF0NR9And2xIQ0XRdxkGxGEnj3vgKAv1MPEUJ2ZooNrbDj6Y7CQEB0hmBxLvar/nSBr9eRjiewj4LtXs+FTzbtyq/9oUqgBux287Pvr5BZrpHVElABkIVtzHd1mQYMWeWO5UUky2GsSOyVL+h2SB4j4nb9gYqQGOKVjqXMRv/npdzNYIALFnzLKUeK6oQWDEdErv7U5sIyLsCuD6f7xvujR4D0NZhfDJRSQC9ETKqdUORqomZG4i+ATpYy+Zw/exs9n1SprIPTl6FwiB2jzuogZANANFRADqxuRiyVVHIswPxOisz3FIaL9IHBXnu264aM7lpka+2ZUnRFFg4fVYyshwme7Nx6NPRzjiti3ffQAaVAQSF45JBEHOu8MN1/ZD2ytH7S7UzYNodSkWEsT4dMWjDL2RKT02bBtBnn1qUFLqRKXRyCWJL102/zVKWi1HreczkvaBpsYbvGoQs9XCBEua+M9lp0cuwxtinE3fzkdkZNddqUoZmxdZ1drUj593YsgRPbp5HGnmxtsim7Xgc8syZX8g8r/Gssvr1uB+doVPpNsPz8GlFyBtTowxX8LAiBC7VgAhWoCTgr1ysbH50BGCAlx9WWKP4/FadT0ZAXZnSyJKWg==',X'ce9861258419f9ad5e312f4b4876c567151903e2eab843c62efd8306a71c19115ab79a55d5bd5dcbf32c2fe366a97c4f63c319a4e0b2029b43c1976d1f65731dcba198572a67fecf8b7b63a1bc72e018439063e3b6a89ada3c56897f4f01d84689d80a3009b553a016600154e758d407a2f696dcfb70bffcb919dee1208da518a176e367c0bb840fab843f6f97d60a6657802d47c76b6133c15e29702821191122b53ee9d913ef0298ec8a6bd361111ef578fe053390b469ac06dad26dbd886e07dab685947d1524315068f9c2148148b07c55e313c0df3a97fba7c1ab379ceda7a4cb001198a617eb5efdde0f1602bcd246d7e61ace2d72ceb3a9379990dd31',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('64B5160113E5D8830B5DC5047571E338','C52',1,1,'QdQPsAMp8vfskrkea4YgILQkU00nnvKiggv00icq01A8+smMi8oO95U5wfmuHXRS9gBq429aLPzJYR/SA9C8koiSCClDsVQT5SeBKRmZVEed500cFwnPyKs8FyhVzMs2f0vWP+kKnNTkz/p1aUQdap3zK1B7oPh2z5bzXDLBYQ6IPkjKpIa83NNizOJNM0vVVG2XoR0vUxpB6+9p3uK5hmicGImBWvuv/csdL8ooYqc9cFlYqgSMmhO3x0hAK+TJiE8GadTUL6tMv6N9Xu759zA/IgqwY80ZegCZ3t7hX5i2eHQjLir8ghk7I9ZgiGQmkaGliNY8SyIdQtLzZVo1+peXMbIVhfG2nk/P/yL8CRRaeZ3rbOJps8QD+eZMeAwaHbIDwPjUeFJ+MItou0vpwkMqRW9r8ng/ilQgA7XzyMpeL4j5k4ECXp1+qurVIC/BfyWe1Rhscrd+OuT+6AQF3gXKoxuGm3PCs54jzGzgz0znj28UdNSP3Wd3J3rt7q4vNWG+o58LY4eld2RQIFLvykOw+Tzs3dLC7UNnK83g6hm+6Q7Ot3htqLySiOxFJq/8hJUNmp17wUzNjsLPBD9CKjD/IuwhZjdLhlpggNhPQ+NFUr64kfdzFJMbtJzg30Ad5d/P1RJ/LzDICHDA0o5fa5XvsXpyMZ0+R/JUpLqKN/JE0MHmxrWCWgJ0PwyHQmEkc3ELlbdvbiorbt9V9Eau9DmZxZXIYfp0ikYU8IgSesg0Y//DHGxHnhpfr224Z7QpWUPPKrsgF2oX2oZu/X9TK8oJ+95AvskgJ2g1qzpRyqyggqxWgAlpDNpCBo93AdCLgHu5sat+2FWkeljT3gSQliNOG4sdKE5r1T/RzY4adRtfgykPQPY/o0/y4+/2CcaCVhGVYvbadsM/IdHqb4mA6E5AWY4BEBvbi4sQut8l62YOMg1ek4YgIfOcG+/a1mrS5ZOpNE7S0DE5PX7WrX3i84ovtFObWEX84Ei92Vh0BNXzRWQzJh5d0DgfxdwVaGspO2S0oqz4wLD4LJZ9OpSYul/0NftrtM7G/MAaNxdicrUpGQ8QYrf5ZyKU1w6JUP3kA0DXG2sNZqU5waCWZ11jDF7sWToJw3RsYQJIHmNnY5GAzqSE0GoRCuwnSC2Dkr5299UAl6ujxk3MwhkgUmmuFQ+cVJgd7iiwA58zBOQIgnvxNfddnPRdZnF9fhD4JG/BAYo19Im5myNZ3H2ksgh5Rce6RA3MQmEcdF6CDC91I428az5Ev3+cp7jGdzG1DtA4w2FKSy3weTJrMwJRnV0mKMpppMUpbPldqKsc2lIF+L3vM/vg3VizK9lOOoLkqvhabSEVTYaCgc2MGf1jkTTYbN1uLzNVHyfXLDvIaBu65a5fmoY+HI33OHmFz12zYbqQJomhpLvrgHF435j+xtTkRNR/nbYv4ILdb6HLf3U9/8CWMBgdJbngOcDTQo8AvrWKAnjjEA1ihBLN5jV1Fdtesg==',X'75d6f372cc6a851f0b3d4680791f523e09014f882bb54399c9acc3ec8a5cc2adfae67379bd20ef02d6466148d8280dd178ee2c62c9b0972b778ab19ec252440653685193cb20c8219953e549108ae9ed54b7d188497ee55557b00233c4dbd199a6927bdc6b3468851e169f60bccd9fa9cc3028d9dca53a463457c4c473870afc962a1871187d859556d8ead6429244d2eb787253947e9936424498ad31e5ad3757c9cf1eaa50ccfb136914974400cd2d2aac2d1d8840dc6d854bf98c18b329623bc6b833fee003aabf0b438343b79be212311821117181b04229e661fdd4f92c49aa627dcdef1e4eb9277afaae9745b47c7dfc288916ae17eef25f9de5f8de8a',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('016BF5CAA28715A0765A798397980413','C52',1,1,'t1UFNSgn3cDzVUPNG4AyKPaegdg4xPnjM1FmFG4ZlsuqbVPbwxWzcwxb3bcFiLnvX/fJM5GWH6+/BnODZKGk3gCy61sRAbnavhUOaWm6hmED+JqN2s9kS/j4R5F85/sP45Wv47k/lYrNyl06fDjIilXuPl/p9a7naunbT38XukuSBugo27/y8NAGC+4fGFNT60Fcc22RD2Pu3MLzJoEsanxgaXEwuIG2wpLV15rG8bwZ1yDQvg/SL1CudGQiL42SP7jDLPxinkMB1r2M/XuzH1GdLw8Ci5CjXErDZp5ofNzLV79zyyrqxqQJvadSzfTWoKkjTx7s+ElPYkAuhF7VNQiwZPvMuM+oLUQdSRGadXGGxGT9enAcZ0ZrpRUTrzY4OFKbqVseRSB1yuZVGiRfoz4dXRHcNWMht5IyDdUD62rcM8tTXjQuZwUb5nvB4romTIwAY3Ksw7uUnnPRrs6Z2C1GsXPEKPMI9SeR+UvHcHswDBe/5q+PdRwX8laLMYmIe5cCxiI10rRyaBncLF3oVh+01gy8TshIm3LUb3XAVF/iLWZZmGPOcPpDScoi4jfQ7pJP7eWWJkZx384tpKaCKLI0sUQDojhuga2IfyP02uFCTiaQQRCpA53LoWOLHIXYJP2PNUVGtjWmIFmeHcX8Y4MieLfzbarCegqCepszrbPocN2SHvQ4GbDZhrjJMwHKhLTPU2arN10aKoZGw7pxoQmFbYPjZiAP3i89TSOGuA6jo7UkPuoRlt5Hre92+srS55WEpOoWQpfyNO3PndL6ZjxKs0Ai3yf5oMpQUBWnM6ge9fSdJVedCtPQsugFnJCXuptybFNuNY/QHHJSj+HsZuQYFGRzShidw+ACGrqXfpMdFh4olS0QlLJruyD/CiSErM64+HfXtx0lLXDptomIpZgqX+jD8KHjnW95DqywCdhk2iSEyzsmUT0QOqZVBV/VbM8U77dO0z0lIN2b0k2Qgin05YS4JGH61g4w5mBr/4QNqQ3UEotKYEx31OFfDz17/0XrYBJKkL4BW8jJZxVsJ43F5TFuZV/a0faf1moSyYH8SAXJ/i+G6YtSr3Ci/kSXyabjUMeKOqx7OlmT+Rpf0fMdi7OQ3DYca2ojckxsVU6Hxuava11AjSk1GCWDOrAOZGU6yS4VYAnMYNN3duPu6RFiyDm7SIY1TEjmKaAh8DS6GoANXJpuOdgBwevywMGf5hD3j1VJfSwytIf/l1SiDdx0346B37Loi3MBuiv0MnX8aEJnYnzt1sPys16RthRJUr7G0wljUOaDZWgh75WdCJ8nRTstlTlpLLX4gParO2MUe4zHPKQqlOi/BkFC2T468IKiFnUqyWfUrKDvIfHCdl3r57f3cQYUCxJGIyNlqQrCywkBjVVlaAXlVRBJTsDMN+U3lqkr/R9mfCvEGWtHbdvp0ZyahgWTIu8vbgMSaBXtN/vqUSztZQGFCSsREPbfW7tvXnM6zJ3KzYIe0ZrXJw==',X'2efda266ae63e23e6f8721b029563b5841df9001ac6e171da5940962cc5b9b94ed24024a8c5e08f003a82f49c287baf004d960eb9ac713a7641424dd0bca4710bf107bc3cb7244e023ed63fdffc5d32cb95f791a9c43a664cf170c826d158f74e23a256c99e8d835b3102dee45e1e113c31b90787803c2402faf37bb8d1a978c7f05a1713984eb8b3dd10cbaf39be4e1a8825b3e8798086f7d4a97141c8c3c93dc53a02f4b1e868eecb332a17639aa2b69b6cac6e706d93ba1c4338e4381ecfd798c6b532b9363ae2cd5d1d6d53930503486154fdf5438e0340e3101760039211b3c7613d6b3f478da329d27886ec9b4db04f1485255024bf9aab35201563b0c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('AB09AA1A1F20CC75E6836BF82669401D','C52',1,1,'TuJacdEgrX9rf8fbmnACGA4+e9NyDC5c67hWa5DEdY87vMxSKtUYRCMXz4TJsws9ytCNQ8a8Y2NBrxPhW51s7s9X932z/nCNc1WZrE1xuOyTmXP00Nm7Gz50Ct2MM24TP6HW8Uf5Wz8kstm0PXo6+Zup+AUiXLoPuXgNQGxmDKUzFCWwqF5NQMnPDSHfMFPUWQrF9zlDHT3lOzIwKzYl92I5vD3xINhM/cSmT8QtwTT2US08xg8n16UsD+5P7pqbIdtT1QMN8caEfrO7RPrfHQDiLHQnP/OopQNZzi+QIz2nUrh+7R2EksZ25r09JRLm3LTX+Sk2/WTC4YZrGwPSPwLrECG0JM2rwamsUTL0ik99eaY1nRztVrQ16j5r9UX9lofRXCxMIUKtcNpjSJO1NgIIqbj78Y6D4t3OrSTFy6kyqAxlQBc1i5g0dVWJnm0Ob35Vx2aAJKFjstb2EUcNji3fIERYtvthxS1JAgs2QxtTbM7JVtUsAwCz099jaRr5fJICbDvEypyDfMXt//wqzGq4IzaOAjVf1qqTXC8vrRVw0SFI0akl2ADnuK8MIS3F/9/2p5Akk/oynoCux884fBxf2aO58H5UG3ZRLvqG2atOOKpY1Wwq6gh6rQIhkeLFzK40DdwBAVUa/Ys5lYRyPbadOHRDhSEPKHezg7SBpLzKGDUPXJAWa6hBNBwLGtoKKvL2/tbpUkOxyZStfD43tQEpwVbG8agEIHgY4vT0ljUpvOifAo/ZnvX7FHc+wF/G8x5YnMvU7Cih+mqqM5ZUxoEvekSWsUjZ2Hn+jioXmaOtTxlmwBBIjpzkVbn6mNO4T0HbQPEyhe4u2ZRUo3fWneEFnC8gB2mSxLV+uOfazPPhvdLOXTa/BSVtvAPRXYt4f8+ix66Wh/yUj2tB7wWBT7oy0hVEqSDM8D2ytubiutsjHR7JVqXsPcHnTW4DJsrGHvG3/d4ZyhgrH/A/m1ejk+iq86ch9dd7lL+WYPNGF9UZwyuDTqz4sT1MgwSpsJa7qs3KVoojg1wbT/mzgfuNzd1acUDMxgswxX0VtIIXnuQ5UZxnWjUDSr4AV8d5YW2aEMWCWmZI2vP+RTQ+kW+ggqJk0N6tuZn/CDMP0gnY9u0Sj55bCG8OoXbJF2kRktENvMkgTz4u0RU4Tw489UCpeK7itTZPQDDtoNMovkFC+qgJwZlrv7E5/4ksBhNrtdTFlR7aLZiso1DJhZ3BRUFKgQG//p2ME6y4heisAMJ59UH2xmQGNzFuL+q5um7wZc+AyeWIJmly5bV/fX5+6ZyWwaCMPOiDgssWfRwByrVi8TZ+SN+vwuYuaQhuoZLRPyiNps/3HGeUhJl66AsiVIfEjxnxImKUTNnffvN+TaHMfs3Wgek+xW96k9+7XciOqZNF4HVmLVYSv/XiSkqiexotpd9bGP8ia45ZtLbfDg4wV7fKTvJs7/4USgFg0wsgLfuhxMCgwtTlWJiHcTk2yUgYpg==',X'08f1e8421b952def1aa63d676685cb2abdfe9b5506be1ff9840d82f8e009ae911210452b1fef385787e740a656b9e19c82ee7bfc04019c183943c1a8d849566c2936fe2582a88229fc79c7fb715505263411a3c0baec5161f6258619eee3ad4ca3484ba808d0b7420113e7b72ce4601243975dce1ae1ee65ab3186fd557e1e5df11b566697425419efe32319becaed28392043bb8b5978c1fefbf99297b8577476212b74221c7515b6c54eb4022307970421e53d53ad9f7201165476e96e71bf82660cc8342b6da4ae3a9d5e788425cae0b0bba0d538b1c211dec60b0f82d68ff72f483bfef0f55eaae456447c1b324b7a0388a8f54d054d2163591c5d0b7662',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('8C4827C1AC15891A5C169C6F9BC7F08E','C52',1,1,'NlGJYxMRT7DID/daDx0epKzU/RNj2oPwLE77armo89epkY/rQmZ5N/Fma/0NAEL//q1PybW3Wl2DUw04oKCtamMBO9UmnBnUWUXC3lSlyWE3rgXPJGoem/UTZv9vCYHYtC2VIieNgF+psrGCwA/oSVpsybE9CbxdUKBQotkmglSuqjoPYqDgUlVS36Shle8RX3DfZXXi6ZFm+M5kN9FXIdlFYiG397ANzvv+IIPMQg71JRKl3ouH8ol1319lbgvFZLHTxkZi3QYx8AwRvxzXK9LlpPAFSuhOzhdYymwJSAUL6iOeUg/05QPq+8QWqp45wIvaef9+L80t5jTYnUN+Djas+OzaOGDkfY/JcqkOB04QHLf1u6yoq8eqWVNK2iBrL9V8Ycu/leNBwiNj5C/AkHjGohf8lBWADn7YBjAVcdX7I0D4fcnKnvc+uG0ifHVph1WHA9HN1xhugSzZv5bOvB0fP1D9Y9Tnr+Kxlf9Gql/NEVQaIlsZ4YerHDYEYZwBhesUXU3o4O2XvvVwOVsmvSdbwbDMeFfBks66fFdBZWAiXVHh5+gqpnoj+IqZEA5ARmjLRw9/EqWmQTZAlN/p1ujjo1INyJ3Kz57AZFQ053Ep+DMh5caFnQntq6jhp46LpEz7rQMRmniXIF2A4FvY063vgTYXYVGpTYonZXNA67Lc45xolOJcclmKJmbI30uVrei5K+CXsDvhNp4vdJXg7Gz3l0ktRYi+9cnpS839/xtJeN5UYJB75F45+gW+eEncUPqeNjhXz78qP8diBgicXpAyuFLTtvZkFv+RfoyOqgsVwpxn4BbziZoeBQCDUVIKAAO4iEKTjzetmtTU/9b+psziKZYBGfeAJQV9gWT6kHoZ/IwtcOItzkw9lFQHbahUGKbdXQDpZbhTqhIKVNHtaSmSwP0wFMTSDLoqTDFbRDEglwLEUd85cwmVc9LUcn2WApeiFvSVd8Byj6ExeYdahoWQVAna6KnSosaRe3NeEowAt/wN1M4+BYp9H6e/Irn1Z/THfl6mi3CylpNSb8Ix0uvgKyl+e1bHpcJzgwKP0XbKzzf6nL6sM+XlkTo35TcqWWQ/tbyfbYJuw0/ZkMr4D6qnmMvMlpcbjaTA10/o3s1byhgJv/vP0O59skj9yQGvNUM1oqGh357SoiSXC81ntqKtnkJtbXu2c+KR/l1W/LLQBe47bk85mkzzqgfK4NB7ucWtu6eUQs2a39Cz4MZ5ceDu9GBeG0rLasLQBfQCjh0+d7OMXnEiVNXBGqimcc3FkKism0jy+fUJLh1VElV60d2yLgW+/9V8tOn+a3Lb5vPbyHZ3ZyJ0RyxfizZdWWzdIGiFvfD3kaeKJAvFpWok91oWHN+cAa5Ho7EPejqPftMTTuxCVis/JT1nWc1jcisnw2raTDyQ6Z1HYYWpqPkECwMz2bKBMprPhbyXcmujmPlFt0IZmaVuEo30zYg/UjooNivbTqNW3BPU8ljB8kUE6Q==',X'139d2da98475179aa9981799cd7ca288849844fc5bda05d73f9a0715ce612d0e2a10214b3a3ac42fe54ff8f0caec015930515929dfc0cfb25273f68da160404e0bb4472ab7035856b07574a4dfcb8d80d146fbaf2fcbc7e9fa690e00f8ef78cb805f7b854eeed7f2e9e5285786fc0418d75b8887e5ef8b11620fcee9ad4f88905cf2480f844f3344b93a5e0403d3b7db57acbb834a86232145d6e2437d2a8dc9db9e44259b5f53e9b833fe38c597ef7ab13254f807581338021f9da0ea015ce3fa1af46c5b806b120d2d0655e954e8a18300154d31428bf0d53578bce270493744722514a4a2339c136ff5fe2eb48238de19a4ee738ab14220b9be9e1cef9b80',1,4096,0);
-CREATE TABLE EbicsUploadTransactions (transactionID TEXT NOT NULL, orderType TEXT NOT NULL, orderID TEXT NOT NULL, host INT NOT NULL, subscriber INT NOT NULL, numSegments INT NOT NULL, lastSeenSegment INT NOT NULL, transactionKeyEnc BLOB NOT NULL, CONSTRAINT fk_EbicsUploadTransactions_host_id FOREIGN KEY (host) REFERENCES EbicsHosts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_EbicsUploadTransactions_subscriber_id FOREIGN KEY (subscriber) REFERENCES EbicsSubscribers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE EbicsUploadTransactionChunks (transactionID TEXT NOT NULL, chunkIndex INT NOT NULL, chunkContent BLOB NOT NULL);
-CREATE TABLE EbicsOrderSignatures (id INTEGER PRIMARY KEY AUTOINCREMENT, orderID TEXT NOT NULL, orderType TEXT NOT NULL, partnerID TEXT NOT NULL, userID TEXT NOT NULL, signatureAlgorithm TEXT NOT NULL, signatureValue BLOB NOT NULL);
-CREATE TABLE BankAccountFreshTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, "transaction" BIGINT NOT NULL, CONSTRAINT fk_BankAccountFreshTransactions_transaction_id FOREIGN KEY ("transaction") REFERENCES BankAccountTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO BankAccountFreshTransactions VALUES(1,1);
-INSERT INTO BankAccountFreshTransactions VALUES(2,2);
-CREATE TABLE BankAccountReports (id INTEGER PRIMARY KEY AUTOINCREMENT, reportId TEXT NOT NULL, creationTime BIGINT NOT NULL, xmlMessage TEXT NOT NULL, bankAccount INT NOT NULL, CONSTRAINT fk_BankAccountReports_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE BankAccountStatements (id INTEGER PRIMARY KEY AUTOINCREMENT, statementId TEXT NOT NULL, creationTime BIGINT NOT NULL, xmlMessage TEXT NOT NULL, bankAccount INT NOT NULL, balanceClbd TEXT NOT NULL, CONSTRAINT fk_BankAccountStatements_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE TalerWithdrawals (id INTEGER PRIMARY KEY AUTOINCREMENT, wopid BINARY(16) NOT NULL, amount TEXT NOT NULL, selectionDone BOOLEAN DEFAULT 0 NOT NULL, aborted BOOLEAN DEFAULT 0 NOT NULL, confirmationDone BOOLEAN DEFAULT 0 NOT NULL, reservePub TEXT NULL, selectedExchangePayto TEXT NULL, walletBankAccount INT NOT NULL, CONSTRAINT fk_TalerWithdrawals_walletBankAccount_id FOREIGN KEY (walletBankAccount) REFERENCES BankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO TalerWithdrawals VALUES(1,X'5b70ee3b47204404a6ae531967fb66be','8',1,0,1,'Q85DYPJ1ZKMMQ6066DB77KMJGERNNSEV6T7EVF3TXMJ349FGTFGG','payto://iban/SANDBOXX/DE064129?receiver-name=Exchange+Company',9);
-CREATE TABLE DemobankCustomers (id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT NOT NULL, passwordHash TEXT NOT NULL, "name" TEXT NULL);
-INSERT INTO DemobankCustomers VALUES(1,'fortytwo','sha256-salted$Id5JBvbpq88=$9AdJKZ5UXFne2r4c3L6tTl4tyZodwgVLTPigBAnC5js=','Forty Two');
-INSERT INTO DemobankCustomers VALUES(2,'fortythree','sha256-salted$Hsr7AxzS3TM=$cqL1EVWGADKHnKSl/KeBrgo7REEFk7qKvAN6ltw8p0U=','Forty Three');
-INSERT INTO DemobankCustomers VALUES(3,'exchange','sha256-salted$hEzlwT9plIw=$goi3TAD0K2yuptsTb3ly16eOkjhMDjl8lYW7VBN3k64=','Exchange Company');
-INSERT INTO DemobankCustomers VALUES(4,'tor','sha256-salted$O31VBRz/MJU=$OQGLkOJMIl8FXatxK4AX0j+HYSwqyhuIPpFYKx8qqAM=','Tor Project');
-INSERT INTO DemobankCustomers VALUES(5,'gnunet','sha256-salted$Iz6Hl2JbEtQ=$FETDUYgT3g3MUr0UC8roFFlixKclWKBvdzRjROFP2rU=','GNUnet');
-INSERT INTO DemobankCustomers VALUES(6,'tutorial','sha256-salted$fwgje2Mqg98=$FBVQEVwMb85VTjUvpu+/G+ccNdAGlwzRMHOmk317dTQ=','Tutorial');
-INSERT INTO DemobankCustomers VALUES(7,'survey','sha256-salted$Mr3E8PWXjlg=$84n6ewGs/FxhvFfDsDjlTL2doy0wD3c+8QEvw+GROTA=','Survey');
-INSERT INTO DemobankCustomers VALUES(8,'testuser-9oiyqxiw','sha256-salted$LvjFt0f2TXA=$L/njE1Jp8CFyBJZsxIR+2XImBbHgLqWthnpC307cLd8=',NULL);
-CREATE TABLE NexusScheduledTasks (id INTEGER PRIMARY KEY AUTOINCREMENT, resourceType TEXT NOT NULL, resourceId TEXT NOT NULL, taskName TEXT NOT NULL, taskType TEXT NOT NULL, taskCronspec TEXT NOT NULL, taskParams TEXT NOT NULL, nextScheduledExecutionSec BIGINT NULL, lastScheduledExecutionSec BIGINT NULL);
-INSERT INTO NexusScheduledTasks VALUES(1,'bank-account','exchange-nexus','exchange-payments','submit','* * *',replace('{\n "rangeType" : null,\n "level" : null\n}','\n',char(10)),1660252041,1660252039);
-INSERT INTO NexusScheduledTasks VALUES(2,'bank-account','exchange-nexus','exchange-history','fetch','* * *',replace('{\n "rangeType" : "latest",\n "level" : "report"\n}','\n',char(10)),1660252041,1660252039);
-CREATE TABLE NexusUsers (id INTEGER PRIMARY KEY AUTOINCREMENT, username TEXT NOT NULL, password TEXT NOT NULL, superuser BOOLEAN NOT NULL);
-INSERT INTO NexusUsers VALUES(1,'exchange','sha256-salted$qiiUAJRkeO8=$JMlhXyDvcvuLlYsfau72OgeVUHVJgW+vWIpFgtmuEDI=',1);
-CREATE TABLE NexusBankConnections (id INTEGER PRIMARY KEY AUTOINCREMENT, connectionId TEXT NOT NULL, "type" TEXT NOT NULL, "user" BIGINT NOT NULL, CONSTRAINT fk_NexusBankConnections_user_id FOREIGN KEY ("user") REFERENCES NexusUsers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankConnections VALUES(1,'talerconn','ebics',1);
-CREATE TABLE NexusBankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccountId TEXT NOT NULL, accountHolder TEXT NOT NULL, iban TEXT NOT NULL, bankCode TEXT NOT NULL, defaultBankConnection BIGINT NULL, lastStatementCreationTimestamp BIGINT NULL, lastReportCreationTimestamp BIGINT NULL, lastNotificationCreationTimestamp BIGINT NULL, highestSeenBankMessageSerialId BIGINT NOT NULL, pain001counter BIGINT DEFAULT 1 NOT NULL, CONSTRAINT fk_NexusBankAccounts_defaultBankConnection_id FOREIGN KEY (defaultBankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankAccounts VALUES(1,'exchange-nexus','Account Holder','DE064129','SANDBOXX',1,NULL,NULL,NULL,30,1);
-CREATE TABLE NexusBankTransactions (id INTEGER PRIMARY KEY AUTOINCREMENT, accountTransactionId TEXT NOT NULL, bankAccount BIGINT NOT NULL, creditDebitIndicator TEXT NOT NULL, currency TEXT NOT NULL, amount TEXT NOT NULL, status VARCHAR(16) NOT NULL, updatedBy BIGINT NULL, transactionJson TEXT NOT NULL, CONSTRAINT fk_NexusBankTransactions_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_NexusBankTransactions_updatedBy_id FOREIGN KEY (updatedBy) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankTransactions VALUES(1,'AcctSvcrRef:3OCNEK2S',1,'CRDT','TESTKUDOS','8','BOOK',NULL,replace('{\n "amount" : "TESTKUDOS:8",\n "creditDebitIndicator" : "CRDT",\n "status" : "BOOK",\n "bankTransactionCode" : "PMNT-ICDT-ESCT",\n "valueDate" : "2022-08-11Z",\n "bookingDate" : "2022-08-11Z",\n "accountServicerRef" : "3OCNEK2S",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:8",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE496362"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "Q85DYPJ1ZKMMQ6066DB77KMJGERNNSEV6T7EVF3TXMJ349FGTFGG"\n }\n } ]\n } ]\n}','\n',char(10)));
-CREATE TABLE PaymentInitiations (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccount BIGINT NOT NULL, preparationDate BIGINT NOT NULL, submissionDate BIGINT NULL, "sum" DECIMAL(20, 2) NOT NULL, currency TEXT NOT NULL, endToEndId TEXT NOT NULL, paymentInformationId TEXT NOT NULL, instructionId TEXT NOT NULL, subject TEXT NOT NULL, creditorIban TEXT NOT NULL, creditorBic TEXT NULL, creditorName TEXT NOT NULL, submitted BOOLEAN DEFAULT 0 NOT NULL, messageId TEXT NOT NULL, rawConfirmation BIGINT NULL, CONSTRAINT fk_PaymentInitiations_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_PaymentInitiations_rawConfirmation_id FOREIGN KEY (rawConfirmation) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE NexusEbicsSubscribers (id INTEGER PRIMARY KEY AUTOINCREMENT, ebicsURL TEXT NOT NULL, hostID TEXT NOT NULL, partnerID TEXT NOT NULL, userID TEXT NOT NULL, systemID TEXT NULL, signaturePrivateKey BLOB NOT NULL, encryptionPrivateKey BLOB NOT NULL, authenticationPrivateKey BLOB NOT NULL, bankEncryptionPublicKey BLOB NULL, bankAuthenticationPublicKey BLOB NULL, nexusBankConnection BIGINT NOT NULL, ebicsIniState VARCHAR(16) NOT NULL, ebicsHiaState VARCHAR(16) NOT NULL, CONSTRAINT fk_NexusEbicsSubscribers_nexusBankConnection_id FOREIGN KEY (nexusBankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusEbicsSubscribers VALUES(1,'http://localhost:18082/ebicsweb','talerebics','talerpartner','exchangeebics',NULL,X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100bbb5f6d9010223796047d129b97dd2ec8a3efffde972e3b0d0bb1ac73b229404715a04d9005bff9130c25b2a1badd7f7d5d847aea43a6436259ec6ba59de6416fcc5eb0b3df939fa5fbe3f327061450c6e9e9329d92e393eda311984fae771d3110f7fb6536fc6dec6c60561232815fc9f752af9b0cb5453a3a79db648537875648d8c5dc3f09f2b8c0ea2fdb2f178fb6fcb327ac279afb43b0236e6fca7fa4d711f895c3385e4b406e6ddeabbca99673de51bf33fd4b7e4406d61fbf3fd31cf1532233064a8376049adffaed07a54c42de502d9c630cbbd77b17b8b3d44f1baf4a9c2495f17cb780b07cdcf8f4be84b9911994758a22eb623ad88edac5b18b902030100010282010100b15efd350a8de1c564641851ebf3e826196ff467127bbc892c83508767ea81a13d16c9b3df720f293bc0bb722b9b7692ba5fd7443fece91a7d2bee2ed292a1535361157b9700f47710976d9214bce5091d51fc4f33e848b18a6d90e6a64ba2b3c5d03666abaad86953bc7402d8bc9d220bef243fb27e3f5d952be28c0705d0b0c67ff78272584c1ab5f4fb6a59685d7db073eef4897a165095898edb2321061058145966163fb01c161187f73a83f3395d630a7ec513cf06d914ba727a566b50105bc323a393c100b134e76c486782e4d1af4aa7cc3bc6266d9bdd3b52bc6aa2d0098fc17096726bfc7c05745dd9636603cdb39a94022de239184aac562b237d02818100e085c11c74742c4db9e876f25ed7af5b9980bdffc2f89d1824b3b6dad01ff1c392ddbf3fe8c19223c618f41d8641e21aeb3f400e7509809e198058cf21122d4eea71306f9ffab5a3353e0e3a8ec319eff80251e8e5cd6ffd871239166def43945d6e4616d8d2b6de7e84cc13400c1b59a268e4886c3f5333306dfefe82e8e9b302818100d6070449f04456613775b9285da27ac3011facfc1b31d184c8f2c9ba30c5a816c9c10dc28e08dd7f1bef88be25b78dddecadefe4f1581b679a665f336084553ce39f566c7ddbb9bc0ba5699e17acc1e4fcd328a11d06a3384ca65774aa543f97c0e35c0a2d1c410886177e1924aef7e72a38e94b76067d7493a32238693f25e302818023087bd366d061c1570ad0d48cbbf6dec21af68a9bef93039b667757b935e2d1736f2a525c8d27b2714c9f7aa3e24fd787717d1b4463d12fda26ceb4b32254f3855d580372e0f9ca979a313a2de07f81941f388cb09ed7a4a598d053919fcdd9aea270494c57c4b4fee4d5bb0339606322165fe2719187f7eacc9f073382084502818017bc47797bafd874879602a6bb5b9d89aac23c88e8eb29753463d883518d5a0acced1ffd878aec25808f9bf69a7034c77bcbfe62c17127f8e162a1042d9bff67f546626b3db9f46b2a4f79db127d1233b6e624075a14b65d3402ee87fdabc231ae2e88b288362df0280ecae936ec4089de60d95e8904473d7a7209058086844902818100aa420a12d57f21b7431e94fc05490ea9980541fe77d8c0f49d8a60660d2126ea24d250b49921ec0417067664df8fea169d706afbc168154b722d74d918c773a799fb442da16668de342ff6add1107093a40d9ec48de9a49e3f7f9a85d37893e570e49cf16ff05f46e80ceddb9770a5bf62ee9afc1c6010f44da03191616d83da',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100d037ad2bcea58add86b77a7c1073bb5732006a7154b5b2e93a3798c49d6e4ed8df7e013ea665b8dea0a90adc1ba54d661b83487300d452bf3fce101738404edd057689f096ff554011aba727e986a635706e10d0c78efd71493d62a21c0f6181979dbe8ef49e0506d6e4f6f4d9163db01873457140ca60e3d56bba1a18b188c4cb92cd5282d1154bf91f878110d6c6e3affbfb3478791a2d9431455cef9e0a8d2eb7af155a5ff16e0ae0937f4212acf61aaaed08ffd5c987b7862b64c01bda71ad91d9341111de96ff15138685d2bb07c199e3cbe4d80c35db4d889b7d0a6c8bad1b09281a6c866a6d77a50610547339126e03acd09d9b1939f858d97270cb9d020301000102820101008a0b7fba3d852f6df3750db5d74a837829e470adb695c88a2c58d3e5f6e23d5037cc5892eacb222827a82b5506d72f5b74fe33385be26901f7116d4597bbbb0d7a23bf0c4d6ff75b44dbe334e8f4a6996372f59f15cf4d64a0441c7291dbf8af6c8fded8f48117a01335362ddb078dda843b585cdfb1cd4f001e2e024340e105355ffa2278472e7ab011daa27ccfa15f2cba4f93fc2ca66408b0bf67d9d57ea960e289e2555343955cf530d96997bdd3a9efa530e6d126d12cd46ba08234922409f02cdcce95e58104288bb2c3ebaa3da1162f09ca510e8d4e7308975ab5e84626f09aecefe5b17466926317d3c46afbac9fbd13eea95ec196719ed9e890e34102818100f8a05f5826aef9638df30d0c62f53df2cd9da71ed5c9ebafa0acb1433b8705b0af08a705d67ca14bc6c4de33ea0164b70c06b3af41c73cfb082625fd959bac13519eceef7ca490306a79e8fc88d0a13789694a578a44edd7f3f77ba466651d4d623d358892fd29b6c663c1444faaaf8ac7bd8b0e9784cefb49382010cadc2e9502818100d6648295bfa2f274286782a4b672700082408fa62fe55c0b2905db422644018e876a0ea47d266a655be870492046e0b1ecfacabbef83359b97ed9050a903f7b0566ef0c92c3b51c6f90a73af2b0252e2c257b266921b27e5cc77a6c96b4ac81ba42ea3c8c1561100c3c72e163f864a8850b9dd4fb5c5a7bf3760002781354ee9028180267f8ec3f3997c7c71ea84c6ba3c074fa58f17e5aa6d0dd5b0278d7b3fa874b51b2557d78b92d8d706fc4cfbf4ec2a503dc87be253692a84248ae3af148f7a61b36dc7d54593a5d0196caf2b0b7462c25ac0b7063f1ed5456f3d8f23b1c74e764114014a1898a2f0ee5f5bf9dbec2e2a6b2b6a70e3fd689f7882fc541d5562d102818100a1c5fdf359436f87cee52c6375782ca375a599bf60ecc4e376f500598dde4afe6d97cdacb8f2bfddf3d814c25924a2701fcdae24d9ba3c3d480aee96aeb25bb827c056d8b6139cc5732e3bd4b5b36f2fc44dc0443d83583bc26996e4ed9ce41a576d0a117631a76ad84ff7aaba0c6f392510daba4702fa6d032fe16dedc577e10281803cd6b77128cb34e05b7d343f43c2e7ecbf6afeb031224eff018973a23849c74b34e428aaa4b72d098103cd8d0e2b1aa0b996ec5a4a5e93552ba12b6fa8217c5e9d7932bede8b18fe770b9324cb084f47645595459653def3057927a58729b77c2dd86a93a92ee1ef657ba5427011df9c83995d7534093c9d69dd398320a39753',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100998d7bef44b3642dcb7bd17ca5903e090da9ca3cfbda972dbaab97c0d63aa6f8b9ad5f203f517ba654894a14a629194462e62657fbc46212bc6aa3f215e90604047f683307772c4e512a82539a534774395368bf23997b29ad4091454c1c880682d140396f49808bbe924c23629d14b01678a16f0211d7c38e15192d6e9df26bc20e311868bde1972bd7391749798ae4c470a03cc75c338f369fd8894b5946a1c20860aed64a408e53248ab56e240bc95cc2ced2aef4fcef469529bd1df45ddb18073e7fc9cabc637cf141f5fc1e8d9af5d2bd23b5e0cb558de1df628c3a88d48230e43565483adc85657045d5fbe9ba9c4299cad0482f0fe02bd86caf148395020301000102820101009012ab4d55c587e25c01420e54fde0e6f7b5eeb6878c92ba6a62a41160304a0827975f20cfa8317f5fe42ce8f0fab0e57472035a1c3527dbf283906e0d56c5b9314b25c67363c2e37cce88d7ce7e03162ecf6f01a0725a984121caec1d3ccbf867f7d3edcfd8444f5a30c455932a5585de9fb2c0884d9b87b5a1602d3b93e126fc2a31306efbf59718837decd44a29c4e4e902bcdd4222718761143b81b7c4b82dde272c4a12bb57cd160d3eaddc811899b2c03d77a576ee429f0408ab7dc9669fcd8408b972780770713c9888fa1eadab8e8c1a9df0941374fe17651dc5c9c4580cbb50b832fede6931a8c33f8fbd84b326be52f0816099bcc420b161f2eca102818100c84fc518b67f8586614b7025a107b3c67d434f11746ab4d2761f6efc177e966e1d5cff5883ebe9c74fcbcf226b638ac1f21dbfa5a07e68cd2eea240f13264359ab46cd65a02038c860f8e54666390d3b105f80627632189cda671bbcb3f32aa7502d8d14e3babc117d74ed6f5c7ba1846080971cda56e2663701f06fa52428e902818100c43dde67c8bd6d4047cf79069092a78c978b461cbd83622ffa56ac6f6e8010dbf59bf5a322d97b1964954b26ebbdbb4376a333e72709f654fc43c04276705824f47374d5e9ca03dee266022533c230c76f3288bb984dca7f5820ca9eceedb92f0c7b3c317b4366ffa75b5c2db8bfa775ca56707f7eee849b844fbf751b7919cd02818056ae6e542b65339adb2f91f036a6e69cd647f247536179ae397f90bf764b493d8d6758f82cde41e4061be41eb8e9f279cb142482bfd8f3f116842be67a1aecba38ec02a61f8cd205a43110c64e26121ba5122eb46d0170b52fadbecb01f4105926d10f6422c803ea6da7d3b78505daf735eb6f7904e2e445e737e79be892a54102818100b1fcef68b06066e3c37e00e61c60778903b6357c41c3155e30af462cb74b7e7f1230474594892ea6645d28517fc591406a2d32193886479ee342cbf13c1d3f451d564ea4ea2be900d1d4f5a32a63b9fc58f5bba0724e3418f6249fc2142af7281e28f3fa6933440b228eb17762b6a9bb232eed50261f4db503f794ce3181d00d0281804dd758d3d8736fea217a9d8b8fc0b0ab8b863e28a90965c7d1cff405019e6730878003cebe10edfadc91860b102329e784c75d7d09d912c4afdeadb4ea00cd755f816a4ce92b0d78455d188d81ed4aa56079f84a496963b0ed5adc22353f4c59b3d1b46991dc239bddf432dd776a0761056bcce03c83b2e3c10de75d92dfead0',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100df078e3d7cf57ef95d249b74ae45fbbb95b84d28ac454d97e7acfb6015f0b974a5aa770a31c77045c480676218de2b96a6dd167cac16f67d41d4e35dd73c1d09cb60b651e18bb6e755273b8b15025491bfd8271e1be6cb4d43702688258fe59b698e1dc172383d13271b4e6e4502b292267e4fe1108cb982d64e882f8c797c537f77c0500ad1683319ee9f8e228ac64ac6499cca275a3c03811b201e8a2bcc3c69a48dcf9efabc8c364b4e585201e15dae4ceda5912d523bc6df83f21bcffb26626aca844e89b0b025ed2110dd07b9992c20cf989ed1f0cd687d355bc9027e113857b52fa1263162855b20483a389bb0da6e5d90f4f38b6536d8450680cdf7a50203010001',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100cd3484cbdd418f6bcf52207824a6af5750333f1ca7d924ba3143474385e69bb98d8fd20a8dd98012cdeec6570134bb0477d3338ff657c5a7af4312a869fa4a5e9d2a37f41c0d4a5cb1719eee25d2e22ee79533461eaee44fe8e6384a55ea7b33c438bb6d8b599c793bdcf3e6177b5fc1ab44cc2eaf9bcd8d2fa7b115a84d5b81bceb20ec053aa2d58c0e5363f941509dd7bf7d2a1412ded0bf1c977bc8d6d85b315cbd7ccf845d74512ea88e61da3f4f772001f7d64d90871ca803c0b29e64d66aa986aa4334cf5a65b0923f7ab49591c00cc0b7ca62f9d32fffb8066fa08ec873df7fcbd501019bfcec1cc6740f5ef60618f6c35351372e14af90a97c4ed3330203010001',1,'SENT','SENT');
-CREATE TABLE NexusBankBalances (id INTEGER PRIMARY KEY AUTOINCREMENT, balance TEXT NOT NULL, creditDebitIndicator TEXT NOT NULL, bankAccount BIGINT NOT NULL, "date" TEXT NOT NULL, CONSTRAINT fk_NexusBankBalances_bankAccount_id FOREIGN KEY (bankAccount) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE AnastasisIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, subject TEXT NOT NULL, timestampMs BIGINT NOT NULL, incomingPaytoUri TEXT NOT NULL, CONSTRAINT fk_AnastasisIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE TalerIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, reservePublicKey TEXT NOT NULL, timestampMs BIGINT NOT NULL, incomingPaytoUri TEXT NOT NULL, CONSTRAINT fk_TalerIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO TalerIncomingPayments VALUES(1,1,'Q85DYPJ1ZKMMQ6066DB77KMJGERNNSEV6T7EVF3TXMJ349FGTFGG',1660251988156,'payto://iban/SANDBOXX/DE496362?receiver-name=Name+unknown');
-CREATE TABLE Facades (id INTEGER PRIMARY KEY AUTOINCREMENT, facadeName TEXT NOT NULL, "type" TEXT NOT NULL, creator BIGINT NOT NULL, CONSTRAINT fk_Facades_creator_id FOREIGN KEY (creator) REFERENCES NexusUsers(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO Facades VALUES(1,'test-facade','taler-wire-gateway',1);
-CREATE TABLE TalerRequestedPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, facade BIGINT NOT NULL, payment BIGINT NOT NULL, requestUid TEXT NOT NULL, amount TEXT NOT NULL, exchangeBaseUrl TEXT NOT NULL, wtid TEXT NOT NULL, creditAccount TEXT NOT NULL, CONSTRAINT fk_TalerRequestedPayments_facade_id FOREIGN KEY (facade) REFERENCES Facades(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_TalerRequestedPayments_payment_id FOREIGN KEY (payment) REFERENCES PaymentInitiations(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE FacadeState (id INTEGER PRIMARY KEY AUTOINCREMENT, bankAccount TEXT NOT NULL, bankConnection TEXT NOT NULL, currency TEXT NOT NULL, reserveTransferLevel TEXT NOT NULL, facade BIGINT NOT NULL, highestSeenMessageSerialId BIGINT DEFAULT 0 NOT NULL, CONSTRAINT fk_FacadeState_facade_id FOREIGN KEY (facade) REFERENCES Facades(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO FacadeState VALUES(1,'exchange-nexus','talerconn','TESTKUDOS','UNUSED',1,1);
-CREATE TABLE TalerInvalidIncomingPayments (id INTEGER PRIMARY KEY AUTOINCREMENT, payment BIGINT NOT NULL, timestampMs BIGINT NOT NULL, refunded BOOLEAN DEFAULT 0 NOT NULL, CONSTRAINT fk_TalerInvalidIncomingPayments_payment_id FOREIGN KEY (payment) REFERENCES NexusBankTransactions(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-CREATE TABLE NexusBankMessages (id INTEGER PRIMARY KEY AUTOINCREMENT, bankConnection BIGINT NOT NULL, messageId TEXT NOT NULL, code TEXT NOT NULL, message BLOB NOT NULL, errors BOOLEAN DEFAULT 0 NOT NULL, CONSTRAINT fk_NexusBankMessages_bankConnection_id FOREIGN KEY (bankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO NexusBankMessages VALUES(1,1,'sandbox-1660251976629','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313937363632393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a31362e3632393330385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a31362e3632393330385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(2,1,'sandbox-1660251978999','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313937383939393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a31382e3939393639365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a31382e3939393639365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(3,1,'sandbox-1660251981244','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313938313234343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32312e3234343436395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32312e3234343436395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(4,1,'sandbox-1660251983477','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313938333437373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32332e3437373632335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32332e3437373632335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(5,1,'sandbox-1660251985695','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313938353639353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32352e3639353832325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32352e3639353832325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(6,1,'sandbox-1660251987891','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313938373839313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32372e3839313437315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a32372e3839313437315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(7,1,'sandbox-1660251990234','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313939303233343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33302e3233343134325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33302e3233343134325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(8,1,'sandbox-1660251992399','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313939323339393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33322e3339393137375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33322e3339393137375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(9,1,'sandbox-1660251994580','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313939343538303c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33342e3538303235335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33342e3538303235335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(10,1,'sandbox-1660251996781','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313939363738313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33362e3738313137385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33362e3738313137385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(11,1,'sandbox-1660251998953','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235313939383935333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33382e3935333130355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a33382e3935333130355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(12,1,'sandbox-1660252001118','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323030313131383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34312e3131383431375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34312e3131383431375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(13,1,'sandbox-1660252003275','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323030333237353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34332e3237353634315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34332e3237353634315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(14,1,'sandbox-1660252005442','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323030353434323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34352e3434323637345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34352e3434323637345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(15,1,'sandbox-1660252007609','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323030373630393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34372e3630393434395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34372e3630393434395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(16,1,'sandbox-1660252009768','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323030393736383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34392e3736383638325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a34392e3736383638325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(17,1,'sandbox-1660252011923','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323031313932333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35312e3932333035315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35312e3932333035315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(18,1,'sandbox-1660252014075','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323031343037353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35342e3037353038345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35342e3037353038345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(19,1,'sandbox-1660252016223','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323031363232333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35362e3232333734385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35362e3232333734385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(20,1,'sandbox-1660252018367','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323031383336373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35382e3336373030365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30363a35382e3336373030365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(21,1,'sandbox-1660252020509','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323032303530393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30302e3530393337375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30302e3530393337375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(22,1,'sandbox-1660252022681','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323032323638313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30322e3638313333345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30322e3638313333345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(23,1,'sandbox-1660252024824','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323032343832343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30342e3832343631365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30342e3832343631365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(24,1,'sandbox-1660252026963','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323032363936333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30362e3936333033375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30362e3936333033375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(25,1,'sandbox-1660252029101','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323032393130313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30392e3130313732335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a30392e3130313732335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(26,1,'sandbox-1660252031238','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323033313233383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31312e3233383338345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31312e3233383338345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(27,1,'sandbox-1660252033377','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323033333337373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31332e33373738345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31332e33373738345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(28,1,'sandbox-1660252035513','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323033353531333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31352e3531333839355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31352e3531333839355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(29,1,'sandbox-1660252037639','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323033373633393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31372e3633393235395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31372e3633393235395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(30,1,'sandbox-1660252039781','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303235323033393738313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31392e37383136335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31315432313a30373a31392e37383136335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453036343132393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31315a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e334f434e454b32533c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453439363336323c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e5138354459504a315a4b4d4d5136303636444237374b4d4a4745524e4e5345563654374556463354584d4a3334394647544647473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-CREATE TABLE OfferedBankAccounts (id INTEGER PRIMARY KEY AUTOINCREMENT, offeredAccountId TEXT NOT NULL, bankConnection BIGINT NOT NULL, iban TEXT NOT NULL, bankCode TEXT NOT NULL, holderName TEXT NOT NULL, imported BIGINT NULL, CONSTRAINT fk_OfferedBankAccounts_bankConnection_id FOREIGN KEY (bankConnection) REFERENCES NexusBankConnections(id) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT fk_OfferedBankAccounts_imported_id FOREIGN KEY (imported) REFERENCES NexusBankAccounts(id) ON DELETE RESTRICT ON UPDATE RESTRICT);
-INSERT INTO OfferedBankAccounts VALUES(1,'exchange',1,'DE064129','SANDBOXX','Account Holder',1);
-CREATE TABLE NexusPermissions (id INTEGER PRIMARY KEY AUTOINCREMENT, resourceType TEXT NOT NULL, resourceId TEXT NOT NULL, subjectType TEXT NOT NULL, subjectName TEXT NOT NULL, permissionName TEXT NOT NULL);
-DELETE FROM sqlite_sequence;
-INSERT INTO sqlite_sequence VALUES('DemobankConfigs',1);
-INSERT INTO sqlite_sequence VALUES('BankAccounts',9);
-INSERT INTO sqlite_sequence VALUES('DemobankCustomers',8);
-INSERT INTO sqlite_sequence VALUES('EbicsHosts',1);
-INSERT INTO sqlite_sequence VALUES('EbicsSubscribers',1);
-INSERT INTO sqlite_sequence VALUES('NexusUsers',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankConnections',1);
-INSERT INTO sqlite_sequence VALUES('NexusEbicsSubscribers',1);
-INSERT INTO sqlite_sequence VALUES('EbicsSubscriberPublicKeys',3);
-INSERT INTO sqlite_sequence VALUES('OfferedBankAccounts',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankAccounts',1);
-INSERT INTO sqlite_sequence VALUES('NexusScheduledTasks',2);
-INSERT INTO sqlite_sequence VALUES('Facades',1);
-INSERT INTO sqlite_sequence VALUES('FacadeState',1);
-INSERT INTO sqlite_sequence VALUES('NexusBankMessages',30);
-INSERT INTO sqlite_sequence VALUES('TalerWithdrawals',1);
-INSERT INTO sqlite_sequence VALUES('BankAccountTransactions',2);
-INSERT INTO sqlite_sequence VALUES('BankAccountFreshTransactions',2);
-INSERT INTO sqlite_sequence VALUES('NexusBankTransactions',1);
-INSERT INTO sqlite_sequence VALUES('TalerIncomingPayments',1);
-CREATE UNIQUE INDEX accountLabelIndex ON BankAccounts (label);
-CREATE UNIQUE INDEX NexusBankAccounts_bankAccountId ON NexusBankAccounts (bankAccountId);
-CREATE UNIQUE INDEX Facades_facadeName ON Facades (facadeName);
-CREATE UNIQUE INDEX OfferedBankAccounts_offeredAccountId_bankConnection ON OfferedBankAccounts (offeredAccountId, bankConnection);
-CREATE UNIQUE INDEX NexusPermissions_resourceType_resourceId_subjectType_subjectName_permissionName ON NexusPermissions (resourceType, resourceId, subjectType, subjectName, permissionName);
-COMMIT;
diff --git a/src/auditor/revoke-basedb.age b/src/auditor/revoke-basedb.age
deleted file mode 100644
index a3d92fa3b..000000000
--- a/src/auditor/revoke-basedb.age
+++ /dev/null
@@ -1 +0,0 @@
-1660252041
diff --git a/src/auditor/revoke-basedb.conf b/src/auditor/revoke-basedb.conf
index ebe5087d2..706f97347 100644
--- a/src/auditor/revoke-basedb.conf
+++ b/src/auditor/revoke-basedb.conf
@@ -9,7 +9,7 @@ enable_debit = yes
enable_credit = yes
[exchange-accountcredentials-1]
-WIRE_GATEWAY_URL = "http://localhost:8082/facades/test-facade/taler-wire-gateway/"
+WIRE_GATEWAY_URL = "http://localhost:8082/accounts/exchange/taler-wire-gateway/"
WIRE_GATEWAY_AUTH_METHOD = basic
USERNAME = exchange
PASSWORD = x
@@ -18,17 +18,17 @@ PASSWORD = x
WIREFEE_BASE_DIR = ${PWD}/wirefees/
[auditordb-postgres]
-CONFIG = postgres:///taler-auditor-test
+CONFIG = postgres:///revoke-basedb
[exchangedb-postgres]
-CONFIG = postgres:///taler-auditor-test
+CONFIG = postgres:///revoke-basedb
[taler]
CURRENCY = TESTKUDOS
CURRENCY_ROUND_UNIT = TESTKUDOS:0.01
[bank]
-DATABASE = postgres:///taler-auditor-test
+DATABASE = postgres:///revoke-basedb
MAX_DEBT = TESTKUDOS:50.0
MAX_DEBT_BANK = TESTKUDOS:100000.0
HTTP_PORT = 8082
diff --git a/src/auditor/revoke-basedb.mpub b/src/auditor/revoke-basedb.mpub
deleted file mode 100644
index 4f647cea0..000000000
--- a/src/auditor/revoke-basedb.mpub
+++ /dev/null
@@ -1 +0,0 @@
-QKEQ98KRJ7RGKBZ2FSW0S0Y07G1AVJMBDHPZ23098JC5731MNYY0
diff --git a/src/auditor/revoke-basedb.sql b/src/auditor/revoke-basedb.sql
deleted file mode 100644
index 97af658ca..000000000
--- a/src/auditor/revoke-basedb.sql
+++ /dev/null
@@ -1,16039 +0,0 @@
---
--- PostgreSQL database dump
---
-
--- 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;
-SET idle_in_transaction_session_timeout = 0;
-SET client_encoding = 'UTF8';
-SET standard_conforming_strings = on;
-SELECT pg_catalog.set_config('search_path', '', false);
-SET check_function_bodies = false;
-SET xmloption = content;
-SET client_min_messages = warning;
-SET row_security = off;
-
---
--- Name: _v; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA _v;
-
-
---
--- Name: SCHEMA _v; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA _v IS 'Schema for versioning data and functionality.';
-
-
---
--- Name: auditor; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA auditor;
-
-
---
--- Name: SCHEMA auditor; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA auditor IS 'taler-auditor data';
-
-
---
--- Name: exchange; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA exchange;
-
-
---
--- Name: SCHEMA exchange; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA exchange IS 'taler-exchange data';
-
-
---
--- Name: merchant; Type: SCHEMA; Schema: -; Owner: -
---
-
-CREATE SCHEMA merchant;
-
-
---
--- Name: SCHEMA merchant; Type: COMMENT; Schema: -; Owner: -
---
-
-COMMENT ON SCHEMA merchant IS 'taler-merchant data';
-
-
---
--- Name: assert_patch_is_applied(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_patch_is_applied(in_patch_name text) RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- t_text TEXT;
-BEGIN
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_patch_name;
- IF NOT FOUND THEN
- RAISE EXCEPTION 'Patch % is not applied!', in_patch_name;
- END IF;
- RETURN format('Patch %s is applied.', in_patch_name);
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_patch_is_applied(in_patch_name text); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_patch_is_applied(in_patch_name text) IS 'Function that can be used to make sure that patch has been applied.';
-
-
---
--- Name: assert_user_is_not_superuser(); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_not_superuser() RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- v_super bool;
-BEGIN
- SELECT usesuper INTO v_super FROM pg_user WHERE usename = current_user;
- IF v_super THEN
- RAISE EXCEPTION 'Current user is superuser - cannot continue.';
- END IF;
- RETURN 'assert_user_is_not_superuser: OK';
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_not_superuser(); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_not_superuser() IS 'Function that can be used to make sure that patch is being applied using normal (not superuser) account.';
-
-
---
--- Name: assert_user_is_one_of(text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_one_of(VARIADIC p_acceptable_users text[]) RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
-BEGIN
- IF current_user = any( p_acceptable_users ) THEN
- RETURN 'assert_user_is_one_of: OK';
- END IF;
- RAISE EXCEPTION 'User is not one of: % - cannot continue.', p_acceptable_users;
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_one_of(VARIADIC p_acceptable_users text[]); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_one_of(VARIADIC p_acceptable_users text[]) IS 'Function that can be used to make sure that patch is being applied by one of defined users.';
-
-
---
--- Name: assert_user_is_superuser(); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.assert_user_is_superuser() RETURNS text
- LANGUAGE plpgsql
- AS $$
-DECLARE
- v_super bool;
-BEGIN
- SELECT usesuper INTO v_super FROM pg_user WHERE usename = current_user;
- IF v_super THEN
- RETURN 'assert_user_is_superuser: OK';
- END IF;
- RAISE EXCEPTION 'Current user is not superuser - cannot continue.';
-END;
-$$;
-
-
---
--- Name: FUNCTION assert_user_is_superuser(); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.assert_user_is_superuser() IS 'Function that can be used to make sure that patch is being applied using superuser account.';
-
-
---
--- Name: register_patch(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(text) RETURNS SETOF integer
- LANGUAGE sql
- AS $_$
- SELECT _v.register_patch( $1, NULL, NULL );
-$_$;
-
-
---
--- Name: FUNCTION register_patch(text); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(text) IS 'Wrapper to allow registration of patches without requirements and conflicts.';
-
-
---
--- Name: register_patch(text, text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(text, text[]) RETURNS SETOF integer
- LANGUAGE sql
- AS $_$
- SELECT _v.register_patch( $1, $2, NULL );
-$_$;
-
-
---
--- Name: FUNCTION register_patch(text, text[]); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(text, text[]) IS 'Wrapper to allow registration of patches without conflicts.';
-
-
---
--- Name: register_patch(text, text[], text[]); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer) RETURNS SETOF integer
- LANGUAGE plpgsql
- AS $$
-DECLARE
- t_text TEXT;
- t_text_a TEXT[];
- i INT4;
-BEGIN
- -- Thanks to this we know only one patch will be applied at a time
- LOCK TABLE _v.patches IN EXCLUSIVE MODE;
-
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_patch_name;
- IF FOUND THEN
- RAISE EXCEPTION 'Patch % is already applied!', in_patch_name;
- END IF;
-
- t_text_a := ARRAY( SELECT patch_name FROM _v.patches WHERE patch_name = any( in_conflicts ) );
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Versioning patches conflict. Conflicting patche(s) installed: %.', array_to_string( t_text_a, ', ' );
- END IF;
-
- IF array_upper( in_requirements, 1 ) IS NOT NULL THEN
- t_text_a := '{}';
- FOR i IN array_lower( in_requirements, 1 ) .. array_upper( in_requirements, 1 ) LOOP
- SELECT patch_name INTO t_text FROM _v.patches WHERE patch_name = in_requirements[i];
- IF NOT FOUND THEN
- t_text_a := t_text_a || in_requirements[i];
- END IF;
- END LOOP;
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Missing prerequisite(s): %.', array_to_string( t_text_a, ', ' );
- END IF;
- END IF;
-
- INSERT INTO _v.patches (patch_name, applied_tsz, applied_by, requires, conflicts ) VALUES ( in_patch_name, now(), current_user, coalesce( in_requirements, '{}' ), coalesce( in_conflicts, '{}' ) );
- RETURN;
-END;
-$$;
-
-
---
--- Name: FUNCTION register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer); Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON FUNCTION _v.register_patch(in_patch_name text, in_requirements text[], in_conflicts text[], OUT versioning integer) IS 'Function to register patches in database. Raises exception if there are conflicts, prerequisites are not installed or the migration has already been installed.';
-
-
---
--- Name: unregister_patch(text); Type: FUNCTION; Schema: _v; Owner: -
---
-
-CREATE FUNCTION _v.unregister_patch(in_patch_name text, OUT versioning integer) RETURNS SETOF integer
- LANGUAGE plpgsql
- AS $$
-DECLARE
- i INT4;
- t_text_a TEXT[];
-BEGIN
- -- Thanks to this we know only one patch will be applied at a time
- LOCK TABLE _v.patches IN EXCLUSIVE MODE;
-
- t_text_a := ARRAY( SELECT patch_name FROM _v.patches WHERE in_patch_name = ANY( requires ) );
- IF array_upper( t_text_a, 1 ) IS NOT NULL THEN
- RAISE EXCEPTION 'Cannot uninstall %, as it is required by: %.', in_patch_name, array_to_string( t_text_a, ', ' );
- END IF;
-
- DELETE FROM _v.patches WHERE patch_name = in_patch_name;
- GET DIAGNOSTICS i = ROW_COUNT;
- IF i < 1 THEN
- RAISE EXCEPTION 'Patch % is not installed, so it can''t be uninstalled!', in_patch_name;
- END IF;
-
- RETURN;
-END;
-$$;
-
-
---
--- Name: FUNCTION unregister_patch(in_patch_name text, OUT versioning integer); Type: COMMENT; Schema: _v; Owner: -
---
-
-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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_legitimizations_partition(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.add_constraints_to_legitimizations_partition(partition_suffix character varying) RETURNS void
- LANGUAGE plpgsql
- AS $$
-DECLARE
- partition_name VARCHAR;
-BEGIN
- partition_name = concat_ws('_', 'legitimizations', partition_suffix);
- EXECUTE FORMAT (
- 'ALTER TABLE ' || partition_name
- || ' '
- 'ADD CONSTRAINT ' || partition_name || '_legitimization_serial_id_key '
- 'UNIQUE (legitimization_serial_id)');
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || partition_name || '_by_provider_and_legi_index '
- 'ON '|| partition_name || ' '
- '(provider_section,provider_legitimization_id)'
- );
- EXECUTE FORMAT (
- 'COMMENT ON INDEX ' || partition_name || '_by_provider_and_legi_index '
- 'IS ' || quote_literal('used (rarely) in kyc_provider_account_lookup') || ';'
- );
-END
-$$;
-
-
---
--- Name: add_constraints_to_purse_deposits_partition(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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);
- 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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_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
- );
- 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',wallet_h_payto BYTEA NOT NULL CHECK (LENGTH(wallet_h_payto)=32)'
- ',PRIMARY KEY (purse_pub)'
- ') %s ;'
- ,table_name
- ,'PARTITION BY HASH (purse_pub)'
- ,shard_suffix
- );
- table_name = concat_ws('_', table_name, shard_suffix);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',deposit_serial_id INT8 PRIMARY KEY'
- ',wtid_raw BYTEA NOT NULL'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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)'
- ',merchant_pub BYTEA CHECK (LENGTH(merchant_pub)=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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',shard INT8 NOT NULL'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',known_coin_id INT8 NOT NULL'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',denominations_serial INT8 NOT NULL'
- ',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)'
- ,shard_suffix
- );
- table_name = concat_ws('_', table_name, shard_suffix);
-END
-$$;
-
-
---
--- Name: create_table_legitimizations(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.create_table_legitimizations(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
- LANGUAGE plpgsql
- AS $$
-BEGIN
- PERFORM create_partitioned_table(
- 'CREATE TABLE IF NOT EXISTS %I'
- '(legitimization_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY'
- ',h_payto BYTEA NOT NULL CHECK (LENGTH(h_payto)=32)'
- ',expiration_time INT8 NOT NULL DEFAULT (0)'
- ',provider_section VARCHAR NOT NULL'
- ',provider_user_id VARCHAR DEFAULT NULL'
- ',provider_legitimization_id VARCHAR DEFAULT NULL'
- ',UNIQUE (h_payto, provider_section)'
- ') %s ;'
- ,'legitimizations'
- ,'PARTITION BY HASH (h_payto)'
- ,shard_suffix
- );
-END
-$$;
-
-
---
--- Name: create_table_prewire(character varying); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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') || ';'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',partner_serial_id INT8'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',coin_pub BYTEA NOT NULL'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 '
- ',partner_serial_id INT8'
- ',reserve_pub BYTEA NOT NULL CHECK(length(reserve_pub)=32)'
- ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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);
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || table_name || '_merge_pub '
- 'ON ' || table_name || ' '
- '(merge_pub);'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA CHECK (LENGTH(coin_pub)=32)'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',known_coin_id BIGINT NOT NULL'
- ',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'
- ') %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_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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',rc BYTEA PRIMARY KEY CHECK (LENGTH(rc)=64)'
- ',old_coin_pub BYTEA NOT NULL'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',melt_serial_id INT8 NOT NULL'
- ',freshcoin_index INT4 NOT NULL'
- ',link_sig BYTEA NOT NULL CHECK(LENGTH(link_sig)=64)'
- ',denominations_serial INT8 NOT NULL'
- ',coin_ev BYTEA NOT NULL'
- ',h_coin_ev BYTEA NOT NULL CHECK(LENGTH(h_coin_ev)=64)'
- ',ev_sig BYTEA NOT NULL'
- ',ewv BYTEA NOT NULL'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',melt_serial_id INT8 PRIMARY KEY'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
- ',deposit_serial_id INT8 NOT NULL'
- ',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'
- ') %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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA NOT NULL'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',reserve_pub BYTEA PRIMARY KEY'
- ',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);'
- );
- EXECUTE FORMAT (
- 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_exch_accnt_section_execution_date_idx '
- 'ON ' || table_name || ' '
- '(exchange_account_section '
- ',execution_date'
- ');'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',h_blind_ev BYTEA CHECK (LENGTH(h_blind_ev)=64) UNIQUE'
- ',denominations_serial INT8 NOT NULL'
- ',denom_sig BYTEA NOT NULL'
- ',reserve_uuid INT8 NOT NULL'
- ',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);'
- );
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_in_serial_id INT8'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_out_serial_id INT8'
- ',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);
- 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',wad_id BYTEA PRIMARY KEY CHECK (LENGTH(wad_id)=24)'
- ',partner_serial_id INT8 NOT NULL'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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'
- ',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: exchange; Owner: -
---
-
-CREATE PROCEDURE exchange.defer_wire_out()
- LANGUAGE plpgsql
- AS $$
-BEGIN
-
-IF EXISTS (
- SELECT 1
- FROM exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_delete_trigger() IS 'Replicate deposit deletions into materialized indices.';
-
-
---
--- Name: deposits_insert_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_insert_trigger() IS 'Replicate deposit inserts into materialized indices.';
-
-
---
--- Name: deposits_update_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.deposits_update_trigger() IS 'Replicate deposits changes into materialized indices.';
-
-
---
--- Name: detach_default_partitions(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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;
- 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 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 exchange.reserves
- WHERE reserves.reserve_pub=rpub;
-
-IF NOT FOUND
-THEN
- -- reserve unknown
- reserve_found=FALSE;
- balance_ok=FALSE;
- 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;
- 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;
-
-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 ruuid bigint); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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, bigint, bytea); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.exchange_do_close_request(in_reserve_pub bytea, in_close_timestamp bigint, 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
-
- SELECT
- current_balance_val
- ,current_balance_frac
- INTO
- out_final_balance_val
- ,out_final_balance_frac
- FROM exchange.reserves
- WHERE reserve_pub=in_reserve_pub;
-
- IF NOT FOUND
- THEN
- out_final_balance_val=0;
- out_final_balance_frac=0;
- out_balance_ok = FALSE;
- out_conflict = FALSE;
- END IF;
-
- INSERT INTO exchange.close_requests
- (reserve_pub
- ,close_timestamp
- ,reserve_sig
- ,close_val
- ,close_frac)
- VALUES
- (in_reserve_pub
- ,in_close_timestamp
- ,in_reserve_sig
- ,out_final_balance_val
- ,out_final_balance_frac)
- ON CONFLICT DO NOTHING;
- out_conflict = NOT FOUND;
-
- UPDATE reserves SET
- current_balance_val=0
- ,current_balance_frac=0
- WHERE reserve_pub=in_reserve_pub;
- out_balance_ok = TRUE;
-
-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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.extension_details
- (extension_options)
- VALUES
- (in_extension_details)
- RETURNING extension_details_serial_id INTO xdi;
-ELSE
- xdi=NULL;
-END IF;
-
-
-INSERT INTO exchange.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 exchange.wire_targets
- WHERE wire_target_h_payto=in_h_payto;
-END IF;
-
-
-INSERT INTO exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE PROCEDURE exchange.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 exchange.prewire
- WHERE finished=TRUE;
-
-DELETE FROM exchange.wire_fee
- WHERE end_date < in_ancient_date;
-
--- TODO: use closing fee as threshold?
-DELETE FROM exchange.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 exchange.reserves_out
- ORDER BY reserve_out_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.recoup
- WHERE reserve_out_serial_id < reserve_out_min;
--- FIXME: recoup_refresh lacks GC!
-
-SELECT
- reserve_uuid
- INTO
- reserve_uuid_min
- FROM exchange.reserves
- ORDER BY reserve_uuid ASC
- LIMIT 1;
-
-DELETE FROM exchange.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 exchange.denominations
- WHERE expire_legal < in_now
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.reserves_out)
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.known_coins
- WHERE coin_pub IN
- (SELECT DISTINCT coin_pub
- FROM exchange.recoup))
- AND denominations_serial NOT IN
- (SELECT DISTINCT denominations_serial
- FROM exchange.known_coins
- WHERE coin_pub IN
- (SELECT DISTINCT coin_pub
- FROM exchange.recoup_refresh));
-
-SELECT
- melt_serial_id
- INTO
- melt_min
- FROM exchange.refresh_commitments
- ORDER BY melt_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.refresh_revealed_coins
- WHERE melt_serial_id < melt_min;
-
-DELETE FROM exchange.refresh_transfer_keys
- WHERE melt_serial_id < melt_min;
-
-SELECT
- known_coin_id
- INTO
- coin_min
- FROM exchange.known_coins
- ORDER BY known_coin_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.deposits
- WHERE known_coin_id < coin_min;
-
-SELECT
- deposit_serial_id
- INTO
- deposit_min
- FROM exchange.deposits
- ORDER BY deposit_serial_id ASC
- LIMIT 1;
-
-DELETE FROM exchange.refunds
- WHERE deposit_serial_id < deposit_min;
-
-DELETE FROM exchange.aggregation_tracking
- WHERE deposit_serial_id < deposit_min;
-
-SELECT
- denominations_serial
- INTO
- denom_min
- FROM exchange.denominations
- ORDER BY denominations_serial ASC
- LIMIT 1;
-
-DELETE FROM exchange.cs_nonce_locks
- WHERE max_denomination_serial <= denom_min;
-
-END $$;
-
-
---
--- Name: exchange_do_history_request(bytea, bytea, bigint, bigint, integer); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.recoup_refresh
- WHERE rrc_serial IN
- (SELECT rrc_serial
- FROM exchange.refresh_revealed_coins
- WHERE melt_serial_id IN
- (SELECT melt_serial_id
- FROM exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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, bytea, boolean); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_wallet_h_payto 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 exchange.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 exchange.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 exchange.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 exchange.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 exchange.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 exchange.account_merges
- (reserve_pub
- ,reserve_sig
- ,purse_pub
- ,wallet_h_payto)
- VALUES
- (in_reserve_pub
- ,in_reserve_sig
- ,in_purse_pub
- ,in_wallet_h_payto);
-
--- 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_wallet_h_payto 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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_wallet_h_payto 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.reserves
- WHERE reserves.reserve_pub = res_pub;
-
- FOR blind_ev IN
- SELECT h_blind_ev
- FROM exchange.reserves_out_by_reserve
- WHERE reserves_out_by_reserve.reserve_uuid = res_uuid
- LOOP
- SELECT robr.coin_pub
- INTO c_pub
- FROM exchange.recoup_by_reserve robr
- WHERE robr.reserve_out_serial_id = (
- SELECT reserves_out.reserve_out_serial_id
- FROM exchange.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 exchange.known_coins
- WHERE known_coins.coin_pub = c_pub
- ) kc
- JOIN (
- SELECT *
- FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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 exchange.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 exchange.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 exchange.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, bytea, boolean); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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_wallet_h_payto 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 exchange.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 exchange.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 exchange.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 exchange.account_merges
- (reserve_pub
- ,reserve_sig
- ,purse_pub
- ,wallet_h_payto)
- VALUES
- (in_reserve_pub
- ,in_reserve_sig
- ,in_purse_pub
- ,in_wallet_h_payto);
-
-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_wallet_h_payto 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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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_wallet_h_payto 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 nonce_ok boolean, 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 exchange.denominations
- WHERE denom_pub_hash=h_denom_pub;
-
-IF NOT FOUND
-THEN
- -- denomination unknown, should be impossible!
- reserve_found=FALSE;
- balance_ok=FALSE;
- 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 exchange.reserves
- WHERE reserves.reserve_pub=rpub;
-
-IF NOT FOUND
-THEN
- -- reserve unknown
- reserve_found=FALSE;
- balance_ok=FALSE;
- nonce_ok=TRUE;
- ruuid=2;
- RETURN;
-END IF;
-
--- We optimistically insert, and then on conflict declare
--- the query successful due to idempotency.
-INSERT INTO exchange.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;
- nonce_ok=TRUE;
- 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;
- nonce_ok=TRUE; -- we do not really know
- balance_ok=FALSE;
- 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 exchange.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 exchange.cs_nonce_locks
- WHERE nonce=cs_nonce
- AND op_hash=h_coin_envelope;
- IF NOT FOUND
- THEN
- reserve_found=FALSE;
- balance_ok=FALSE;
- nonce_ok=FALSE;
- RETURN;
- END IF;
- END IF;
-ELSE
- nonce_ok=TRUE; -- no nonce, hence OK!
-END IF;
-
-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 nonce_ok boolean, OUT ruuid bigint); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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 nonce_ok boolean, 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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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 exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.purse_requests_on_update_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- IF (NEW.finished AND NOT OLD.finished)
- THEN
- IF (NEW.in_reserve_quota)
- THEN
- UPDATE reserves
- SET purses_active=purses_active-1
- WHERE reserve_pub IN
- (SELECT reserve_pub
- FROM exchange.purse_merges
- WHERE purse_pub=NEW.purse_pub
- LIMIT 1);
- NEW.in_reserve_quota=FALSE;
- END IF;
- DELETE FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.recoup_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.recoup_delete_trigger() IS 'Replicate recoup deletions into recoup_by_reserve table.';
-
-
---
--- Name: recoup_insert_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.recoup_insert_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- INSERT INTO exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.recoup_insert_trigger() IS 'Replicate recoup inserts into recoup_by_reserve table.';
-
-
---
--- Name: reserves_out_by_reserve_delete_trigger(); Type: FUNCTION; Schema: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.reserves_out_by_reserve_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.reserves_out_by_reserve
- WHERE reserve_uuid = OLD.reserve_uuid;
- RETURN OLD;
-END $$;
-
-
---
--- Name: FUNCTION reserves_out_by_reserve_delete_trigger(); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.reserves_out_by_reserve_insert_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- INSERT INTO exchange.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: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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: exchange; Owner: -
---
-
-CREATE FUNCTION exchange.wire_out_delete_trigger() RETURNS trigger
- LANGUAGE plpgsql
- AS $$
-BEGIN
- DELETE FROM exchange.aggregation_tracking
- WHERE wtid_raw = OLD.wtid_raw;
- RETURN OLD;
-END $$;
-
-
---
--- Name: FUNCTION wire_out_delete_trigger(); Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON FUNCTION exchange.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;
-
---
--- Name: patches; Type: TABLE; Schema: _v; Owner: -
---
-
-CREATE TABLE _v.patches (
- patch_name text NOT NULL,
- applied_tsz timestamp with time zone DEFAULT now() NOT NULL,
- applied_by text NOT NULL,
- requires text[],
- conflicts text[]
-);
-
-
---
--- Name: TABLE patches; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON TABLE _v.patches IS 'Contains information about what patches are currently applied on database.';
-
-
---
--- Name: COLUMN patches.patch_name; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.patch_name IS 'Name of patch, has to be unique for every patch.';
-
-
---
--- Name: COLUMN patches.applied_tsz; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.applied_tsz IS 'When the patch was applied.';
-
-
---
--- Name: COLUMN patches.applied_by; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.applied_by IS 'Who applied this patch (PostgreSQL username)';
-
-
---
--- Name: COLUMN patches.requires; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.requires IS 'List of patches that are required for given patch.';
-
-
---
--- Name: COLUMN patches.conflicts; Type: COMMENT; Schema: _v; Owner: -
---
-
-COMMENT ON COLUMN _v.patches.conflicts IS 'List of patches that conflict with given patch.';
-
-
---
--- Name: auditor_balance_summary; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_balance_summary (
- master_pub bytea NOT NULL,
- denom_balance_val bigint NOT NULL,
- denom_balance_frac integer NOT NULL,
- deposit_fee_balance_val bigint NOT NULL,
- deposit_fee_balance_frac integer NOT NULL,
- melt_fee_balance_val bigint NOT NULL,
- melt_fee_balance_frac integer NOT NULL,
- refund_fee_balance_val bigint NOT NULL,
- refund_fee_balance_frac integer NOT NULL,
- risk_val bigint NOT NULL,
- risk_frac integer NOT NULL,
- loss_val bigint NOT NULL,
- loss_frac integer NOT NULL,
- irregular_recoup_val bigint NOT NULL,
- irregular_recoup_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_balance_summary; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_balance_summary IS 'the sum of the outstanding coins from auditor_denomination_pending (denom_pubs must belong to the respectives exchange master public key); it represents the auditor_balance_summary of the exchange at this point (modulo unexpected historic_loss-style events where denomination keys are compromised)';
-
-
---
--- Name: auditor_denomination_pending; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_denomination_pending (
- denom_pub_hash bytea NOT NULL,
- denom_balance_val bigint NOT NULL,
- denom_balance_frac integer NOT NULL,
- denom_loss_val bigint NOT NULL,
- denom_loss_frac integer NOT NULL,
- num_issued bigint NOT NULL,
- denom_risk_val bigint NOT NULL,
- denom_risk_frac integer NOT NULL,
- recoup_loss_val bigint NOT NULL,
- recoup_loss_frac integer NOT NULL,
- CONSTRAINT auditor_denomination_pending_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64))
-);
-
-
---
--- Name: TABLE auditor_denomination_pending; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_denomination_pending IS 'outstanding denomination coins that the exchange is aware of and what the respective balances are (outstanding as well as issued overall which implies the maximum value at risk).';
-
-
---
--- Name: COLUMN auditor_denomination_pending.num_issued; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.num_issued IS 'counts the number of coins issued (withdraw, refresh) of this denomination';
-
-
---
--- Name: COLUMN auditor_denomination_pending.denom_risk_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.denom_risk_val IS 'amount that could theoretically be lost in the future due to recoup operations';
-
-
---
--- Name: COLUMN auditor_denomination_pending.recoup_loss_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_denomination_pending.recoup_loss_val IS 'amount actually lost due to recoup operations past revocation';
-
-
---
--- Name: auditor_exchange_signkeys; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_exchange_signkeys (
- master_pub bytea NOT NULL,
- ep_start bigint NOT NULL,
- ep_expire bigint NOT NULL,
- ep_end bigint NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT auditor_exchange_signkeys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT auditor_exchange_signkeys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE auditor_exchange_signkeys; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_exchange_signkeys IS 'list of the online signing keys of exchanges we are auditing';
-
-
---
--- Name: auditor_exchanges; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_exchanges (
- master_pub bytea NOT NULL,
- exchange_url character varying NOT NULL,
- CONSTRAINT auditor_exchanges_master_pub_check CHECK ((length(master_pub) = 32))
-);
-
-
---
--- Name: TABLE auditor_exchanges; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_exchanges IS 'list of the exchanges we are auditing';
-
-
---
--- Name: auditor_historic_denomination_revenue; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_historic_denomination_revenue (
- master_pub bytea NOT NULL,
- denom_pub_hash bytea NOT NULL,
- revenue_timestamp bigint NOT NULL,
- revenue_balance_val bigint NOT NULL,
- revenue_balance_frac integer NOT NULL,
- loss_balance_val bigint NOT NULL,
- loss_balance_frac integer NOT NULL,
- CONSTRAINT auditor_historic_denomination_revenue_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64))
-);
-
-
---
--- Name: TABLE auditor_historic_denomination_revenue; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_historic_denomination_revenue IS 'Table with historic profits; basically, when a denom_pub has expired and everything associated with it is garbage collected, the final profits end up in here; note that the denom_pub here is not a foreign key, we just keep it as a reference point.';
-
-
---
--- Name: COLUMN auditor_historic_denomination_revenue.revenue_balance_val; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON COLUMN auditor.auditor_historic_denomination_revenue.revenue_balance_val IS 'the sum of all of the profits we made on the coin except for withdraw fees (which are in historic_reserve_revenue); so this includes the deposit, melt and refund fees';
-
-
---
--- Name: auditor_historic_reserve_summary; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_historic_reserve_summary (
- master_pub bytea NOT NULL,
- start_date bigint NOT NULL,
- end_date bigint NOT NULL,
- reserve_profits_val bigint NOT NULL,
- reserve_profits_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_historic_reserve_summary; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_historic_reserve_summary IS 'historic profits from reserves; we eventually GC auditor_historic_reserve_revenue, and then store the totals in here (by time intervals).';
-
-
---
--- Name: auditor_predicted_result; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_predicted_result (
- master_pub bytea NOT NULL,
- balance_val bigint NOT NULL,
- balance_frac integer NOT NULL,
- drained_val bigint NOT NULL,
- drained_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_predicted_result; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_predicted_result IS 'Table with the sum of the ledger, auditor_historic_revenue and the auditor_reserve_balance and the drained profits. This is the final amount that the exchange should have in its bank account right now (and the total amount drained as profits to non-escrow accounts).';
-
-
---
--- Name: auditor_progress_aggregation; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_aggregation (
- master_pub bytea NOT NULL,
- last_wire_out_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_aggregation; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_aggregation 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: auditor_progress_coin; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_coin (
- master_pub bytea NOT NULL,
- last_withdraw_serial_id bigint DEFAULT 0 NOT NULL,
- last_deposit_serial_id bigint DEFAULT 0 NOT NULL,
- 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_purse_deposits_serial_id bigint DEFAULT 0 NOT NULL,
- last_purse_refunds_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_coin; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_coin 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: auditor_progress_deposit_confirmation; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_deposit_confirmation (
- master_pub bytea NOT NULL,
- last_deposit_confirmation_serial_id bigint DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE auditor_progress_deposit_confirmation; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_deposit_confirmation 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: auditor_progress_reserve; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_progress_reserve (
- master_pub bytea NOT NULL,
- 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_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
-);
-
-
---
--- Name: TABLE auditor_progress_reserve; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_progress_reserve 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: auditor_reserve_balance; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_reserve_balance (
- master_pub bytea NOT NULL,
- 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,
- 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
-);
-
-
---
--- Name: TABLE auditor_reserve_balance; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_reserve_balance IS 'sum of the balances of all customer reserves (by exchange master public key)';
-
-
---
--- Name: auditor_reserves; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_reserves (
- reserve_pub bytea NOT NULL,
- master_pub bytea NOT NULL,
- 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,
- expiration_date bigint NOT NULL,
- auditor_reserves_rowid bigint NOT NULL,
- origin_account text,
- CONSTRAINT auditor_reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
-);
-
-
---
--- Name: TABLE auditor_reserves; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_reserves IS 'all of the customer reserves and their respective balances that the auditor is aware of';
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE; Schema: auditor; Owner: -
---
-
-CREATE SEQUENCE auditor.auditor_reserves_auditor_reserves_rowid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE OWNED BY; Schema: auditor; Owner: -
---
-
-ALTER SEQUENCE auditor.auditor_reserves_auditor_reserves_rowid_seq OWNED BY auditor.auditor_reserves.auditor_reserves_rowid;
-
-
---
--- Name: auditor_wire_fee_balance; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.auditor_wire_fee_balance (
- master_pub bytea NOT NULL,
- wire_fee_balance_val bigint NOT NULL,
- wire_fee_balance_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE auditor_wire_fee_balance; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.auditor_wire_fee_balance IS 'sum of the balances of all wire fees (by exchange master public key)';
-
-
---
--- Name: deposit_confirmations; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.deposit_confirmations (
- master_pub bytea NOT NULL,
- serial_id bigint NOT NULL,
- h_contract_terms bytea NOT NULL,
- h_extensions bytea NOT NULL,
- h_wire bytea NOT NULL,
- exchange_timestamp bigint NOT NULL,
- refund_deadline bigint NOT NULL,
- wire_deadline bigint NOT NULL,
- amount_without_fee_val bigint NOT NULL,
- amount_without_fee_frac integer NOT NULL,
- coin_pub bytea NOT NULL,
- merchant_pub bytea NOT NULL,
- exchange_sig bytea NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT deposit_confirmations_coin_pub_check CHECK ((length(coin_pub) = 32)),
- CONSTRAINT deposit_confirmations_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT deposit_confirmations_exchange_sig_check CHECK ((length(exchange_sig) = 64)),
- CONSTRAINT deposit_confirmations_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
- CONSTRAINT deposit_confirmations_h_contract_terms_check1 CHECK ((length(h_contract_terms) = 64)),
- CONSTRAINT deposit_confirmations_h_wire_check CHECK ((length(h_wire) = 64)),
- CONSTRAINT deposit_confirmations_master_sig_check CHECK ((length(master_sig) = 64)),
- CONSTRAINT deposit_confirmations_merchant_pub_check CHECK ((length(merchant_pub) = 32))
-);
-
-
---
--- Name: TABLE deposit_confirmations; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.deposit_confirmations IS 'deposit confirmation sent to us by merchants; we must check that the exchange reported these properly.';
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE; Schema: auditor; Owner: -
---
-
-CREATE SEQUENCE auditor.deposit_confirmations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: auditor; Owner: -
---
-
-ALTER SEQUENCE auditor.deposit_confirmations_serial_id_seq OWNED BY auditor.deposit_confirmations.serial_id;
-
-
---
--- Name: wire_auditor_account_progress; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.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: TABLE wire_auditor_account_progress; Type: COMMENT; Schema: auditor; Owner: -
---
-
-COMMENT ON TABLE auditor.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: wire_auditor_progress; Type: TABLE; Schema: auditor; Owner: -
---
-
-CREATE TABLE auditor.wire_auditor_progress (
- master_pub bytea NOT NULL,
- last_timestamp bigint NOT NULL,
- last_reserve_close_uuid bigint NOT NULL
-);
-
-
---
--- Name: account_merges; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- wallet_h_payto 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)),
- CONSTRAINT account_merges_wallet_h_payto_check CHECK ((length(wallet_h_payto) = 32))
-)
-PARTITION BY HASH (purse_pub);
-
-
---
--- Name: TABLE account_merges; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.account_merges.reserve_pub IS 'public key of the target reserve';
-
-
---
--- Name: COLUMN account_merges.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.account_merges.purse_pub IS 'public key of the purse';
-
-
---
--- Name: account_merges_account_merge_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.account_merges ALTER COLUMN account_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- wallet_h_payto 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)),
- CONSTRAINT account_merges_wallet_h_payto_check CHECK ((length(wallet_h_payto) = 32))
-);
-ALTER TABLE ONLY exchange.account_merges ATTACH PARTITION exchange.account_merges_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: aggregation_tracking; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_tracking (
- aggregation_serial_id bigint NOT NULL,
- deposit_serial_id bigint NOT NULL,
- wtid_raw bytea NOT NULL
-)
-PARTITION BY HASH (deposit_serial_id);
-
-
---
--- Name: TABLE aggregation_tracking; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.aggregation_tracking IS 'mapping from wire transfer identifiers (WTID) to deposits (and back)';
-
-
---
--- Name: COLUMN aggregation_tracking.wtid_raw; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_tracking.wtid_raw IS 'identifier of the wire transfer';
-
-
---
--- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.aggregation_tracking ALTER COLUMN aggregation_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.aggregation_tracking_aggregation_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: aggregation_tracking_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_tracking_default (
- aggregation_serial_id bigint NOT NULL,
- deposit_serial_id bigint NOT NULL,
- wtid_raw bytea NOT NULL
-);
-ALTER TABLE ONLY exchange.aggregation_tracking ATTACH PARTITION exchange.aggregation_tracking_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: aggregation_transient; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_transient (
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- wire_target_h_payto bytea,
- merchant_pub bytea,
- exchange_account_section text NOT NULL,
- wtid_raw bytea NOT NULL,
- CONSTRAINT aggregation_transient_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
- 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: TABLE aggregation_transient; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_transient.amount_val IS 'Sum of all of the aggregated deposits (without deposit fees)';
-
-
---
--- Name: COLUMN aggregation_transient.wtid_raw; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.aggregation_transient.wtid_raw IS 'identifier of the wire transfer';
-
-
---
--- Name: aggregation_transient_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.aggregation_transient_default (
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- wire_target_h_payto bytea,
- merchant_pub bytea,
- exchange_account_section text NOT NULL,
- wtid_raw bytea NOT NULL,
- CONSTRAINT aggregation_transient_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
- 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 exchange.aggregation_transient ATTACH PARTITION exchange.aggregation_transient_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: auditor_denom_sigs; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.auditor_denom_sigs (
- auditor_denom_serial bigint NOT NULL,
- auditor_uuid bigint NOT NULL,
- denominations_serial bigint NOT NULL,
- auditor_sig bytea,
- CONSTRAINT auditor_denom_sigs_auditor_sig_check CHECK ((length(auditor_sig) = 64))
-);
-
-
---
--- Name: TABLE auditor_denom_sigs; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.auditor_denom_sigs IS 'Table with auditor signatures on exchange denomination keys.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.auditor_uuid; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.auditor_uuid IS 'Identifies the auditor.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.denominations_serial IS 'Denomination the signature is for.';
-
-
---
--- Name: COLUMN auditor_denom_sigs.auditor_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditor_denom_sigs.auditor_sig IS 'Signature of the auditor, of purpose TALER_SIGNATURE_AUDITOR_EXCHANGE_KEYS.';
-
-
---
--- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.auditor_denom_sigs ALTER COLUMN auditor_denom_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.auditor_denom_sigs_auditor_denom_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: auditors; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.auditors (
- auditor_uuid bigint NOT NULL,
- auditor_pub bytea NOT NULL,
- auditor_name character varying NOT NULL,
- auditor_url character varying NOT NULL,
- is_active boolean NOT NULL,
- last_change bigint NOT NULL,
- CONSTRAINT auditors_auditor_pub_check CHECK ((length(auditor_pub) = 32))
-);
-
-
---
--- Name: TABLE auditors; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.auditors IS 'Table with auditors the exchange uses or has used in the past. Entries never expire as we need to remember the last_change column indefinitely.';
-
-
---
--- Name: COLUMN auditors.auditor_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.auditor_pub IS 'Public key of the auditor.';
-
-
---
--- Name: COLUMN auditors.auditor_url; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.auditor_url IS 'The base URL of the auditor.';
-
-
---
--- Name: COLUMN auditors.is_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.is_active IS 'true if we are currently supporting the use of this auditor.';
-
-
---
--- Name: COLUMN auditors.last_change; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.auditors.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
-
-
---
--- Name: auditors_auditor_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.auditors ALTER COLUMN auditor_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.auditors_auditor_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: close_requests; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.close_requests IS 'Explicit requests by a reserve owner to close a reserve immediately';
-
-
---
--- Name: COLUMN close_requests.close_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.close_requests.close_timestamp IS 'When the request was created by the client';
-
-
---
--- Name: COLUMN close_requests.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.close_requests.reserve_sig IS 'Signature affirming that the reserve is to be closed';
-
-
---
--- Name: COLUMN close_requests.close_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.close_requests ALTER COLUMN close_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.close_requests ATTACH PARTITION exchange.close_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: contracts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.contracts IS 'encrypted contracts associated with purses';
-
-
---
--- Name: COLUMN contracts.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.purse_pub IS 'public key of the purse that the contract is associated with';
-
-
---
--- Name: COLUMN contracts.pub_ckey; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.contract_sig IS 'signature over the encrypted contract by the purse contract key';
-
-
---
--- Name: COLUMN contracts.e_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.contracts.e_contract IS 'AES-GCM encrypted contract terms (contains gzip compressed JSON after decryption)';
-
-
---
--- Name: contracts_contract_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.contracts ALTER COLUMN contract_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.contracts_contract_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: contracts_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.contracts ATTACH PARTITION exchange.contracts_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: cs_nonce_locks; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.cs_nonce_locks.nonce IS 'actual nonce submitted by the client';
-
-
---
--- Name: COLUMN cs_nonce_locks.op_hash; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.cs_nonce_locks ALTER COLUMN cs_nonce_lock_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.cs_nonce_locks ATTACH PARTITION exchange.cs_nonce_locks_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: denomination_revocations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.denomination_revocations (
- denom_revocations_serial_id bigint NOT NULL,
- denominations_serial bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT denomination_revocations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE denomination_revocations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.denomination_revocations IS 'remembering which denomination keys have been revoked';
-
-
---
--- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.denomination_revocations ALTER COLUMN denom_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.denomination_revocations_denom_revocations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: denominations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.denominations (
- denominations_serial bigint NOT NULL,
- denom_pub_hash bytea NOT NULL,
- denom_type integer DEFAULT 1 NOT NULL,
- age_mask integer DEFAULT 0 NOT NULL,
- denom_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- valid_from bigint NOT NULL,
- expire_withdraw bigint NOT NULL,
- expire_deposit bigint NOT NULL,
- expire_legal bigint NOT NULL,
- coin_val bigint NOT NULL,
- coin_frac integer NOT NULL,
- fee_withdraw_val bigint NOT NULL,
- fee_withdraw_frac integer NOT NULL,
- fee_deposit_val bigint NOT NULL,
- fee_deposit_frac integer NOT NULL,
- fee_refresh_val bigint NOT NULL,
- fee_refresh_frac integer NOT NULL,
- fee_refund_val bigint NOT NULL,
- fee_refund_frac integer NOT NULL,
- CONSTRAINT denominations_denom_pub_hash_check CHECK ((length(denom_pub_hash) = 64)),
- CONSTRAINT denominations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE denominations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.denominations IS 'Main denominations table. All the valid denominations the exchange knows about.';
-
-
---
--- Name: COLUMN denominations.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.denominations.denominations_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN denominations.denom_type; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.denominations.denom_type IS 'determines cipher type for blind signatures used with this denomination; 0 is for RSA';
-
-
---
--- Name: COLUMN denominations.age_mask; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.denominations ALTER COLUMN denominations_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.denominations_denominations_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: deposits; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE deposits; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits IS 'Deposits we have received and for which we need to make (aggregate) wire transfers (and manage refunds).';
-
-
---
--- Name: COLUMN deposits.shard; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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.known_coin_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.known_coin_id IS 'Used for garbage collection';
-
-
---
--- Name: COLUMN deposits.wire_salt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.wire_salt IS 'Salt used when hashing the payto://-URI to get the h_wire';
-
-
---
--- Name: COLUMN deposits.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.wire_target_h_payto IS 'Identifies the target bank account and KYC status';
-
-
---
--- Name: COLUMN deposits.done; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.done IS 'Set to TRUE once we have included this deposit in some aggregate wire transfer to the merchant';
-
-
---
--- Name: COLUMN deposits.extension_blocked; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.extension_blocked IS 'True if the aggregation of the deposit is currently blocked by some extension mechanism. Used to filter out deposits that must not be processed by the canonical deposit logic.';
-
-
---
--- Name: COLUMN deposits.extension_details_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.deposits.extension_details_serial_id IS 'References extensions table, NULL if extensions are not used';
-
-
---
--- Name: deposits_by_ready; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits_by_ready IS 'Enables fast lookups for deposits_get_ready, auto-populated via TRIGGER below';
-
-
---
--- Name: deposits_by_ready_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits_by_ready ATTACH PARTITION exchange.deposits_by_ready_default DEFAULT;
-
-
---
--- Name: deposits_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits ATTACH PARTITION exchange.deposits_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.deposits ALTER COLUMN deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.deposits_deposit_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: deposits_for_matching; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.deposits_for_matching IS 'Enables fast lookups for deposits_iterate_matching, auto-populated via TRIGGER below';
-
-
---
--- Name: deposits_for_matching_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.deposits_for_matching ATTACH PARTITION exchange.deposits_for_matching_default DEFAULT;
-
-
---
--- Name: exchange_sign_keys; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.exchange_sign_keys (
- esk_serial bigint NOT NULL,
- exchange_pub bytea NOT NULL,
- master_sig bytea NOT NULL,
- valid_from bigint NOT NULL,
- expire_sign bigint NOT NULL,
- expire_legal bigint NOT NULL,
- CONSTRAINT exchange_sign_keys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT exchange_sign_keys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE exchange_sign_keys; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.exchange_sign_keys IS 'Table with master public key signatures on exchange online signing keys.';
-
-
---
--- Name: COLUMN exchange_sign_keys.exchange_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.exchange_pub IS 'Public online signing key of the exchange.';
-
-
---
--- Name: COLUMN exchange_sign_keys.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.master_sig IS 'Signature affirming the validity of the signing key of purpose TALER_SIGNATURE_MASTER_SIGNING_KEY_VALIDITY.';
-
-
---
--- Name: COLUMN exchange_sign_keys.valid_from; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.valid_from IS 'Time when this online signing key will first be used to sign messages.';
-
-
---
--- Name: COLUMN exchange_sign_keys.expire_sign; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.expire_sign IS 'Time when this online signing key will no longer be used to sign.';
-
-
---
--- Name: COLUMN exchange_sign_keys.expire_legal; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.exchange_sign_keys.expire_legal IS 'Time when this online signing key legally expires.';
-
-
---
--- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.exchange_sign_keys ALTER COLUMN esk_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.exchange_sign_keys_esk_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: extension_details; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extension_details (
- extension_details_serial_id bigint NOT NULL,
- extension_options character varying
-)
-PARTITION BY HASH (extension_details_serial_id);
-
-
---
--- Name: TABLE extension_details; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.extension_details IS 'Extensions that were provided with deposits (not yet used).';
-
-
---
--- Name: COLUMN extension_details.extension_options; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extension_details.extension_options IS 'JSON object with options set that the exchange needs to consider when executing a deposit. Supported details depend on the extensions supported by the exchange.';
-
-
---
--- Name: extension_details_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extension_details_default (
- extension_details_serial_id bigint NOT NULL,
- extension_options character varying
-);
-ALTER TABLE ONLY exchange.extension_details ATTACH PARTITION exchange.extension_details_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.extension_details ALTER COLUMN extension_details_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.extension_details_extension_details_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: extensions; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.extensions (
- extension_id bigint NOT NULL,
- name character varying NOT NULL,
- config bytea
-);
-
-
---
--- Name: TABLE extensions; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.extensions IS 'Configurations of the activated extensions';
-
-
---
--- Name: COLUMN extensions.name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extensions.name IS 'Name of the extension';
-
-
---
--- Name: COLUMN extensions.config; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.extensions.config IS 'Configuration of the extension as JSON-blob, maybe NULL';
-
-
---
--- Name: extensions_extension_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.extensions ALTER COLUMN extension_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.extensions_extension_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: global_fee; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.global_fee IS 'list of the global fees of this exchange, by date';
-
-
---
--- Name: COLUMN global_fee.global_fee_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.global_fee.global_fee_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: global_fee_global_fee_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.global_fee ALTER COLUMN global_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.global_fee_global_fee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: history_requests; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.history_requests IS 'Paid history requests issued by a client against a reserve';
-
-
---
--- Name: COLUMN history_requests.request_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.request_timestamp IS 'When was the history request made';
-
-
---
--- Name: COLUMN history_requests.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.reserve_sig IS 'Signature approving payment for the history request';
-
-
---
--- Name: COLUMN history_requests.history_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.history_requests.history_fee_val IS 'History fee approved by the signature';
-
-
---
--- Name: history_requests_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.history_requests ATTACH PARTITION exchange.history_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: history_requests_history_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.history_requests ALTER COLUMN history_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.history_requests_history_request_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: known_coins; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.known_coins (
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE known_coins; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.known_coins IS 'information about coins and their signatures, so we do not have to store the signatures more than once if a coin is involved in multiple operations';
-
-
---
--- Name: COLUMN known_coins.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.coin_pub IS 'EdDSA public key of the coin';
-
-
---
--- Name: COLUMN known_coins.age_commitment_hash; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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)';
-
-
---
--- Name: COLUMN known_coins.denom_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.denom_sig IS 'This is the signature of the exchange that affirms that the coin is a valid coin. The specific signature type depends on denom_type of the denomination.';
-
-
---
--- Name: COLUMN known_coins.remaining_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.known_coins.remaining_val IS 'Value of the coin that remains to be spent';
-
-
---
--- Name: known_coins_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.known_coins ATTACH PARTITION exchange.known_coins_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.known_coins ALTER COLUMN known_coin_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.known_coins_known_coin_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: kyc_alerts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.kyc_alerts (
- h_payto bytea NOT NULL,
- trigger_type integer NOT NULL,
- CONSTRAINT kyc_alerts_h_payto_check CHECK ((length(h_payto) = 32))
-);
-
-
---
--- Name: TABLE kyc_alerts; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.kyc_alerts IS 'alerts about completed KYC events reliably notifying other components (even if they are not running)';
-
-
---
--- Name: COLUMN kyc_alerts.h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.kyc_alerts.h_payto IS 'hash of the payto://-URI for which the KYC status changed';
-
-
---
--- Name: COLUMN kyc_alerts.trigger_type; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.kyc_alerts.trigger_type IS 'identifies the receiver of the alert, as the same h_payto may require multiple components to be notified';
-
-
---
--- Name: legitimizations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.legitimizations (
- legitimization_serial_id bigint NOT NULL,
- h_payto bytea NOT NULL,
- expiration_time bigint DEFAULT 0 NOT NULL,
- provider_section character varying NOT NULL,
- provider_user_id character varying,
- provider_legitimization_id character varying,
- CONSTRAINT legitimizations_h_payto_check CHECK ((length(h_payto) = 32))
-)
-PARTITION BY HASH (h_payto);
-
-
---
--- Name: TABLE legitimizations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.legitimizations IS 'List of legitimizations (required and completed) by account and provider';
-
-
---
--- Name: COLUMN legitimizations.legitimization_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.legitimization_serial_id IS 'unique ID for this legitimization process at the exchange';
-
-
---
--- Name: COLUMN legitimizations.h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.h_payto IS 'foreign key linking the entry to the wire_targets table, NOT a primary key (multiple legitimizations are possible per wire target)';
-
-
---
--- Name: COLUMN legitimizations.expiration_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.expiration_time IS 'in the future if the respective KYC check was passed successfully';
-
-
---
--- Name: COLUMN legitimizations.provider_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_section IS 'Configuration file section with details about this provider';
-
-
---
--- Name: COLUMN legitimizations.provider_user_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_user_id IS 'Identifier for the user at the provider that was used for the legitimization. NULL if provider is unaware.';
-
-
---
--- Name: COLUMN legitimizations.provider_legitimization_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.legitimizations.provider_legitimization_id IS 'Identifier for the specific legitimization process at the provider. NULL if legitimization was not started.';
-
-
---
--- Name: legitimizations_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.legitimizations_default (
- legitimization_serial_id bigint NOT NULL,
- h_payto bytea NOT NULL,
- expiration_time bigint DEFAULT 0 NOT NULL,
- provider_section character varying NOT NULL,
- provider_user_id character varying,
- provider_legitimization_id character varying,
- CONSTRAINT legitimizations_h_payto_check CHECK ((length(h_payto) = 32))
-);
-ALTER TABLE ONLY exchange.legitimizations ATTACH PARTITION exchange.legitimizations_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: legitimizations_legitimization_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.legitimizations ALTER COLUMN legitimization_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.legitimizations_legitimization_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: partner_accounts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.partners IS 'exchanges we do wad transfers to';
-
-
---
--- Name: COLUMN partners.partner_master_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.partner_master_pub IS 'offline master public key of the partner';
-
-
---
--- Name: COLUMN partners.start_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.start_date IS 'starting date of the partnership';
-
-
---
--- Name: COLUMN partners.end_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.end_date IS 'end date of the partnership';
-
-
---
--- Name: COLUMN partners.next_wad; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.wad_frequency IS 'how often do we promise to do wad transfers';
-
-
---
--- Name: COLUMN partners.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.partners.partner_base_url IS 'base URL of the REST API for this partner';
-
-
---
--- Name: partners_partner_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.partners ALTER COLUMN partner_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.partners_partner_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: prewire; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.prewire (
- 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
-)
-PARTITION BY HASH (prewire_uuid);
-
-
---
--- Name: TABLE prewire; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.prewire IS 'pre-commit data for wire transfers we are about to execute';
-
-
---
--- Name: COLUMN prewire.finished; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.finished IS 'set to TRUE once bank confirmed receiving the wire transfer request';
-
-
---
--- Name: COLUMN prewire.failed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.failed IS 'set to TRUE if the bank responded with a non-transient failure to our transfer request';
-
-
---
--- Name: COLUMN prewire.buf; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.prewire.buf IS 'serialized data to send to the bank to execute the wire transfer';
-
-
---
--- Name: prewire_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.prewire ATTACH PARTITION exchange.prewire_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: prewire_prewire_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.prewire ALTER COLUMN prewire_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.prewire_prewire_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: profit_drains; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.profit_drains (
- profit_drain_serial_id bigint NOT NULL,
- wtid bytea NOT NULL,
- account_section character varying NOT NULL,
- payto_uri character varying NOT NULL,
- trigger_date bigint NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac bigint NOT NULL,
- master_sig bytea NOT NULL,
- executed boolean DEFAULT false NOT NULL,
- CONSTRAINT profit_drains_master_sig_check CHECK ((length(master_sig) = 64)),
- CONSTRAINT profit_drains_wtid_check CHECK ((length(wtid) = 32))
-);
-
-
---
--- Name: TABLE profit_drains; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.profit_drains IS 'transactions to be performed to move profits from the escrow account of the exchange to a regular account';
-
-
---
--- Name: COLUMN profit_drains.wtid; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.wtid IS 'randomly chosen nonce, unique to prevent double-submission';
-
-
---
--- Name: COLUMN profit_drains.account_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.account_section IS 'specifies the configuration section in the taler-exchange-drain configuration with the wire account to drain';
-
-
---
--- Name: COLUMN profit_drains.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.payto_uri IS 'specifies the account to be credited';
-
-
---
--- Name: COLUMN profit_drains.trigger_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.trigger_date IS 'set by taler-exchange-offline at the time of making the signature; not necessarily the exact date of execution of the wire transfer, just for orientation';
-
-
---
--- Name: COLUMN profit_drains.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.amount_val IS 'amount to be transferred';
-
-
---
--- Name: COLUMN profit_drains.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.master_sig IS 'EdDSA signature of type TALER_SIGNATURE_MASTER_DRAIN_PROFIT';
-
-
---
--- Name: COLUMN profit_drains.executed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.profit_drains.executed IS 'set to TRUE by taler-exchange-drain on execution of the transaction, not replicated to auditor';
-
-
---
--- Name: profit_drains_profit_drain_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.profit_drains ALTER COLUMN profit_drain_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.profit_drains_profit_drain_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: purse_actions; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE purse_actions; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_actions IS 'purses awaiting some action by the router';
-
-
---
--- Name: COLUMN purse_actions.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_actions.purse_pub IS 'public (contract) key of the purse';
-
-
---
--- Name: COLUMN purse_actions.action_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_actions.action_date IS 'when is the purse ready for action';
-
-
---
--- Name: COLUMN purse_actions.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_deposits IS 'Requests depositing coins into a purse';
-
-
---
--- Name: COLUMN purse_deposits.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN purse_deposits.coin_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.coin_pub IS 'Public key of the coin being deposited';
-
-
---
--- Name: COLUMN purse_deposits.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_deposits.amount_with_fee_val IS 'Total amount being deposited';
-
-
---
--- Name: COLUMN purse_deposits.coin_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_deposits ATTACH PARTITION exchange.purse_deposits_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_deposits_purse_deposit_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_deposits ALTER COLUMN purse_deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.reserve_pub IS 'public key of the target reserve';
-
-
---
--- Name: COLUMN purse_merges.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.purse_pub IS 'public key of the purse';
-
-
---
--- Name: COLUMN purse_merges.merge_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_merges.merge_timestamp IS 'when was the merge message signed';
-
-
---
--- Name: purse_merges_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_merges ATTACH PARTITION exchange.purse_merges_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_merges_purse_merge_request_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_merges ALTER COLUMN purse_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.purse_refunds IS 'Purses that were refunded due to expiration';
-
-
---
--- Name: COLUMN purse_refunds.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_refunds.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: purse_refunds_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_refunds ATTACH PARTITION exchange.purse_refunds_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_refunds_purse_refunds_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_refunds ALTER COLUMN purse_refunds_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN purse_requests.purse_creation; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.purse_expiration IS 'When the purse is set to expire';
-
-
---
--- Name: COLUMN purse_requests.h_contract_terms; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.h_contract_terms IS 'Hash of the contract the parties are to agree to';
-
-
---
--- Name: COLUMN purse_requests.flags; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.flags IS 'see the enum TALER_WalletAccountMergeFlags';
-
-
---
--- Name: COLUMN purse_requests.refunded; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.purse_requests.balance_val IS 'Total amount actually in the purse';
-
-
---
--- Name: COLUMN purse_requests.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.purse_requests ATTACH PARTITION exchange.purse_requests_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: purse_requests_purse_requests_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.purse_requests ALTER COLUMN purse_requests_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.purse_requests_purse_requests_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: recoup; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.recoup (
- 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))
-)
-PARTITION BY HASH (coin_pub);
-
-
---
--- Name: TABLE recoup; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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.coin_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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_by_reserve; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup_by_reserve ATTACH PARTITION exchange.recoup_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup ATTACH PARTITION exchange.recoup_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.recoup ALTER COLUMN recoup_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.recoup_recoup_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: recoup_refresh; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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,
- 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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.recoup_refresh ATTACH PARTITION exchange.recoup_refresh_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.recoup_refresh ALTER COLUMN recoup_refresh_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.recoup_refresh_recoup_refresh_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_commitments; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_commitments (
- 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))
-)
-PARTITION BY HASH (rc);
-
-
---
--- Name: TABLE refresh_commitments; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_commitments IS 'Commitments made when melting coins and the gamma value chosen by the exchange.';
-
-
---
--- Name: COLUMN refresh_commitments.rc; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_commitments.old_coin_pub IS 'Coin being melted in the refresh process.';
-
-
---
--- Name: COLUMN refresh_commitments.noreveal_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_commitments ATTACH PARTITION exchange.refresh_commitments_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_commitments ALTER COLUMN melt_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_commitments_melt_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_revealed_coins; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_revealed_coins (
- 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))
-)
-PARTITION BY HASH (melt_serial_id);
-
-
---
--- Name: TABLE refresh_revealed_coins; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_revealed_coins IS 'Revelations about the new coins that are to be created during a melting session.';
-
-
---
--- Name: COLUMN refresh_revealed_coins.rrc_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.rrc_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN refresh_revealed_coins.melt_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.melt_serial_id IS 'Identifies the refresh commitment (rc) of the melt operation.';
-
-
---
--- Name: COLUMN refresh_revealed_coins.freshcoin_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.freshcoin_index IS 'index of the fresh coin being created (one melt operation may result in multiple fresh coins)';
-
-
---
--- Name: COLUMN refresh_revealed_coins.coin_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.coin_ev IS 'envelope of the new coin to be signed';
-
-
---
--- Name: COLUMN refresh_revealed_coins.h_coin_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.h_coin_ev IS 'hash of the envelope of the new coin to be signed (for lookups)';
-
-
---
--- Name: COLUMN refresh_revealed_coins.ev_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.ev_sig IS 'exchange signature over the envelope';
-
-
---
--- Name: COLUMN refresh_revealed_coins.ewv; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_revealed_coins.ewv IS 'exchange contributed values in the creation of the fresh coin (see /csr)';
-
-
---
--- Name: refresh_revealed_coins_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_revealed_coins ATTACH PARTITION exchange.refresh_revealed_coins_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_revealed_coins ALTER COLUMN rrc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_revealed_coins_rrc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refresh_transfer_keys; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.refresh_transfer_keys (
- 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))
-)
-PARTITION BY HASH (melt_serial_id);
-
-
---
--- Name: TABLE refresh_transfer_keys; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refresh_transfer_keys IS 'Transfer keys of a refresh operation (the data revealed to the exchange).';
-
-
---
--- Name: COLUMN refresh_transfer_keys.rtc_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.rtc_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: COLUMN refresh_transfer_keys.melt_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.melt_serial_id IS 'Identifies the refresh commitment (rc) of the operation.';
-
-
---
--- Name: COLUMN refresh_transfer_keys.transfer_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.transfer_pub IS 'transfer public key for the gamma index';
-
-
---
--- Name: COLUMN refresh_transfer_keys.transfer_privs; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refresh_transfer_keys.transfer_privs IS 'array of TALER_CNC_KAPPA - 1 transfer private keys that have been revealed, with the gamma entry being skipped';
-
-
---
--- Name: refresh_transfer_keys_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refresh_transfer_keys ATTACH PARTITION exchange.refresh_transfer_keys_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refresh_transfer_keys ALTER COLUMN rtc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refresh_transfer_keys_rtc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: refunds; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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);
-
-
---
--- Name: TABLE refunds; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.refunds IS 'Data on coins that were refunded. Technically, refunds always apply against specific deposit operations involving a coin. The combination of coin_pub, merchant_pub, h_contract_terms and rtransaction_id MUST be unique, and we usually select by coin_pub so that one goes first.';
-
-
---
--- Name: COLUMN refunds.deposit_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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.';
-
-
---
--- Name: COLUMN refunds.rtransaction_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.refunds.rtransaction_id IS 'used by the merchant to make refunds unique in case the same coin for the same deposit gets a subsequent (higher) refund';
-
-
---
--- Name: refunds_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.refunds ATTACH PARTITION exchange.refunds_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.refunds ALTER COLUMN refund_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.refunds_refund_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves IS 'Summarizes the balance of a reserve. Updated when new funds are added or withdrawn.';
-
-
---
--- Name: COLUMN reserves.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.current_balance_val IS 'Current balance remaining with the reserve.';
-
-
---
--- Name: COLUMN reserves.purses_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.expiration_date IS 'Used to trigger closing of reserves that have not been drained after some time';
-
-
---
--- Name: COLUMN reserves.gc_date; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves.gc_date IS 'Used to forget all information about a reserve during garbage collection';
-
-
---
--- Name: reserves_close; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_close (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves_close; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_close IS 'wire transfers executed by the reserve to close reserves';
-
-
---
--- Name: COLUMN reserves_close.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.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: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_close ALTER COLUMN close_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_close_close_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_close_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_close ATTACH PARTITION exchange.reserves_close_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves ATTACH PARTITION exchange.reserves_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_in; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_in (
- 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))
-)
-PARTITION BY HASH (reserve_pub);
-
-
---
--- Name: TABLE reserves_in; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_in IS 'list of transfers of funds into the reserves, one per incoming wire transfer';
-
-
---
--- Name: COLUMN reserves_in.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.reserve_pub IS 'Public key of the reserve. Private key signifies ownership of the remaining balance.';
-
-
---
--- Name: COLUMN reserves_in.credit_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.credit_val IS 'Amount that was transferred into the reserve';
-
-
---
--- Name: COLUMN reserves_in.wire_source_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_in.wire_source_h_payto IS 'Identifies the debited bank account and KYC status';
-
-
---
--- Name: reserves_in_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_in ATTACH PARTITION exchange.reserves_in_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_in ALTER COLUMN reserve_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_in_reserve_in_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.reserves_out (
- 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))
-)
-PARTITION BY HASH (h_blind_ev);
-
-
---
--- Name: TABLE reserves_out; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.reserves_out IS 'Withdraw operations performed on reserves.';
-
-
---
--- Name: COLUMN reserves_out.h_blind_ev; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_out.h_blind_ev IS 'Hash of the blinded coin, used as primary key here so that broken clients that use a non-random coin or blinding factor fail to withdraw (otherwise they would fail on deposit when the coin is not unique there).';
-
-
---
--- Name: COLUMN reserves_out.denominations_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.reserves_out.denominations_serial IS 'We do not CASCADE ON DELETE here, we may keep the denomination data alive';
-
-
---
--- Name: reserves_out_by_reserve; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE reserves_out_by_reserve; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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_out_by_reserve_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_out_by_reserve ATTACH PARTITION exchange.reserves_out_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.reserves_out ATTACH PARTITION exchange.reserves_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves_out ALTER COLUMN reserve_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_out_reserve_out_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.reserves ALTER COLUMN reserve_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.reserves_reserve_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: revolving_work_shards; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE UNLOGGED TABLE exchange.revolving_work_shards (
- shard_serial_id bigint NOT NULL,
- last_attempt bigint NOT NULL,
- start_row integer NOT NULL,
- end_row integer NOT NULL,
- active boolean DEFAULT false NOT NULL,
- job_name character varying NOT NULL
-);
-
-
---
--- Name: TABLE revolving_work_shards; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.revolving_work_shards IS 'coordinates work between multiple processes working on the same job with partitions that need to be repeatedly processed; unlogged because on system crashes the locks represented by this table will have to be cleared anyway, typically using "taler-exchange-dbinit -s"';
-
-
---
--- Name: COLUMN revolving_work_shards.shard_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.shard_serial_id IS 'unique serial number identifying the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.last_attempt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.start_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.start_row IS 'row at which the shard scope starts, inclusive';
-
-
---
--- Name: COLUMN revolving_work_shards.end_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.end_row IS 'row at which the shard scope ends, exclusive';
-
-
---
--- Name: COLUMN revolving_work_shards.active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.active IS 'set to TRUE when a worker is active on the shard';
-
-
---
--- Name: COLUMN revolving_work_shards.job_name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.revolving_work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
-
-
---
--- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.revolving_work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.revolving_work_shards_shard_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: signkey_revocations; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.signkey_revocations (
- signkey_revocations_serial_id bigint NOT NULL,
- esk_serial bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT signkey_revocations_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE signkey_revocations; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.signkey_revocations IS 'Table storing which online signing keys have been revoked';
-
-
---
--- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.signkey_revocations ALTER COLUMN signkey_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.signkey_revocations_signkey_revocations_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wad_in_entries; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wad_in_entries; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wad_in_entries IS 'list of purses aggregated in a wad according to the sending exchange';
-
-
---
--- Name: COLUMN wad_in_entries.wad_in_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.wad_in_serial_id IS 'wad for which the given purse was included in the aggregation';
-
-
---
--- Name: COLUMN wad_in_entries.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.reserve_pub IS 'target account of the purse (must be at the local exchange)';
-
-
---
--- Name: COLUMN wad_in_entries.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_pub IS 'public key of the purse that was merged';
-
-
---
--- Name: COLUMN wad_in_entries.h_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.h_contract IS 'hash of the contract terms of the purse';
-
-
---
--- Name: COLUMN wad_in_entries.purse_expiration; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_expiration IS 'Time when the purse was set to expire';
-
-
---
--- Name: COLUMN wad_in_entries.merge_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.merge_timestamp IS 'Time when the merge was approved';
-
-
---
--- Name: COLUMN wad_in_entries.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.amount_with_fee_val IS 'Total amount in the purse';
-
-
---
--- Name: COLUMN wad_in_entries.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.wad_fee_val IS 'Total wad fees paid by the purse';
-
-
---
--- Name: COLUMN wad_in_entries.deposit_fees_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.deposit_fees_val IS 'Total deposit fees paid when depositing coins into the purse';
-
-
---
--- Name: COLUMN wad_in_entries.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
-
-
---
--- Name: COLUMN wad_in_entries.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_in_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
-
-
---
--- Name: wad_in_entries_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wad_in_entries ATTACH PARTITION exchange.wad_in_entries_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wad_in_entries_wad_in_entry_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wad_in_entries ALTER COLUMN wad_in_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wad_in_entries_wad_in_entry_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wad_out_entries; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wad_out_entries; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wad_out_entries IS 'Purses combined into a wad';
-
-
---
--- Name: COLUMN wad_out_entries.wad_out_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.wad_out_serial_id IS 'Wad the purse was part of';
-
-
---
--- Name: COLUMN wad_out_entries.reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.reserve_pub IS 'Target reserve for the purse';
-
-
---
--- Name: COLUMN wad_out_entries.purse_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_pub IS 'Public key of the purse';
-
-
---
--- Name: COLUMN wad_out_entries.h_contract; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.h_contract IS 'Hash of the contract associated with the purse';
-
-
---
--- Name: COLUMN wad_out_entries.purse_expiration; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_expiration IS 'Time when the purse expires';
-
-
---
--- Name: COLUMN wad_out_entries.merge_timestamp; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.merge_timestamp IS 'Time when the merge was approved';
-
-
---
--- Name: COLUMN wad_out_entries.amount_with_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.amount_with_fee_val IS 'Total amount in the purse';
-
-
---
--- Name: COLUMN wad_out_entries.wad_fee_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.wad_fee_val IS 'Wat fee charged to the purse';
-
-
---
--- Name: COLUMN wad_out_entries.deposit_fees_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.deposit_fees_val IS 'Total deposit fees charged to the purse';
-
-
---
--- Name: COLUMN wad_out_entries.reserve_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
-
-
---
--- Name: COLUMN wad_out_entries.purse_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wad_out_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
-
-
---
--- Name: wad_out_entries_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wad_out_entries ATTACH PARTITION exchange.wad_out_entries_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wad_out_entries_wad_out_entry_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wad_out_entries ALTER COLUMN wad_out_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wad_out_entries_wad_out_entry_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wads_in; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wads_in; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wads_in IS 'Incoming exchange-to-exchange wad wire transfers';
-
-
---
--- Name: COLUMN wads_in.wad_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_in.origin_exchange_url; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.origin_exchange_url IS 'Base URL of the originating URL, also part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_in.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.amount_val IS 'Actual amount that was received by our exchange';
-
-
---
--- Name: COLUMN wads_in.arrival_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_in.arrival_time IS 'Time when the wad was received';
-
-
---
--- Name: wads_in_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wads_in ATTACH PARTITION exchange.wads_in_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wads_in_wad_in_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wads_in ALTER COLUMN wad_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wads_in_wad_in_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wads_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wads_out; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wads_out IS 'Wire transfers made to another exchange to transfer purse funds';
-
-
---
--- Name: COLUMN wads_out.wad_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
-
-
---
--- Name: COLUMN wads_out.partner_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.partner_serial_id IS 'target exchange of the wad';
-
-
---
--- Name: COLUMN wads_out.amount_val; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.amount_val IS 'Amount that was wired';
-
-
---
--- Name: COLUMN wads_out.execution_time; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wads_out.execution_time IS 'Time when the wire transfer was scheduled';
-
-
---
--- Name: wads_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wads_out ATTACH PARTITION exchange.wads_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wads_out_wad_out_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wads_out ALTER COLUMN wad_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wads_out_wad_out_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_accounts; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_accounts; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.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: COLUMN wire_accounts.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.payto_uri IS 'payto URI (RFC 8905) with the bank account of the exchange.';
-
-
---
--- Name: COLUMN wire_accounts.master_sig; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.master_sig IS 'Signature of purpose TALER_SIGNATURE_MASTER_WIRE_DETAILS';
-
-
---
--- Name: COLUMN wire_accounts.is_active; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.is_active IS 'true if we are currently supporting the use of this account.';
-
-
---
--- Name: COLUMN wire_accounts.last_change; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_accounts.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
-
-
---
--- Name: wire_fee; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_fee; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_fee IS 'list of the wire fees of this exchange, by date';
-
-
---
--- Name: COLUMN wire_fee.wire_fee_serial; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_fee.wire_fee_serial IS 'needed for exchange-auditor replication logic';
-
-
---
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_fee ALTER COLUMN wire_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_fee_wire_fee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_out; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_out IS 'wire transfers the exchange has executed';
-
-
---
--- Name: COLUMN wire_out.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_out.wire_target_h_payto IS 'Identifies the credited bank account and KYC status';
-
-
---
--- Name: COLUMN wire_out.exchange_account_section; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_out.exchange_account_section IS 'identifies the configuration section with the debit account of this payment';
-
-
---
--- Name: wire_out_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wire_out ATTACH PARTITION exchange.wire_out_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_out ALTER COLUMN wireout_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_out_wireout_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: wire_targets; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE wire_targets; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.wire_targets IS 'All senders and recipients of money via the exchange';
-
-
---
--- Name: COLUMN wire_targets.wire_target_h_payto; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.wire_target_h_payto IS 'Unsalted hash of payto_uri';
-
-
---
--- Name: COLUMN wire_targets.payto_uri; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.payto_uri IS 'Can be a regular bank account, or also be a URI identifying a reserve-account (for P2P payments)';
-
-
---
--- Name: COLUMN wire_targets.kyc_ok; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.kyc_ok IS 'true if the KYC check was passed successfully';
-
-
---
--- Name: COLUMN wire_targets.external_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.wire_targets.external_id IS 'Name of the user that was used for OAuth 2.0-based legitimization';
-
-
---
--- Name: wire_targets_default; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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 exchange.wire_targets ATTACH PARTITION exchange.wire_targets_default FOR VALUES WITH (modulus 1, remainder 0);
-
-
---
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.wire_targets ALTER COLUMN wire_target_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.wire_targets_wire_target_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: work_shards; Type: TABLE; Schema: exchange; Owner: -
---
-
-CREATE TABLE exchange.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: TABLE work_shards; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TABLE exchange.work_shards IS 'coordinates work between multiple processes working on the same job';
-
-
---
--- Name: COLUMN work_shards.shard_serial_id; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.shard_serial_id IS 'unique serial number identifying the shard';
-
-
---
--- Name: COLUMN work_shards.last_attempt; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
-
-
---
--- Name: COLUMN work_shards.start_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.start_row IS 'row at which the shard scope starts, inclusive';
-
-
---
--- Name: COLUMN work_shards.end_row; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.end_row IS 'row at which the shard scope ends, exclusive';
-
-
---
--- Name: COLUMN work_shards.completed; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.completed IS 'set to TRUE once the shard is finished by a worker';
-
-
---
--- Name: COLUMN work_shards.job_name; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON COLUMN exchange.work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
-
-
---
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: exchange; Owner: -
---
-
-ALTER TABLE exchange.work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME exchange.work_shards_shard_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_accounts; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_accounts (
- account_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- h_wire bytea NOT NULL,
- salt bytea NOT NULL,
- payto_uri character varying NOT NULL,
- active boolean NOT NULL,
- CONSTRAINT merchant_accounts_h_wire_check CHECK ((length(h_wire) = 64)),
- CONSTRAINT merchant_accounts_salt_check CHECK ((length(salt) = 16))
-);
-
-
---
--- Name: TABLE merchant_accounts; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_accounts IS 'bank accounts of the instances';
-
-
---
--- Name: COLUMN merchant_accounts.h_wire; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.h_wire IS 'salted hash of payto_uri';
-
-
---
--- Name: COLUMN merchant_accounts.salt; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.salt IS 'salt used when hashing payto_uri into h_wire';
-
-
---
--- Name: COLUMN merchant_accounts.payto_uri; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.payto_uri IS 'payto URI of a merchant bank account';
-
-
---
--- Name: COLUMN merchant_accounts.active; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_accounts.active IS 'true if we actively use this bank account, false if it is just kept around for older contracts to refer to';
-
-
---
--- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_accounts ALTER COLUMN account_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_accounts_account_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_contract_terms; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_contract_terms (
- order_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- order_id character varying NOT NULL,
- contract_terms bytea NOT NULL,
- h_contract_terms bytea NOT NULL,
- creation_time bigint NOT NULL,
- pay_deadline bigint NOT NULL,
- refund_deadline bigint NOT NULL,
- paid boolean DEFAULT false NOT NULL,
- wired boolean DEFAULT false NOT NULL,
- fulfillment_url character varying,
- session_id character varying DEFAULT ''::character varying NOT NULL,
- claim_token bytea NOT NULL,
- CONSTRAINT merchant_contract_terms_claim_token_check CHECK ((length(claim_token) = 16)),
- CONSTRAINT merchant_contract_terms_h_contract_terms_check CHECK ((length(h_contract_terms) = 64))
-);
-
-
---
--- Name: TABLE merchant_contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_contract_terms IS 'Contracts are orders that have been claimed by a wallet';
-
-
---
--- Name: COLUMN merchant_contract_terms.merchant_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.merchant_serial IS 'Identifies the instance offering the contract';
-
-
---
--- Name: COLUMN merchant_contract_terms.order_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.order_id IS 'Not a foreign key into merchant_orders because paid contracts persist after expiration';
-
-
---
--- Name: COLUMN merchant_contract_terms.contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.contract_terms IS 'These contract terms include the wallet nonce';
-
-
---
--- Name: COLUMN merchant_contract_terms.h_contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.h_contract_terms IS 'Hash over contract_terms';
-
-
---
--- Name: COLUMN merchant_contract_terms.pay_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.pay_deadline IS 'How long is the offer valid. After this time, the order can be garbage collected';
-
-
---
--- Name: COLUMN merchant_contract_terms.refund_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.refund_deadline IS 'By what times do refunds have to be approved (useful to reject refund requests)';
-
-
---
--- Name: COLUMN merchant_contract_terms.paid; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.paid IS 'true implies the customer paid for this contract; order should be DELETEd from merchant_orders once paid is set to release merchant_order_locks; paid remains true even if the payment was later refunded';
-
-
---
--- Name: COLUMN merchant_contract_terms.wired; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.wired IS 'true implies the exchange wired us the full amount for all non-refunded payments under this contract';
-
-
---
--- Name: COLUMN merchant_contract_terms.fulfillment_url; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.fulfillment_url IS 'also included in contract_terms, but we need it here to SELECT on it during repurchase detection; can be NULL if the contract has no fulfillment URL';
-
-
---
--- Name: COLUMN merchant_contract_terms.session_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.session_id IS 'last session_id from we confirmed the paying client to use, empty string for none';
-
-
---
--- Name: COLUMN merchant_contract_terms.claim_token; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_contract_terms.claim_token IS 'Token optionally used to access the status of the order. All zeros (not NULL) if not used';
-
-
---
--- Name: merchant_deposit_to_transfer; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_deposit_to_transfer (
- deposit_serial bigint NOT NULL,
- coin_contribution_value_val bigint NOT NULL,
- coin_contribution_value_frac integer NOT NULL,
- credit_serial bigint NOT NULL,
- execution_time bigint NOT NULL,
- signkey_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- CONSTRAINT merchant_deposit_to_transfer_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_deposit_to_transfer; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_deposit_to_transfer IS 'Mapping of deposits to (possibly unconfirmed) wire transfers; NOTE: not used yet';
-
-
---
--- Name: COLUMN merchant_deposit_to_transfer.execution_time; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposit_to_transfer.execution_time IS 'Execution time as claimed by the exchange, roughly matches time seen by merchant';
-
-
---
--- Name: merchant_deposits; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_deposits (
- deposit_serial bigint NOT NULL,
- order_serial bigint,
- deposit_timestamp bigint NOT NULL,
- coin_pub bytea NOT NULL,
- exchange_url character varying NOT NULL,
- amount_with_fee_val bigint NOT NULL,
- amount_with_fee_frac integer NOT NULL,
- deposit_fee_val bigint NOT NULL,
- deposit_fee_frac integer NOT NULL,
- refund_fee_val bigint NOT NULL,
- refund_fee_frac integer NOT NULL,
- wire_fee_val bigint NOT NULL,
- wire_fee_frac integer NOT NULL,
- signkey_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- account_serial bigint NOT NULL,
- CONSTRAINT merchant_deposits_coin_pub_check CHECK ((length(coin_pub) = 32)),
- CONSTRAINT merchant_deposits_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_deposits; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_deposits IS 'Refunds approved by the merchant (backoffice) logic, excludes abort refunds';
-
-
---
--- Name: COLUMN merchant_deposits.deposit_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.deposit_timestamp IS 'Time when the exchange generated the deposit confirmation';
-
-
---
--- Name: COLUMN merchant_deposits.wire_fee_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.wire_fee_val IS 'We MAY want to see if we should try to get this via merchant_exchange_wire_fees (not sure, may be too complicated with the date range, etc.)';
-
-
---
--- Name: COLUMN merchant_deposits.signkey_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.signkey_serial IS 'Online signing key of the exchange on the deposit confirmation';
-
-
---
--- Name: COLUMN merchant_deposits.exchange_sig; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_deposits.exchange_sig IS 'Signature of the exchange over the deposit confirmation';
-
-
---
--- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_deposits ALTER COLUMN deposit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_deposits_deposit_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_exchange_signing_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_exchange_signing_keys (
- signkey_serial bigint NOT NULL,
- master_pub bytea NOT NULL,
- exchange_pub bytea NOT NULL,
- start_date bigint NOT NULL,
- expire_date bigint NOT NULL,
- end_date bigint NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT merchant_exchange_signing_keys_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT merchant_exchange_signing_keys_master_pub_check CHECK ((length(master_pub) = 32)),
- CONSTRAINT merchant_exchange_signing_keys_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_exchange_signing_keys; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_exchange_signing_keys IS 'Here we store proofs of the exchange online signing keys being signed by the exchange master key';
-
-
---
--- Name: COLUMN merchant_exchange_signing_keys.master_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_exchange_signing_keys.master_pub IS 'Master public key of the exchange with these online signing keys';
-
-
---
--- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_exchange_signing_keys ALTER COLUMN signkey_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_exchange_signing_keys_signkey_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_exchange_wire_fees; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_exchange_wire_fees (
- wirefee_serial bigint NOT NULL,
- master_pub bytea NOT NULL,
- h_wire_method bytea 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 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)),
- CONSTRAINT merchant_exchange_wire_fees_master_sig_check CHECK ((length(master_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_exchange_wire_fees; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_exchange_wire_fees IS 'Here we store proofs of the wire fee structure of the various exchanges';
-
-
---
--- Name: COLUMN merchant_exchange_wire_fees.master_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_exchange_wire_fees.master_pub IS 'Master public key of the exchange with these wire fees';
-
-
---
--- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_exchange_wire_fees ALTER COLUMN wirefee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_exchange_wire_fees_wirefee_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_instances; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.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,
- jurisdiction bytea NOT NULL,
- default_max_deposit_fee_val bigint NOT NULL,
- default_max_deposit_fee_frac integer NOT NULL,
- default_max_wire_fee_val bigint NOT NULL,
- default_max_wire_fee_frac integer NOT NULL,
- default_wire_fee_amortization integer NOT NULL,
- default_wire_transfer_delay bigint NOT NULL,
- default_pay_delay bigint NOT NULL,
- 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))
-);
-
-
---
--- Name: TABLE merchant_instances; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_instances IS 'all the instances supported by this backend';
-
-
---
--- Name: COLUMN merchant_instances.auth_hash; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.merchant_id IS 'identifier of the merchant as used in the base URL (required)';
-
-
---
--- Name: COLUMN merchant_instances.merchant_name; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.merchant_name IS 'legal name of the merchant as a simple string (required)';
-
-
---
--- Name: COLUMN merchant_instances.address; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.address IS 'physical address of the merchant as a Location in JSON format (required)';
-
-
---
--- Name: COLUMN merchant_instances.jurisdiction; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.jurisdiction IS 'jurisdiction of the merchant as a Location in JSON format (required)';
-
-
---
--- Name: COLUMN merchant_instances.website; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.website IS 'merchant site URL';
-
-
---
--- Name: COLUMN merchant_instances.email; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.email IS 'email';
-
-
---
--- Name: COLUMN merchant_instances.logo; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_instances.logo IS 'data image url';
-
-
---
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_instances ALTER COLUMN merchant_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_instances_merchant_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_inventory; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_inventory (
- product_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- product_id character varying NOT NULL,
- description character varying NOT NULL,
- description_i18n bytea NOT NULL,
- unit character varying NOT NULL,
- image bytea NOT NULL,
- taxes bytea NOT NULL,
- price_val bigint NOT NULL,
- price_frac integer NOT NULL,
- total_stock bigint NOT NULL,
- total_sold bigint DEFAULT 0 NOT NULL,
- total_lost bigint DEFAULT 0 NOT NULL,
- address bytea NOT NULL,
- next_restock bigint NOT NULL,
- minimum_age integer DEFAULT 0 NOT NULL
-);
-
-
---
--- Name: TABLE merchant_inventory; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_inventory IS 'products offered by the merchant (may be incomplete, frontend can override)';
-
-
---
--- Name: COLUMN merchant_inventory.description; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.description IS 'Human-readable product description';
-
-
---
--- Name: COLUMN merchant_inventory.description_i18n; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.description_i18n IS 'JSON map from IETF BCP 47 language tags to localized descriptions';
-
-
---
--- Name: COLUMN merchant_inventory.unit; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.unit IS 'Unit of sale for the product (liters, kilograms, packages)';
-
-
---
--- Name: COLUMN merchant_inventory.image; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.image IS 'NOT NULL, but can be 0 bytes; must contain an ImageDataUrl';
-
-
---
--- Name: COLUMN merchant_inventory.taxes; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.taxes IS 'JSON array containing taxes the merchant pays, must be JSON, but can be just "[]"';
-
-
---
--- Name: COLUMN merchant_inventory.price_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.price_val IS 'Current price of one unit of the product';
-
-
---
--- Name: COLUMN merchant_inventory.total_stock; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_stock IS 'A value of -1 is used for unlimited (electronic good), may never be lowered';
-
-
---
--- Name: COLUMN merchant_inventory.total_sold; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_sold IS 'Number of products sold, must be below total_stock, non-negative, may never be lowered';
-
-
---
--- Name: COLUMN merchant_inventory.total_lost; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.total_lost IS 'Number of products that used to be in stock but were lost (spoiled, damaged), may never be lowered; total_stock >= total_sold + total_lost must always hold';
-
-
---
--- Name: COLUMN merchant_inventory.address; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.address IS 'JSON formatted Location of where the product is stocked';
-
-
---
--- Name: COLUMN merchant_inventory.next_restock; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory.next_restock IS 'GNUnet absolute time indicating when the next restock is expected. 0 for unknown.';
-
-
---
--- Name: COLUMN merchant_inventory.minimum_age; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_inventory_locks (
- product_serial bigint NOT NULL,
- lock_uuid bytea NOT NULL,
- total_locked bigint NOT NULL,
- expiration bigint NOT NULL,
- CONSTRAINT merchant_inventory_locks_lock_uuid_check CHECK ((length(lock_uuid) = 16))
-);
-
-
---
--- Name: TABLE merchant_inventory_locks; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_inventory_locks IS 'locks on inventory helt by shopping carts; note that locks MAY not be honored if merchants increase total_lost for inventory';
-
-
---
--- Name: COLUMN merchant_inventory_locks.total_locked; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory_locks.total_locked IS 'how many units of the product does this lock reserve';
-
-
---
--- Name: COLUMN merchant_inventory_locks.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_inventory_locks.expiration IS 'when does this lock automatically expire (if no order is created)';
-
-
---
--- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_inventory ALTER COLUMN product_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_inventory_product_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_keys (
- merchant_priv bytea NOT NULL,
- merchant_serial bigint NOT NULL,
- CONSTRAINT merchant_keys_merchant_priv_check CHECK ((length(merchant_priv) = 32))
-);
-
-
---
--- Name: TABLE merchant_keys; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_keys IS 'private keys of instances that have not been deleted';
-
-
---
--- Name: merchant_kyc; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_kyc (
- kyc_serial_id bigint NOT NULL,
- kyc_timestamp bigint NOT NULL,
- kyc_ok boolean DEFAULT false NOT NULL,
- exchange_sig bytea,
- exchange_pub bytea,
- exchange_kyc_serial bigint DEFAULT 0 NOT NULL,
- account_serial bigint NOT NULL,
- exchange_url character varying NOT NULL,
- CONSTRAINT merchant_kyc_exchange_pub_check CHECK ((length(exchange_pub) = 32)),
- CONSTRAINT merchant_kyc_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_kyc; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_kyc IS 'Status of the KYC process of a merchant account at an exchange';
-
-
---
--- Name: COLUMN merchant_kyc.kyc_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.kyc_timestamp IS 'Last time we checked our KYC status at the exchange. Useful to re-check if the status is very stale. Also the timestamp used for the exchange signature (if present).';
-
-
---
--- Name: COLUMN merchant_kyc.kyc_ok; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.kyc_ok IS 'true if the KYC check was passed successfully';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_sig; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_sig IS 'signature of the exchange affirming the KYC passed (or NULL if exchange does not require KYC or not kyc_ok)';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_pub; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_pub IS 'public key used with exchange_sig (or NULL if exchange_sig is NULL)';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_kyc_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_kyc_serial IS 'Number to use in the KYC-endpoints of the exchange to check the KYC status or begin the KYC process. 0 if we do not know it yet.';
-
-
---
--- Name: COLUMN merchant_kyc.account_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.account_serial IS 'Which bank account of the merchant is the KYC status for';
-
-
---
--- Name: COLUMN merchant_kyc.exchange_url; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_kyc.exchange_url IS 'Which exchange base URL is this KYC status valid for';
-
-
---
--- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_kyc ALTER COLUMN kyc_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_kyc_kyc_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_order_locks; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_order_locks (
- product_serial bigint NOT NULL,
- total_locked bigint NOT NULL,
- order_serial bigint NOT NULL
-);
-
-
---
--- Name: TABLE merchant_order_locks; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_order_locks IS 'locks on orders awaiting claim and payment; note that locks MAY not be honored if merchants increase total_lost for inventory';
-
-
---
--- Name: COLUMN merchant_order_locks.total_locked; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_order_locks.total_locked IS 'how many units of the product does this lock reserve';
-
-
---
--- Name: merchant_orders; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_orders (
- order_serial bigint NOT NULL,
- merchant_serial bigint NOT NULL,
- order_id character varying NOT NULL,
- claim_token bytea NOT NULL,
- h_post_data bytea NOT NULL,
- pay_deadline bigint NOT NULL,
- creation_time bigint NOT NULL,
- contract_terms bytea NOT NULL,
- CONSTRAINT merchant_orders_claim_token_check CHECK ((length(claim_token) = 16)),
- CONSTRAINT merchant_orders_h_post_data_check CHECK ((length(h_post_data) = 64))
-);
-
-
---
--- Name: TABLE merchant_orders; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_orders IS 'Orders we offered to a customer, but that have not yet been claimed';
-
-
---
--- Name: COLUMN merchant_orders.merchant_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.merchant_serial IS 'Identifies the instance offering the contract';
-
-
---
--- Name: COLUMN merchant_orders.claim_token; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.claim_token IS 'Token optionally used to authorize the wallet to claim the order. All zeros (not NULL) if not used';
-
-
---
--- Name: COLUMN merchant_orders.h_post_data; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.h_post_data IS 'Hash of the POST request that created this order, for idempotency checks';
-
-
---
--- Name: COLUMN merchant_orders.pay_deadline; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.pay_deadline IS 'How long is the offer valid. After this time, the order can be garbage collected';
-
-
---
--- Name: COLUMN merchant_orders.contract_terms; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_orders.contract_terms IS 'Claiming changes the contract_terms, hence we have no hash of the terms in this table';
-
-
---
--- Name: merchant_orders_order_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_orders ALTER COLUMN order_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_orders_order_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_refund_proofs; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_refund_proofs (
- refund_serial bigint NOT NULL,
- exchange_sig bytea NOT NULL,
- signkey_serial bigint NOT NULL,
- CONSTRAINT merchant_refund_proofs_exchange_sig_check CHECK ((length(exchange_sig) = 64))
-);
-
-
---
--- Name: TABLE merchant_refund_proofs; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_refund_proofs IS 'Refunds confirmed by the exchange (not all approved refunds are grabbed by the wallet)';
-
-
---
--- Name: merchant_refunds; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_refunds (
- refund_serial bigint NOT NULL,
- order_serial bigint NOT NULL,
- rtransaction_id bigint NOT NULL,
- refund_timestamp bigint NOT NULL,
- coin_pub bytea NOT NULL,
- reason character varying NOT NULL,
- refund_amount_val bigint NOT NULL,
- refund_amount_frac integer NOT NULL
-);
-
-
---
--- Name: COLUMN merchant_refunds.rtransaction_id; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_refunds.rtransaction_id IS 'Needed for uniqueness in case a refund is increased for the same order';
-
-
---
--- Name: COLUMN merchant_refunds.refund_timestamp; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_refunds.refund_timestamp IS 'Needed for grouping of refunds in the wallet UI; has no semantics in the protocol (only for UX), but should be from the time when the merchant internally approved the refund';
-
-
---
--- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_refunds ALTER COLUMN refund_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_refunds_refund_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tip_pickup_signatures; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_pickup_signatures (
- pickup_serial bigint NOT NULL,
- coin_offset integer NOT NULL,
- blind_sig bytea NOT NULL
-);
-
-
---
--- Name: TABLE merchant_tip_pickup_signatures; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_pickup_signatures IS 'blind signatures we got from the exchange during the tip pickup';
-
-
---
--- Name: merchant_tip_pickups; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_pickups (
- pickup_serial bigint NOT NULL,
- tip_serial bigint NOT NULL,
- pickup_id bytea NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- CONSTRAINT merchant_tip_pickups_pickup_id_check CHECK ((length(pickup_id) = 64))
-);
-
-
---
--- Name: TABLE merchant_tip_pickups; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_pickups IS 'tips that have been picked up';
-
-
---
--- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tip_pickups ALTER COLUMN pickup_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tip_pickups_pickup_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tip_reserve_keys; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_reserve_keys (
- reserve_serial bigint NOT NULL,
- reserve_priv bytea NOT NULL,
- exchange_url character varying NOT NULL,
- payto_uri character varying,
- CONSTRAINT merchant_tip_reserve_keys_reserve_priv_check CHECK ((length(reserve_priv) = 32))
-);
-
-
---
--- Name: COLUMN merchant_tip_reserve_keys.payto_uri; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserve_keys.payto_uri IS 'payto:// URI used to fund the reserve, may be NULL once reserve is funded';
-
-
---
--- Name: merchant_tip_reserves; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tip_reserves (
- reserve_serial bigint NOT NULL,
- reserve_pub bytea NOT NULL,
- merchant_serial bigint NOT NULL,
- creation_time bigint NOT NULL,
- expiration bigint NOT NULL,
- merchant_initial_balance_val bigint NOT NULL,
- merchant_initial_balance_frac integer NOT NULL,
- exchange_initial_balance_val bigint DEFAULT 0 NOT NULL,
- exchange_initial_balance_frac integer DEFAULT 0 NOT NULL,
- tips_committed_val bigint DEFAULT 0 NOT NULL,
- tips_committed_frac integer DEFAULT 0 NOT NULL,
- tips_picked_up_val bigint DEFAULT 0 NOT NULL,
- tips_picked_up_frac integer DEFAULT 0 NOT NULL,
- CONSTRAINT merchant_tip_reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
-);
-
-
---
--- Name: TABLE merchant_tip_reserves; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tip_reserves IS 'private keys of reserves that have not been deleted';
-
-
---
--- Name: COLUMN merchant_tip_reserves.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.expiration IS 'FIXME: EXCHANGE API needs to tell us when reserves close if we are to compute this';
-
-
---
--- Name: COLUMN merchant_tip_reserves.merchant_initial_balance_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.merchant_initial_balance_val IS 'Set to the initial balance the merchant told us when creating the reserve';
-
-
---
--- Name: COLUMN merchant_tip_reserves.exchange_initial_balance_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.exchange_initial_balance_val IS 'Set to the initial balance the exchange told us when we queried the reserve status';
-
-
---
--- Name: COLUMN merchant_tip_reserves.tips_committed_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.tips_committed_val IS 'Amount of outstanding approved tips that have not been picked up';
-
-
---
--- Name: COLUMN merchant_tip_reserves.tips_picked_up_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tip_reserves.tips_picked_up_val IS 'Total amount tips that have been picked up from this reserve';
-
-
---
--- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tip_reserves ALTER COLUMN reserve_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tip_reserves_reserve_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_tips; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_tips (
- tip_serial bigint NOT NULL,
- reserve_serial bigint NOT NULL,
- tip_id bytea NOT NULL,
- justification character varying NOT NULL,
- next_url character varying NOT NULL,
- expiration bigint NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- picked_up_val bigint DEFAULT 0 NOT NULL,
- picked_up_frac integer DEFAULT 0 NOT NULL,
- was_picked_up boolean DEFAULT false NOT NULL,
- CONSTRAINT merchant_tips_tip_id_check CHECK ((length(tip_id) = 64))
-);
-
-
---
--- Name: TABLE merchant_tips; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_tips IS 'tips that have been authorized';
-
-
---
--- Name: COLUMN merchant_tips.reserve_serial; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.reserve_serial IS 'Reserve from which this tip is funded';
-
-
---
--- Name: COLUMN merchant_tips.expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.expiration IS 'by when does the client have to pick up the tip';
-
-
---
--- Name: COLUMN merchant_tips.amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.amount_val IS 'total transaction cost for all coins including withdraw fees';
-
-
---
--- Name: COLUMN merchant_tips.picked_up_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_tips.picked_up_val IS 'Tip amount left to be picked up';
-
-
---
--- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_tips ALTER COLUMN tip_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_tips_tip_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: merchant_transfer_signatures; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfer_signatures (
- credit_serial bigint NOT NULL,
- signkey_serial bigint NOT NULL,
- wire_fee_val bigint NOT NULL,
- wire_fee_frac integer 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))
-);
-
-
---
--- Name: TABLE merchant_transfer_signatures; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfer_signatures IS 'table represents the main information returned from the /transfer request to the exchange.';
-
-
---
--- Name: COLUMN merchant_transfer_signatures.credit_amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.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: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_signatures.execution_time IS 'Execution time as claimed by the exchange, roughly matches time seen by merchant';
-
-
---
--- Name: merchant_transfer_to_coin; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfer_to_coin (
- deposit_serial bigint NOT NULL,
- credit_serial bigint NOT NULL,
- offset_in_exchange_list bigint NOT NULL,
- exchange_deposit_value_val bigint NOT NULL,
- exchange_deposit_value_frac integer NOT NULL,
- exchange_deposit_fee_val bigint NOT NULL,
- exchange_deposit_fee_frac integer NOT NULL
-);
-
-
---
--- Name: TABLE merchant_transfer_to_coin; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfer_to_coin IS 'Mapping of (credit) transfers to (deposited) coins';
-
-
---
--- Name: COLUMN merchant_transfer_to_coin.exchange_deposit_value_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_to_coin.exchange_deposit_value_val IS 'Deposit value as claimed by the exchange, should match our values in merchant_deposits minus refunds';
-
-
---
--- Name: COLUMN merchant_transfer_to_coin.exchange_deposit_fee_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfer_to_coin.exchange_deposit_fee_val IS 'Deposit value as claimed by the exchange, should match our values in merchant_deposits';
-
-
---
--- Name: merchant_transfers; Type: TABLE; Schema: merchant; Owner: -
---
-
-CREATE TABLE merchant.merchant_transfers (
- credit_serial bigint NOT NULL,
- exchange_url character varying NOT NULL,
- wtid bytea,
- credit_amount_val bigint NOT NULL,
- credit_amount_frac integer NOT NULL,
- account_serial bigint NOT NULL,
- verified boolean DEFAULT false NOT NULL,
- confirmed boolean DEFAULT false NOT NULL,
- CONSTRAINT merchant_transfers_wtid_check CHECK ((length(wtid) = 32))
-);
-
-
---
--- Name: TABLE merchant_transfers; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON TABLE merchant.merchant_transfers IS 'table represents the information provided by the (trusted) merchant about incoming wire transfers';
-
-
---
--- Name: COLUMN merchant_transfers.credit_amount_val; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.credit_amount_val IS 'actual value of the (aggregated) wire transfer, excluding the wire fee, according to the merchant';
-
-
---
--- Name: COLUMN merchant_transfers.verified; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.verified IS 'true once we got an acceptable response from the exchange for this transfer';
-
-
---
--- Name: COLUMN merchant_transfers.confirmed; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON COLUMN merchant.merchant_transfers.confirmed IS 'true once the merchant confirmed that this transfer was received';
-
-
---
--- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE; Schema: merchant; Owner: -
---
-
-ALTER TABLE merchant.merchant_transfers ALTER COLUMN credit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
- SEQUENCE NAME merchant.merchant_transfers_credit_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1
-);
-
-
---
--- Name: auditor_reserves auditor_reserves_rowid; Type: DEFAULT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves ALTER COLUMN auditor_reserves_rowid SET DEFAULT nextval('auditor.auditor_reserves_auditor_reserves_rowid_seq'::regclass);
-
-
---
--- Name: deposit_confirmations serial_id; Type: DEFAULT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations ALTER COLUMN serial_id SET DEFAULT nextval('auditor.deposit_confirmations_serial_id_seq'::regclass);
-
-
---
--- Data for Name: patches; Type: TABLE DATA; Schema: _v; Owner: -
---
-
-COPY _v.patches (patch_name, applied_tsz, applied_by, requires, conflicts) FROM stdin;
-exchange-0001 2022-08-11 23:06:00.102085+02 grothoff {} {}
-merchant-0001 2022-08-11 23:06:01.190116+02 grothoff {} {}
-merchant-0002 2022-08-11 23:06:01.583736+02 grothoff {} {}
-auditor-0001 2022-08-11 23:06:01.726936+02 grothoff {} {}
-\.
-
-
---
--- Data for Name: auditor_balance_summary; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_balance_summary (master_pub, denom_balance_val, denom_balance_frac, deposit_fee_balance_val, deposit_fee_balance_frac, melt_fee_balance_val, melt_fee_balance_frac, refund_fee_balance_val, refund_fee_balance_frac, risk_val, risk_frac, loss_val, loss_frac, irregular_recoup_val, irregular_recoup_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_denomination_pending; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_denomination_pending (denom_pub_hash, denom_balance_val, denom_balance_frac, denom_loss_val, denom_loss_frac, num_issued, denom_risk_val, denom_risk_frac, recoup_loss_val, recoup_loss_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_exchange_signkeys; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchange_signkeys (master_pub, ep_start, ep_expire, ep_end, exchange_pub, master_sig) FROM stdin;
-\\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc 1660251974000000 1667509574000000 1669928774000000 \\x672f96a79906416c79911983f7f421ea7601768c5682b00c0182e6127c394ce5 \\xaef46bdc9c4d567dbd397ec55797c87379aeee60d6756af2c0d32ace59e32f0afcf671521ad58c69e92b2e06c6049f01793c7b539323c438483be063abed8f00
-\.
-
-
---
--- Data for Name: auditor_exchanges; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchanges (master_pub, exchange_url) FROM stdin;
-\\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc http://localhost:8081/
-\.
-
-
---
--- Data for Name: auditor_historic_denomination_revenue; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_historic_denomination_revenue (master_pub, denom_pub_hash, revenue_timestamp, revenue_balance_val, revenue_balance_frac, loss_balance_val, loss_balance_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_historic_reserve_summary; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_historic_reserve_summary (master_pub, start_date, end_date, reserve_profits_val, reserve_profits_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_predicted_result; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_predicted_result (master_pub, balance_val, balance_frac, drained_val, drained_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_aggregation; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_progress_aggregation (master_pub, last_wire_out_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_coin; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_progress_deposit_confirmation; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_progress_deposit_confirmation (master_pub, last_deposit_confirmation_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_progress_reserve; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_reserve_balance; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.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;
-\.
-
-
---
--- Data for Name: auditor_reserves; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_reserves (reserve_pub, master_pub, reserve_balance_val, reserve_balance_frac, withdraw_fee_balance_val, withdraw_fee_balance_frac, expiration_date, auditor_reserves_rowid, origin_account) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_wire_fee_balance; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_wire_fee_balance (master_pub, wire_fee_balance_val, wire_fee_balance_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: deposit_confirmations; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.deposit_confirmations (master_pub, serial_id, h_contract_terms, h_extensions, h_wire, exchange_timestamp, refund_deadline, wire_deadline, amount_without_fee_val, amount_without_fee_frac, coin_pub, merchant_pub, exchange_sig, exchange_pub, master_sig) FROM stdin;
-\\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc 1 \\x8441fd1913c230ce67352d8eb45d6c172a1b5e5855d8b46b4697557670d81e8dad19fe10cb06f98c00112665d5cf514100ff77d7319c87709f638c1a91092ce8 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x0678b2516a6a03a07d769bdcecf7a468774ffd8d9fdc71dd9db51083b16ec263f2c97333baaed167625c522e0b6498f54c4f522a1e78d307b5b99550fdb12e8b 1660252005000000 1660252903000000 1660252903000000 0 98000000 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\xd50dc64ca5b7862a12c155e61b64594afc040a31a2be906a362afdbd8aab7b3a5170546d859add936f63fe8355da242984643faf82de20103ab5eff7c78bc606 \\x672f96a79906416c79911983f7f421ea7601768c5682b00c0182e6127c394ce5 \\x206ba860fe7f00001d59ed840f560000dd12aa850f5600003a12aa850f5600002012aa850f5600002412aa850f560000c09baa850f5600000000000000000000
-\\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc 2 \\xd7b5b06be021d66ce41c6560f4717a47aa0b555d40e5791a644bb0586713b09286338aa317eb152d53e5f01914f565c98294bd0e1c75a9844760606674fd4a07 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x0678b2516a6a03a07d769bdcecf7a468774ffd8d9fdc71dd9db51083b16ec263f2c97333baaed167625c522e0b6498f54c4f522a1e78d307b5b99550fdb12e8b 1660856839000000 1660252935000000 1660252935000000 0 0 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x2224d9bb7f6af8966c5f4eaf1041a3b8034a5ea9ade16dcae7a330da5d455afd94f9b2436372bc2c2031c1f5a7d8253caabb111ee71d44f2909cae0c0e71ed0d \\x672f96a79906416c79911983f7f421ea7601768c5682b00c0182e6127c394ce5 \\x206ba860fe7f00001d59ed840f560000bd43ab850f5600001a43ab850f5600000043ab850f5600000443ab850f5600000015aa850f5600000000000000000000
-\.
-
-
---
--- Data for Name: wire_auditor_account_progress; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.wire_auditor_account_progress (master_pub, account_name, last_wire_reserve_in_serial_id, last_wire_wire_out_serial_id, wire_in_off, wire_out_off) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_auditor_progress; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.wire_auditor_progress (master_pub, last_timestamp, last_reserve_close_uuid) FROM stdin;
-\.
-
-
---
--- Data for Name: account_merges_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.account_merges_default (account_merge_request_serial_id, reserve_pub, reserve_sig, purse_pub, wallet_h_payto) FROM stdin;
-\.
-
-
---
--- Data for Name: aggregation_tracking_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.aggregation_tracking_default (aggregation_serial_id, deposit_serial_id, wtid_raw) FROM stdin;
-\.
-
-
---
--- Data for Name: aggregation_transient_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.aggregation_transient_default (amount_val, amount_frac, wire_target_h_payto, merchant_pub, exchange_account_section, wtid_raw) FROM stdin;
-\.
-
-
---
--- Data for Name: auditor_denom_sigs; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.auditor_denom_sigs (auditor_denom_serial, auditor_uuid, denominations_serial, auditor_sig) FROM stdin;
-1 1 16 \\x0edc8505bbf15aada1bc79b9ef37abefdc379c685ae92309f6b3bb3cc5180d42ab92c35980e7780b0a31649d043710b71c6e428d640c12a515bada5c15d1c609
-2 1 33 \\xfb10e64bdf7369347f69f590870f4d4c1f35f393893e763be9e5ca16e3ce69aa9045ecfba5c72d0815566830ed1c149d31b9c6b9978dcbf488c9812f3a172c0a
-3 1 399 \\x8d131404c33775eeb279c83b2f8a89b0c5ec17f69bfc61e5308836b80007b1ce0909241882e0f5094fba3cfde875ee6cb2bc8afd3885d8264341a7accf805b01
-4 1 43 \\x91303fc99ffc4eb349a3d50884634458c5ec722e193cd7915470c0d61fe30ba3d1055a6f4d411c9c6a15c27961c17ea49f131b7faed8e64667f0d8637111820b
-5 1 117 \\xc8728e301d44815a3e914ec0fa24141a9745b0af0f44000322f8dd8b17572522a433a7ab913d52f3fd2ffb5ccb1654226c4873a9ce54062fd250c59a05cf8a01
-6 1 51 \\xe30280a983e09a60edc401d546f7f4c311f834f65d6ba789d29d66d6c2009fd33abfd0a95d333f2094b5526fa43e5c1b9ee73203936eacf940221423cbb9d104
-7 1 386 \\x712e1aa79d52c3b7ad1b4e63996cb3d542bbb6df0ee5669ea830a73ccbf1d6122c30779944c579f1f9a21fa00a3304caed7f54e784fef0daeed94660fe2d6b0b
-8 1 213 \\x7750a67c7925cf4dea6f2c82473ae701f2457237c182707e76957661a9207bfef621144b28ffac6ce04d968ae614b8889016b5e70c82af55238a557f914d0908
-9 1 188 \\x82045fdc85b6bc1eab3ed0fa364f2826c0cbbaf899d542e5c4781796e57a17285507347cf58fdd4271359b44b1a4515e7d24da0ca1d80811c0e0b061418faf01
-10 1 194 \\x88e1d461d8137386b6b95a9be109a346ff0eea4a9e880ce032abce74e0750881f7bc5d6f552c0ff633a8797ae22d98848cb433815d49754052217e023acfdf0b
-11 1 171 \\x38747f8c017456b849479f5539fbacfb89c1e5fd7571991e2a92a6e3aa3d1cc67216f7b4399bfbfed5cf5eafb1a83d34dd1e92222b3f1e6479b149fee9740d01
-12 1 204 \\xa94aa9b2262d4815c0bb81f8d523417efbf400450daceccf6985efabc3c4cf4e2af0dbdb0f2c6f7121b67e350052427ecab74d67d2e0b08347f8834aca29db01
-13 1 224 \\xd304add810ff4a3601e5b43d90446fb9e9e44b697f5d9c17a533ae7030aa7945cacf2f2eaabe952bdda043bb7f2cc7090b33600e8ac6a8a7e88635e8c2947807
-14 1 263 \\x5ac0a957a299aa06ce9abfde927a5426b1aee3bb98f3380b7ea2607dffa84887135751db0c83946451d9fc7e1855036756bf57edaab96d7fe1297546e2b74e0a
-15 1 248 \\x811d1972c277dc3ef10dbaa43d90c1a97f953aa720a4a0789edb552bf257be76bdb5e6be723884fefb1fc38c0dcea0958e87c31a700b2ebb14088335843c9d05
-16 1 310 \\xbd272f0a01b275f3ede018a4dca9a2a46776be4ae868487c812e1ca7ffc4493331a79334b88a5a89d55583bc62062127160e215e4659679b2f2364eb44d9ba0c
-17 1 327 \\x9f2a661cbe2143492a44c6043f57b12ed24d0f6ece3366307df0b5e262f0424293b4da5d361af7a3ff34f94fa7bca3bf5a2cd12d34980a6eee9db382d8dfd80c
-18 1 304 \\x1a5de6c44821ecb35be173f9dfc5b5723a3d62148cd48fbeb8b14f74eab80c0b137748c12b82758cb1e767fe7c899079664c022d1e47684d42a1646f44960804
-19 1 256 \\x4e23bd5ff742a027f3987f5bdb493331163e03648708434db96d68aa7ec9151efc7e5188dbcdd41b1f03a97747fb6d456356cfb21b6051e238a561b78a2be70c
-20 1 98 \\x8f70ccca770fbe04f30921631ba082febb0a002b21570766c26ededc6bf4ffea221cf5bb53fe7de953626a4d5edcb33787bfd35af8ab1a11166ee513792c3c08
-21 1 361 \\x8c3ac60cf64ca563eaef49fb3911b587fd3468aada1952876aac07ffde06f692c18f22a7de5dbd3be6faa484d0a86b65dace0d4fa01b1f68eb46ad707f492303
-22 1 20 \\xd17bee01f58f5241958534ff7090d18f0aae5be5f22eb5c233faa276e4b5d149654c9a7cda33aa9a7b271b69b66357082ccf4185be9d3478260654ddd25b3d05
-23 1 110 \\x3f9eda69d7f1cb8a69c9525e4a2aba8e36867d096feb2bca8b15d99fe151c36d2ec720269d28274738cf6ed43b7cdc6e466aad67416a477c5193078a3e99b304
-24 1 149 \\x49497771ae6cc30a3747271ec7341ec69a8f800db713558b2c16aa82d660d6dd7354a454ead41bf656fa7bff453f11e6d92cac218dfeebb9e46ca7a75df1cd0c
-25 1 18 \\x9b0eb799756527740783de8abd3d291080df4ff6c9b5025b1e182c0f5b69b8451bd41a32af35ff7f7a7bea94a71afd784586347893e9be634b14c091eaa74c0c
-26 1 92 \\xe7963da484ecb925881119f752834c782eaefae891b05c5ea3d5dce9f0de3991d6d8735859d65b6bab8db5c61c3bc6e4dc1b8e447f71da6ff9f38d9dfef4ff0a
-27 1 354 \\x1b0e13b16e4817aa95492f020e1da3c2bc0f3952c623bf67c74b17aa94d7c566502c39722b61728e0a68337c9a5b054c28216acbed61987e5732c54c4afe5e0e
-28 1 270 \\x68adbf4b874604acd2b4221bc19cc3cfb5b7f1196f5cd2250f9a34378038e7764c79608453827c530dfffa0a2fac3dc3f628bdf796ec958244b7527f5d54bd0e
-29 1 413 \\x76c856fcbac8e7ec06fc0924c4d600d302bc3b1808f02bf2ad9dc0c4d2f9f681a8d2f030c4ccc00cece64a0469acd07d096033b4ac6cdb63c8ca1c61a2687006
-30 1 296 \\x314680a5bc8567a3d84f0fc10794eb0cf44f2d5d7efbaa5bbb83e37ced0ed80bf8b6e227d60b58c51b0e02eb613f9781bc525de56e5c1c942f2c77bf34d0a708
-31 1 19 \\x0deacf6ec75753a4b695c2a31e3bba907a8c98ddcc04fddcf1f344079e23b4129c84ce1f9ef83372bdba84325f936e59f0a42eda1112e245eaa952c05c62a10b
-32 1 97 \\x6c3a0a1580a7cfb7f384fea8620bb5cc5a754ca9c31f7495509d970963613a6f009d1604447b780164d5d64c329d01e329616e9983564ff4017b5fb8b2acad09
-33 1 38 \\xa2eb6bda77bcc520f4d7ca535517e08587addab9a739ab0803e0cc525ac694aa73f6ef34090ab1f55c5792d81e2f84f073b7ff01956ea015dbc796e8f9313806
-34 1 362 \\xd185bc51a066c618b35b4b0228d868dfa2ce3f2fe375f0a4c5dbda1e61198eaafb6b7985e3e0a7ee794dea0152e2b231f04dad1e9190647c85bb89fe869c9403
-35 1 14 \\xc2c2d8cb3d3e8f3328043b18b52a895d0410e99968005cfed186e403fa8fbf1319bb857c31baf8a0645e825b4abc02f496ebc65d251918cdb21a88557888410a
-36 1 383 \\xf9931bd6b341b0b9d748c3a4db74b16e8a18e52ba73ac2d24aeed62f79a9597f618b75b10a57d5a16c3325d59149b01c23177b697a50ade916b5ce4fcf46670e
-37 1 72 \\xd404b22f09e6d47ca3ae0c92edd7dc7727203bb515f9673a6697ef4cf5d0008453c6ff754dbf17e9d138600452341ed7d3fe0ef7d05eca9716c6535c513e2204
-38 1 208 \\xe7955263a9e36ba3188f0965313d757eb26a0d185fc52142e371f75f1c3dbacd3d44cbea3da8997650937d90e0af06f56b12164ad465c3129007a817c1a6ef0f
-39 1 273 \\x6381077c88c4745837233f97bb4fe4e0e2a927621b2b20a6677f151d1ed29d4e7a89f08e07f716543d282174f896a6c1830322b948668ea1d97b7bfa9c5e8102
-40 1 319 \\xab66f647160f7d82e49d052e21c795f8b0ecc60b0b9047db6459666cffee0b74d721854c6e7252a2e3431ad363140a850939f6d2bc06fbcfd129597fcbad4903
-41 1 280 \\x5b4bba35956fcc923618fedfe631e22d153bc6fa7ccb53318feb00328f6b8a6492b5771eacf79488620f09b4c889fe80f01c4f4b83b6438dd5b711b03d244d05
-42 1 415 \\x6cba0e5b348e4a26464688114dac9bf51ee0765749d3e7f715bcd1b93c441d1705eb93998372c767c90a7a0b7fd4cfae7fb2cd91d7f4efea2962f0bdb6d8e00e
-43 1 26 \\x81f4a3d09c9292d2b00be72675c4835673e8343f74da22bde20e42818b590c8e44579e9a37fe0e838d35e7be4f553507a776834402252512dc746e5b1d078705
-44 1 391 \\xd95317f30f49f95b28e9363ef9c3fe446d48e331b58a33bdd90d16466aa1a41694385cfe3076a804ea0b68133aef510a0be50819e8a7be6b76006d4fabc63208
-45 1 180 \\xb36ab310034bb29ff688edf09df38f9b9353e7a14be062f11727ee54e39a519b151ff0016ec01b720731e26e354c5a0ddfa8a139c6705d7b79269521756dcf0a
-46 1 411 \\xb8b0c0ad888055bd3822d4365da34b7e7efa0a5b47ba3233953b344d1a08526dc3ca1486e01e22ec44e373cc1e268f64911b316ca6164259858992d4215e2402
-47 1 359 \\x7bc70a79a1281012c7ec775e3063e53404473765957df3157b5d0521c5e79590bc45640131dbac47cb55d77a0d7ed2ec605cbf8f47a226f77953582808047f0c
-48 1 239 \\x4e0790ab604727e554aca82a36205b6d64e2ff8121acb1f7fd5dfde668e1c6f2b6e61038f348ab76ef9ff6d115e2a0cd29885445a8f43dd23fc5309e57704b00
-49 1 66 \\xb7b7617fe45f1e2b6c1caa8d84eab6f7ac75b56ddd5109bef79cd14281147779060cf806a931bf139ddc019200f5b966dfbcaaddf991fceaa2f3624ff9e2af0c
-50 1 382 \\x1564ba7fbca959175fd6f7bb52c9cd0c42590d703b87f88bf83461dd9bcc564aa1a16051b380530675c5e9be684bb4d9199d1e35b19ff0dfb2413c51d73a9507
-51 1 153 \\x3971a94b5d1201569a95c6d3da4411822a8df6dc11128d6eb00ed56decccf088edf6fdd99f2d18fa8fc0934707cb70a18e3e2fcd548b0e5a0cd79b16609c790a
-52 1 220 \\x86f6c99db8f6a76ff7764e496989330430af1e06b2ad5f05154d2913d74f429f98a21c3998b4b55824cd867570f15ed9787b85fdaf84caaf3bd59861f5077600
-53 1 423 \\xe24985badb50740e6e65a4c15619f9051bc373145932c4ab1ea73e45a63a9f4d867f7c6a544f2ca0374c3119ed22f22efa1133bd34589709fc1fd57d18a9c707
-54 1 259 \\xc1928fc8082d67bf599396a10908a263b3e4b7ce6ba0d1acdfd9f93e97a6f46e931290b70c3de7cdf042faac98768f5a4893e00e51cac8c459bd1f102736a70d
-55 1 283 \\x7422d7951c55ad6903f877fdbbf4acfc4d2a16d8255af6ea07bafd5e19ce5fab6da78445af32cdf452180bdcdaf50f9e7425336779b1027ddf2e0fa0b90d3f04
-56 1 269 \\x1abe586be1ed8f121573403102c44c4a962828f83766a8019242e351e47688bec8bef65fa7e2ae6ca0eb58493d38883e8d44de047b6ed453525b54802e082906
-57 1 157 \\x7c8032f182733627134368df08dfc7052a07dd0ad2919328839dfc2111f0d61d64f5197f780059f66ae962736db125a90d268da98256289c3b83ede12098bc03
-58 1 240 \\x044e9ce045008da15e4b658c7474e068724397fc54ecc25cc1db12dcea0a6138dc302e054c5d808affa475171f2bd8a1fdbdf5dee03bc2f7a75f0d3644d11a00
-59 1 267 \\xbcc79bf1cef2cce3045c62b8ec73fd86e109db740bf8d1ee8ee07f0f1d7ccf7b162c5cb3ba6a06cd04fe790ef33cfd3808529c1e6dc220cb35f059e2ab467a05
-60 1 196 \\x09abc0bcc926f50cf0f35d079afd2b791933c307fb51e252973cb378065c3e08ac0319aa9a4827f57578385ef33780677b960046c492310b0657faf2c324e80a
-61 1 236 \\x94e61cb6bb269a7c1646eb2326d18c5885b1137239e6f078a6c1f1f7a3f8a48a0c5784f8f58c67ebc073c0745acd27794c254754e36c07a1618f935cafb0c608
-62 1 294 \\xba063965fadc83f5d425c7609fafd061f1c5b8d4eebeb8f4b4aa8c53b61ea4f582b44fd446d8cee08da4c1f374a851be6a3e760e32d58a64638f7c7844d9e60d
-63 1 370 \\x3d05fa167eb648d2e3f8dcfe9d27a851e71f0babcfb70cbc181a6cf370babed1035a7163d2ad7ea57aca92ea8ec5de384738198815af182da2788a04133eb605
-64 1 218 \\x1f931623a3fb3f55d9bc3f4619ce58976823f74e3612f42e227d7a60dc6e6938f78eeabc1d703d1ce02f7b54b8ce13dd6c565d625d34c28f59dde0cc4bdcd804
-65 1 214 \\x6929bf680e9570174011f81a8ac3126dd326dd30bf3630eb73fc7cb26a4ed109c9d38a3f340f76d78a62b1d057049998e8958df9c7e3b150924afa0bdf37440e
-66 1 222 \\xe80a115127ad4dad6501224fbb5ad437bd869b7874a9bccbe71ce2602873236364ca3781dc1603846a90d8160391ec4715fd50655bd8112fd2490d647f9b2007
-67 1 217 \\x486ad81f56e23b839f7763d43857b8d2249895a702f35906cac06cfc4135b56115172cd11b40620e422c6b3c2eede2b8ba7b2be1fc263140a2d77aad77f47d06
-68 1 119 \\x203c641d0bbe495cb34528f2af3bc00b3269a5f8d150dc0f0edf30f5192029c7120270996a7bfec713534fe8ea2e63df316bc216b1c7ea05a81bd1b6cc65840c
-69 1 190 \\x5333b2e570cbb39879540fdfc0abb55d69c49739f94bc1fb65b0c059cf21092339f4649b336afd2309d592b72dc186f17a7aee7917365391670c319d19177503
-70 1 46 \\xa613d67ae48a78dd78e199d11e40f6e2276cd1b0ee7da36e861b5bea0bc421525347ca99317fa64e9a69517801c93429f92d3d18fe850b813912d00ea718b20d
-71 1 290 \\x8aebe72125fb7fcd0e34cc96518f23f69c0819c0a640d4469875283f08728b5a7b7822290e7ea7f88d8a22025e5e40271ab87e14653329abebd0d44a85817409
-72 1 71 \\x517d6f5f57bd1847f30764d81ede75145cfbbb035ecd1effcfc38c171794f85e5a0f284b97796e77e4f312caacf285168fab89a7df8393757dcd3fa6d5642b07
-73 1 88 \\xd02b95ede6a452b52dd3faa1529bea3d76f1a79c3d1c928f8e86b9d613dd59ef495753ad695e13481a140c6ecff2c45eaf9706e31bfafa74ee3d7d80b929e906
-74 1 126 \\x096d7b2f910d84982332bbc0cad9560d6c4816d01c48b44242de34134b6c63cafbe210f0bd2f7c568ff77a4a4d00f93aeb702c32f2c9c9df09a6cfb310db1a0b
-75 1 151 \\xb60ae7c95194c9dfecf4b5251315332b473cfab43ce13fdfb83814494ab1f7b459871f60a376f1a095ab770b6f263bddbcc039fc780c5dafbddd6ea21b046e0e
-76 1 421 \\xde6cfa9eca2a583f5cb490184f3647ef53dca0224fe899e70a78624fd93c4876d2764af7a7559c968b3eb44a5575782d4a3f738d314d7ce7483fc85c2feca60b
-77 1 242 \\xe77d869615c278db6af6af5608ac93109cbb5caebceb45b6fb9e90c100e69242b7bce3a232d452b982a00ade84822745a1219a4e573dac4627f432025ef12308
-78 1 175 \\x8e395f0c2e9cd42b232aa7ae625a8b9f416f174f5c0ec808cc1a6a072d4aba38ea1281dc5c2ea5d0994614ce7751c60232354f7dd22b511354388bf2d2eb220a
-79 1 187 \\x328b69684f6857da9895c4b08103a84f0bf99f20998821c6e24cefc51fb1f87173b9a774a64d97fd53f167b15f88fed953c9d162e23f8d9e65cb9eaf38f86506
-80 1 136 \\x6ef067375f80672f03ef06b4d3e4ce52384931b25743f42bea017844042a6f4076b010097d2f09e4b6fc9ac55d33c6755589c911fa5c6617403ddbbc97b2770d
-81 1 15 \\xf03e2d6a535f893eee4f2b6f8ba445700e787a254e35d4b80efe26f1de2cb4b912d34a57c318852e0332c29eb17491ecc190ef5597e64e56168aefcb64aea800
-82 1 49 \\xc2f5ec7d5ba44b9d65d45f7336c251237972650633dc2abfc4f897b364779f6a9071cf158b130c607b9ff7e95686cff098d410e8e8efeb9e0558df519834e107
-83 1 123 \\x5d0f2d6806072b41e1b09bd0e08221501b4c8ee713877b65bb833bb4be9f75550630d117ea7496183803b8cf326bbc08a66121abbc2cdd2ee15d730222b15e01
-84 1 380 \\x6320d5c21143d1ed9e4689b77e17c0789d9f132c123c3f0bf9610b959a9c0a75fefa69c0a194ba33899c598d19149de73b4ff459288d4b0051c18b5fa1d0f104
-85 1 223 \\xb7c0451200066450d99b5a4e18c435b7d84393f3c37d794797a7a828e1419a989782f6536c7f35efb038584443c4ec89d546c58d2c7b4e5ed2741f828c5c9d02
-86 1 114 \\x32552fac16985f060d7509746e9607ef5c90e733d73f14d619527a83aa3f3f5d3476e6222c5003a9844e26b9dcfde0df7321ae423e210e71ab9ce944d9457b09
-87 1 332 \\x1be9bc2f58f5f98dcb63a8d1c3f6548fa25bbba9003436cb4a4c008b061143b72d16f31b05f939eedee37bff572635ddff875ae07df2da20e7a3dd0432e19a06
-88 1 40 \\x8a44d0f92cf88925cf12899ee1d8c229598f2d6ab718acd91f664f69e5c043b9794cbae470deaf47b832998c182d0f1f2d590b584c98c38ca07f3c457207400b
-89 1 28 \\x0daa2556f44e7a84eff4dad58b4b793b4d28146645cbd7b2dfa281ba2a1aa7d964ca863efa30dbc5fb9c361f18de180512abfea9bf577cc4601c1a0637ba0407
-90 1 408 \\xdbfc62fd3b94e3ba13b9789b81360650644566f3b9126ee7ae8c4960ba0ac903eff2a6cca8545460c4b083afe38bc659d0b5a2059031e6dae931c263b46eca00
-91 1 330 \\x53e1b851fe4d8d8dad8a67deb9b9150a17bb4aa98564839f7f957e00a4e9b21546a696e47eb2ec95039a86d84d4e3baf54902b730bfa3fba6f7c82e866e01b0a
-92 1 162 \\x9a7dfc72b06e58095c151b0707e52a0c921f0c47dbdc901f7b4f7b4bff54ffcf093be70317299440f60eb02b0c03a19009686c1d07dc4ddc7c9fafabd4db1508
-93 1 324 \\xb815d7e9d6ba6d81225764bef2dafbcd86ce1a7f0812c881c27cc4f27fdde331fc6716478acbc890f1b27217fc3c3cd77697783e250162b425b753415bfb0701
-94 1 275 \\xe85e6b8be1f5473f89bd5f3f2d1ec12631e24794911fcf76a3ee81fa212069e7f74bc1e5439404b78b3afac3cd16c7caa48723414345dd7c6dcbf137c1fa6401
-95 1 347 \\x085219db015a705c6d58fc0b51197d3d0f46b7fba9eef364ff2845a24cb8863ea2b63229b39bf4acb0e06d8466b66c50e20589f2d9a8606b1f1b290c53da6e08
-96 1 133 \\x00ae1fcf489ea4e13c838fbb3e0a759f468f2149ff4a477e6076364014d53e44d31b2d1520691a63bb4290f4406ddbd3fbd4d7da6e2f8556cfbc47e7eedf8d0e
-97 1 56 \\xe6360c5efaebafda941f5aa0841c83c5b574944da730c884db7e65d2571728a7beeba1b2dab8ab50df24503024c6cf9435f243c0b411e0e360cec6941d5e2e08
-98 1 285 \\x3bef2b38f70e9bf47b524e19afab3417c7c5674adb9e54c80ba3898994fed15fd32674914c451c29087da131f777dc4fe266891bc1594397575368fbbdcae009
-99 1 1 \\x1192740e01af574b937c971c31236a4699c4201a6847f07975b154017eb1ff441d98bf1bd642f424a0d2278861b40889bc37edc4cb1330e12d175f94510fc504
-100 1 331 \\xebb2d659444d702482c46381f85d4e09aeb8a18c15938bb1c5594d6a1eddc6f896faaba325af8972c3cf0a7f0353b3fa88a0a3a60b31915f09d52d89d43d840c
-101 1 389 \\x13a9c94d9bc2a40c31a1e9dd07ce4703a6e49331aaa5719640234a068fd767a3bfa4907c1b945df459b24c02542c899c1416aa6685531874161b52c36e5c3a03
-102 1 313 \\x809b336b4f77d1cb76bee48d49a586adc236ad154fc6facd20398c302c7d4b5d9fe1625a2a3e7958e1a9fd8ba7c16e752f7009c610f44a80b4532f32b3c43e06
-103 1 160 \\xa7a3490a4be5e4d37d848d6f39dd91dc7fd84aaade62a746586811fa0b498ac1e91a598d382e792f68ca4a651de41431ffe82fb8c84deb80cf99d64f7307f203
-104 1 164 \\xbf8286cfa929aa66c6f2424e032f1357fb69dbca922989d277c1f0b7f5341c0bf7158c402fe7ef578b7ddd181d1c32a939f58fb3fa4120dbe65ac1780fbd4002
-105 1 385 \\xb5398bdcc85676c6b07aa123b27e525a14f5c9111c18b7c4f66382e3545e48df8344650bafa6c55dd28b8960386641d843d3ff3ac854925632c60d0e90b25a07
-106 1 209 \\xf435d26f6795c2da7b5c585ebb16c82196f4d17def36eb0fc878592e0ea6216095656ac723a74a7ff1ef8a4b190b0ae7ccfdfc2bd49d62414aeefd5280e32500
-107 1 281 \\xbf2b2016196e7c73210d331eb42f71e1a871c53c2e320776b623493d78837b49c709554f853ebaf6d294e005155de70578b88cebada037a6a865c631b49e1e0f
-108 1 318 \\x273b62465280c34acf764ea1e4c455b990955578bfc4273341501273767223e251d3c53726b93d2490b1af38a386a67ccbc2cdc7d9fb50f095e55d49ba5d0f0f
-109 1 101 \\xb0d811868d29f57ce20d30d5aba8bbfe318e230df5812e47fbc63983223846d7370bd1515bf0016b067b9ff6679ef56f34f02b573cb56e623c6d56e69f27e60d
-110 1 10 \\xd3718c14ad067a318c655253391c7ea3f468f609c2e395be92c88be4bbd81ceb6981a994f202de6aa67c1750364ab1f34b5db94fc1942ec735b99257fc75ef0b
-111 1 372 \\x2e660ef63f98ca43a4687c8bcbeded0a6c780446895ada0b9ecf5b6dee8e690701ac8b2f8de63c26f2eff7cc67fe24f0ef2c4fa45ad2d1b39cacf8811c038a03
-112 1 156 \\xd0aa4da24a5a9bd578886b17b38fec9f466b225e1bd914a54c53af41100d27d43a559da544e675dfcd6a03d097411d6aa263b3470be8c8e8888463621ed2470e
-113 1 325 \\x156321cef4b8b28fd25689bca42902c6f378358ad159ce9cd23950717b894479eecd597309fbcc83600d6568415958e63ec5c728159fc6fc3d8e97a4ce595d09
-114 1 75 \\x3df10e0c42f56be6542919b9eef5a5e177328036b621d642873c9c2c83bbeee35a4643e93b31b6c6e186325a8575a8fa16e76e0e9bee87eb1dc54ec16dcbd009
-115 1 253 \\xe9fe85d2331cbd102c665511e252c1bf7eb28f57c17cf68c86b89adbe247ff791a082fc24e1704967e0c4dea1a54193db7a061a5310e82d4ebcbcf0c912e1002
-116 1 234 \\x38d32e3d9e1290a7e5ae7a3512ec381c2b8f26ab1726ae1e345b42eafc61dda3c90ddc8cdc26720547a61441d218b0da86b77281e58a8c73bd2bc810165add0f
-117 1 401 \\x01d52df9eba288a61230030b7bd092714c9096583308973a977dcb4df4c64fc04188001e96196565580026139adf455ebcb01594676803f8d9baf6a969b94704
-118 1 182 \\x11f578ce0f6594fca8f44c1f794f841dbdef2853f099252f33a63488ad64da6c2798227664623e782487317b7110b8200747f84fb3a68fca3ba8888ab9be0b0b
-119 1 35 \\xb7225aefbab4480e795287b7bd15b93262aef15b29baa5a16eedb007ad6f80cfd3a80ebb2e43c68b3f10bd05283bdfa43f5b79af9012cb954911f2fbded31502
-120 1 9 \\x8e4c45f4f1fb4d9884f54b85d241d9dc72bf32c8d6db8a0cdfa82c251b995f16998c1c2f248c2f0a66a60b942c45cc7bb6d6d802a26938297b4195772962f50d
-121 1 189 \\x9c37d3a8f0b98eae87b60fdfc2867103bf87abe6baec2f56eba4f56cc559dfa4e1462ac4a020128bbd85c60a1a89a84ed4fe1d56483524ebec2e226d6d0ca003
-122 1 353 \\x8de6f457b99f0f7e34aceec97169f1e21cd11dfbf97a48ac5eb2b9105df367fe52f6750077e3b5cb85adb0ac2ba1b8f48d849b7f0c7956dbfd7045ba03adc20a
-123 1 316 \\x1c23557236e804086b4382532bc7be9d32003123e69d2b82e8332fcfbe0a76cf72c15f77ed04ce8d414d4a277b8d1d9cf282b1d61471a448d2616d75eda78801
-124 1 409 \\xf4e0e1ab4b1aa709813959a15d2bfdb6259fa677a25f16402e8aabf8c52e687793dabfb20d6b593a40e9cf358b86aa175280e8ecfd7d997117cd9d93461d3c02
-125 1 78 \\x78f5a2a605e8dbe478e9a6c5ee5cac4bdb12378e5d8fb58bdc9c6b1a6154fe815742590a6fde48458e6ac25037d22ab3553242c5a76e46b770ab9f090a2e1a02
-126 1 167 \\x0bbcb49bacbd80c1fefcbf09ab9631b154d88859bcd0c87bde0313083da851edb37604e371ce9b16642089dab167caaaf63b6760a63182ebcfe99fe0221b9d02
-127 1 63 \\x9d4f9edf4a15bb9dc0e6aa774f714c09ee2e591b8f2ddb2c6b78615da5b3d74bb0e6b28574fd8416b6317a84c162ceb38b94cb75b1e2c657a71423cd936a6800
-128 1 25 \\x98a64d5e9d908a0bcbee03e1de6f8f7b2b322aa543cfefb3bcb2a6cb7fcfd52ce30549dc5c931afb5813b37271377776b00cff365b5ab5dde137133a8f7cfb01
-129 1 45 \\xdbafac38435aa12e490a1a686b1678a5648c27e3889dac501ea05fbf2c2d430ae7f3adf14b6c523108b584ff1ac685e31658c1fa6b0306b3664ce95b283a0202
-130 1 410 \\xf91de1cf54bef436dbecbd9136fc47da132e9c3349589543251e590c5f8333a128e5004f4d7ac52596ca3ef028695e3261935eb8d55bb31e3c702ef23d51bd08
-131 1 141 \\xc53e981610496a6874d8c3f522e4d4664e0a0f12c5f41c4904de648d002326685f4e68fdd4b1337133d741ce3cb7e587aeda4c5a2a984d8ac9d63f420913890b
-132 1 90 \\x3e2a90a32cf6d3def7e7c6b6516155a655c1aac449245448b2cbfc74ea3e26c138cff1444e70423f0bf4646f384c0e7fb9ddfbc0668476c56bc7bdffe0067d09
-133 1 335 \\xf4ba73d881deeb354c0c3d1257fcb191e69870bac8ac846701b3f067c6be35e6abd0af28500869fb88596ed9558f20121a0e7535faf0aabd30fd7bd34f539f04
-134 1 37 \\x99bb42adcd346e128940f05b237c145c6574a5880fe5f51eb50836868ad69e0bd2dfa7cafc02384df7300bdcba3b5f85d61bb16faf8b419ce28d0f5ce86fe90c
-135 1 315 \\x39413226baa7c8d232afba87e261be9f75eae2ad8b0301e4b9cc8da138054c2a86b56b01a992ffc73e9e5ec2b38f8e3a7646d02ce80c2f24cb3ebbd95b1f1503
-136 1 178 \\x823fc00fe7f15609b0c29c783761f31cfb33b5a491e38607c1b269aa869f962c2177b36969022e4985223427ca8d14048642f61529b1c58c3a701f656fdfdc03
-137 1 250 \\x7da51c95f0867ae58bd4893a7dafe5a3834ed5a88fa589b29d9662502261711e0d671e44a99d6601333969536123d68b234f46f93e9bea8586649f6272f30b0d
-138 1 6 \\x90e530d9e8da810c5a978ad156a6c852416b55bf042c7426b28c5739b90ce74b39ae7e5ee9c32e1e9070b9d6940f9b52bc02fad196f302b3e67f95f049aa1904
-139 1 150 \\x001f9da2054dba2ccd29a320d592f41ed1a3122a8e1d53695ba5d84118daa4bf7f71c18ba0a982b9c796f91c897be8db79b775bf3cc46f95b9a39ffab3ac0d0d
-140 1 152 \\x6b18d2ff4a7e753e918c718fbe2b1e07c8bf4cab715ec53fa08f65c69867790c4b42253a27aaf17d7ea85fc36ee1e043cc459db9365c313bb9846c221e58400f
-141 1 232 \\x7fc28887af7bef9d1b93dd8579b8b914a70e20235d03159ea70d833beeccdd685207b1928c5b7d556ebeab4dac4d074b3111e7d1e0e6d651b2a7ad6f3d9d4200
-142 1 115 \\x434e03bead41de7fa2f7f8ff1e350cb3701da4f3531dc62c860b0fb02849797b427a32065955b612642f6408370b836bae7e6350ae32f26ddb5863af4c9a6208
-143 1 23 \\xa45c15dca93e45024cbebac1ceaff049201f619e71756ac204c5c4f34f1c0ce9488745a2761bd31f12a5e4f4d3e768434135a18fd63b0f87f26c2514d77ad10a
-144 1 374 \\xdfab8cbbcc254134557a595036cbffc4cdc21aec39e64a00dec184381a746dd869e4d6b56b2830e171e627046df448fd7656cc4b75aeec7e1b4ac40bd1395e08
-145 1 176 \\x710ff911783b30e68381ea65ed783b7022f8c6f8f8609c7382a90c3b989aa981d0f8b5a98ca3f69f53d4be51d2256f4a9373eaef28f51b99e7f79654711bec0c
-146 1 197 \\xdcc5ec383af1949534571dfa7175ce783574bc71cd1286c818f4422dc5683dab472738498328ff978a20440fab7f58b64f3876fd546d1a79d191388ac220f60d
-147 1 402 \\xec05fdf245f9e7010e3447f8e20461cd193fd43e508b4cdacf36e0c0ed2a8d12a0d5b7798361db217524cc8e8e824546856093afe68efb8d9a3ee95d2ac83d03
-148 1 128 \\x6438a2e85149409adee971a14f7e2e511ee440c368c7a0cb88d33645d4b8aaffe35f9c5f561936466e6aed69b7a6f8fc30ea610277b2dd4604ecbae26087200f
-149 1 225 \\xcfdf24a13d7d61422f33ba51b9789a6887ad36f1264fd8e4e00f906c11ea8013bc0b0713fe16fefb3a2fffb2433bf8dcf5bc4f0cbb03c54fa6bac319d59ed108
-150 1 369 \\x2eb2d318b588e49ec3070a7267951e77764bc62f0ea67a5bd3aed7e6a22cbc94ff0ebe78e8d4402a4e8198e348bbfe84583ec469b0e07ed905833bee67a36c05
-151 1 215 \\xa959dc72531232d22ee274208cbd6537a123d26dea1c4249c9748deb974fb52a1ccecc6c56e85a94ee3b7936baab4f9c60d4d2a9d0c158c37a3cc3e4618d2b0c
-152 1 60 \\x3d9399a44e6d334ca92db81f4674b4b6fc2dc90984846e6debbeccb254e0e9aace6588af63a7a807d1a0e75f52dfb33317b2f327a88b4bfdd90459612bcc640f
-153 1 148 \\xb957e6fd8dd23f94504ce194c506bf79b2502c623a8127047dfee518e6da685751566f1519ea34d8d50276214653c2c9ee18194b9157e4dee6f19d12afdafc0e
-154 1 30 \\x0102d8c7a768a95b62ec87e4893ca40d27ebf57db38d8fc7de8f06c7609e69d417588c36d1b6dec89a9a77dac956cab62e1f872222723c344a1aed0898b65400
-155 1 29 \\xdea19d7307566620f7a497a0a0e2c86123c8c5ce5bf0b61b21938663d3f47966dbf5c7af3b912c995295a1693e3bc0d610a6c7ebe175ccbb1d581593990b5904
-156 1 134 \\x85a54da598a3533fde8696b2b600461f634aeb7c96eab7b890cd52bd59c7d60e06536dbfecfc2cbeb28695421e8baadb86939bf94f8e45c438943f37d470440e
-157 1 252 \\xd0f5501a3c85cb825b0a2ec2977ce0ef467fce1c803fc5e7e463641d9ce3ae9e8e8877fa5fae0b9bd55d9435f9de492889f4157d1fe6de099e88fefe37694907
-158 1 96 \\x9e5eb870e8ac9372bbce0b90bb398c0a21d0054d7b4ccfacfe67f74a2070fe2c3aacf0ec86cbb8741db901fa0c204da7e44012d4b893ebb8f21114c755fefc00
-159 1 303 \\x8c17ace4c445284bdc142ceec67095963030bfb1c39ca45e71e9ae6c63fe3df1c6a7bb40efd7aa5421edbc7dbd53c4c9c72901663c06f9eb458e3e57d8ee5507
-160 1 358 \\x989405f8b331c9d7f2f5bcdb8b984299ff56d4de283b9739a3985fa6c062db06b07ea6f1273b099b94d9fb7e23dccc93c220db69bc53a114781b73a14106b80b
-161 1 158 \\x797a4017c3ba03259eefb050ce01de7fe0aee10f5fefc8c37754a92b45d2c105f4ede04faadc04e60137f23fab0481bcea8308fb1af827fb27642b2fee7b7d04
-162 1 292 \\x6231e93a6b6ba628c417a03bcf729ae26a4eb24da173fd46277fa430bd42ee2b972583b210e644f8043b78d250148610ae57d6fae557ac47ab5601f433f1c00d
-163 1 84 \\x99994d6c74f5c59b1d52724d8dda97d95089d3960741f5f04a223e98c35047d009e35f4a2b9f003a0d6b8d62f57486ec1dc5dfbe5f0038d78d55630da827340e
-164 1 36 \\x57066b2a262deff8663102b2bd7e76d582ddebbade672da0c1302a44b23af0e33a7b5c5611896731cf7d3a4d83571ba8a315a6396a65f1c4a4593ea72e9b8a03
-165 1 62 \\x6e8a0bf6faf44a0fd7940982b79be99dd8bbc3f118b369fb8358264be9c1b19e3b74e8cb34517a85e16f59449de5f8f8219ec3b57e3a55a8f246a1ddf3de6d00
-166 1 293 \\x10d63dc95d712f4b93e770f356473779c1bd839033c4cabd11644a3b7e50d424b72a1419710cf3af08c7ec2a4d0fa9fae7a7d55adaa60828e52b946d50772004
-167 1 103 \\x7970dd54481f300e87cdd8d59fb340419027da69dba8ac05e9429ec82fe4a1c0219d24c52011b9ebe368b271c5610a036cb53af2f73dc15f4e3cf74741193b04
-168 1 205 \\x3c7ba9ea047b72a989e3ada54456e241751ffb70be47462020c5759cf9593da675a2b804ccf5d24491444cafc38060468fa85c33720a980ad39c31ac04bc6e0f
-169 1 4 \\x16048d4dd7e490524e1b51c4b8c8784e27fe4032265c866de1122c6fc52e87d2619ef61f97999e96ca98dc2e94777c7eb8dd4fb1343c7a86fc1329096040e902
-170 1 195 \\x92c0b8c5efded955cbd19adfd1128ebf15e702fdc11785a9ce1c98c5ee64b51f42a1f5cb21e969aa411c2b64425d578abde414c3a1512889005eb9df8ae9e30e
-171 1 235 \\x56979d5f5596cb2969a8e4e3d65853e443786d8025f1cb1e205c22adac3592e849349b890872f03c9ea8025572c03ee59077c026dc103494c9caa83202e5100b
-172 1 201 \\x813b433ff540c61e87a37b030227e8f988ccdcf6e5650bdd9e43a1f06b2726571b68ac43030b5c36d5d522fb6d0f53bfa8b352573d1645db908b0cf17fab5105
-173 1 360 \\xeee680e8b5379c4f0a26820c2aa1ae95e036f2ffa3741a949da4cd5aae81ae5535235d85641ba541a90251349f605d517deaa056a6f31c716e8879d9ae4eef0d
-174 1 108 \\x180aa5b8ca3a264fbff82d2dc47accb8831444f109e8485b5d264c8484be0e8d1f976a4f6e20a13bef46dd0b29b88b26910273e10d0f6a7fba97943941bcca02
-175 1 186 \\x686af1b68c0f411597de7009efb5f1c45a049c629c5f0b5eaad9f7446ec27861a76821a771ff87f93f0e77652e06b0f33d3638395684994e009a607dcf781c02
-176 1 288 \\xd4d866917cfec56fb1f2092fbc563633a410379cbebf464f7ad6c47c3c819174fc1241635c95c880b8ca6c09492244f4ab967fe3c06084fbe643e9a5efd79306
-177 1 212 \\x329e4e0c571d631545047e20c031f44f8448d1a07dddfd322c7c5a46d0f1fd82fcb624a9e02a1509e998441dbacc5f7a4c5e90bede8454a95a05cb32c425ff00
-178 1 143 \\x640380a28150991cdf2e734f1f6b492bd48a477bcafbf72e45cd5107ce1649b504edd894495d578b1ff5f207d25dd7f07c739faf7e135d2ef497141450b1590c
-179 1 95 \\xd252bd15f7328b1bad9a52a928df50b672f5e998ce75518f225bce0df778fd25a6d2cd502bbffdf064ca924e87c0f52f3e7ff72ea031c4202f0128fec3c1820e
-180 1 262 \\x894cbc6a2c718b0def3efdef8a4674df62314bd61a51e4295da11f9ec8c6dd7d788a3c66d736efba7a30c3e9a281e7690cabc3f1c36c92ab501b3ba2b8bf9708
-181 1 412 \\xe827a0401b3ff3895c541720e87a079364f0f7e89359b4f333a3a853c77e5eff7979a76de5377d254dc7ef7e81d609fad14be74c27721dae97adca5a6baee401
-182 1 206 \\xf8c597ac02232753f2e582cd0c789a31cee69dcde950e4408561b242573278f930925b7961c032cb68eca53f01b39b4424cd9895b046ed6f9835ab4a50b9600e
-183 1 268 \\x7a2ce348a509672eb3e2b88166f927f44d8fdbff73c7fc69080af709c42492255f25e544ed34d35ceb468136a024ca119cbcc68bde1d00e7a05b099428b62504
-184 1 396 \\x93bf8122e1913c976aa418165382b19f3f1186c888ab4d88cdb2fadde7d90b54c94b0935ac82f58332369fd66d8cf19ff246b98c110ea62c3210e74dc23ce509
-185 1 264 \\x0123765df441bd2898c50c8df0f9bf226f674c3ced41509706781614579a22263748d441fd74a8632670ae084eded7b93d4239fa36ac93a14ecd06827e594f0b
-186 1 211 \\x64f4531accdf72590cba735b63bfca421afed1451ecccf961f933f50b57376d4cc528d2f46106808502ecf99ce877b2c0a8480b43494fcccdf992d7948b2cc05
-187 1 173 \\x53eae3d2590a1784d4f7db122802b0bec4d4e0e2f292ed192918fe1ce870947141681353b506024b4752d970fd334332c3bf8ec8b1281486b00b4a8699c5d50a
-188 1 350 \\xffb4af489f4386bc2f9375a5e8eca21fb15e8ecba686c76a2f03bbffa29c3a80ecfde4df5b1ecba0d38b25e5d9f4aa87c64a9a63e8d9216f0d921cdd68662001
-189 1 276 \\xf00abe239f8d3ec5f3868b9b9cacdebfbb3a21bd0e396bc2ed7b7bf43c8432a955a0d306ea2d7a0dc7b98f2f498e0e69418ff5abbfccbf1db3e6d7f3e70d5f03
-190 1 246 \\x188e3d890af094a49ab858ed166e26d1e218650571bfe549ae1ed56f0186b893ce696e08af3ecae23cbd02c59224068bbba523e301e7fb940f70cd1beace9e0a
-191 1 80 \\x135475af7e2ddc1a50a946dab155a362a07482d7cd576231e4e481ceb2217a68bf65e2cefeb7187a9d3f93aedb5ba0623ab3df0a5fe4abed9c5606fcef24020e
-192 1 230 \\x9e7c53bdcc85f551b16392c359ab5a0f7affa5c377e228f80b82a528356c0ec2143bf521f2e57ae6b85af4d811c7110d3098a7cd9234e48dcf42217afe33760c
-193 1 238 \\xcdc55900ae750ab22d3f280c6d588e70e163a24d78f1edfbc517fcc35694b1f7861dcb9c838af01ba8fc0d37c0e70fbefbb83fa0af94b66210664dd7bf50cd09
-194 1 147 \\x1bbdf590f9cd1b5a99b4bfa1b6d3e15d446962762f08b6764fea6c341ced6ad9263053513d4935c13f87e5a459620a4672488b2003acddbc6a278ba57fc70500
-195 1 61 \\x599ee83b296e0a03bbda361b988a004722ff9132ce3c94b766657131118e8acd1a64050ed764c399b797af4b991f4e36664f5680757fe7d05a94eff6586ecc03
-196 1 161 \\x2c3f778693144f9977c7836db8ebd358c5cdbd44f859871f9707e20e700c74ae764c32fb13211a7dd8d4f10a1c1edd89c3feabeffeb8f0d8a0f95e3210e3d202
-197 1 287 \\xa147bf9be5b60c44d53c40edebe6bad432bbcf0c22250fdb28be1796f2c9c8c5ff3ca65168ac107a43ba216ad9501558bf81aac5e35464f5676f32056e400f05
-198 1 52 \\x59ccaad2dd3625edc3e5bba9b8343854ab51c763ebdb18257f51e53e63fdfa99883bbfb5a534832e4366e8a74bf254936e1569a08195694d38265122f76f8b04
-199 1 356 \\xc731dd40653f6037af8b3be6777c542e967ad55dec85c185fc203335ea7eeab516da27691b884c34a34184ba8851fc998c0daaea93b560e36e10828209f5d203
-200 1 198 \\x456a60332fcb0eabc7296c3124dd4eba2ff39caa7ea652abcc84590ec59a96796a0edaf10ed9dac3908e8d5d4cefa661b253b36ad07edb2f3aa2aa838f2aec00
-201 1 179 \\xff8be143b91e0b524505ecfa5d0fc87a3fe1890c60c5af7561d115aa70db3649593db9084bbf3e39badde22446dabf2f7bfe244991cbaf5d693ea96ce3b9ba06
-202 1 342 \\xf0f3127353c0b0e2b80d1d87b234909b4a6da6568cd37cadebf316db2619ded0832a93a400739f6242550e3d5a07f46811a98e21ef7ae4781c8481befbc72609
-203 1 67 \\x7ae488dc93ef8f730fb61d79cde111afec231bd8b9bc8f774a85860b8f07fff2ebffc83267ce656c67efd9c544702de8d9466f65f36ebf27c68b117368ba0000
-204 1 305 \\x43c84243a2ce5541f330ddd7271a227a23cb185578b82f88d4f89e9cdfa4524246e16eb5cd26c422db10e89f93658f8f90f7dac1beb7a40c49836d294269b500
-205 1 339 \\x62685b055f8da05002a9a58239fcb2113134286050912afe6d3e126c427bff7cc4680eb17a5fc5ff01fdad8998aa34f03ba2a51e8c2d06542dcc14d53e120a00
-206 1 229 \\xfa7bec56bca4f1c2f2c559ecd3c8a24cc9feae9de10061d7873380f778816ad799efe2ddb60f3e0fa2c9894e2d47cbab2ca89121bcba3737d75466dc793d8a0a
-207 1 244 \\x293e76fad04013fd5a190301bcfb5d6ce0f5fd935bb969a5324603e8b43529f198f84b9c54c40586badd853b83bac32085d317eac552c982259b40597979220e
-208 1 8 \\xda0c792dba50c7ae0433810721c5dc3428909c2ac12d83f2f02a3b8772f2d28de7f0668accd7927a9dd97c838c59773fe625445608f8173144e3e13ee620130f
-209 1 363 \\xf06a5635f28da838e2e0b8dab8e76f6c48b4be13b240930ca2782d7da2d38a210739be8b5eff53c45eabbbaab1f20f7519987f3ae66f63db9f82e4ec926fd20d
-210 1 345 \\xc9ea299d3bfef3d62f33979ae84dfa9a604d9a05e62e719ab7c9e7e5160e49827e2ee645bff518ab634035e0d275d8737460124043f66b9a2246c68919bed308
-211 1 44 \\xea56265f038597059ad867ffaff8d2c9db37c65533f8c227deec10a6939360a23712006fc01c5da7e6d6b6abf1cf8cd343e98e7e24885895c819bb2c969a160e
-212 1 404 \\x0df8d81cb1e6f180cc7ee9a76d605533c517388715453b0c0e4589fbdce6ee71ee976593607ac5d19ce9438899a89db8f4a9937a722322484257af014b654f0f
-213 1 422 \\x4f0531bd111b83b16d394484b62d2b5dcc5c63afc20c36584640ab608a6ec0e58fd05423be856c253517197c070c84613d350f720e940583752077c3e1817f08
-214 1 91 \\x6ff48eadac032b4758546033688cfdba9587c908bf5d9e7f4d99fcca6124adedc4540cc2e6a33da97ed16e3261d35f4ef4f60ea3609a84956ed8a40b09960905
-215 1 390 \\x44aaf666c3c7c3cbad76f62e7aeb013d03c9b5387befbe071fc7ad9191fe16e8377417df4f154214b043a842a96c85b48257673abb9cd4e5ddc108c6f0a38005
-216 1 277 \\xf226dae42c32e949e0c5104736df2a9f6f49ec4ad75de0c08a3bed101d88807a141130c355fe7b81ebb8b459d2a1c90f2f69cb873bd2fa0eca029b9039453a0e
-217 1 392 \\x8e1e253d1b84e75f6262cae999b4b6d2880bc8f9f03eb498ea2e246a242e691dfaff60f9768a4ed4521180f89495166713be49648945cd1bcd1ad143a4e89f00
-218 1 181 \\xe855edd68a6f435273613a1f505cbf611f85e0e6539e83156d9ecf61aac807b2071addb79334f75c89ef026daaf004ba44752a4301eec5005c93694983678a0c
-219 1 12 \\x0f9045376d35f270d69f1e3ac43ac1912e7acaa09df55dc00e9a2b71cbd7c2ed594ea76a0b49d3bbc26d84732254ad74f029e6df4226d03fb02a5ef501a92c0d
-220 1 364 \\x50fd907255f8d28dcd795291b0ded3096e8958870a1739d871735d5c2aa61b83185d294a547c2499be948791bf52657302fb1d9d0695b056144f990170d86c0e
-221 1 398 \\x0daf4dde11afaeb05b9f10a761134999cc69cc36d7e1f4ab3bf7a7a00bc0c08c28ca4e9d1d87c2a66eaf9c3e1caca902516221c5d21f013eca2802a40c35e107
-222 1 142 \\x9aa86a84e395f80d4ee3683b498e8c7812b82b7fc9ffd771cb786b430bd790bb809714d22140605730a06f391f6d5d3ffdee358b855f4997fb62e154d49afa0c
-223 1 155 \\x38a2d2103e7da0f53f9e61e1a0c98b38e7986b99d53621f7850a4247b1f2e0f0c35d07a0d06090a3d8d47acb03fdc21dc3286bde9c27b5e3ced21b301a1a6204
-224 1 34 \\x3ca427695c778541bb04cfbdda476a95242fda9b541a7959b6f5df608a2c8387577f0026e444296533983775a08c73a9389f340432edb4429e8b4814a26d1505
-225 1 113 \\x07462d679843e4918f7644cbfa2b419fc235be88107ea7056d95195471613c75caca9650912bd1fa6c318ee01cb276d768de4693e364702986e5e1ea4dadf709
-226 1 368 \\x50a815e72322bf501bc75b196237a9f8c4d92b3802534410e89544d326c5b9e053d0bd716e04e89cc63bce87c7fcacaad50c5c81e549f88105a96c3dffa34d0e
-227 1 2 \\xe84fc96cf591638810188c0306594dd301f85134974904b574b11244193a57e496f6c66d74cb211b20bc20d08f887325a3b6f3359788ba98165eb9a27f18bc00
-228 1 340 \\xe6b7437de02566ca639777df2d2eace105d8fd08d1f7a5886b62b34b03d9461ee5ad59ed73bf9a10aed1a45d49acf954d1736ba356e232c9f17d1c9c17cdd407
-229 1 260 \\xe544134d160775d192e327a9d4029b29ad6ac770f5973385e7f8ef3cdc48602a25fd8607a3fd6f5f8bc648ac798f8467a0b4574ee23194e39942e0fa9c580a02
-230 1 299 \\xa28a445cb29ad7a45b7b806c03d49067ec9c80dfd1fcc3031cfd63b1a4151686fb4b6be26a166892fd8c00d5df186ecb51b1d8e30000fddbe627f15bdab7a308
-231 1 365 \\xfd8288b75c2b974999d2a0d3925db3e03d9e0fcbac9e61d8a9b4229f755603a9b13accc58fbdc6bd1d92491b778136addfeda45f37226c044ef316e22c5dd00a
-232 1 192 \\x31d2a44efc4ee4ee4749d2f9af642aeb4a30bd15fd761c4cf1e465c281fffbb8bc1163f11df0ab329c05441bd56e3aa6136192ac9815cd25dff76bfa038bbf09
-233 1 272 \\x9922f91c154fec68d75dc80a8ae7c79c87c1f6bd6220d8c08dc8b2f5dc623eb7a7d80d664074d142aef1cdc4bc3f38c62fd2b09529b77e3132b75b931711b205
-234 1 373 \\x87b0b580603cdfea188beb9e0fca728ec466496fd17a0909480454d2c0f124f08d0b45eeccf122f3f4bc0782dbd8f70fa143ceb1c9f11c1afdcee49a3aea6d05
-235 1 414 \\x60997030f483327d0fe90f617a4f6e70744e0e179af08196a8966a53c1793dcd4fc99f7e9e20e21c552ad26f180569a50b9a0226470275603ae71b342124090f
-236 1 394 \\x2747d595dd4be393c490a65b3b28236e40680a4d3698d1b8239669438480f5bafe9b0eefb06e5f79f2e69bcbadce8f7a33243f61f6cc9cf7fb5ae8cbef00ba08
-237 1 348 \\x6e0ae20347f08f574dbb797234ea48fae4f2ed9ea606ea74cdbcb400fa0bb7b161f8ca85072c64c057db60787bb2ebbe6f7d6836714581e56e8d235a09ac9c03
-238 1 337 \\x1aa7dc273ee03ee79faf24f65ff3fee4c776ee7f333729c7d9088f5a887e7552d5ffa9b276ad0b0a48068a6265c135b98d2bba7c47868b6200b2bd3b84383f0d
-239 1 351 \\xcc079083435f507110cf4cb09ed89643f94b950b495ed63585e02df72ffc83cba9250943419af16ad05d5192613ac8248f6b722de1760efed18531861696fd0d
-240 1 65 \\x83470384da4f60c4060d60a468d4c9d7098c251808f2f1d8170ac173df54379e8aefcbaac43efcdcc8fbdc89eae4ac317e5dc9615d561ec4ad6acc98d710f103
-241 1 397 \\x4c89fb8e3469bec806bd0f443b5da50fd2fe563de3493b16cb07c6b48c6ea04c1453a3dc85866575d561c46c8cf5a3be9ee48e8e7d403792ff2d2da8277b1907
-242 1 420 \\x267d9c6bfa5192a524d7be510a364deb85a9a13bfa00cd7cfa6bbc54f44486067cfb4383e60285026a67ae0ba259ec2624fe1b31ffdb2014e1a8157e36592506
-243 1 58 \\xa6e8f41965a3c28a2f204380f2f3166f66d4c9d43d31f9f06a1220571420fd3212b352f7aaff0790db5ebad74ca38b4d74af4a138e28e61803984974764dd500
-244 1 124 \\x48b91bcf9b6c34f0a251ba5eef49bd494bf0f9252db8f533c6533dbc818e7da3c0a104e3558849b5c7e1ac14f9fc9a9c033307bcaa1e8261ac00742e42228e0b
-245 1 226 \\x66c42649ec67b617479a77c8bf7392e816b406b2c142f025c1471d7106636659fa90042970374e356c41d7a774fc58967e7551498d4cca0d7bac02abb52f6b0e
-246 1 343 \\xfc7d38876d730b33b0e92fea8cd6175641c818f372488ff6f66a5e7f13257f4a1810a375d7bb1c4fa5357d89618582d5d7f9d73fba9a27683be36f37af3cd702
-247 1 210 \\x96d36bbc2615eb2fba4a36636eef6831503337debda4740dd8e0e3c753783da6a9b99c2ba5dd74eecb9b2d2813744f93d768abaed3874e5e76b3bcbbbcf19a0c
-248 1 375 \\xdaeb047e0a5ea79a9335d8a14c73129571421d4ed81694d020155ecaaf302b349e341dce057eaaa2e90154989ae7d02b56f09cc50900bdedcacf5a3f467a5409
-249 1 154 \\xccb3e9d36bb8bf7e5ec0d4787b8d57664ff9763f9471a2c6c7e3bb44b3a2586eaa8c50a95fb1df6eee42a3af60b1aed0f830d798dfde6aeb71f79e19ad3d0703
-250 1 254 \\x0929d29ad722278f40a06d9b1bd1296d0ddf5f68a9227490695fb0132642f20072c285bdc228846f831423b05635f447cdb959d9d2a8260069ea7bb86f635608
-251 1 295 \\x21864893316741c0335c4c4397e3cbf79ed7fab4a396a077614d4b723fb04ab13b0832460b92fd7993fcf2a1e24227aac64708fce3d0b7887a0397fc5fe36200
-252 1 333 \\x0a1275aa4cb0e474eee7fc3bab87bfa83950a511a00bbfecfd41d87bbf3b6495ac6871baa139a9653e1b7d5ec255d460dea8f39058348fcde1006e9716e8c405
-253 1 207 \\x9c6deaa532ac351162fbf4a765e3808d49929da4fb93ffb715f15c56aedc4d8eb6863264c67f8bb8fbb078874bcb83decc700164628583ac6d4aa3dbfaf7e303
-254 1 249 \\x54a8f45960d143bea541c2e24b9b617952b9809acd58b76c0ce5e24587e9f813e9b3f4b0d445fba756f09210cd28aa62dba08e4bb79045d106433fe193d37609
-255 1 320 \\xee1db8eb7266bd1e8fae1520d030aabb9bf71adb24a29383503628b28ddfcabf7febe28e150e73b41a82da9d8521e96eb2fb0bbc6279fb093d08c414df15190d
-256 1 311 \\x770321b335290311f2ab09a806cc9d4e273695445ce110aa189ab9847527e144a1484b5f0a953ef754b3cf8c06eae22905b585a6325992f0b0f8e7b55ab92302
-257 1 202 \\xce1dca013bec393161a380dacf999dcf854f2ee1b04670e19cd271168eb8c5757a3ed5af94dcded31930e86def29432971543daade8997fb51ae16990da9fe05
-258 1 308 \\xc5e35e22436221cd25b61c14cb0bf995186e8ea8141ac7a3aab9dd2b4f6a2e80408f34051be9548d50d0878caadca330d66112b3303bf95177240721ef9cc808
-259 1 163 \\xbc27c214ad1f036e18a66ad798de49271793c83c4d766922e1ea0076e6c7e93b3dd7bd0ed422f5f7113f3bd2efa51b352617c6018362141e754c18141287330d
-260 1 317 \\x9a9e13a2af8024c7345400ef850f508834503e122299178a43203766ac160e59cc604a9135fc841cfefaab2c9cb60483f3d3493770605b6f774ea028ace0910e
-261 1 307 \\x6908f1c20260f8d6e6cf1ee29dc7f91c61d3c51424f4390da7806c23a7b13f700992d693794868f45f4cb32ad811778dbad1537e25b6b24c6ae62b4b12acc900
-262 1 172 \\x77b0ad15e759853ed08318813ee798b217e4434b1ecd9ee09cf821d92702b0eb97526e7069f29cedfac2c37e986acc32bbb443ef89606061b0d97719d1b23201
-263 1 135 \\xa119a1597c19d2c8c77d5cfdf8851f7e2a95d9740859cbe4d681160c38db743d6e7697e8754a6d2b0fd92dacab10b36fadac2f310712107722a288b411ee9100
-264 1 302 \\xab3282f65cd359c7f8323dfb87e61ad255dd2161b2d75ecbbd581ab1c27664f8f586b7db63b0fd353530fac577b46bde79c713ad324a212ad538732cb9e7ac02
-265 1 86 \\x506d4e0849e25f32b23eef690b50e427fa0a7bbbf41ca14e12ee8a361f01928ce4eaa8f34ee0a841f696abf37b2e6d47b5b4cef5eced1f666a6ad965649ba303
-266 1 79 \\x0a472271ecb10caf296f0c57a5903e9bbfe763c7962eb22ea062cbfdff86837aab1851a13dc6963e43405e2e1709ed274ed6800caebdcee586aeda15de764f06
-267 1 83 \\x9e92fcf7008a4e832cb20641e29ff9325c232269def8727caf817056e8f940a5ed891e3b75b2e7f78a9b41f624d96f25eeabc6b9d6a1d4be95edd4e86249220a
-268 1 300 \\x5f88e21886db874804f0f6842c656c331957452e67104b93f9058066ffa2956aa0799238507eb7fa986d266f53a9979f562f4c42be2149d9db33416753d44208
-269 1 416 \\x02ec681de856d45a1cfbdcdbad57ea15049c631a581d63a0bcd72e66ad07ab4de44fcd0a096a2a95bf4a4108f16091f389aba8cfcba0bfccb26ece83f5572d03
-270 1 116 \\xf3a41bb27ca1a40a66cad58fd6ea170a0d86c5e3d86aee917d1f018ed3bc3380644ca69073f3f5e68f0103038b45981aecd35534d745939c5e6a093a401f6507
-271 1 41 \\x81632c4cab2303ec6c291d7cbd57760434447fa4fb26710bb18be6a66cd90ae56fe070703b54aad4db692fe26334852c5e90d77f5e5217b01c481493c3de2902
-272 1 395 \\xbe04d1de72dd7861139e87d76bf396b17ea4f7334a83816849d4b483ff41f7978bd5e7c40fad82edac411ee8340f6608350ebd6ca4cde59962272756e12cbe04
-273 1 405 \\x907dd1bb77e3bc557409a718c63abf11bedc468038aea024c547a40cb1eaee44100ec845740a8aefb9b35c262ad44fe1fc8d7af35aba286878c277328acc0205
-274 1 279 \\xe67a5d88868d41e265cdc4cf8264541ed54f040ab596183c2eca878055ce3c9af8124b9070d74f425914a79f6d91454ed3e6fd37e99849b6dc6d977a757cd302
-275 1 314 \\x29f9daf05f000bbc23824a309fad0cdaed02c0edd206a052e7353402d3b23d2255d783414e7b7f88b17c7b49912f12fe323a3e381f30973a125b20e93ed50007
-276 1 57 \\xa2aadd2f427b280548592b69941534c06e22fa9fa30810d827ee6c0b096c2f9eb84104328e121987f3a7f413649f417e5bf20dce058cc7c173227c115f86240f
-277 1 424 \\xce5b83ba5e31c656cd08878f5fd1eb113938d6b8660f80d82597c8c6db05183d26634f388d6879d7f1b734287c9a84806df08b5e6be6c05c5293256c3ea3f603
-278 1 406 \\x899526fa9fc93e31bbfee50905c1f36e1491b8c0dd33cacb074efa1b2c0bb9da00a0076b8c1485f3c0895ae78fde77b9a98f596cc74be159c9b82d64795bf709
-279 1 344 \\x2d55e6665ec8ad01a118650ed9c5cabae2fac52781e1884f9986ec0bf647fafa04739d9a849b77e424252a311c94d3e749e265a2944261229c6657d8f5c7a70f
-280 1 177 \\xeb78440054975b42f262d5f853597df3787165cef6a69f830433e6104cf03308a8fd5a19ee458ec52f114a76125517f5e37203c3169ec7544d9e15aefdaaeb07
-281 1 278 \\xe640d960076ae5bbb46f9f5c1de89cdc4aab19cc6f913fb3f498ad497154def4bb57ff5f9602ec9cd778c91abaedb048b1021b6d7b30162b0cf23673e89ff906
-282 1 233 \\xe065135bce930b042172bfceff15fceed5ad4420e3fa64d00a1eeae2d84378b406a6e248fde3266177140be9f8d8e353b404ad7d431f0967a334b60aeeb7620e
-283 1 228 \\x4dbfb9820e9064e97a0e943bcac9cd427846abad522e250157f6ab5d4f17973591a641fe0579bae899023d39bd05bf0409b76699833fabfba8e556d45e6bb503
-284 1 130 \\x0f3777a40b79eb8447ee2e33805f503f89408da8b7d174ac5f1f626f24ad62959edacbbde6e85871a7756b3f0102744d7404aeb7d829a7fbe04aab1bcb922f0e
-285 1 247 \\x557bd010d519af7a0ea52fb3f0c80a01a15bbb46d39e2d1d4e1a7ad515ef44f3408a0ad27fff04d3b14ca0d88d59e45cf6df861374c58de045ddd012dd7f4f00
-286 1 322 \\x6b94f5e68abcef781a8389dbf754910920ce420ae730c652ce60b9317c973ba8133cac333715d8c39bcaa1ca9190852ace6828193991ff383958f74ca7a4a901
-287 1 241 \\x948e8fdfe28ed35d76113956cc1126d0a5ab1032e56ea7aec705de8d16dfae8aa06bfadccf290b117989b2edf1e3bf9e897df7c7b52e90119cf8fd3dc3fb690b
-288 1 24 \\xd1033c5de9efd0e023ea80b030bccef1864ac321c6031a29935502e2561add7ccbfaf58076f29c9799a392e3f7ba36a095add9b262236d024c8c04c1562f0a0b
-289 1 168 \\xf1dbd6b9e9f479d2f470456a88cd21263093f0d6e232a55ade36b3805333e329c9480fbb01b862fe8b34c89a8bd22db086709d8546888878862127afe7a73a01
-290 1 352 \\xf59982852273d2313561790fb2ca1f12e1bd02bf3c121de0be3bdedf86ddd0181ed4eb0941b426461637b080d77028417fa45b58bc8be56a7235be105b72aa00
-291 1 203 \\xb9ca7d103b1f6bce86a10f64cd98f9d8dab66a95118e8dce0026a7352c6a2945aa8467d33d33af6c30f50e7a8cc1413c6d1edc451e8a11a62cef09bb2dd9c70d
-292 1 82 \\x11ef90da490edd9cf787660b1059070e596b0185528113a816c3e40b8a1478cf5f64b79425cf6eede420ffb285d6c6bc285818658df2f3d1cb7acdaceb680e09
-293 1 13 \\xcad1c8ceb109a3e4e2910283bf0fde3b8310cde9bf3cf1e099638867427bcb9338f34e5a359c2d37d79e57a08783f7835d4f955398725db15abe270da06d8f09
-294 1 298 \\x7ca5ce128fe008c7d4ab274f01e9914bace704d39a26ab3b274a2651cd83dea659356d7d9817b3dc42c6f5ff55f19ecce99f59e6750cfd36d36f71769a2c5f09
-295 1 245 \\x536f07c5fdae1981c3475071e5b4592a913c2635871bfc9559d8e6602ac11e2e7b6502207a523821536f22f6347094eb0509b01ace1171be8ab5980274eb2d02
-296 1 199 \\x68eda76ac6772a111e0f161f12585e2d523cb52d5f214db8efadd6bb858b4b5eeb9e8b21ecacf76116323927d0a8dd93ef7a3cd81258a010f11c738b1eaad10f
-297 1 388 \\xae5a79f2abd5060230813fd903186ee0b6ac79a66e76199296e0cd0358700e699319533bbd7a8c8ebe5ee758963bd2f535ab0ee0a47ff4a023ab23b812dfe80c
-298 1 309 \\x4fcbb0c244493ed438690b534a92ce61b1ab75a1962a00dd7c658352b376d1ceb78a2a1c2a2594053545e9ce2813886c78b1eaa876a20b6960a9886b4f99b507
-299 1 169 \\x7d03aa73a28347918a8600298fee438acae1bc15c41aab69ab240a78f599610244d9066fa1c9a79dc47da2ce168b87baeac644905f6ce084a19eaeee98045503
-300 1 73 \\x1be6c198fe853df4e149e5ffb4a4c00a2fa936369cc9923a293df9d7011513fb55225427dd6e151f4ddf5df91b3ea932109d3aaebf7561ef86bbbebc215d380c
-301 1 55 \\xb1eee0205d477818a1d2bd423a28ce676e97a3809e3e766d36a4d538a3f33ee7752f22e372e6ff2296edca169d81037f0de980cb1b6197934fdc61b32bc0e501
-302 1 144 \\x52bb5271513b3e22e5f30c5eb328d4b603b0ea0ab98545036dfc52e9e1e6a730652ef5fa241d683c55eb770cdb5fd437c97fc0713d50c71b708066f64ce6c40d
-303 1 77 \\x6109d9065308d6b2b39482c12d29a01588355f96c458a7a535578c046d243189e7f8feb7eccfe421da599ab2468900b52af849a69757129930ef78b1d590de08
-304 1 105 \\x5f3132ca23709013f8c23b9f1b8a584bf92f6f95ea65f73e7ac68a0064058987046d51c2a9855cd80e8889f29d36585925da18a2cf5d96a448f7ade291c6fa0b
-305 1 122 \\xc07258da81bb1ce070323ef00f5bcd1f0df6e4d6afe77eeaf242a8d06b3123342a57342a11902befe4d958a8f8635057721e77642b74ede4f67ea51019825705
-306 1 47 \\x567e1e238e10c2b19bf8d87965d38bfaab578eafba80c386c6a3549ae253b46c99e84f770eb010e47f9a337b6e4803af3c7f676d6f8cc073333c1de6a0066800
-307 1 112 \\xdfa29ff53a6c4c14148968d494351d5599f2e28e1cd26d72812949ce7cb5d95deb090b6373d4383628d55b8fc03fab42b4dc899154c71c02792e774a9d10a803
-308 1 243 \\xf038f5580ddaf7e20c335f729de29d5948e629126d4e5f161b0facad4c59be401ff0af8ea01c721f47856958ccaf13131819bc635be0d0010b672def5f27d003
-309 1 371 \\xda80d5ad676ebe06c477ede34e0cf2de3f0564cda2c370c354b001dc32e98992e76d0dc16ee43ce5f242cc975bd28cf5bcac0b62e8bdf8dce9bdca767de4b408
-310 1 31 \\x651eab817e84e8864893f188cc2b19e1082fe2201b26183560be6ec845ee7b7b203e83b4441ab334c5f46394ba8cc38a2e1e01f7a0a55ac383f28c3ddb07280b
-311 1 94 \\x35ed82e04457f8480ea007d64e488990e37bbc50ffa9cba226e40a2903bf9dd5236d8ee55e20ee8165374c4a772c9fc4b30c85ef5bb950988fc527d85efa750c
-312 1 11 \\xd679bc40e3dcd0b3d3a12f1a061a275d2c24c6ea7c46f721ccf7ba2c477524627dac90ee0d2a2210d8c60b8b609385fef492e60080bc0c82ec59dc5cfe5f030f
-313 1 89 \\xb72793a7426e9995bf52f6b3ebf30155def72ddb6d50ef745e3f6315bdd8466adeb6439c1d2af4982a59dc4fdcdca25b5884005dcc092265559168655f3b1c09
-314 1 137 \\xa82b4cd4369b5ffcea8e85148455a0370028b1cb5fd31af279f87194209122821921b4feb574bf7e1e589c2b53a0465a764dc838a291e46d6319d2dc36d47108
-315 1 284 \\xbf0dcac855d77aa222756b1d836b2fec9a3a2dd0ed1f9a621b3ff7b8afc2944fb26bbf91ac4311725241dbf2afc5bbf5205bea951d8672d3fc9e28016f163e05
-316 1 387 \\x0a63cb13d77bc3a75f85f0ce2628688a41c48ccc1d97abd428931e9d92aac9c6e3d8cac2196cac074a1a46508de1ce138a67b54b790e5f1de5e1e9803e70fc05
-317 1 237 \\x19e2e284e757e1f8e2e344c8ffe39a4bca614d48c3badd7d801ba9b32b480ad052b41547ff472909b54e58cf150e8f1d16746efd3c654da0dc61fab517979703
-318 1 323 \\xc0bd85a8ea28d73c5611f5974565476262e25ace6aef017f7aa83de9864e4b7a0a8cc84628d7c690869d3c214277b1ec59733247b8e14519dd9dc693c7414f06
-319 1 3 \\x12ffc2a166b11476e383f24790588cf1045e267bd952176fd013d909c02103d4a4de0852fc6e4aa8176603ee574d0f6f1fc239d39f7e0f0df887e84baa67050b
-320 1 376 \\x9710c2b76fa4ae5c26a4a8a8eff0338742b02c83e1c3c590caa7dc6b3bf810cc94a56c46e6e4581842d7300fdeb69f3702703d8b6e74b12f843c582f240eee01
-321 1 266 \\x255ba0bb30a72554b07142842ec34c9ba12c6ad4c01c1d8ef902d2a1544576043bd070eb81c534b1de0f2aee1c444ac387741604d39ea975db7a73e015ddcd00
-322 1 48 \\xe9a8aac1d5b625242889fb195490404673e98da8c2ccd549115cba79c08d05140f9b3c75368473940ee3a50062d625aee9ad4d4ed4a968a55082bc74fe94d80c
-323 1 76 \\x9080e09ccfb55f531f57847da3ed5df000a5c965c3c152eae5b584f54588ca46eb1525162d1e33da1fb2837edb6fb74073a0b10da4757f041855eaf17e124500
-324 1 301 \\xb227479c87379f65bed8685bdf47e04267165c0824ea074705bdaff7ab16fbd3cb21ab42625d46dd882a0053e5e115bbe55bbcbaee2fa07446291ec0a019ce02
-325 1 111 \\xe6a0e7a8ea2ce69a77eddd0e0e76dbf2ba5a48aa901b352a6a4fc830a9e382ccfeb0ec20020368fac96c3010d4477edd16c695d2c1f14b6ebdf6e32b5710990d
-326 1 282 \\x9f47eff461e65ce720f4fa95390c59465f3c78ffa2d645a4a5b8a0e0d84e2aa622b6ebd3b12ed08babe71d4201b8367c525e25b684b98e7ce7ea2366c6c8970d
-327 1 22 \\x0b954c8dac0265afb200af04ba111ee91911cae06daad1df73a31f6637b6a18071f0bc1da726b8627723d92faacb20700dd45d8ead0132cd8559a8f2bb96f601
-328 1 102 \\xe6cf2f9054d46afb15eea9681de1494ddfb86bc63a833b2498ac9217aebc0ce4f73f242c0ceaa795b292751b845e6f5c5dfb83a1a38febcd7f9e7fd3ceede309
-329 1 384 \\xf58b987dd0657b6f982501cc8bf877ef55f0df52e4a9467375b063f73b554bf1d1279809c62fc6611e6a2bddad006052824c106c0587601faf91d47ab9c9de07
-330 1 50 \\xa47b801bfdfde82d58f7e35df81df9ccf56a00c69f7ebc850b30c795bbddbdb303adad455ce8b1f57e6ff60be41fbd4b38123e2761c7ac9853b3ca5110de6f02
-331 1 261 \\x5387b7404cf983697c8e1d71e5736bdc47826deba32e0426f6a24e6ff131c52228fda931d71036448464903ccdac02f56833b87f5ee00206250d67611438790e
-332 1 68 \\x943ca1aa274e25e09b1a7a87ea0c88809ebccbe165b0575ea641ce7bd89fac44cea682d0fe880eb42a20df8560dcf8daeddcea478e939515be58fe54d448d10f
-333 1 258 \\x9a1e93fd0c03e82e4f015767d9bdde71ef2c8596afbd36b39edb2c063fee95631bf78dd6bd1ef52114dda7f73a4ca21102ce29868aaba2c5e5419b71b9f90701
-334 1 145 \\xb363d6b4091a947d36272f3efef1906dcd955e9aa2f5b4ef789abbab11f69152b2989535ef0938c76b8a31f1220de3d715eefe2a2d419503ba9695a23b11ae00
-335 1 338 \\x8d9d52a4a872994d3e41ca313fde1a29ce58b040edf9bf3798983f984f51acc8606be5defbd2e2fb57de02b466db92438a684e5c91025550b8a2292916d6e90d
-336 1 166 \\x84c9dae5d7903b07ffca1171e1b81691854823f1b939585ef4ad41f4836b5ee515e9e565dc6ec28fa22e6553930b8193604f86d49d229c5f55f218d811a6e303
-337 1 418 \\x64820d4a01a997900f3c947ee6038b2a43df728f586dad2b3f3c005e99cdd4d06bbc8cee338bff8ef15425d059ed968c49055285a6f03b995645f9cd23f75304
-338 1 104 \\xb51fba555e7f1dda78448e696e49d23a0df42558d19a5270f68a71756608f0e07a00ed5b5431d4b523d51565a7c67c11265f446233454501fb9ee9c4248bc004
-339 1 328 \\x67d2c565188ed527977b1adb77566501017fc38f0484d15d3808c38116129ec07881bde1b2d9ee47567528393ea635bf30d5c526364843848fb1637efcd7800b
-340 1 170 \\xedf01df695372562b79c2b9fa2b9da1a7fb67674d3994b5d5c4eeb2e41bb1f48a29cbaf6d4dfb4eb1780b8f103c4540831a3e8541ae846d3f933dec2a41e540f
-341 1 357 \\x3e3188fa4e3dabab545b7ade1db9f2d1079cc0b30e14ea5d40b2ca742524543f8539f873bea49160e8ff71735358fa6c9e9b2b3a2b22bd448d368391f0978903
-342 1 64 \\x2c11938d1f6d5a1ac16db0965d52d56613be3e90fb47362a4829ee3fa0aa1ebe6eaca4406f67aa3037ffa12fa398dfb3cad1daecefdbf311c868fe3d0d1a3008
-343 1 291 \\x8a9a49b44ce67b7642d9e38d63e213bec65efc2fd9a99ecdcb48161e24f5fc70762f1daf743cf0b8045f2758991dbcdace3dee60caba6e222bb8c4a648920e0a
-344 1 99 \\xb3f903aa439683abfcb77d4d496a4ed1292561de8f7da3dc19e395a4f4ada2c525c71d1a5b584dca2767e48ab7a160415d41b4cca7e7926f6a88513fd6537400
-345 1 219 \\xed5aaf218be3224aaf647b814d2f4d0c3f30a4da5a2ceb1fdb17b390eb683f1dfdb4f8d40407e4bdca4d99fc3a9a4ab7065bd35fbc8aef0f25e2d797710d430a
-346 1 419 \\x413f0902db5a87184d4e4765f3a086d8b59f20a1bca0a6ee996b808b69d98635ddd16530c8d1761a5f8370c4171464ac4aed33e72d47d333a226fe5ee660190b
-347 1 131 \\xa37f6488241b5aad7f6a47656574510aee0046d18e896eb1b75bdc537e5f7c8d0877185ea6c235a1fb12cf24dcb8518f527ad577b1563d317c892905ab1ce50b
-348 1 378 \\x5766fb304c9723625f68764cc83d67a95111fb9ce95914bb6b9eb6054505f3d766dcd32232c0881c830bd7949cea0964ac52268aa65efb968f45430166e7eb06
-349 1 216 \\x8267f5e2640de289d0260975e1befca5811d9730253b9e985bda725797ea38ff04e528f3ab9ebae80906ced130e1e93a399c8862731799987de81b7010904808
-350 1 286 \\x8d24080fcafebe5e932ecc4ee56463075195eb389c4bdc56e2f4de39e7127b3bcd955ea370bf00e3b5f347cbff818936f0a4057fb8028774d8d6fb47a58af007
-351 1 381 \\xd079faba7b6de346704e74df2eac3d84925f0d506a008f6344706d87b065f6abffa70d4a5025f02de1952e4a04920e2a3830a3ff3ba072b9bc8be5eae6a62300
-352 1 271 \\x86471d82147369ee1388cbfa27dff16e0589052035f77d0c2edabc4e18db88c4d2d7b6352e8a88434d118b121f07c1c7a4f902cfcbf8d323f4539ba4131ce30a
-353 1 326 \\x0dac2f3c814202d50521a8d5c2e3a8bb7dc416f0b34de4e725c5c818341f6b1a543f6fc7aedcb8598d6c1f5a0b1d0b8a33f20e109a1099fcedda1794cf490506
-354 1 231 \\xd282d0f27c9a84f12dcfa70ffa554d01f2bda54ccfc2e25678bb1d0633980f915c01ded2dd10544ee8772fb590c5eb46490189b88c086e9a1331ec0412c3810a
-355 1 54 \\x572a7212fdb28eb43f729b09d086cfe2ef8cef00681d6ec4b7acdc739c1eb7a037e08d8b07fbb9e40f1f08d343982ad59ccdca8887953f259d7d34b01e97aa0c
-356 1 321 \\x7a17662585f5c58716b4406076555597f64188ce1ff84459201a4667e54793d10cefdd6a4e8794bc25f44be364c21c202a7a8ac477a815a433bd6dfdf5e70000
-357 1 355 \\x688adbaf3578cb333aa22555c7d5947643eddf340b8d73c01d116cd9ea3a704c7ac6856a678cc3219bae7a24e417150f6fe545bff2a99dff5db1344811342601
-358 1 393 \\xc9667caa0e160efbc0c038827ebedb9795c04c8945e89e5b095f3fd54dc80719608e2e5ff9f9d763584d2007cda82f761efe5a441bdcac309c7817701d6a5308
-359 1 200 \\x0fe353f9dae49d80ada92b1149657a0671734556a1d0ce7826267cbe907af5bc48b40b5e127a52c977700ce442bb75b542eda064aee2fd016e79249c8458720c
-360 1 274 \\xd8c8884e23d5d826cf560c1ee4e61387d90d04d248a96da61378d54a027767f61e32dcc27765eb03bc6a43450c21a2c0527d05c650ad4969cb0f643c4c4bc203
-361 1 400 \\x34f2d763f6fe64ab5faa520a458cbadd21b867ba90e5bc6e97e3e0cff48a642cc9252258ec355d61b8a5847c1607eb3f6e1075111ce95b1070929b681a03d100
-362 1 87 \\x8d35df58a73fd549b44c3a5b52acf97d4c9f8eb5642be1e8558a3eaf853a24d5de7e0e7fe448f752e6d26956c4c179fb7fb03391d49f6757f80940111a13e80b
-363 1 39 \\x5df0885e3738fe721941efbaacb9b83953b14a151295bc61f062aad9aa26bd3979ab1bc7dcf6c662116169a8006117064ffa9f921800013a05ed16a011b8510b
-364 1 138 \\x96979deea8ed1d4d9e113d7208d2896a4489dc35313c353513d4a7117a41de401b36bce000b1780e075c4772caa60ec4dff77e79911eaebdbeba907462e4a40a
-365 1 341 \\x8d4236a330e75e906029cac410d7c1b6c077d2a889c8963b9518293193c1c9d2a0c7fdbc6871532c0ba60e9821b4527f105db12e09504afcfc019e48da87ca04
-366 1 59 \\x503f0710e57d6ed8c91a70a00a274e32a907bcd5c4a0b7de7404771186b4972078d3a4992af5e0c2571f6da623c8a6e9c06f2dba2b009324d5c8b3e1e8a2e20b
-367 1 69 \\x34ee3d35d8a18dab8c00fb702db0172dad93a8776eab6d6d3c4e928535e6a8b17faf5b5f91146627faa387d06f61ae2248c139da5df6f41da723b9ba8281c10f
-368 1 120 \\x9cf28d6971d9e0a32b11f08160c37577b650720fbe1697b2a9be1499e92a2be2c28e1ce7924ab8c206ebef7b4c95159f7243c8c2b00934a3b4d71043857bfb02
-369 1 21 \\xd6c486cc7baf8ce78fec7b167f0dea21d65d1fa30cef64b1fb5b98e4db7a87a554361a54d80eb8ec3d6cfb0f99202a02db4babb8a1ed3427b436680790bfb408
-370 1 129 \\x12d3a2c01393234f44252c7eac769ed7f54d4ac6a5e70598d7b887f2231dd8de1221f88bdd9953d0a02e10e9e0bbb58f39b99f3c69ba3e7264e7bff06c490200
-371 1 221 \\x2c31b17ab0f46a7ea6f30ef0a4808dded0b7709e486b136b4210d29c2f89a71ba7e7fae00dd5e4ed24047488d86a45c98cd737fe28872cec01a5da2555182a02
-372 1 5 \\x3596cb0f6bf7876810d9f19f2901bf5c481775d81c36883f571d65f383693ddd1abd72479b5a60e7b1e2bf91b0bdc1fb3426954ccbc354907168d4476b35410b
-373 1 183 \\x9e8139ef0bfd736fd934422a56b9e5e9b9fcf044beb667c9fb65442617c1d3ea51b4c37e2e5bcc4383c0e346ff2a51828151db74aa5bc418debb5750cb557307
-374 1 139 \\xfab5e0450b22aceffcb13cc570f2c84b93989864e0555dda3847f6de9e6c8d0a62b52d19f3f51391274c21e86444a4b715fca69e911fdcd24b5eb8217626b60b
-375 1 146 \\xe1b65e96e673a1ba8f384f38d80f596ebad7a134d3e25bfbe8fcb9a768707d69729bbee4ab3a0e2978e0e284446c5c662ec0d79f0299aaae70d6a68b51a9020d
-376 1 140 \\xc9f98934637b966928aa7fd6d3ec963527b1022119c58e805e246e78dc555807e2bf0032ae0fa2a746bfed4985d08fcce9eadf409473a0752454309d4528910f
-377 1 93 \\xb0082f7e428b1cb212aaccbaef303c7fc2cef5a8f9742a56e694daa47575b30fcb9282893ae482192b3ca5e9691725e3d5959ecd7f19056e8872fc73ac4fd40f
-378 1 132 \\x26ceaaaf89b0914b18ac7cc68d510c65c3bac52f46525322dc73dbdd3286bf7379a61084eec26317273fb9dc4d65e59952807aad274e01c707d60fcc5219b306
-379 1 366 \\xdf3098ea7b90215a1b2ee0b72ef4614c8b1e84a1aa328d6ee1e0cf52ad6f065ac973c01b571d39e48bd5cf7de4876a46e96828f4a309d95f73caa754fac07e0c
-380 1 185 \\xe20d00d841f8bee884dcdec1e1aef0f953ca9fe4887bfc1f7f4ec8f257eefa6df8a7c57000cf18fdc8b7e55013b3a373ae920d2a0060a6a06587e3674dd47005
-381 1 379 \\x56e1857c992ecee9e6df040f5031fc5e0ea5b59ba956c5d451a053a856eafcf4059e16a95035e833399f44557a89efd763231708257d651d8c66e9ddb16f3507
-382 1 251 \\x04c4d5f8e9cd2001745ed6c94b346903ee0b11ffa6643c684687f0005428645844b3027028c8f1312a3b4223306648db4905ab1f39307bb80a85f8b34d6c6704
-383 1 417 \\xf85e62cfa7b506e40184134b7093a3a0985c4761bb82228fc83266515c410fcbae08a3a4f8b18e250d35c0f273e76ea4f676aa93b09b76c515f028311dac7a08
-384 1 184 \\xfb77d88c14d9631dc1543743de97b39b9c79b95d7640782ee2aea6a20c6e2e660cf706fd7be4ec7e31dc342269524c102c7ba2a051615b1ba6711cd99b360706
-385 1 255 \\x332b0df53828b74eeac105b0083543e5beb3d24f4a4d8941e4cf3b7b2a00ac604e774838ff82cb957231cf080cdd390eb571cc3860edd93de0a4493aedef0f00
-386 1 81 \\x73c8e7b6a8457aeadc47c1693fcfcee7f7d5ad43b9e3a489411a13169394ded87109a8f05f76098e8ea3c0fe4b6aa6b741819bffb2131923b159fa122e34fd00
-387 1 118 \\xa74f04eb588e8f188fb72d8040b145c845c6f87d5c6eb074d37e045334427344d8cb17adb7457922e0e7f1e8724e2049da8afe9ad81833633eb13319b4f36e0c
-388 1 27 \\x8e0d8d6e73966742b861375f7aa938e0aa3c9c14b6ae4a91c53247383b2650c5ef57d90561654359db81bc084a40a8b4fde2348b621bdc7b4c0cc6fcbf1e7408
-389 1 289 \\x294515beeacd6bfe5eba9461db8ebcddafb4eb57d9340aaa433a3b95f2684ed7c60311b1417c190573947f273ac3b663487005ea76df7b1cd975ebff38732201
-390 1 85 \\xd2fbfd9b2b3bca20cd73a7396f8acb343fe35f3e2d7563e2d49aec17d2ba24678075f0156d86eeb01f43455a14fb2218921d7cee848131345db942e250c4460c
-391 1 125 \\x49120bf797d27b237a37ef0ce8afa97602e2899c2fa60c34521cb20b0882cae50fe48f50fda18e8f15763d985501ce6415b3d572fdf8df627358835ed005520b
-392 1 174 \\xea9c4dbebc5f2d1be88661bdbe153e51e8cf3cb72eec725d03ab83669c011630bcabce359b3aebfea43415b22e56b1e2f2e5c20cb4bd101694b7e22aed066904
-393 1 109 \\x0e217a20bd736836c9379ec6011d55fe3e26e752e9c1271e22caf63052c97079e873c909a674de9f05ec1be3a4a7f2db7baa13f36ea1027d864929f1b6444e0e
-394 1 17 \\xac5d905ed93e0f3005b065c570f1477fbd3b214b3a9956dee4f531395c6e3057c23b8ee611869ea36dca05424c763c518dfdfe446e60a0e953019cff618c4c0b
-395 1 32 \\x90f48d3dc66746660ed096409d65d25ecf43b7152339a878012e59020dbe3708c13c38082609415806d86ba6a1768e07cdaa6145b8070d53821ae287ddfa8e05
-396 1 312 \\x08505194920ac6fd9953294e1e51437358674c6d0df38bcaab0e2c752f85abad4595747228f14d3bee01d8cf874ce70c57dbb12f087ba86ae31e8463073fef07
-397 1 329 \\x13c616d2ca79b350e7e42a44a5ea8dd1eba0f69cc13444a608a3ee46899f018d05dab6f9df2a32d3c7f54b3c024bc467bd1a0f19ffebce1da4f207e8ea42940a
-398 1 107 \\x3458b386584af4e3fa98ebbf678684612b3f3b8f6d43b74b8eb7f5f207265da25846264691530b35b3163f2e2cc2d8339fa3b724e41f32000e02cbb9765aea01
-399 1 265 \\x15090bc2a5f0a889d72e00dc3ce89f0c71c7ce923b22fe90af7738bd47d37eaacc8ba5b9b0aa3b6d3aff7d7d7139a9615948ce56260b18e7b2c4254de991040b
-400 1 297 \\x69d38d0024958fde8d4c57d35b98c8231d7ccc0f2427fe0d09e9c21b4476cb260609cba0cd9d0b1251f6a7fb1f45ff6789468f4b3814167365190b705cda360c
-401 1 407 \\xf46286fd69e2cbc477992a778dd0c416f768afe6120ebbc1bc537cb188bb35402f33f171ca96c3ed5b149256b991c1642d8f6f0fdf4ba0898b53309215c3630f
-402 1 349 \\x7789b44edc5c05c5abd062824e8e39c90f61e4310b0052633d40d500e7829d48393c1ddb28809a93070b321ac1a8cba3f17bfe707c19a5700e8373e7e3550406
-403 1 42 \\x288153dfc0e00f72d3043e486ca79f9691f31382e884a77a600923980944c8ae2cef7c39ff5fe4a9a6ff9e80c8dca882cc633bc7fc40bd85a10a890775fdd60f
-404 1 106 \\xfc4c3120ee9a50b9d464c7b942e25ac99b2f5b057b4019731afe838993a5c830916bc44736cd3fe7a20ca16a0fab0168cacca5647d74492d8f0b84a590a0dd07
-405 1 334 \\x43d88380cfa12ee213bd72a99fbbbe0f51b64db303bb10e4c8e665984cc67ce4975c3b17f7485ec073b814617458b4484c9ed3e43692f51dbc96dedb0d15bf05
-406 1 227 \\xc1fe23a2522e8556d883af20febd3a9e66c2f6368a322413dcbbacede7b1b5a9184ffddb3c753483eb1cb3a65bba52b0d9051503a44071f07936098f12f3ff09
-407 1 377 \\x06f85de91c1cb31f556dfeeaa95bd1a680cc2e3f9a71186216854176b0d1a8daba23c02ac24c2a9a676f24c013d4579c3e4fb4c6b355279262c33455cd95590d
-408 1 159 \\xf269426ccd96b787a7729e919b39b563483506367425562e25767ebc4b31f58a631a5519bbf0dfe5ff4986fb6e83fe435e79b4bd7f0b32a9705ef52b4458bf01
-409 1 74 \\x4e4b9f33f97dc7d74ce3e750884b079cd8184a108b20e6dddb6395b455ae51674c56e0ce28cb7f60f55835ffb0d846a5ca61df4ce285ebf5ef80d2e66ffcf903
-410 1 100 \\x843566e83fe460eee05b7314d6b98cf11f07b8a0d4153dbbe94ac4b0bc736a5989cd327dfea5a07493c3f4ca8cc5c632bdfe0215e85add1436494bcbfc81ad0f
-411 1 306 \\x2c6d57cc70f33b758dfe130a00174ee3cecb59d73fbb5ee30c9942f72f22d8f8772c4bd6d1d67e5af917d775186433c5156e7e8c14a3c4172705b36fd0f5170d
-412 1 127 \\x0b40e375ae380615af08ce0ae519c7ea4c72a24b7a5e98cd571d544679fe534171b1479d7812eb59e267f370cef4902006e5e94fdc1649538970d7f186759a00
-413 1 70 \\x39e09de43b6a0589eab3696391d154e951525edfbc4f12359184158a391c41bf79c7dc04f8d96667b9cc4ef70167bc77a9a97453e408542405f9aeffee539c04
-414 1 121 \\x37ef585ab7e4b4444d8a98df1ebb029471b5e625e6888e9496e6c580bc8ef441120d9b34bfbda2e05aa194ed0373a4701944c410174be3baf39fe5ec46b3250e
-415 1 193 \\x9143146e7761ca7c1bf5ebea15c7740a6f072f684a198609b2f1506aa54f73541514aef542482e3b622cb3f114d36067e255bb16968c7f20329c7e9d790a4a00
-416 1 165 \\x31e84bd0f1492a643bcf977a38647481412e8c81d922cf3a298df35a4908317703a857e45b260f5aa6425b5c66edfad9b163178101ea74e2c0935d849f144d0c
-417 1 191 \\x9a7a1bea0c31d55c0029effe10a07f62ec86a4e5aee04b798ce5af58506c1295ef93279101e75878eb047b94a30b92ca7cc0fec6dc82c8d5448b50c4c7457c0b
-418 1 346 \\x31486ebf0f736ef92fec91c0ea89331982744deb007c45f49ddd1ecb482fc093c8291b7e15fc4a0fe73b9596c929b44a7bccef1cccb093940f786761bdfe330c
-419 1 7 \\x7500475302cdff38ca2446c81f59e161f277c69bd53e94df092ebfebb654b2c2594570c5ef0c68a5486a4495698f973508ab6af77ba0d0bdbbb81c29887ce801
-420 1 336 \\x509da103b5bf4a45f24d3ae3605d200c9bbfe2cdc7d97ba3360a5e539c576ef4affa8b4395ac11dfd233265b47a4d46ca83da3d234b9616dc92f9fbe6efb0e05
-421 1 53 \\xe332d75c290ad366f668f62036c51048e7f1d5c6c513cdffa457f8268b7df8e857880125d45319edc3606ed9fcaff9b8417797764b4d3e386d418edd1e1e7201
-422 1 257 \\xb8c66e1e38f42d45e7c629e21c730bfc7ebbda8e2f82a598825c029cb8847397c13174f2411e85f9bfd79d020a9daf50e1ec56a5aef68b77728d4366cce8e80c
-423 1 367 \\x36e46bbcfbbb825ddbe81b3bac4b0990e7396dbe2d573bda6a5ec006373e5109d8d91535c42b983603eab6577c7d9f3f01fab6bb0d6c1b5c9613a768f2b69703
-424 1 403 \\x34c46ed721520a69f74ef1167e6441ebea461ba29f3faf26033a721e335e347751cbcd7cc42d071d324b2087d024d1cc3b8927ef62f7d4483cbb906831bd0b06
-\.
-
-
---
--- Data for Name: auditors; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.auditors (auditor_uuid, auditor_pub, auditor_name, auditor_url, is_active, last_change) FROM stdin;
-1 \\x4eb9807e7cdc3e94b223b9ff2cee1514010527e9dca34f4162a3fda3caa894c3 TESTKUDOS Auditor http://localhost:8083/ t 1660251981000000
-\.
-
-
---
--- Data for Name: close_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.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: exchange; Owner: -
---
-
-COPY exchange.denomination_revocations (denom_revocations_serial_id, denominations_serial, master_sig) FROM stdin;
-1 7 \\x72702f68a7f8fe933dccb46537476f90137b4ce7feedc7048244efafbc8f7f8740b6b8b18e922e9fc109037ada55ffaca1456963d543bb35f8e902fd40982501
-2 193 \\x259bb32c4b2f70176d1f22a187f52f7a085097dd9b5222a475b1b9e4d0f93304d7737078303b16a37b08a0bd1e31a7a3df94079393235ddbbc8e8d3614c78107
-\.
-
-
---
--- Data for Name: denominations; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.denominations (denominations_serial, denom_pub_hash, denom_type, age_mask, 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 \\x010cfca8cc9e5b19d075cf60c68d536a23b703d353ad23dcad038cce3cba282c5ddaea1f18e6c188151d9c59cdaa4404bbadbafb86cab94641a2208ef24a7b98 1 0 \\x000000010000000000800003bb7e607be2d9d1a3f7f7e3cd7ff3c558cdbe99845d261590a6a2b585d6f63f4a6ceb61fbb33d828234d6429503cc0f373e7c3e23e0170bea653a8c640474532b582b7cb2e651107d658e2b721283bd00139731d04c5c217b662632e0c275ac837d12289fc741fdaa95d182b6b1adb2f5376fdd8ffca20cf73c6e2c11924fe499010001 \\xdf21316827f2decf525b0b4f29ee142dbfc79e7fbb47da5e9eb708d460d657797accd1b7d51a87242b07b1f67bcc6b382d5e4a570b86d6a6dec72e40926e8a04 1684431975000000 1685036775000000 1748108775000000 1842716775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-2 \\x02dcc689811fabe69203f6d1269a1f1f8dd5c9d36a2540c856a0ed1bf9af1277e733dbffe6a906ccf062b45e4d0ecc01c64adcd86d88acfa138a6f7a0952c1a7 1 0 \\x000000010000000000800003d4e5205e979852869c0266b74661333bbae907ddeda3553dfab7224b4b3f4e6135c84313570e918eea206bfad8a3a4d97282aac77e22d524d7b8d4f29ed0989b8f5804ee8a4810902bfc01381d2acb4ec567d94526fe084a72e71c4dadb9175e5115cdb7d767c7c17fba3ab1a3a609a4f1767c8d84bb43118d4b7228537d35d1010001 \\xf9b8b2425c601c88cd4ee8de108838c3a7663a2cbc39faedfd33b1a69e789a6c23d3f257302bf0c9418d00112136d89dcd35f1501c5f9e6d65bd182b0b562801 1674759975000000 1675364775000000 1738436775000000 1833044775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-3 \\x0704bb7a3583f5166565d1646472c6a8bb4a09772d3c788d8838841cc1ca526a221a013e5ddb4ddb9509074e023e24235c86e735793a56e39eb0e239aafd2ea7 1 0 \\x000000010000000000800003b33768fcd86ff082b26194d56626269acd9f9d1475642fe0564ff1ea3d6882e54e2dd32814638bddfdf6fb22b84b4136a8f726965d9a2f7e2e16c6fe6d55aa176666c7c4e8b97ae1f48c612afb13c7893e88f0a157def419539a2f984dd0e41694f5cb205bbc4390f4052c956494c242881026b551643fd17d590ef1eb513a09010001 \\x4ba71388f3a44a9a026fb5fbc4ec5b7fa06753b37651029e02ad193f9c151b6645b3ed7fbf9ec793291f9be1455b5630f2c1908848d550028625dcd5528d3c08 1668110475000000 1668715275000000 1731787275000000 1826395275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-4 \\x0a88f3672463775dd2cff913deca8d18b401bb7f9683e5ed36404ec39acb18514c098ed291c74773b4ff7bc5b47a9d1ffe17715a9ce829c9a05464a1a2223ef4 1 0 \\x000000010000000000800003a7034d07511048892eeb8eba607713407433304a94ec6f19c449e616f4e42c328d38031be9cf75b787bd1cca889a0a520e5087b7870d6e9c487533259f91bf2330d783cfc140709e88e662d2dc70c3f87ae95ad3f6802c1413c877ebb108bc1336930dfec1b5cb5cba136652d561a85515ee9256a82622da315303ff0a469757010001 \\x92daed943297df1909df60ae5efd4ec430f58c2b0416f4f6429c17b55ebe12fbabf79ebe64fcc3b6bbffc6b49a61db78445d40c1c097b842fcd666688547160c 1678991475000000 1679596275000000 1742668275000000 1837276275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-5 \\x0ca070de9ca7adedb93dc5d2b6731f3f8113013452d7e270517cab2094a75805f022c236978c0fcc2aa1c3b35279e53006a55ce67ea436a7f6324acf07b94cbc 1 0 \\x000000010000000000800003a45649c63a4707f794caa0c50663286b999c9742a5970fb9c46cf161546c521831220c0816c8be42cc38750534f5be93e48a29c8e693cbb0b43ae3c4e612ac13e7675cd6c239404492f949edd415de9cd2f7e0b106658dc7970f3b168d7d0fa1aa9788d6ee80d34db53717fd57a5e5deda70febdd67e9100d5b9734a168e80a9010001 \\x6146e6fdfca08b02193f3f733eeeb520be5d3f15c2df511c23c7c4a144c700565c7bc577b029966117494512bb88191789714c685d517f05de5547f13d46500a 1663878975000000 1664483775000000 1727555775000000 1822163775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-6 \\x0fe09fea8f21bd1c7935a8f1c84bc9f3921c106c30e56a82e9458dda9b5de15e9fbc463b0aafed9243bdd2b32f9a923ae9bfb8d7fced94993342984818aaa155 1 0 \\x000000010000000000800003bc2308ad45996bd4235481e0dad6366d6f635da3111df53ad8a297537283a534da21f9f154b4b79df14bb2d0586a50d24fb8ff284c2cd90e4e227af4b17350151c04bba95515a0947a361ca0262b853de65bd3e726c4702c3cd124baa0133040d2eb5cb712b62ab1ea1c2c60d572ba38f182c1b378ffcbbe584c19e6dc4ca645010001 \\xf09418107361607a9abdb673679ce7b3c8f4f90b273762743a02461e2c2cb862c448464f3364e8b35860958309cb3b1da7513a5c8143e3121d39f2ba93dc2b06 1681409475000000 1682014275000000 1745086275000000 1839694275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-7 \\x10f882592bea44739e872800944f8c69369bb916d0263958fa465193b67737c8f0473a63825492010b0f2434b48c20fe8fd64c5478710a6ca72f08ff365c0a14 1 0 \\x000000010000000000800003a03fccd74f61971c05f7f3a14810b06051020c39ae8e0eb92df36ce9ad584cbee9e0438be5cbed1bdc75cf519f67fbcaab56ec93d6f6cdd76de67f11e13882f1e783a0a969c3d09e46bd230c0f815484b674b2dd7cfa8366a5a90698286b81ed442ed28ffc4c12564727ee86854eed89d05a9a1c6143de6cfc56c89af0609af3010001 \\xb30a2e2fd71fea4b050a29d20a5fb2631741b7083e3068325dfba8af04ef5fb3ecb391e28a38ffcb5722d209ca3145a0e5979b5014e1c826463062718e9c0b06 1660251975000000 1660856775000000 1723928775000000 1818536775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-8 \\x140c1e687a912e4ec61de5e3904ffc3205c05bb8dd8e7f1f3908f41a8b2558593ad0e4ba1255946363f41b58911b0a0e0d373dbab90764d14d92f0cfbdf88f25 1 0 \\x000000010000000000800003d6fc68e924f7bee7edeac259c821cbed1b34a0487f1f75558be2f4305eb4c357a22757046ec58603ec9bff65a10690042e29a95d505780ca46e994553745f4cd2444706bb7a61c89f551f1e72271ccee6dc4175f2f082ac841264e072d096dada91a0bb1c3db9ea13c8c93c393a7cf153e10a4017bde716aa166cc575b579213010001 \\x1c874a2a7a55340a06f9a2e167d629c46a9b71987aec8a913b0bfbcd0d85b1a0ac21f1603a725c2bd030b271a50edacd2884fc17a89eee3c161adb3d4f51ad01 1676573475000000 1677178275000000 1740250275000000 1834858275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-9 \\x1524ef50e8629cb62814faa6003ff4f87ceb8d9538efd80b1b1d5062ce797d8ba6f9cb06ccebe82ea28ab10f0003b169d7b58158e3205e8b4f0ccdaa514f030f 1 0 \\x000000010000000000800003a9e03b40591fccfec3786018a5c18137ffea6ef41eae0cbca2292d29625796cdbaae982bd5debaf2375b08160fa8c57d452282da114e694cbc568e337bcf8290877b0c0108b5e515befaf507a830cbabe741744087c547363202e63b4fa32627b114ea6e0e4e58d2a8dbd0ac78853d5e829aec4065998009e1d2180905697165010001 \\xd9a73c698a38947c3df47f8ed4f8d9f8261a9d7e21378f6165825b22b4a96ce18d3a5de10d9e014fc6176891a647ef36c9c2050222e55f3ae5dc20b33fa7350f 1683222975000000 1683827775000000 1746899775000000 1841507775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-10 \\x1acc1395f6139d5a25d8710f0c04ea5c5d7268e5bfa7877c731c2a27308e6965937600f7543907e6b14882ed2746a25a2a86356205db1cfbb24b5134ce8ead62 1 0 \\x000000010000000000800003f66602f28ee8371e2904ea0ec5221b29e2d2285e8c9c9a23c25200bc824bee8675175b7583d78cad4737051992d280f32f13a338820875b95f7a2e82bebbe18f23e66f2878d25bc5d8dedca97a5ba150beb618539657fc8d035083f862d30ab03b61bcb0dff9dd9f7b1311fa7df30c023fb8f0daf4ba1994e4fa71ab749cc0c7010001 \\x96b8cecc165fe3d25ed780f7f625324b8da6e9edf24acc4efcb8d906ccb4585d0dbbbf3e86b4ee9550a78acc9f21cabdf148306914588e73673a14ce3dcac505 1683827475000000 1684432275000000 1747504275000000 1842112275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-11 \\x2098d1b90b770bdbdd53766f7792f857aa37efa543ca6f41557c5b50d56f8f68eb475158e35e16db51aa2c1c0300c5cce91a47f0af9b47767f4d539111418d28 1 0 \\x000000010000000000800003c57d117ca632d7a93bfe28a9cca5b10ee5620db8334fea17cad035dcab5f0fd6e1ff8f3318116ef5276d8ece9718ed5363dd46bc76df91ecdc2266b37e7d8783b8d64881dc874cf05be35e2028d814f0844272af55b412369acfa467c55bf9de93be52c7e792d32df2caea63de574820001c57669978883f8fc301c146a03145010001 \\x4cc49eb3cb8158c440cf30bc545afe46812c5c69eb0672e9a0f9b3e5d5d90421a8c33dd2cafb71920ed29638ee8a4d558d36da88fcd1995d3770ab8627d01200 1668714975000000 1669319775000000 1732391775000000 1826999775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-12 \\x2868312e96e0f166537a5bf96981167181403467e8755e3ebba04afb31e7c6f7cb4c1035eea601224b63d23e3ea3543bca0a554d2103239e5649065df02c011e 1 0 \\x000000010000000000800003c2f6bddde4506dfe8fefc39dad9cdf53e49e80c8678731b5d1215428cc81684c3b6f4b35d1267fddc8b96613f6fdbc0eb5d9df6c4bd2f22255f2743f4918c2f86427cf80eb601d6df99efdcf945f8e31cf93d4d34c72e65f21a5a01dadf2e18652b194b21ad589614cf4fbdde39142780e446f855ef783343a2f9bd5120d7a91010001 \\xdd1765b5850465c6b44bb8dcf9aa333cdd17a7fc4a24a492ff7e98f2a08968f149517a592377c8cc241553abfff7f43c46e82af44b69ba4a553f6f9ceb1f960d 1675364475000000 1675969275000000 1739041275000000 1833649275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-13 \\x28983a901a1278d5c6d04a232756b96155b2fa2634c65f953aad0a1cf0b9da712056e5d0b1ff49b3b221e39d7228c41b872fb649a246f9cc4078454dcee43b00 1 0 \\x000000010000000000800003a084b1eb46da5de3fde2dc7b2f355d2bd2e3bfac8e0040fd99d6dbbfd0b3357ccc5c11d3a6e1729d417523f8281447cc173441120189bdaf98d63e5679264105707e0f74d5479b7141039feb3605bda0309e756d5d30f015880ea8c15d796b798dd311997f37512429dfa526f9da608b7957d92b83a877990acd0fd82899a19d010001 \\x9817300963ce98d7ab038484c9302a269b0e6f47851d37ecfe0d202731b3972a1ee689256129a7fdfe8b53d127371477ed1c7ca8c9ecd760696959f4a1ef6e00 1669923975000000 1670528775000000 1733600775000000 1828208775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-14 \\x2aa43bdd4739f4d106377286dd364d80dfba897a809f434104b148f3f021b17f5b0198fcc6559f933c698ef328932ee5afca382e45ba548ab076bd58bad177ec 1 0 \\x000000010000000000800003b23966d22241f4935dd30f69ee8f62ab78a834da7be9c22eb947518519533f160718ee9c009f3399079ecc0ef32f71bc086dad1841bcae8092cd7cbe503c6cb1f38d5be1c699567cb01997993e0334868fff8b312602b2f06493b38a078928be032f4a62c0ee9960375ca5182a12545d87cfdf27ada5b0ed826be791b9c82169010001 \\x5ce0046caa77491affb5c45da1a6b0dd29931d18151519b66a241f2c311534bd9f0f5b491ab933ca0bca9b1eaf39b635a9c635f40c6c6920140fd1a51bb1fe0f 1689267975000000 1689872775000000 1752944775000000 1847552775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-15 \\x2ae4bd6ca14a7516dd28d7b2906dd52e2472251a8791ad41ad050823a36a19b34a06f16a4ba57cee31a9db925efb3a1d030ab23261f616071834f63da18313cf 1 0 \\x000000010000000000800003d4ffaa32f7915c1483cc57ae339f94777c748e4238a5971974f3761a384a97fe1ec7e9ca0809a228c82487866433fb9fe7d50066ecbf6d954c3611a8e384993b29a56b2550bd4dc8d403d462c43681ddc10ded8a6eb89a57cbf3a445901818678bb197baaa9d1964b4539f750f8db12c5852f16cb22d622c1ac3fb773cf1b493010001 \\x5823a5d75087bce9d464169141c40eb4782906077e2c5bd9b41e7c09d7523a85501da475453d6bde8d1d20b638b237f74629bb4a87eec5b96bc9cf476ab57a0b 1685640975000000 1686245775000000 1749317775000000 1843925775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-16 \\x2e88b3c8bba21adec67fa9ee14d226057c7ba5d6232bfb06e432e4d1da3ac1409143f529435265270e369b4dda8afa4151c92533556c4c6d939ccbab3ca0beeb 1 0 \\x000000010000000000800003a7ebf7cdf2da4a05826e7237f5cc3d928529a0960821f19834c85540255b8608320429459257be064bd70edb15c16d662499db87bf125699cafde7646d50fbdbf88ae8c3b5a4b4c29535cc38e6073fe3d52dd0ebe3b41e2f8602a2f399ffe0bb941bbd9b1b2210adcad9e7db1365362517c31a2636d7fb561385f99b519ce423010001 \\x54977dc535ad4eca70e1915abc1005dbad86dec3b6af530540a5d6f533ea386966adda31d45a11c8ec8727162f3d562dae513b9eb6496150dba05abd28a97f0c 1691685975000000 1692290775000000 1755362775000000 1849970775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-17 \\x2f6012d6a231fc5f475894aaf693d7d95eb13759a4255cec34c90e61e616b5c7cc41c484f25c5124ef13b6894c180115d22879808c1cbc33ce0889d66237755c 1 0 \\x000000010000000000800003dadbb4ff97149e85aa77bf75499f8d77279af94453c3abe1161f843765741f8ceda4541780ad511be267748fdaf65c4e211146a8567e253365fe701aa36d60c8bbde75c5d805ed1501b422b4eb77d57363a1fab5d8d750a69ae75697b2c0865b507a8a53feb92b393c5f02f702b71a1d45dda2d351c0db74bcba6af7c3ce0ccf010001 \\xda8dd843d5f4266818328228d06d3315abe47b84b3463d3e663b06c707e2760ad02adbf5fdd69aed03db79785e9a6232bf549c3964ffc4f1d438fce98917c30f 1662065475000000 1662670275000000 1725742275000000 1820350275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-18 \\x3008984489dfd2389c6c6e9e0e0b11b1848a4088d32fb3455b77efcae7a2de0b4ba6d4fbfcd7bb0d232d6df820053f3f844f1c187a353536356c7e556fa42a77 1 0 \\x000000010000000000800003c1c29d65a20b0343eef4b9602b0404a2504ce8ad47c4d7f8befead8b2fee98c1cef4425b3b9a0c26336ea7e521cce532840ff0ec1bb8c081589a03422aedb02b214b56cb2635879be4551ca1650b05d8a540ca316b45dbb63b5722eda41c49ecb49d5f80d49a8f1605dca4f83350e4eb4a005c96da33be04105679b286055cdf010001 \\x092391d0b81421c775a2850b5910874dabadea504d4a1bc3d20ff1da60fccc3ee1db972cff7c282ff7e2e44fc18f7c97ddd7a4f87cbcb2bbdb58ed681b7dfa04 1689872475000000 1690477275000000 1753549275000000 1848157275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-19 \\x31fcf21049b45987cacb844f6f8a8297f3a52a8adb12970eeea8ce84540fc43fa217ad71f3bb41db4b2750b439795b6e5e1349ee65f746e27325c57694c21324 1 0 \\x000000010000000000800003c47798bf4a9f39b0c36deb6c693f1ad07970a1c0120e97d3381bfc5c7d177d333155d67ee51e5dc22367ae1b746a28d701741d628b3639ac7569dffe858475609cd59376f416934cfa9f393cb0fee23db69fb1ed1342bab5546d5f5788e7fcf8a3d7ab1c7a7c2742731fe4a811d6d89703f6be32907e361a029d0745f822be4f010001 \\xfb9a7b5cc1e3bb362487841cf1f5fd252ff9cf7edf54085bb8f5970affe92bdd81bc2959096fb78338932774efd121ac5bcaec3f44db1c52251a1bb7c28f1f01 1689872475000000 1690477275000000 1753549275000000 1848157275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-20 \\x35e4dfe5b70e61b9360c0e3d97f7747a065dfbbda93f67ccc5fea8e1feb8734f857e235e4fcb1541784964eea7ea85b65d05409bb545a0261894855c0935fc33 1 0 \\x000000010000000000800003bf1ed314ecc996a7078ccc9fbe2cddd5c10c8ef80e74338aadec31e06bdbbdf4632292829f2cab40d5ee774a967549225bf3e93b7b6b8bf2a06ef316bd44473a33eedde493905f3fe9ebdf052c49864172cee84ff73e3297f33e1b4b3a6711ab81ca536fb35bada8134d85fe8e338866499510ca6cba814d294f90364c50b015010001 \\xe397060c25acbaef622c0cf12ac7c16ab551a0b73f4bff12a1bda2c3696d64970c63d5867bc0297bbe96417ae0a76734746c5bae4600b713596391e40b597d09 1690476975000000 1691081775000000 1754153775000000 1848761775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-21 \\x36b81ab9e9a71e75f79cce1772b4d70396a0082fd990eecff54dfe56c94373e247190952b938ef05a047895283ade770844c64ed72848fd9af6289dc7e2ee48c 1 0 \\x000000010000000000800003ae77d361126fd26629bc49e3485da801581fe5af18befc9de5d6e9e463060aa89d91fb5a413658d800de11bd49d6f488ea37bd58002ba462a3c08238a23a677dbd580f3a9292668271685caed5691d73b84393f18a6a63948294427096a196ff273e6750e23d949418e48395df85507289ee1ea493f0c985013e8ebfadf97d8d010001 \\xfed4356958b896a91a256bba5038472d618be7f50894b956ea2aa8e8f494a6bf646aeff1dd125496b6e5d8d403f0dcfe4bd32f2b027e901ca03d912977243206 1663878975000000 1664483775000000 1727555775000000 1822163775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-22 \\x37a050b1adb41b20f50713a2a2da01e427e1e3f1bf54399647dd5ac993e6742e6ccefd75d441d6f724a6f41d3f705bb8d1050a32dfaefa12076d062e82c279b4 1 0 \\x000000010000000000800003d5bf1ab6644d6a3d66d2dd9c40f25e6399a6c28a4506e5758ce55d48e82d954135eec776ab0a5f6e9fb0702e411ce6fe5eea823983220b1586928b0e98fbdaf7c230fded6dfbecad6f932c610799045bf135e18400717bbd33e0d1f397d1276623da11fab1a51ddd38467685fa66a6674a4b3c39a6e9149662fd34a82899aeed010001 \\x5b2c821940c7322b27b07d5ecaf41965f103289e945bef9df4116447e8884de6914d9ee2ceaed6b26095e1000d120df8f9d40424341de6b483ecf6666fcf4406 1667505975000000 1668110775000000 1731182775000000 1825790775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-23 \\x3a4ccedef256fd7a1644b9b1f7101471d1605bc1e39bb3aba295b090196bba1b53785fa7fab87c96e8693d00471a26c0aff14e51b7fb1b9049008ef9ca20b5a4 1 0 \\x000000010000000000800003b5a7a13df1d4fece7b3d93bdc9cbb1b8d82426b79e278e07846b6cf67162255652565561d191953ca126ed52b592953f688bf14ff9417c27626427f5295761d038e3b962135e82baaee523caa2cf56d5bcb0deb21936d320fde753e32957890315461cbada77ef622b6dd0178310e10e8bbb0c0b8221496c2ac6daf9cbe12931010001 \\x0f3610f78432298d712ab55c788c64d1c094854f60360288e6beaaf5a1dc84a74687f10bfb101357b4d2501079c13a9166d2f6e682a8957b3a1b97908d94bd0d 1681409475000000 1682014275000000 1745086275000000 1839694275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-24 \\x3ad4ec3ae8e2d81e521a0efaabc32ea6ebedb5e52b663876d565c5adb6119e24c86dcacc6aa2d64677ea26c5274b22b067fc019b71b02dffc4b602ec1369021e 1 0 \\x0000000100000000008000039cda9f752d862017de6df76f1bc1b247c420b42e12cf841d3bf84c600db7d0391a74e1fa457db40a2c8ec2a7b0201105a20bf66c4b9d1442b887f6c0fbe52daf70d2d171ef920a94946c6c7bf2cade8575ab0a835e63580725a1e1e816d8a97a3c6149b8be8fdfa75a8a14266c01132efd6f9272fe2ee348e053d23ac4dab6d3010001 \\x43fbdbfc25561a440ade86b877b2e6b022e4a7e00fe455df5e4f8e66f1d69177d5f83678be0045d9625ac36e56e4d40867055b11ba2e148db5c322f676682408 1670528475000000 1671133275000000 1734205275000000 1828813275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-25 \\x3e90a896e744010344a192a4aabc4bc10cd54752a7775d840a7ce430db9fd086c546fe89d83b0772a9ed0300d6e44e4ad4f39a79cb4d60653e4c2814867b9434 1 0 \\x000000010000000000800003ecb970743b29f34935d86cd4d77eb21698fe4a9fe533da0127da64125ff5293392dd2584862fafde631dce2814031ce8f15ebbe2fd4b8b3661ea7f98beea39b2d79c2b5350f917353cb07aa2f375845f7e3f00b0fa8b977e9059355b9f199daf5cde7e40498f25276553bfbc8ee59b65b754aba727d0d2e43b8d52d617ae670f010001 \\x2bf1e885fdfc3bc3a90bab63b24adc0cb3f1e26a700fb9e795f8c8bf320c5ba23386245a2bd7c10b9bbad0baf617e74e025719fd5830428ba8c549099d10cc0b 1682618475000000 1683223275000000 1746295275000000 1840903275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-26 \\x3ee0a4c16881700bea6c7d9190f83b8105b121ecfc81dd560809c410ed81c0dafb874da317deeb5a05d2feaaed863101ca2cf68381d560af23a0c7d350eac1cf 1 0 \\x000000010000000000800003d7252a6387ec235335d9ef3e142eb9e1cc068341fe5c2acf1a8214f9f07e07468f241c730dcf0c7403e5f6d2ffeef3744ac59a319dea722c7501061d7a6d4bc2e5169206c08b562538283609f3c7d70085361e282ba407a3ea4f97dbdcd215a388dc8c1779f7b17f20175c17ea4f5ae2f3f221607f05d23ce4b971a383fdcfe1010001 \\xf87c2a42639e1fdc5bb0150def5d44bb59326f8271cdaf1d4b32d047455d8d3d92423f93d93a15f143475ebda68704ec36e96dcb598c51ff79bb224c88a7310e 1688663475000000 1689268275000000 1752340275000000 1846948275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-27 \\x416c27ddcf77ba8aebc27d06fd132c0971d70103717fdce2dadcb80ee391d533f016dbb29e26cb423b1bfd6fce71eb563ab8bf6490dfd404f92ca7e6e7835c17 1 0 \\x000000010000000000800003c8e0a36437d03ded00339c62ea8906ebf24ecd57a7d8b9c0d9b9488bcfabfd59f9b1a02f4dfd2fd0a5a5d931ba40a3b1d1209871c9d7acef899750f997ff852e01a45201572b3547868474eeaf055f568045de0905bbf8b4f2bdf35cd42c755b00e875d7508ed39823dd70d8de07b74d13c6b779115d73c5b2e87302b0f918dd010001 \\x8c446d92c9257be6cd37c0d4fff98d86f51600ebc6cd79e1aa9d8e82c8294a1c3f4797d22f56dfd3a39fa79cfd89e49b2dc32289b1efda7eb53945b45f83670c 1662669975000000 1663274775000000 1726346775000000 1820954775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-28 \\x42809848342f0fcb16e56bca752d3bfe7305d727c16b73b0171944918a0425c55c11001effbe527beea99a5aa8ca0d2acf051fbe11a0ede07c0ba93d74c7089b 1 0 \\x000000010000000000800003c5f94d58394f613a12d08c56c673dcafec5f149070239a7d13d229ae9f086b1fa7d1da2e0bf60c924e050cf9f4889ca468e8c3f24c7a3b5c5bd49912d2b50b1836e306ce2af8ba117a678d4b1fcf64c6ecea0d541ba04e24bc6d61e6ec3ad5b77a84fdc5421f543f7ae079d66057afdce98fa503daf96f083e1483dd9420fe5f010001 \\x190a8dd4e8ef3c05a848320a9caec44c304eacf4820fd9f7ccd58f616f08f108e5e426775021b730967e5bf24549f61ed14e426a748ce47405c8bb35e3751103 1685036475000000 1685641275000000 1748713275000000 1843321275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-29 \\x43685791c591dd797fe39615a65a2d0b60485db760e40af5661ba5613625b00c6c35a234c66f31e5f306cce80ae071800ca68389d1270beb5967773b15d50db0 1 0 \\x000000010000000000800003b978b9c02541c4c6c2c9daaadfd7d7c7cb19b225dbefa26594571d28285914275ad1b62edec5b76f6c2437a7d0c26822035d529661757be1dd504c9e5471ccc8f269011f8e63c170037722916bb7ebb1b472e74e9645f136b0354298a37a99f6e7c85b3c46aece2396504831187c3866741832dfe04da6151060c18d43b98987010001 \\x2699aa6e074438c8649c23c2b467747a195e5f2997031177eb3b816741d89f39992f904ab01dee8fd449c9e714dc73e0e01d1effbbf338d2239c90f6e2e7200a 1680200475000000 1680805275000000 1743877275000000 1838485275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-30 \\x4450c77926e3c5d37055ac8e2d3923bb7cdf4a42f509fd2bf54b8ac717117c6e3b05ce7098940784025eedc237c3224bea6d4dcde375870a05b9f0cdabb8643b 1 0 \\x000000010000000000800003ac1c3df8a683b0b84d3989d764fbc8f0bcb309d915230ca72db64cbd12cd0b2fd86654615270cd33631902dfc85f00457526f35e637e3a7868ffb4e2ef755864f0d52240e8c87386b208656b2af3d7941d67dd1bc7d7d4ff73d665abb5b5f9fbe2eba00fda8759815fe203ec55891cdc9c22e57a92a24cc37528c6a0a542e059010001 \\x16bc4c9f1513fd117541a1625d67f0fa08ccea46725f32d3f87f7f967fabf9e39f160938c9e52eda4beefce591553f50024bc423a90ab275b756ed30b35f400d 1680200475000000 1680805275000000 1743877275000000 1838485275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-31 \\x44507adf34939182e741d4316b52d1aadb5d02ecf977b6beaf4d929b34b3c91b9ebd853e305c89b144073ee1018aa19d889b155fd561afc625f4195238315465 1 0 \\x000000010000000000800003b6f9881dd2bce7311af3b25ae09fb56d8fc445f63022c938a690dcd3a7ebe15bea14ecd7896331e750ea60c1aa6d4ccb1213ed68f0d09a3283f7862149d738de929d4ef647cceb299bb6ebea1b4c007bc8169755a3a79c5e7a3b7ec6e17ab156dac55563e99060cf1fba6f786f26b663aefddc5f9c3754ba9cdd768aaa97e525010001 \\x326c8678b265b1a0fd6efcbec6a3d627a69d2f073e2b13a2a76e0aa82e6d88ee80e2e19331a04da4e0edd347bc1d37305c5aa4bdd68e777b7742e9df9be32b0e 1668714975000000 1669319775000000 1732391775000000 1826999775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-32 \\x4754464af2cd2ae2a5bbf949e7b24ed59548618560f5328bf58935f8f253ff8e207cfd9b58244dd8b052d17fedf15900dc8d454307eee8725fccf2679f7f8822 1 0 \\x000000010000000000800003a4b4f2da41266d45f9575fe13451ebb570ee564bd3ddf848b2553da31e4c574fa5df374222781f33aba0564c1d347301ea70214348f0c6cff6784ae5eab42b43c191fe380280d957b0854353402935a9b70e67d6d995cf707207ffad2cce7a0ba852933d6c4b5d9950dcc37e501d4f31ee9c63291f3ff12cab329736dd936a2f010001 \\xb4d9cc676143d5097fa4c498cf352d2cb3f7403f7763a6927b37438d4b3afb3af9af77a19abb83919d1e25ed7cf0c050865a81f180b0afb358acc21816ac8803 1662065475000000 1662670275000000 1725742275000000 1820350275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-33 \\x49f074d824cc7410f942b1ec2016b92f19bc5c5fa5d3f6230e2d07ad722e4fe304475538e523ba4678394ff5f1c4a7ec14a2932bda44a28c462a36c045a09a0c 1 0 \\x000000010000000000800003b7dd0b4ceb68fbd21565f75c25c2133cec70a89db42dc3586f22e10f3328159d38db0bad156a98dc607b698227a815ff7d05fe4300269e9e4a073d91b7ddfd2a8c7c24f9a0785981d649029f97130e5a656237cf3774f0d7ee665b7a23fb1f764c8bdd62efb3a0fcda0984eb8418414bfbe7f11d00f84063aa39aee82716bbb1010001 \\xbf43e44bdfba3df64f8827230ca01048ce5e779da096665b6352ba342221f9ce04dc608cff1479652b28249e867cd1ddace74214ec4da4019cf88a3af13d310c 1691685975000000 1692290775000000 1755362775000000 1849970775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-34 \\x4aa8a2d156c82e8809d39bb38e0a09d1a2af344c399b57528582fb804465b7d8e1bdd0cafdecefc240f302c4ec59a1efac9bf97a15a838f24943e839a94540cd 1 0 \\x000000010000000000800003c2893ccf70cd63707e628f89d05b77844cd721971de0086cf205f50b6b5be6e26861ce5ad67fdeb692ccf151698ff5ab70e73d9a5014b82914782ce054df0c5354d7780f848e76af505bdbaeab4f1787d20e81b3bf526692460fe52c76401063fb01f8578ea6e482463267b626cd84fd5aa28bf1ec61a2c15c5520b0531fe907010001 \\x79b366dc3fff7eabaa277c6045212c1b509cb9f7b845ca45de70c1b0fa95c7fdb712c59a14fc2dec6a0b8ef361bc024c66b6de537366bbd24414dab80dc1c405 1675364475000000 1675969275000000 1739041275000000 1833649275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-35 \\x4c2c2afa406db883f6ddf306ff8e8f2c38dcb123b378d28d1ed213ac24704621632bdc31d32805162d2237730ec0007d58982532c28f5cace19b232dc9a617d5 1 0 \\x000000010000000000800003b003e7bb95da90e606f4ea5e9d28a107a5c0cbf80eb804936b6be40bfd3301f3a9eced165947aa1c30a663319a35c431a1636e4432d3f1caecd691957363ca6ae30783c88777159e5dfc9bd9a56a587245a2c0bc12301660d8865e67e2ce66bdb2baa939d9eecd69c0503145758b6c803c00c62c1e2d97ffc9794eccfad7ade1010001 \\x4857480cc2682c3633813337aea2ecf539f3eed1927423ea4d9612e2cb9f183cd830d950ca8f8277508c18bfd5a1ec98657d08ca9663087ab9435a74e6a06d02 1683222975000000 1683827775000000 1746899775000000 1841507775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-36 \\x4e4ca197a649003e09e1a792ec09cd6445c37186c7d0f48c59fd726a4e9d268616f3dc685b19d08bf4617c631e17f58ce935014eef34d11269c9e0d36ee6acea 1 0 \\x000000010000000000800003a315344dbbe30f2d451152e95128d509457420db43aae82f96bcb62b89e1a4a6cb4896107e8e13383a1af4654ae628e103c35056858bbd7b7c3a53e2cc627ed832e1f180e3b42026b8bad79790f10f65e977f4e3ddda1f5cd48589f547e42914740c002b5b20ef350c15f14775aebfe0eba6aa341473f7504f82d9617dca569b010001 \\xef7245cf2687db12ca9203f3946b6a09126516a6ddeadcd476046a2c7f6b2f0c35257459e9874b9af2e53e3be6c0b491fe3f5af7c74e42de4c1dd07cce6ff10c 1679595975000000 1680200775000000 1743272775000000 1837880775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-37 \\x513428345c8329302a45923a9f031a0f108223bbb6a5a14934ee2c4a1e4acab1286f3d02d4ae2830c654016007ab7dd91a1b1f30e220d321c9bd60be784afb81 1 0 \\x000000010000000000800003a97637e1cecee92437746cb0fa1286c900dae35cc013a7c223a040caeb5b94d1462cb5ef06daafcc51d56dabe4dd7819fb48d619b9b0d27d0a0b154a21c56a95c0777bb5a097ebe057701bec4e4c996e946d76c0864ab3b1f919dd46512453996ae85c190e9f79f4de853c86474ffab8a3908d35a7571f9f44a1398caee80cff010001 \\x7114d83070af023d8f3b9e5931bb541e7d3b9fb943e955c999aee21079fd4a823d544982650fe59902960d7cea2afb5e7efafbcd59f5aedac4765b373776a70d 1682013975000000 1682618775000000 1745690775000000 1840298775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-38 \\x57304f3578d4c550ee1623b4557f2fcb6419e41702e968f9d30d5bbf7e99b39a10d44067d54f15fe641ae0d7ed833941810c89f66f875f8f731ec4d1bc6014a1 1 0 \\x000000010000000000800003d54b1444b11e7252a4ccc369afdb3e604029670cb1e7f37bcdef235530ee8143d40cd9c0e17a1fc5873a9ea55377f258dc3ecf6a9e61e6e214f102eb2c25c1929ea5beed22dc3c53e2e80c31d5c99e555038d58653fef9ee74ccb8c58afd87ef19bb2278bc38f3fdab0e91ddc8a7ccf783a95190cef765885349f191aa85f3c1010001 \\x3eb538014d3d518e37313e3c8e26364b6f59071104ef82bf7d6857dd6da904ccf52fabe00f264556d714d9c87ea529f6cb5f325063fda423aceaff50178d0800 1689267975000000 1689872775000000 1752944775000000 1847552775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-39 \\x5ff4e6af3272a4cff7e34289f1a979de9d9392ca1f14662dc995030f839dec06a40ed9fdd97dad0bb08a63d1582fd1eb20c6a79d42d8cb15f71ca0e07e0bd7c8 1 0 \\x000000010000000000800003bc73dbf041e222b8c7bdf3fccd33119c52e19a548598c35e358c23dc292e48d7ac66f2932dd131b8a7133531b856eea4e04202b11cb21b9ac9cc0727f4634c454a9b4b79476da8bfb87097aba7bc27246f905003ec124692a9935736da0deb8d68ac4451641544e35293102c90aed69cb0fa7a88426c43046d16c0c41cf16305010001 \\xb5fbbcb2f2a859a4c33ca98f9f80aee4aefa2b87cd2d60f6b68fbd9623a082c149b14c330504c43f313af1e8a8521879336958c3ca8afa41a21971522df06d0d 1664483475000000 1665088275000000 1728160275000000 1822768275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-40 \\x6068fbc6777498e8d240003ee16098adb6bd66c045eafa37aeaeec312d44101208966b07ff2b917c1211792637a6c9f02369a1b944fb358a068c9c5b536778a0 1 0 \\x000000010000000000800003c49a3049b2247d14df0c304e1b87a21c0878fcc62de598dfcd2693f8d907a11fbc1b047c18487c653e87edbcdad9ad6f8cfdb21843f73301f0a994ab09a23def9fb5a2f1c6adbe9f9f67017d274bf3a1f7025baf53f0dad7dd33299d661d637d0df4a1d67ee81fb08dfde20922dfb9bb92ced3a6cc8364cd5a94b5ffb1b979bd010001 \\x544f48043525a72d4dfc982cfb27b001d25d99a7c73e33dc9df637129e7f3a24dba878c7d5defe87f037eee1d9ac0cf7882df81c0824f3d797648799b17ca308 1685640975000000 1686245775000000 1749317775000000 1843925775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-41 \\x62001460d6b62265b466bc3da8c12f6347c9702154e5f4fc88ddccfc54aedebea5b32d787e6908080b06023960eacd23db7ab8b5cbadd947b5d80e7a0e061e4d 1 0 \\x000000010000000000800003cf409be6dca8f7789557384eeea025e40b501779484488f6a00b9c1da10c0d4be1ed191a7132e32fb7aa578b6d2e2a9c4d25ef84405a51933b39cb1167f949107cbcc87766c4a8f67c18693a0813e75091e1105e201aaa12f9f64a1be8e12f6ed0132f024b3131f34190890a1a4cf2562c93cb9937dc80932d3a26d9903dfd7b010001 \\xe4079b28a1ff4afaaddce7e0c5abcacac3f4bc87bc9f85264fdf42d2da7e9d3b5c182429b35e6f75395dd62a4f0fa2b80db231432637c8edd930b1778c370a04 1671737475000000 1672342275000000 1735414275000000 1830022275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-42 \\x65ec59e1d91b66f76049b615a8efe10d53311b87b578e96742a1b29411b516e0c9b238c572e361a2d516b5b41d613600051c205694d263543ab6977a9d3c7ed4 1 0 \\x000000010000000000800003ddcdcab1ccb84f1524accd2f3e5ffcbf144ded67f815d0c2acef92c747d64b7460dd74d8250c8dae35c793034cae0fee1bca92d47f5e6fec2bf81c590b2d3af140e472f8024bcf0d5a9e1d9c35237c96bc7f740566b0c6f0bedeb16f9a655a165e9bcbb5da771c7ae01c25346fcf6d84bba38808049c464f36a482b16a002813010001 \\x577995f339d82301709ed47c3c0860ce6b18413d74cbad5ab823e9e616eef0d8f9dc00cad91a94be5d467571a2fd1ff60893de62bdbb88959b5694bcdbe83f0f 1661460975000000 1662065775000000 1725137775000000 1819745775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-43 \\x6bc41718d883ea630dc2a97f0313484210f91c21fd093d5866ba98ac0f631ffbe5cda81115dae25cf1fd552bc39361e5c719cb05fc39770d9a55eaa330415057 1 0 \\x000000010000000000800003cee8f481f33550e07409a8a472014bef059d1d80b8e88dfece2e4d7247fbd42a23b0fec92ba54f3701ae027508837813ec3ed1d3427ddd9e208c36bad539a590be76739352e52f07dc7e141ac782fe0fce7336cc4516838fe21d331b595a6e4a0698231d8f09f0a96ee39fb6b25dfdf49c0ee02123403058b7a7f15eee28905d010001 \\x5ec680cd2dca602ab846e2e25b7fddefdaa60307ee02399a2c6348de98687f24065f0c1e3b75b739c651202a361420647b5d413f0edd50b5d1015128da21510d 1691685975000000 1692290775000000 1755362775000000 1849970775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-44 \\x6dbc4c04acd4a3d2dda006e46bd8f3e51b01b1ba6b57468aadfeae97fec3a694aa50701d96dcda6dfe2087d0bb79f9f237d83a8562aa41167f0b00e5bfb7dc61 1 0 \\x000000010000000000800003cc851c101643f7910ff4cbb67928eddcb48d97b818a9899ea83e67543bb13bbd86a7e29e2778a43cee4eee17366bbf453e78b83aaa150835bb69505edc096a75546778afcd1d48b41def5e971478339f7d9053833d73ba4077e1d528d63fa1158762c48611976e87dc4e8391f13d8428c9530cf0728c876f09f5b3e26a15a15f010001 \\x9af0289c3f976790bc1f4cbae7f26d86038055d7c8d44557a40771dc82d6fa4473e2deda1e0d478447418a8f2cd02bfbb3b1dd0cec2e23057e90606c05cf0702 1675968975000000 1676573775000000 1739645775000000 1834253775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-45 \\x6eaccd07aa907f601eebd638a5fdf7b6136f8fbb6959ab111993e85a26e8f1e0245db33e3272920c2db36154a9aba0882fdabb5d69747e6e9590bef1a7a6cdd7 1 0 \\x000000010000000000800003baef8ef23ccd5ad96dfbaf3279845a8017a7b7b54dfd056b9e53e424ea3b86e2ffa07a6c65e75580c3de197083d9eb625d958f7b236f6488734892a58ccf30266fa0df0ea094422e365eff17c739290ef9c5017690bd439721fb00df5fa1114611f08e3d72aee987c27734dba61812de988ad900bdfb3f02a13f68d374e4c653010001 \\xf830d89b05b290fb18be7a6cdf71ac952423efcc17f83ee1b8615c6650ef4b49b28f4e1ecc4b4cc62624ead77f824212ac87a585a539273fe5f8adbc978c3e05 1682013975000000 1682618775000000 1745690775000000 1840298775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-46 \\x731c8c916876ca4789e8dd1e9286451108e5d27b97eebfc094869dbe6e3f476421a7e4ec70c55d70b60d4a6470f418e3f737a8c3f76b4d390e4ecda1682872ff 1 0 \\x000000010000000000800003bf48c4dcaa1756f4a1a8dc9c12cd4ca0d3351de8d7408b382c279403b2c4e2f065e5fc3cfe9ed8c3d98fcd43e383a5b36f7f0e6763bc14cd46518a9d6c9922193b472fa10644e9a8801d712f4a80000b9f224dfd062adefaa912d10f748c555ef65baae5b799a7366acd820c1cb65064c5a97cf68d9bc73131290533f9ba213b010001 \\x5a9fca7e3b51c7d39ad087251c6442d0c109856ca7a3812fae4d3db6fe41200eab883fdb3b7811fbffef80034398ae867a3c2c29d970dea6ebdb7d31dc776103 1686849975000000 1687454775000000 1750526775000000 1845134775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-47 \\x7524a31a34b7a4423d1df79b1dc984c9621db60c3c851764d536d500bdf562c50231f8e2c959e7d90ebb3f7d0830b47adeb77e26c4e8e46bbcea8388b63a7a4e 1 0 \\x000000010000000000800003b6321cd2d159f25141e1d5770a8aa7eca859c46ce3ac6fa3ea60b3cd54165ca08a47251052ea99625dcbfd6235bd39eb340e87dd06b3f4c715ff429fba7a1cc43b5663f8ba48b95da30965fe508caf717ad24ca2037fddb0393a005296e3c70d031c6bec3ebccac16925877bd51dd35b4075aa3289bdceefbc812dd959c6432f010001 \\xed8a771ea673b4bbefe4bbef6a7252336b7493be531aef6f7d1fef1ca9352bfad5403d333a92d8301853ff306118646b9269a3619bc1181c98c0eaef96a5890f 1668714975000000 1669319775000000 1732391775000000 1826999775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-48 \\x780037c3985523e08d722ff077e5bf107c9b0be7b95dc0a7865ba0129b786fad914be29834a520d71b19615ffb59a4941ee10472fefdc807a1fe924f441dd036 1 0 \\x000000010000000000800003dda5e251796824f410f20559d67f2498a5f812b29309f11ee89c310bc26a4680181c5e7aab7664152e12cabd14c7d9fde332281f0d5f114d65613c917832b98aa673e3d5b84bb5018936959bdce50d995c356466ae6dbf1c12c8b2fa9f9113cb23a144cdc6614786aa0bd703b8460d1a69e9d6c80456f1bdd49ae9e5de953433010001 \\x97b92410ec1f4c44497e066d495e37e10838560dff814ba16b5da96fe527e10d51cb6efeacedfc988a0145db48bfdce1e3ebdb8aa6451ed7895e93a56c7fc30c 1667505975000000 1668110775000000 1731182775000000 1825790775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-49 \\x81003cb767570c32a1618e7dc0952bfa1023bf7fe127c928eb4d50ce85a0762b04b93fa9ef43edc2a16c2be2e27b8180aa02a0e465f08e276324f5c86b536991 1 0 \\x000000010000000000800003b8740d89357e9e04aa5682d9775a260b26efc626b27ec05680f53da2f1d6934ab9fa5554eb62c1b6a1287991e1c263c3efc47a948e7337329316dd05f9a3418f46a6a88e7feb7414d94cc1f34667e61eeb28b9a23b468c4c4e1fb84bcc12e30a2aebc6b92439adab5b50fc7df20a55c2d15b759875f9878cfd1f7a406459ccef010001 \\x987aa42e8d2d2d3fbaab6aa9297528510f22021e55155cb5d41dd908822c0391302e9aa2715ae5f298356cf5cad5f357cbedc43aad75c5ee6727d277da473907 1685640975000000 1686245775000000 1749317775000000 1843925775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-50 \\x81e030543087de282877f3f35c4ba4fc33cdd8566966f7307898e0d3616c7b4bfc278f2ce4cdc97f9a4a7fb4474130ced3ff317cc6360cc5bbe30ac0845eba9d 1 0 \\x000000010000000000800003dc7affc3ca81ea7a719f7406a03e19142238b3320164629090a0ad53bf38a5a490793181154daa08440f3339d43936f413002e96f8f5335b513bb2be7ab74d873e0f7c207f4a192bcb15f90596d7e1afd3364ab338b4eb157f6d8d32a6ab25aee13d06780393fa2e0dc007e357c617a1c28adeee77a389a60c26e82c31314aa1010001 \\x32c96ac5d50f30a863b6eade9944607e6e6bfb94a5d21f5e13e981bd89effe1c02f490ab19b939eae66733662f8ee2aff7c0e8d38bb35e67fb8dc519027eab0a 1666901475000000 1667506275000000 1730578275000000 1825186275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-51 \\x8284adc7843e114313536a6d0f3c15556e7e2db6a5a3e111066a57175d0882ab3b7de7845545c2a6f6904c60c659b731137b5fe39d23040bebfa64618fbcff12 1 0 \\x000000010000000000800003d26317ae1ba4eb6a6896591dda066c7c9e8af843a4a5c95e9017952f10fc94b7fce6053b19ecd90829b12139dccd3cca3cbbb68650c156ba9f805d44ea152039af291295714cc879815c384de06f8d684d8cb058db1ee92f54cde22b8530e0253ad9ce3b3fc0779b0408c65d64f86e39eb02f3a3e83815daa279e417540b3f4d010001 \\xd232d268498c5fcb04a4284b5a4c5ab7ae477d6326aa46db5011b62ad77b6ca8cc588b94a07ddd499db567d4dc71ed3b39f29807c3bcc913ceee5fbd67e5df0d 1691685975000000 1692290775000000 1755362775000000 1849970775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-52 \\x82986a8f3713037e20d818d4127ef8b47725412f3a1063a0d219b9024d877a41a953a812841170aac4e9806e829618ce61dbd95d3ac1017f3a7b6d3439fe685d 1 0 \\x000000010000000000800003b87a0322d62d5e783ef9bc73f294440c9c0a453705d52b947c0db70361c3aa4684828b4139c8048faf7a72d2c28d6cdd9e73e2c7be73e9f0425ed2695f4acfc190b4bea4ac544744eddfffa20e0a38fdb8bd0f4d3cb89c1f355895eec62f55e56361745c80f5996fa54fecb9623bdfa01d7060a5c792ca2be28434c5496988eb010001 \\x9e7c1a6b1625a0fbd6f02651ca671cb69cc82eb643ee42fde507670f69b49fdae2727b155a8b70258e2532d229e8dacca91b266f640f2822e59af9a82cad3c0c 1677177975000000 1677782775000000 1740854775000000 1835462775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-53 \\x8208d57a28c789393c72effd06e3b8d1c51881a13bcac347ae7bab9a5beb515506db0b4a0c1608a308bf280a7c8340b25f1ff3393945142d4fbe392a02448938 1 0 \\x000000010000000000800003c2e4265078ad23ca293591caf957b38ef4e4a8f9a592735a803c9364c2595dfc1fd7059ea5bd353fe4b3b34ac09b3950d05dc693b318630bc876c9cba962eb9ea595f29c95332543a5a72b63d2d8a0d11ea6a39150010c3fe369e3f66a9c8229984d1476b7b8439ed39b257b2d6fce0aff59daee8a23208708aaef18f3bf9b3f010001 \\x57d9db202bcdef287f36eb9018eaaf38ad0144905fb129f03024fbf7b46e51d3a155bf62610f12fac21f62c8f710e516258420bf95bc8479b1804b43f0c8940b 1660251975000000 1660856775000000 1723928775000000 1818536775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-54 \\x84387225e471ce2538cd13a33f82ba53a5131130bcd57f90eb8195e2373ee70ed52ccda6d084f21fdd7a26dad4e15f6c857f39823aa4c1954de2acec922d2878 1 0 \\x000000010000000000800003b135b90ac2a9e9a31756293486ba9edf32b364da00f911878f8313aaa841b909ba71f31fbf5b5d1b4316619e4829f22dc0a14652eb6b63e3d2e9bd2741e24ef734a093c30564b47223ec6a02d77a8e96e0e1b2dd799c667a047b09493ed8c4a0cb33e4acb086a1686df700738858b48d260739dd1a81c615ed2d1f8382a14837010001 \\x902ab74e0ab9a075795a13c24e89931b8a2f8b72bf2985fbca5f3e49334af47dd822caf3df61f9835ce7a04182792b8e549f3e95f0d10a964a1723be052c7000 1665087975000000 1665692775000000 1728764775000000 1823372775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-55 \\x87406dbddc0cd833e4a3ab928bf7bd51ac22e57d64ba25b321bf75c369f49eaefa29a39021947fe9d7ebc0fad75cb1b452e50f1959f512b58b7a91d694dd4923 1 0 \\x000000010000000000800003c9592f68da215aeb9b64f041c21d26a3ab0cc8a1b34b00ae4a622656a090ba42f7bae0b82eba104bae607b847fcbc2db0e9fafd82ccc8d7fe125e455ae867983a8225c1735ce87c892fe4a3e9996a973a4dd33c92b3401fc96750787eb293e7995adfea16a66e062a6f64cec699f2719c2b10709e19dc175d57fec50992710cd010001 \\x0be94c1b9e5a8371a144568e8b431828ab0f3449ea2bf396f2ce075680655c2b9e00c591e6b88c569c7b51e669902cb8f3b0db41b7c6117fdec9a621820f6f0d 1669319475000000 1669924275000000 1732996275000000 1827604275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-56 \\x89d8d03fca3619697785c3ffbc04ecb8c8ecc5a08e57d33e09311cc20f5198129f583f4b3faec31d22516410c92dd74deeaab84cfd774473ff483151c16cb2c2 1 0 \\x000000010000000000800003e2b7c0806505b45b4a40c481971432d144f827a7e10a401fb5fb3f6a78c3e039086606ef34d73e256e8218114f2235cd12998ab37fd6a39343d5e17f5d70657f893961bb333bed50b0d077f6fb16f69d6cd49af79fa0d8286f62a7f093f8f65041dbb22d9df01b4abd839f41ce31326e6fe9740b244a40ad749079df447e51ed010001 \\x0b9d1cf54bf9a075c809660045f14420a5cea4f500c0f0d2c40457180082b6330877a8985fdbe441405900e00619ee4e4d67c070296898be3666a81d0e1c4101 1684431975000000 1685036775000000 1748108775000000 1842716775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-57 \\x8cc0703cf641b079bbf5e635bf02aedd2c9c70bbdec4b05bd0b56c527d9364ee2b5e6e2ec731aec2b5134b2551824dd6b845bf206745c80cb04af2cf6880336e 1 0 \\x000000010000000000800003b0c27826afae518d2492deeca180bd119c6ecb7a3b1a05a01aa381e834f6e30e3f0e47fa3956341b7e56881c2e9c865a581d8a466b2a575c882629327945f247a18634c76acdd6ac1c8f6c70885ae3da4854ec68d0d496f8551f28f87e952fdc63b570708c12d7e3e382ae6fedcf91f8079b3e5404b01024ba0a0900c5f15d6f010001 \\x44dce2bac8b9c831436082e13c4abc62d3b4d3eb2b735d71a5238730c8546173974712889daa3063397ef2f908f7db074b4e204bd0a67f665470f15527558c0d 1671132975000000 1671737775000000 1734809775000000 1829417775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-58 \\x91d0a323f7a4e8fe40e8a9c696b2a2e79a7eb949f4f060ef5ae6209227f46afe9d4e24c9bf6f36608832f3126299d69295bb80f9829c59016bcba6b0bf85aba0 1 0 \\x000000010000000000800003a1798b7143ea7b6a1343e9b833a170584cb7969b9dd15776603a6cffe69479b59feee1d8e9f6b48c3f9400b698a89fc31b368051c3c7a40a045f37666ac8f67a669ee68fc384991843d576d24f0076dfc2442853eef31954b7027387c6eb36f3a19905070f65332c243ce1044a26fd1735c7ffea9f0c7c473a8f24b1cbc92f15010001 \\x2bc51ecbaea9c610479aa1f73eeecfc1839263bf767f0bda15a1951b49c4b4c16d47a7af037f3de0d1676a993b862e501afb883324088e94cacc59affd0ba704 1673550975000000 1674155775000000 1737227775000000 1831835775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-59 \\x9238503ff5f72a870ab0c304b0a18aeb7b42a471ef73edd32df280b87212c40cf24b4cf120094fc4e1ba668cf8ed668a7dab1ff4ca738cf19a69cc54bc66d3e2 1 0 \\x000000010000000000800003d6887d93b9126310766d6e975fde568a657bc8a6fa76aa09faebb629e1f85fc640847a82129400090e0338484ca61a47382fc3f6532793daada319ff0f5f761833be882b7dd35b968eda62b2bcfa8cbfad73c4b81ddb93ca820ce7e3dd1550e7d8f5c3f7c1dda024278c47e1e0aafbf99902c1f336d0b6ba85dcdf907dcb4317010001 \\x5229b4f6f374919ca60a5fc9f70dfbe448f68bc0d01d37ff0e77821bd86ae031f3f962de47fce903e8de4245fe68d3af7ee1330a998a10f307983c68df25f000 1664483475000000 1665088275000000 1728160275000000 1822768275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-60 \\x9300669d4c25693c78bc83a07f37d905cb0b7831fa86620fa00cd91f4279463cf5fd4396b0d73a737b9d3c7513c4a7031b59d4b8739cd5e9b817a92325a023eb 1 0 \\x000000010000000000800003b0853548178aa9fad297ecca46318e1dcfbfb30cc3932343a5d53c04b9daf672b578a088cc43841b1d49324756c1f2dc643bd90d48b4d425a39e62bfaf7726530d513890a0009573914d7f696bd49af8ef23b1e84aa5440ce2b073c7e1c2808f6620975f228af36dc0efdee196ccd604603fd6749a4cf2f1c786be885c0be887010001 \\xc436e40c7fcc1833f4f3172414eb8a193c18ae6f1aa9c1bbde5b67bf95f209e09d1fc91941d195ab38220e896a06563de0d6153410d54526c57d4f011525ec09 1680804975000000 1681409775000000 1744481775000000 1839089775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-61 \\x9478b209f5b39c993dfa2cdc7a4a027ddc1e21a01dc3e7192c82785ac59477879fac9fc16b52d3cea5ce6b2d08ecf46de35704daf572be8ce9512ba9d88c2b2c 1 0 \\x000000010000000000800003b78f414858f368f2094c82251b14b2dc76350b78c3bba13de639aaab75c57608dfa2b94d779ad89db3c9c3dab14d8b0e41a3eb49e74124df7a60782158dd332c902671d1abb416a38752b729fc43b3cf744ed3c42b62ca9bfe070fe34340136fc0f24c7d630578bb48a59f91353e05f635d25c174e2fedb7c946544b0c2781c7010001 \\xd400fafe7c94ad7b7dd205136b5ea724ffb3fb4637d8f062772e9a03d5c475159030ff8ab6810c031e9b6a6270d5e80f26b76bf0c2faa384c15ebfa376ab8005 1677177975000000 1677782775000000 1740854775000000 1835462775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-62 \\x974c753b8b30c854d838dbf27ae226a214bb3672c22c2b1efcb09e887ffd25682a3ddff727935e78e0f001e7c06dbd50ff0357ae0da0f583459c61b3e4dfe44e 1 0 \\x000000010000000000800003ebcc122cc9580e12e579f5ebd835238c8466ac2f48909c5b5e2d1908cb0335b7f25ec8758b948d5a4c564396e384b5521abebecbeae002b81957850ba4d246bba8c4905a715c03f730a76ed91322efe77360eb0925df41c37f18429452a9e03e4fff80e68e530e2e3e04bd467db7c981b67bd1cb15ddde72b058a4a0bd90629f010001 \\xa202aa2b5dffd9b3f885d75c989665d9a0c9d824fcd3f8e0ba71bd65eb1fab4be5d78f09506b69aa2d4b822751c932038549194ff1494d9a873532d9c78ade03 1679595975000000 1680200775000000 1743272775000000 1837880775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-63 \\x97fc6631d68b07c46b4500b603821ebc855455c74ab2ed99960e9abccfe29137901f4f7198e5838e2c27e9ecca7d90c9b285538a7a13a94cace64668f9ab0abf 1 0 \\x000000010000000000800003de431f90bed2ae40aaff930c8d839981d64dac64ee9e1a10fa570779db592fe4268f0767584236af8d5c034bfce400bfffecfb1000f1dee8b2db54de5a942b73e643f4507fef50487e347a5ff98b2224e5c35763c2d5f6f643340c10586e082d05ac3d645a1acdfe0e51d87b761e3f3efc09ce5c74f90ddc85e20d7f920e2a31010001 \\x3329566fc84a572180532efe1860e4fb2736bef55a3620b20ce621d914496f49da2ea17be249c01bd48bd481413928374d7082c9dfa0c1ed0359c69091dd340f 1682618475000000 1683223275000000 1746295275000000 1840903275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-64 \\x9ae0ae32420dc1d80dcfc8b6aea8aee846965343d57f10a024ceee441f576b6be02fba4562753d0f6c395bd1cf555b1057df8651ede897fac1335e16557240f1 1 0 \\x000000010000000000800003b6ad314ce49785d788ae5ff02b4eb0cf2731ab29ed4c2bfd25fe39b4ab5c462999a8bc71db4fb7bfe15787677d5cc291c37818c9077be22c5bb07e555f277bdbbe60c9633f4a7b943b9a7b2271474a527c711175025ba14ba23eeb8061edb93e6def6ec0a49c20f4d73b5373f3e84ec2ebd6554da57befde1b4db9770e47f195010001 \\x3c1cb6c541abee4992a423da141b58831548e48bc12aa310434f67834280dfded5f9f93197dd581900c1eae492ce9190dcd848a11808b342054eca98edffae04 1666296975000000 1666901775000000 1729973775000000 1824581775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-65 \\x9c584eabee521f571951602918e70e4fd5a777e25b7b5da8a43e7dd273a73c3b774650cf98510d4120d31d10b7f686eb3d711db919c8a362318239b82c7bf6ff 1 0 \\x000000010000000000800003ebd5d0280f9715cf4c03337e9e97279c475035a1056fa740b4e7dec298950eb2214aae47c5176cfc1de779a7e15d903360ab39348f5f21bc60317b6dd046e4ed7696306cdd9a80b328f67062bd9b8318063ce5ac7c8c4bd62e271c11f9d0423eaa00e6eb8c65803dfa38dd38822a18e406210566eb941c678d43c7041d5267a1010001 \\xd6c9031134842b5189c84514a4b87bdda8a6482f71d62a13137f09903465af3e796a721ed7de9ae7175f275c78ffcf4013b4e72a98f3131e84f4a6a4a177bd02 1674155475000000 1674760275000000 1737832275000000 1832440275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-66 \\x9f28e975d560b24099094cf43a7f13e294f4ba0c4b4527150f80631db98182635883d873264eefb658b7d93cea77e2c49a4c2388d46c5f2a03e561c22cf8c0c2 1 0 \\x000000010000000000800003beea57b56b22c0509351c9db5ce0d2833e3e18d67e11ae606c01de954479bbda974b76c777632f5cb05785cb910fc01ef9ec21904e2ee573c76e60109ad708f06f487d10e11b1087a610e6ca5f42ca366ed7e30743750f7f747724c6acf2c390f18f8597864405b83f9f81a49e8dc485503867b190c06469a9750a279aed80c9010001 \\x0d736118870ea2ef6cd0db4e3031023c68157b31563ca0ee0bf570c80ab7c62ebe157b6dd8e13f4ccd3aa29c8027f3a09142e909178db80ef996f1e7e58cc601 1688058975000000 1688663775000000 1751735775000000 1846343775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-67 \\xa268aa5644b341ebea4f5491b091f49f266046bb2e9a601943c249932c8f6997e85976985e30694148152ee2ddcf4e0bffd2a7ab991b4f5803be97e22ba36d25 1 0 \\x000000010000000000800003c7f6f064f8e8a308e848e043065582afff63edcbaf8339f3693394dc919f70e1b2171fe3aedbc9d9a03d9a46d834ade99a3a71bc65b97178835b4e0ce31f333567157a14633a13f22617797283decd76c3d60488f9dcdefd29cf30f5ac1f016bbb8808db282228b743d681b721196d20cee8339049b9fb8c14dd7e333fb421d1010001 \\xdc86f63d27ecc299cedabd34cfdbdb3e65ca23d5cf6419d4cb4ed3fd6de0f41e6be3c332572ca6e9a6989ee49d5df1ba49f6caaa55aaa4e50d8d7243c9aa4705 1676573475000000 1677178275000000 1740250275000000 1834858275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-68 \\xa2f8445eeab9a8d13b179e6ee73ad4d5109372b6ab5e3bda1a839e82c9e5fba5a464800c069b507682fbbb669abe903ac1878ad6fe6f6a7fd7fa58f83347226c 1 0 \\x000000010000000000800003c0f18216e902ea31c09f579f36b5d4ee36ca579b9c3a789cfd2d88bac41c0c0ac967c359863e8c2c0103af701e599b5bf7c1d3e88a40fe6137993ee13751debae555570d38551f8b46d06a079514bb47444dd7be67ca1e3e70537ab5fa5a93cfe0c794043a3306ffd55b664050016f94ed3efbf0d51696626d2fb0a3d5fd3bb5010001 \\x81a648512a58ed0c9971611947f9952af251e31a7cd337eea1b69f2d622717c6f78e097be6de94f62b931fa72e1838278a691968eea6c256876c985bdddf470a 1666901475000000 1667506275000000 1730578275000000 1825186275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-69 \\xa5944a8c5821a7a4a6b969fa21b9319b43c3bedea4abd4fe7560e7020eea7c55880a7c1a6c20c4deceef6ef40721027daf598ca595aa7cf58ccf6ca93e4becc0 1 0 \\x000000010000000000800003d76cbeb027debbbb35732a17dcfa3bd55f5dfb9a3a5f9f90e34c68960268200d47f0f30a64ecf893a66402fb9136d7b6cdd2ced6ce456d2168236773b8297e850109c84c9cb215f1a1ec0b235683769091a4be70f681dea3974d626065b406ab48c0ca6925f30c780b818e471d7f9520e3b37454f9d209693c562164383b0a79010001 \\xb39191e907b65ff00eabc15bcef3857b50ffe00eddfcf6ad7324ec421840fb8dc8b94737a67b0e6b727e14d5e7dc6b2aa3807fa5b2c8330a4c137ca078867a04 1664483475000000 1665088275000000 1728160275000000 1822768275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-70 \\xa8904ddcd6dfa34384b5b5e1f990a1e8f8677e79522f6efa1075c04ee55f59bc0857733fb3f56a5dd89175b94e442b7527432e05c2dad09fc31f7fdd5cf08828 1 0 \\x000000010000000000800003924cba96198590befb1ec386986d18d4922acc8d22493da08ce5b430490737b56589d4548eb83c80919b0a77fb85dcfc96e42ca0981a755858d2ea6a921666587424b0a85be2759d7661cd69cb1469c7fc85d8a34264f670f301d82bc09bab0fcce61bfc81d2e0b2ffce5f7aef7e9460ef44611fbd3b9a496877aa4bb1430303010001 \\xc44e0842556b0e509afce0da136c2945590ff1730adb597a1e12f2ac4284cbbf7ef320363ed6569216764c552f3b6e16f83595c87586857a3f3c4d31ce069002 1660856475000000 1661461275000000 1724533275000000 1819141275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-71 \\xaa7c53a8f57fbcda6ce27a52a030b3e82960bfede632bbdb41889ecb823d0b2d1e47b56f6ac5cecd78c427d138cd1f86a56d3c7ca4b46379df2fe190c95dea7e 1 0 \\x000000010000000000800003c76d393d431f5d53b100d14933100a1f2073581077095d6cfe7a669a9c58e8bcbbf9724c776ea34f9f9bdaa07c73716a0d825b8430cca8cc149f55669fd4a97f3547fb68e12056c2a2fda4440b7f31f0c7f3a0633ae8321270ad83bfab471c0c7945eaffa5ba519791bc4c7db9b7acc0eaf64a809d67e9b6e209073786299f79010001 \\x29ec1c78015c905d760c8a761b5115d1cbb3b9e3c5c0af6e18c9eca9df77bbf1da3a379510eee0e9c819314e4c5a7c3bd3b03d56a350d454d324b018c0002b0d 1686849975000000 1687454775000000 1750526775000000 1845134775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-72 \\xb4002da99f411e4512007caf9ded359843e16c9d525bb3dd97ac215378191cb86ee2bb66c1afe1249777f37b938ff03fd9680031e5cdb308c1cb6627e6ce7173 1 0 \\x000000010000000000800003a1656fd6b846664f26654d4e0e99c7cf4c0f0f282415fb617bd818507909a558f42ac068604478ec540f6dfe9f4d85e800f7f537442cebeb28ff22b0716e068e36638070a1591ed77100a81172ae73dd96a2e632149ca612d15f91c51a15fdbdb9bae6154d53e1fc77345e1328b246102cc24048c63bde7247977d41a75af92f010001 \\xdf8f9c937468e6abffb04d92479e9b1cd34c24c7c47dad3c14210a6cc0b43493cf341b499ac34ebed96b461d81e123aa311a2eac769545a0140a97ad73ba6904 1689267975000000 1689872775000000 1752944775000000 1847552775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-73 \\xb6f090812745ae4641529dfc2bc7dfcbe451fb1886f35f49f521043d844ae8af62f0ca3af8bfaa358fc864f1869b4a45334d2c14abf577681ab2fe6bad9624a6 1 0 \\x00000001000000000080000398311a468d45c01e07a8017f806c1261a29b7f2352ab2e520e42e2355ebd23aee48fadc189a3728ee418f3f1f3a91e87c60fda1f36e16545342a88e098bc09512aa8b88f23b7dbe5c05d52093cc1c315ae19733e3189842121650b7b82560fb6e9781c5931dd38edfef2845b770de8a6ac2f4a2cc080b5025b70072b5877640b010001 \\x160f42bc87684bbdf95b7f9ac61be08ffbf5624244c0cf1314ed694e528002d5ecb3782b5fa65faf2e538b5bb9c5df9aa5ac79e211f0fcdf15ee97cd9197930d 1669319475000000 1669924275000000 1732996275000000 1827604275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-74 \\xb8cc1ab48750a9d991acc6cb0ebe2b7a216d01acaf29d74e7aee4a2a2f89524e38027c17a556ff041585b690583da0020b0193980bbcb623ad0ba385a4e4755e 1 0 \\x000000010000000000800003fe92e85864494ab045ea64cc4b6b33705e7e4c122b18c92cf0ed1845624b96981769b178c4f31182abc28f668ac8d8a3f1658f03928aabf85449209ec11d49909246f190e296b5a5be6dbb183905470707524af1c4bc62df25893cf187eadc3ff0798eee4b8899a066268fbb5cd2c16470dab9445a6dbcb38ff02128feb31f5f010001 \\x22ac68af317093073f7b01a056bc2785564aab7cba04dcaf7aeb13b2cb58b484316a5e0b863a327c667aff2733476af65509fdade54c61cab3ec51fc7db9dc06 1660856475000000 1661461275000000 1724533275000000 1819141275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-75 \\xbe0054a5992d161bf29047882486af0be3b0529c66343dffc6c285937afdfd51d85b234d1548e43e1155ed0f492cd0ea7394a8337ffb3d18b47648e49b7cf76a 1 0 \\x000000010000000000800003e558e96fdc52ac56023e9dc3a7e0cf6cb2f864461142aee6415086f9a5c3902b660dacbfa8edfa7bbd850d07954f1e1a31ff8bf12506ad79552e58df694913fbddd17ed6cff62c795d2e785104fac6905e1583c390fe819ad36ec1e130d87139ff4fd2bd2c4c0a98c0e20279e20bb563f98376a15781c712c8c0dd9dfe7a077d010001 \\xb54957619583b30b6e3cc37c846c572709693c7a289da22788c70d504be1d51fe8b7f678f90cfc4dede649778789cf78af602366752bcaba52387c594ab94c05 1683222975000000 1683827775000000 1746899775000000 1841507775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-76 \\xbf70f55fb6cc40ebae142a001277930fab9f570daa913227cb02eae783470f1339579c479a1e1dc22596b077018dc72dd5f9dd7265f2e371e419d02913ab00e6 1 0 \\x000000010000000000800003a9795b09a19140a01fc043c89be7821ffeb2c132728b1ad5652a028eba5bba028c95fe3c85bcc76c62cea7f11e7e0342d4f1063425188d1bb1e530413a24c59e64cfa14828ada0facf7d59210b28c674842228afe144ff146b7e8a0f0c2e6a9238fb71a5de312dd26b5d7b904ef22ffc987d833152980b5e5d8b16e32573d5f3010001 \\x38d92cc52b718a1338b03023d8360e0355e76000c3560ccc22d82646f20640fb5f90b13027a85e66fb08b6a051b99bcc6821f47eef5c98de181333f89c12c00e 1667505975000000 1668110775000000 1731182775000000 1825790775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-77 \\xc428251bd8be134f714087a93406ab3372c9b21b8c7940f14244e32a515941052175273643ad8b0d30b7cf649d0c8396cc3f767782cff16d4d7a8033681593a6 1 0 \\x000000010000000000800003dd649ca8e4a4c16fd1a6edb3e3bb0b313938b2ffbf6607d285ef2492346c6a5f846b850c698505a49fb062625cc52390b0072c77f143354a3d7a4dfd8ad3c8d400b8c025e144cb1692826bc3f7922add2daf08516977bb7741d72663b1890eda26b2ae1b945f6e6c5e77d82f9c2afab133abf935f148044fda976378fe9d0a55010001 \\xfd2cd5ebc03c48f0eb740a7117016484c073bfb5e4305a7aafaac552bbba5bf1feaaac63f85377a19ba1798f648ade68e18d89efc73644e35df5b548e323230f 1669319475000000 1669924275000000 1732996275000000 1827604275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-78 \\xd104c19beeca0a777d5815d0272ccb7a640d1aefff782de75fbb0153e37a42af089fc4304f504e92bbc47df2e2f08ffa4eade7d9edc19a999fd8dc6b576ca52e 1 0 \\x000000010000000000800003ca1e3b2749b1d8cebf0a03e3a01400e012d78a5b9f38acbcbe451976391526effe4ed1071aaf50dfbcf52d1a40ba66c0c83193156fe0da39e074e9852f6abab8722adbdbabd8052a27d703c9e6398b7f5617dbf698d8d266b808c5a76850cada1a65999ea7013aac0b728c799f9db9cbf7358fc3dc5a5e8b0fbffe9b59c99817010001 \\xbadc93c9afc5af6095a0858ac7449f3b5b76fe205eae99ec6fd431ae800e2d19960af5f4fe7af34743fb2db89aeb03dfc78b70795ab826282d5aea8242d2530b 1682618475000000 1683223275000000 1746295275000000 1840903275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-79 \\xd1dc3814bc9281f93a361ed49c5a15779d3d62a4a60de7e13d733d9ca7725fb3f73286202799c780fb43d0ebda785eab299b98a116dc19b2aa4e1f4f4ada8acb 1 0 \\x000000010000000000800003b595f22b9b71d0bf0a9b1296bcada81ac2bdc77e99c8bb9fbe211aa5946dc68f57e03a404b6d914f702dbdf7bb5177e62f0b82cce84c508622c60b64f1e4f7068185135eada8f51a4fba142acfe162d01881154e43af5560746e85ae84419228f4c4ae739bbf6c2e2bfdbbc6acf69a3b1202a717f75853dc62fa3b0f20043e43010001 \\xdc4bbfa8cc73665f7333bf47a99e51cb1f8af3661b99f3687f49afde4bb2659d70b66f16e2403c49384363cfb24adec5f9ed9ceca1957997a34649ca9eadcb0a 1671737475000000 1672342275000000 1735414275000000 1830022275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-80 \\xd258272bb2134798f62f54c67a91d03e7a603a2345ae1431f0e2bdccef72d366bf5c7a266c70094d36c8c6206e3992008ec2c07fb4542a5fb90524fa7675ea7f 1 0 \\x00000001000000000080000395dc8f8c2716f84437e758112c489d6ad68004847697a70a9e5c6fc12921b202833f634bc7b25180ac79fd28448f319629d501384df4de172ee382cdb410a8d1dfecba0c5e81440f957d181430cfb294ab9d320b8a352080c456abf872a29bbaa2a2c4d4b1c03e6816ae1c58b8c34b70d79a2d0f233cd7881d3bafe36b6678e1010001 \\xc364b07d895228cab65a586ff27a797df9c7edafe4b0cc42f41c7c378ee006a5ae3b3a2a575d9575d66ffdb3e992ed43b45964ea2f27feb3380b38615a9f1a0f 1677782475000000 1678387275000000 1741459275000000 1836067275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-81 \\xd27816acb0a161b913996172d0a47603356a9fba40f9f0f2640fd4e44ddb309c90e23968d2bd4b500d65a2900c3b55388b91964e2da4d012c7dec4925da4761e 1 0 \\x000000010000000000800003d14f572345494fa7ec69933de63f0791c646f649cf1dd5e48642f69c4b492feed350ea7c603b10bc26a4685dca0212000bc7281c30cedf69364a296f278e701074ff0ae3c57e64472196e2f797475973a8d87f179646117c78cb51a48e5349d0a01a45910d759e7c3bd316f6f9cf8de0a2014eab770a8282e37d39acbdeb43c1010001 \\xd031389c037b2eb936a8ca2a1321dcf36d901dd75457bdd2df5684ee217b897f3525352286db15f52fd79224e7a01e8aceaa5910e5ed57ff89d3c894f617b101 1662669975000000 1663274775000000 1726346775000000 1820954775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-82 \\xd370d35b3bcec83607bd4f310eabd34f576bb596d564961bd7407228b205940429fd85235187801a5b64bcea447f2770904bdd1ccd09c518580501a47db3db56 1 0 \\x000000010000000000800003ea73e5937b7459e14d8422462695c8cb8f9c71e4282b77319756b562e647d20fb23bde9bdc15b58e5bb38e3266e16de8bbd879bac48b2ee794b0d86f30744cacc1f5a3b2ce25ba97169d7b6b0c7b2bc4ee293bccee8c24c58a44c3bfec233095d13ba1b8f43da6c326ec4ad1a90243321c875a8f0367efad9bed670830e32d2b010001 \\xb88610529fd30a4c60c6f4590258d68c865fb5402ae6f494a32b972d3fdb907f0aeea96b42ea2a10e7a17c0ca87e0ac2fe8e82d6e9a2ef694e9c81090ef5f40f 1669923975000000 1670528775000000 1733600775000000 1828208775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-83 \\xd4902b02450d6eccfac452ed0078fb346f7de40a46bf3b09fdf171227e43409a0891a5c866379a56b0dd37fca65cb5def4de849a5819359187095b62623ce62a 1 0 \\x000000010000000000800003db723f237e7de983b888df66c5dec29dde3c63917e8cb4a174780cbf26f5de2f69efe55662c63e18551e68995bc6b23ed08e3c3f1b65b26a49dfea68ef3eded9864261c6a09a2eea12fd6ac0c3ba51529208a1212de4b6576abef93d6009c6ba42a6697e92ea609b7b71c9beb5afc664042258bde1902c60408e888f71e8afe3010001 \\xc6d2784fdd0d71c52721ebe09a7af487febd16b549a8edd5ec750ffaf8fa7a5ef5c05bae22a58718765237f51c4189d45ff33f3c1e62f08c8214d606ebc77c0b 1671737475000000 1672342275000000 1735414275000000 1830022275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-84 \\xd8fc325310e82d52e170c063f25311679e64ee685037b94a1ffac275de97baab152a017f516be01426cca242b11080394c0bfa735de0960e9ddf99c05e1df01f 1 0 \\x000000010000000000800003c475c35467df55eae3fdc0411175fa7c8698c232081edc4579eac94caedd943ad78ad8cb256f977d49f36b5ed924d9713f92ed4ec2ebef86a64f5cde45b7fcb7191662c2c1cbc020459e8074b5874ed5e63cdb022ed95f9027a6fcb5369159ffcac85e57e6da994f7f94e9d1e8394116542e79f12c1e02bec77e3bb0287c4983010001 \\x7ade8d1fcb1bac0be0a5951a93dccbf4f867bd8dfd08665a125a535b7e3f5c3e063bed1bc099197ea9d4fb384ba55f9c5c00be57aba5b22bfd58356a0919b20a 1679595975000000 1680200775000000 1743272775000000 1837880775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-85 \\xd818fcd7aa92a639295b1278249ac4748e51fcb0f6989bbf08f67ae5dde8d6d789b17fd8775672d356fb804513adfc8a41432fa011e2525718b4642e82b515fa 1 0 \\x000000010000000000800003e1b22605b65adb73b3ed06719caedea682f4a7060b270752d889e5bef49a81d165d8c594fd8d40db62082dcf38bb329693a2e92a60a3b2cef23218927d77435d745ec0159a92fbdfcfbc747f43f97ab8cdea94f1f9d6a4cf7e4b3774d43fd182ac99fdd0f478d357950994bdbdeff86c0169079644364445c46b3416dcf99ed9010001 \\x34c82333438021be7a3479acced43fa6aff5f85192b0281ae746c422ea194bac40a225ba2e0562095324ed7f12515e5594bce169200c6f2c3e4297bbedccb000 1662669975000000 1663274775000000 1726346775000000 1820954775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-86 \\xd9844aa089968c4ce4238377df4453a2f69e54ac82d23abbc30d7ffdcfb691ceb47c9d380ff6de69ca623cd52263e100fc3d22b446f6ec9bc95959b5f42f4772 1 0 \\x000000010000000000800003adc5f48e95cccb4303f3a10605b27bec1d092a8ef60ed3cd70514640b505fac553326bd4036c4c1b357a985e78957bcf8d370b030ea6d1dc807fe6025ad3b47320312ffc912b22bad9458096c571dfd1814e22076b87266b89931e17494caa9b48cafc784c1c6b113b1b15784f236bad43f6c84fa48fdc94558c23ceb1f11b83010001 \\xb4fbcd10fdc64e6802463284aaf732e0f4fddb46316677c03af5603030b9f9510f5ad67d2930245a7ea116caac97a2bfd58906c5f6fe7d799e172e9516f24506 1671737475000000 1672342275000000 1735414275000000 1830022275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-87 \\xd9f86b7c30582e1090fe083a0805331540c0173bf99fa57128139373fdd0e9f137689b2b598a2270820cd6606d72e6b2db14292ca26956100843b7fd0bfa3837 1 0 \\x000000010000000000800003d51c72250c78c462cacee714b7f7c7df8e235cf2682e48bf68bbc2807905664d4a82c08796a6be749d70e3211977a80ee7145fb66fe25c6f1913f0530a1c0bec0fe43814b7dc90cd7236209b102c86feab17519336182aa4921d84cb7b76ad9a6e11033424440142c4083f0380487ec93bcb19b508b250845f955c6600d4186d010001 \\x1af37b21a7cb1f98972d74209aad9d70f1146bb259b55272050f2d4804eabcbb359b13db573b195b206735533ad3c30451545e6fb1acfab43118a6e88691c101 1664483475000000 1665088275000000 1728160275000000 1822768275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-88 \\xdb74fb91e62bdf1ff67802d439198bb036ebbea88f33f3a794307ee57026262420d204a7c27bc6e8d92461093c7b7485e071213946594da67a3732b59c13b985 1 0 \\x000000010000000000800003d64384604da69a450079ca168508f3421dd298722f68d2843a7d4dfb5758728e2438a31bc4ebb75ac6cce5e09d2abc8639c9f8921ff8efbc7f445643790fbd4351799d685301da7ad15ae42eb63180afcbbead21daf57c0a0892bae08cdb2dd970239a8525bedc88586b467c88b3df358d9ed453d98bcfe29d57e1bdcc8e1991010001 \\x18e371a3b31e1526ba3a3ddb507a77fdcd3107d1a8d66f1e8191c5eef049497e4e2cf3bf9efd0c604116e57db89ce65434393c9367df06d14ea3cea214d89704 1686245475000000 1686850275000000 1749922275000000 1844530275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-89 \\xdb2ccb1b56911f621d27f0a01a1c8af65297bf42dcab2b22279aa90609a5db6ca969b378032456909231863cce17255a9ab1beb9a6f1791388ba4ca146570045 1 0 \\x000000010000000000800003c5bac520467739ea86d7298cd130be2a7edf41b878bd36c3ecd36b63def64d921047556947fa61eab19b5ae8372b869d899de8a1a0367c297deca6d2a486494875bf2967800611e29512480b8aa7fead2d810db7d0e894ef71a511e9a79fd9e20734c29d2a9101cca6c1c0948f01b6a2380bb7d8641d6a09c3b9380ca5508aef010001 \\xf8044e33385ea2ca6b327565c0f07a03e074e07a393e38276e1baff4a02e2e97bee59b0c742a102b0dadf2b84bb6cc2357c611ca31bd15bbaf53453a4b5ed70c 1668110475000000 1668715275000000 1731787275000000 1826395275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-90 \\xdcc0ee44b05f56a819ff2647c6e5cffa45eb83139c14c4d5acb3433ea8790141303eee4a5f2ea3b8c3c1f88115fd2d8f9d89e4bfb79e8a697044d3a1281523ad 1 0 \\x000000010000000000800003ac4e4104084e6eb0dd4468255e7cd31cf394bfcd226f8e760baaea40417ea2d1d523ae1137751d83d0638645438ce151fbf9264385996cc7a45866437e4ef67b0727faf7bcfbada51a682e99ff22dcaf62067ace46d02be54d5c0d24eb7bfeaa8352cc32a759d53fdca185beea30c3ce5b179b73d2150acc65de1d181e09bdb7010001 \\xe726e0f3af9a31b5d0664c24ba41191b4c56c72b57899526e667caa18f49e4ff59fd81dad66cd2dcd9da4eaa2254c43f0ed8a2c02786c17abb9ab9c0cb7b6400 1682013975000000 1682618775000000 1745690775000000 1840298775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-91 \\xde58dd19e0470b60345c71619e92ced3b4decb091052843dbfc223a418ed1c406afdec0284f0436e5650d9fefe185943e83f6287da7274f182c28d27558bb75f 1 0 \\x000000010000000000800003db05c1e8f4c85da3f417e020c2e46d5528875020f270ad21d448c076e15ceb6d4f80d749e97353b4c6123296c5b440e1a0e016ff7072a2fca3c6da40f41ae49199e6e0c95920c97ad43e4bd0cec6ecdf20d142e8df622bbb13f7b193a99aaa45e922f729e19ddad2ace305fba6ed9ce200aa055965885318c300599c1be14681010001 \\xd98cd7b95704fd84d38f554a0c2ac7fe28512a44c2067663bc113e9674351ea99f2206f90d69961b882358db516435378896ad997c8e327d8d5dc08b2c66fc0d 1675968975000000 1676573775000000 1739645775000000 1834253775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-92 \\xe3d8a0f90f350f58223542a49234fbbc54f6158a8d90723c30ac9b095ea242061230f58c571eb3cb419eb7b6fb34973223697946492fb2acf27d7307200a2300 1 0 \\x000000010000000000800003bc609eabe41125d201ce69c111ef38d617c9b086e3bd8ef3ad177d5c03246e25c05db0635e99b4fd28bec7ee7fae018838079c92244d29f61f9f783a540fc58dfe3f574ddd294963a818cea0314888017e430e84d46d7eb89bd5da11a102e7859e63bdeb81bf25183082af9cb10bf1c491a56184698f2e38e5eb2797e99fa2db010001 \\x5ee16a2710cd6583b3cf8508e8b236f9ac203190f6119e80c3041948440cd6cf5be348dc0d8108f317fb7d9bafc68e96646038a74510cd2cc7d9a5832d31550f 1689872475000000 1690477275000000 1753549275000000 1848157275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-93 \\xe74cc997b950783814c0b8725d80971962bf48eeb5e692c86f84b595a9f86942dcea5e31aa422ac17ab56592e14e41f0410bad86b717f2eb3e778f4ea39d37c0 1 0 \\x000000010000000000800003a53ed377b11e86a4f71f5d67e16456cebe8e856d510c1739f0e4e347872a0d191ea4d013f4818d7ef0354461b2019d21cfa9d195adce6bbe79c03a988b3075133f137568ce730377b212cb5b42444ed15288b514266f952a83f82f9b5762e6c53dd3d9c71c12ffab8f3903427199105d890092a25bb8ed97a569c69d813fb291010001 \\x3af3c6e53ca575761afea5b2ef6630bcc08c61707fe8ac038231f6aa4bf1e10be8b2b9a79b1417212d65f5e24a16a27586f4ba5de7cbdb19ed2e20e13e4cac0f 1663274475000000 1663879275000000 1726951275000000 1821559275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-94 \\xe8346d913ad0745ea91b858226adbac121624b16941f60f3e8a8a30c802f4b6e49712dc79a5467a1a21ac2ad904f5a2daaa7c6ead48407b46432aa04787e225c 1 0 \\x000000010000000000800003cb5b6f0eebdb74ceed4cda070b3ffe7b2f455691399ed82b0b385ad80279c8541b223bddd552ebc51e5952085e0c59a0d64663638e47237b9861c6bff13ed38efe370514676f77bf298bb35875607a3f6b6a37ef2c0d1f6c717681932f0915e00350508ccfb040e2e518349e726714cc952c3d68d6bcbf321925a394829130a1010001 \\xecf31982c0537e966d4999846e28fbd10f79575fc67ff9d5dc5118cc45f51b8e1614e533a8d9e714d81c3377715d8b0d61a517c7693dba8b901c61fe04da280e 1668714975000000 1669319775000000 1732391775000000 1826999775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-95 \\xeb20ce9d975b6d369f3a87c89e42950baf1ec2fdc825e1a0f2b851067c3b8102c3267e67d0ae776fb4b20602c0852dfdf7e418b962ffb48641459c9c18eea5d1 1 0 \\x000000010000000000800003b86a842831857f564de815c4299835a4d3310cfa75d5491d7d27e1e04c10f49cf050251f7325ffe19f9abe539a37a02de1da7f0b2d2f80fe8e5ec65c7485ae1f24f80ae626c9e2ff2fb9c0f7ba37d5e6c390be0eeba1f3b020317aa209f51fa181ee3319905fb5e5c2e1696c22ff531e89770d457f4211dd8e289e8107b6a7d9010001 \\xcdf6ce50d3062a402ee70c60529d9660e201e91cfa3c187d0c1822ed7f01d8be5aea3ee6e9b56a6fbe98ad9d05142cef24713a434bef98bf3aeabf82dd21e70e 1678386975000000 1678991775000000 1742063775000000 1836671775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-96 \\xecb4c3626dd0da07b9061c03f3111d83858e01d5ce3c0d2b3f138cfad31292d024c10605a4124e91826c676312fb6fbc87416bee7b42aa2d423a5493c151da6a 1 0 \\x000000010000000000800003b850ba9589b16284b7a3b02d463ad4054a21e10b51a7949767851509cd68529294047e4034b05940f836bc0ed3464cc13e1d3fa3a02bf46a8c13427e3de4fff20915f21af4cf6867198281a9f5f375cdce396f3ab613afd5cf4f33a96fc466c202e192a24504ee11ecd297e33396fd01380ffc157d8b5b948657f043b97bcf19010001 \\x5ff49a716abf725b3faa7fa6d0c592c285e84f67fde3fd754456fa9aa1ef4617d6540303cea8508627d27a0d72c8f9d70fe7c03757a3220d9b8b63f00ced8509 1680200475000000 1680805275000000 1743877275000000 1838485275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-97 \\xeed8fd74533234c388d25558450ef20cff66bb4406248bfd9c640c20eea521837e770b2d9aa10b26200a6903a104ecc5f8b09b6f188a05118215dfb60b912a03 1 0 \\x000000010000000000800003befb3286b4d218bcc3325a7f1bdfb852f1dfbbcfe298f1a1f72338282592d714f98de3be311b9e5999721d24327d9893f1d4419f4b6882da8d5e487f15399eafc0cd745f0d8ccee91f9bddf10eacbf46437ee1788068eb8e432d63f238d480850b6d71bd7f600f1d72d5e26ec6f050e7ac324ee50a6cc1c142164bfb717e6dcb010001 \\x4fa965aed298a21b670a697ae90ee9606e4925abcd68daaba9e3e3f5445f230afd37917c27e418a5409e36d58f83d474991ddf0a15618e950a8482198a78d206 1689872475000000 1690477275000000 1753549275000000 1848157275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-98 \\xee0c5f6b8367245a8215126c6a062181568b68a833e1dd3abe37f4b05dd858c9a6e8cf4cc811e10752fe05b7873a9ecf82b06eef77cd0bdd82d33d93d46ced6f 1 0 \\x000000010000000000800003bbf1a00ca6c5955ed54225c713ac56cc092c298c3d0c162f9259c2858980dd7ffea99307bf6c9cbf6c28f7472072aee3ca20a1a9ff96c1365edd4f1dcd6a8c363544d8a7553c2a73d833af54623b19d1ac6c4a35020e3b4de9ef09a875f5ae3e1324b17a7f76f67e96b74399c719fa874311911803184b651aaee4c0f6ac175f010001 \\x5504c932097e0576dda585ce8fc42eb01a89e17be6b7eda0e5b71e7db6739a66985941ac0b7408fcc5abb9d76ae2c5b0c9b09f67243c4d712f8696200e77b007 1690476975000000 1691081775000000 1754153775000000 1848761775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-99 \\xef5455fc5ad7922e96cd4f916e9f3fe5845ba75c13c892c72d32aeac740f03131ad992c49d203a47455be96f4257fb9121d7c6e475e5c92e0f4160f2ca8a174f 1 0 \\x000000010000000000800003d8973c130eea343c43f84dddc6592b38a35bbb7bc84016d4dec0e664bb7e833597dc33f3695025253fca5dc18c81f967a5169a50785d378406c0c10c5afd447335651c00f5d3a9608e99ae4725ddd44062cd4938d6f71238edf03bf976feac6999296d263466ecc931e7cdcbcbb5333f5d34b861fe343db3469f4b17ed500c2b010001 \\x00d480b70c5aef199279293f0a3063d8231b93787474ce42bd20bc61a2802c26bb0e5c64ebe6f1ac54c4476ab3e361a4401f0c2cfc3bb3d630af1c8cfc4f0c05 1666296975000000 1666901775000000 1729973775000000 1824581775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-100 \\xf2a8aa4633239b4236a7af1b15bc273faf9adf27103a771a107d42e009769a5c4646e55c3768b3451ce1c30b13b63d58728202053c524d92af3ff2682b408f01 1 0 \\x000000010000000000800003cccc9fd359f75e03d6823c91292fe9eee2eee36c7cc7dfc728b576fc210bef9c4f61c36efec4b98bedfbb6b2b59852cceadb0b321a7470abce64b62850ee3fc42b185a67ee356f337146e030cf2ff5a1d7006584185672ea54356a58dd5d494a7667f1cfd242f6e3fb77e81acfe6ac8c95f84fe76f192115634e40f44c48262d010001 \\x516c9bddffea095ab9944eaf51e721c7ba8cf8ed47006ff3f1076aac553417fd91c313990bed5bec46cef62e1f7c63521132e4ecfc6613aff1e6bac6b326ed03 1660856475000000 1661461275000000 1724533275000000 1819141275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-101 \\xf3e0784038f04948db44bcf43d47151d35d12a6378297399a21a210b10263094de33e9cc9f117591f7a6d58362330d830b0eb1f2459c7a2e5b73c2f3dab875a2 1 0 \\x000000010000000000800003990f0fb4c53e3e08225a812b87a51af2b92f202c2f0d833c3747a66017af386c49c2a53aa5beff1848fafe7ed30f82f3756c9c92807ba9c5422ef78e062bd1bc4cd4461d799912bcbe876d38a43993e74c65833d3b5becc4749b54a4ccf1216cd1bb9abe26b294f90a0d6faa812a444cbacf6725d28bc7180852e4b00af5d72d010001 \\x5f22b3549da15d68964297aed3ba0daefa7184cc385d429eed325d7a70d851aa1a09114f6b18c50e86501711ef49ede19fa24e809df227133a439f463ff6370e 1683827475000000 1684432275000000 1747504275000000 1842112275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-102 \\xfc38f87aa8a3edfb5e899768f38b086e7bb4675dd6d187cb35948cc8d729694d5e7e406a4a52a379222bdebeccc87b65d221a01e15c2d2d0c9f701df89d65b36 1 0 \\x000000010000000000800003dac3b51b919e24d46ac7c8d341c7a6dc8d950c53d5a305817267cd72c2b240d05a4d8df6ea412d2ff46313ed354850b14a484b3fd226242a0c1e3ba0b4f7d0737444a65b35936b91ada3988c69acac2fa37090d2700434dd99d71652b3e031ff3c6a800d2046a73a1d94f428185e4cba14886b370e93c5a5f0b7ae2c2256a9d5010001 \\x9b0714b5a765781fa68fa9e291fd0723a00309942fa7203e178a7a79163a8e70ce3686b778d8a16f3e5f6b1db6409023d9ac99aa802d094d83995dda4ea3bb0f 1667505975000000 1668110775000000 1731182775000000 1825790775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-103 \\xfd0465add1d2a609645c6abd4a8ae91954c0072b2005b363028b8bb53f40aa4523deb22c3c2f99fc8a44d8a75df3dabdb4a4fd5c8a72a72cc6f9f5f38942a142 1 0 \\x000000010000000000800003c0bca180b4795786c6a883fc1def6ef2428f904ad6e843a2309dc01ed13a5c23caac7719833dcead669e930708f914e2dd0b5e50b0145340d2957580f47c329c6febf0569f5aae245ad0875c4af02b4c18d43f17f47eb23f3e5772882b87d139153f08014afe3e4f349cd088e8466cbec539f4761cd9fd395935afafd2c58de3010001 \\x72cf997b4ed7634988cc6d977c818221a168fbec998c6293b0b50fca2cbe016ff1c6c1250e8a383d0f2ddba3f49ee4f17389a570e3bf573eff3f3a139634ec06 1679595975000000 1680200775000000 1743272775000000 1837880775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-104 \\xfdcc175e2c649c4a49f5fbc71b196d79e2bcdb02276a42ce55e5a09fc78c98831ef396c83b86ef55691d74d3d3da874d2feca14bb2e2702f5d62a52f88e55b72 1 0 \\x0000000100000000008000039d8b41265270898a75ca42dbaa36c1bf6615e947755f5eb0207dc169765c862758cf7357082835b455fbc194befad6a830c770007d5cc0b144e309914ce9cd40d2bdefbe4324127899a7be6ae3c8b6c9f0cffbe31f8fd5afb1a388e42cfdfa0da3fa8a3df854c78c01333a9c01c61d3b91c30a54f314f235c60350ecb8a2b689010001 \\x7a98e2219737ae8ec16c68eccbfa142c4bf6e8d55d299a846bf5c066405e083133662944fca4002858247591f328f3b4865baa1c8eba3e607147a78be2315805 1666296975000000 1666901775000000 1729973775000000 1824581775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-105 \\xfe44b9abc9d5dbefd903f44d2fb356339c3d9d0cf53916802219ab51bf2270e8d45ed827061829dca3aec976dc56984c0d9889110b8193269f8e7d4f5c065667 1 0 \\x000000010000000000800003c2514b3ee079515bbeec8fe7f5e51782cdf3e742a76c6d67f675a18cab32e9b4941ac250705700885da5ee46bb6fa25236ecaae840b6a516dd4efa9c3dcfbac8bf3283762bb1cadb931e52f7b08dad9554fd2d467397b53543df0b22f4f0f8e1dfc1a137caf8333bcfaa58cf6dbe5fee9859bbb63d8c6273dcf429fdb09162b5010001 \\xeddd330c4e2b97ce2450e9e3eca267e3981863592902b3ac2e8a5c3bae5b9e961f86dcd6f12460c346825d0cb290473e58d6879f29c2e9a8330a5bc0ac88bd09 1669319475000000 1669924275000000 1732996275000000 1827604275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-106 \\xff3039f4805d96d49a6f77d7d5fc9a5e053caf7e164ac761a7fe5217097dc7d0b2e354c5989790c341e64e53a866e4bc04a0b7390272333c5734049bb91c3fe7 1 0 \\x000000010000000000800003d71337899cd3f9f4a20436840b37382b0b360c1bbcd38cbaeb915bc24933528f27781aa2b0b7fa3c0dbef719eb61eeefa267ae23dfd6ed1a2a9d2013ecdf49dffd6adad7915f6332e3241abce1da7c18f533377c09133ad7b6057259b81e4013e70dd8a6af89a5658860fb89f763b8f9ce07aa7be04b9ca297c17acc920d9e95010001 \\x236fe05bb869c7d5ad2e225ca159120357a59369c237e2b6a65a0e06c4a32be2ca8b46ffa02eb24800e380449d18ce7f607360c85b5edbe56a60f445006a6101 1661460975000000 1662065775000000 1725137775000000 1819745775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-107 \\x01110cac6427398e830ac50957a0bf5167cf01a6f7e51a477728acacdd31e2c79be7552ac4bafb83ddda600b205283f30e413e7ef51d14cc63c27968fa6aef8d 1 0 \\x000000010000000000800003a3eab5c816ef2c34473be929e2594baa5ca1604701083eae012c78a3e27e3a7f69ebf2624ad9ffd094e266ce0598e78e2e61e461ce1130530858523281ef49878a440574bb2fef10dd9102644b8a505c27d2f8f110c9818c146c576c71cac3ddca8c469391fa5c1345d0a4264848c3f6c2b6f941159699fd28fcfe73eb9af909010001 \\xfae0f7162c3dcea065e6858f10b8c9e04cbf0f4058b3b6a06d8cda0fbdb3a2f8a3726257ef0fc6f0305c09f9e53e6367d051f4751342eef3bb3c1b43bf104806 1662065475000000 1662670275000000 1725742275000000 1820350275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-108 \\x02bde39374f54927e5957ce4f8bbf5c231bdb0bd0bfd4875a61c459f5ab7daa4cd3d25ecb4c8dd305c0dccf5c15f20e6d084844764ddaf238e56b1bbe8e7c33d 1 0 \\x000000010000000000800003c329f9ac53467c9c70993f1be46a70ba3824d3ccdbedd031b6b9d3ab8d353ee19b66007c4b0c994824f29d270ed4eacde7f8b007cd494d3c5b47e3bc1074b52f79308f2e0cf44e5621f85e7c6e96c49633be04ec8334f9ba54d2f1aba5139c3bbbc82ab4868f66108af9e6593740592c533a46ce776eddb7810f776bcd8129fb010001 \\x2395e9af40983cc2b70dbc57c736a55438cff9085ac61f396808a5276d6a6c5fdf6097f6d5b4d3aae68795c8c54a3bad6c6b82acfa800114dd7c6d48d1948a0a 1678991475000000 1679596275000000 1742668275000000 1837276275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-109 \\x0225d8b8c42b47b474277c9abb66187fad14a7039815a834f86e116f3b99ab869c9a0e5ae07b2974346bd931e46132478a743c5b962973b21efab3e147d7a046 1 0 \\x000000010000000000800003dec95c9b9a08d30a1727f8e36dbf5dd3e7cf4afa019bf18216ecbeca4466beb068097090683ad14c24aaf1bfd64d6ddc5b3de138cd2104d4b4ef1a12ab5fb4edee78320b1c8486e09e56c5e71ad778ec3a32d5d35ffe54b921dfcfac372d6295cb962a00f546b66fa5e837bb29a272420f2ce30a19d33f53ec417240777fad35010001 \\x547a889c0130d563251e01ab894e8a2a303c04952b8ec9ac0f7125771dd5b995ee7f593970aa0006017c259fd6400543d35a5dc71a883585fce8a78db03de209 1662065475000000 1662670275000000 1725742275000000 1820350275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-110 \\x0379490464a2b867f9fef1b96043221f83d23612c001bdca8762cc28bf95fc056a9ae78ce562b5add73b9cb3cee0b1b4625be5cdc0a3ff20bd633551bd606586 1 0 \\x000000010000000000800003bdbdf3eb30b61822eedb3ee57df344b70f858f54dbb65fb5e76b89eb7129ae6ffc88318c05147b7d1caa2b1497061661f6241d1d515685af6a01f1b1cde5264f450fabdb99872ed61c2039956631fc63c76a0ecac0653fddae784d04eeafa66d6bf57d9f1800f7abd01ea036a077cde8358cba4f94ddcaeb24188da97335bc7f010001 \\x8be8d53cfbaf3b7ae6c6c14ef79efbfbd917552311941633e467bc6dcc9f2889de7a0065572f73c6a442a999b8fb6112c5b412e5196167d853ef7e4782d4d80b 1690476975000000 1691081775000000 1754153775000000 1848761775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-111 \\x040d6f674b36fb05978be0c5f80a4ebe6fb907cf749f513f825f19028e43c088b8bfe14988c7c10b65fe6907fe2475bb7f58140d1614d849445fea4a447cfade 1 0 \\x000000010000000000800003b397b4f1e0d20327633467ab5f09be0efc5ebed2f3a1465b8526654d068d18f233e5afc60aaf31e7e35abc0f4815495142ac88600920105f5b4b4bb756a2be113f7316f19f4645d88a55f309b8b7f779cc87512b40b43335e1773112a320dc67f8fbbce503036635a540bb16306efd9821282a1bcbacdd88b70d0e170c131bf9010001 \\x379fdb60090a6347e64ca10ff5b2d9af63117a404a1a478fc36f81bd78a163b0740a017bd45c1cfe7d212f3dce2e5fb27a2859095e0677cf9f4bc96917721709 1667505975000000 1668110775000000 1731182775000000 1825790775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-112 \\x05212f9f995b96c2796da57d61efdd18b6692a309e985494a8092959f18e6a3e60b1bbb64a02674553a0b936757e54bef573696563992ef421df785d65fad52a 1 0 \\x000000010000000000800003aee3351c3a8a6201fb94b3fbb224bf74009a2d803b6ee80e317d84abd8997a8d92047a4e6dd1b334bfb3c4f0106fe795372f98e2ff18445a5309cd6cca9078ea0434593460d0a2f17dcfb95732e5d7830409ab4e44c332512ef74796ce0e9e660c5e19c13b39f5e5938253c66e3b2538ece319e84b7590add13e6d7132dcb37f010001 \\xb8c321815064a6e2f495435aa75ce36f9df73d6e616093d70504c6b0e15aa515b886aad3ee4e05b5b3ed1a6960d4d39aeb21c25cf62d8be66068d650d6ac290b 1668714975000000 1669319775000000 1732391775000000 1826999775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-113 \\x077501cdbc7ecbb04e3927e4607783c57a8f92aab39c3390e72fa3a21fe430df02ccc5d452eed81a101a6f487f505165aeb51598ce57283ac7af23b6d1e10d0d 1 0 \\x000000010000000000800003d1aaecd5bcc209b8f19790e95d90ac03c0f97eab88da6ac1039bb0205f05e2776fd7cd56c11d9bb351b049c7106b65dbb22ac7ae4c14d8ced86631cb1fcfdffd0c2ba6db388dd96b065670f2f75c742fb8a3d444fc53583dfceb6daaa74a5cfe2d6385f6344d7b3cc336a2bf8db531ce48ffd2df09fa267b69f2e5ada64c426f010001 \\x96a96040a509c0454659d834e49ee4f464061b03c02d2db1230e005119ac850c24825446ebc650466fdeed89e3b6bb79f17afccaa4dd1c16f132f196183a610d 1674759975000000 1675364775000000 1738436775000000 1833044775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-114 \\x0b953ef90ce5e11454123a0b83b5609a0899992292b3f812e48a872f164375df2b631ca2dd4d9a171d7da94f9782d96cbbe166167ebd07b06cdc4a9943f1d32e 1 0 \\x000000010000000000800003c6c9aa9c3a90745ac0b3602cd91ad58fd2a7c711de8b1b1ecfd0dd0b17d699ed5bfcb785b73024873a5bd7bb1a221cdcac5c6610093f4a7ddae3b8c235c0ab435856422f520d889f60bdf55aed78fedea628a924a5bb07c391fa1b86245ef624b7f34655e295aefc76d6ee1aa5d4bf005137bfe61f24e94fcfb7037c95a10995010001 \\x892d3edd3e0d2d85d634085443ce800752b6904f6e0709d19a2b42b9f30422e4a6c2d80642fadc20d8b5f0dcdcd292ef0c91e96dcd04fcc5a6324cdbae1dbe04 1685640975000000 1686245775000000 1749317775000000 1843925775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-115 \\x0efd853bb51cb32aafbe19eaca62ce02ba3054f58576ea2449f158f6de50ba9a7e1f7bdcedf1b3c985673552eef2b54fc896878552496ffb7b45cee24ad38435 1 0 \\x000000010000000000800003c3c681d8acb00d057aa7484edcac55a4ea32a6ed2a53fda87500508c889d2fd2ce7ae5d26ae1f977e66255b948c11cf54ceed06b5fc171f6dfb6068700bf77a45d1d95e8aa908aa11ce9e1af9fccc8a32a63fd7a997f7b72d9a4a0de834aa40f739bf3524a02a90b46fed5d2b83fbbea16f61b44c0d5465ebe7781600e8a1e49010001 \\xe6369c4a68956f81981b74c80320f07938251d6ade6f56cbf2a17d6b634aa92cce9080a1f7778b21926510df56deb77859d97f4be9df07ef76464aabba046908 1681409475000000 1682014275000000 1745086275000000 1839694275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-116 \\x0fb1228ca57827840806327cd01acb144f0b54dad91bcd6cf68aca8be5d8a3070d7172abfea0debebd696d2d0423f2a3c4cf487f9f57ef290ed7158949d05e85 1 0 \\x000000010000000000800003c7dc78fa7fce94fae380d488d232ec8fedbd2b9cbaf03e75ba48eebcb9eed8f4419ccd1f1ddd76d00d66029bbcb13af1711ed529412ecee8871154b2fac486f72d345898fa1e53897b53e3313e3733f3c48f253643c4f8d248209e618587ecdaeefd7417048481a5d9947a8866ed509780f25b3387faa865d02651190a60becb010001 \\x862349cdbb362c536702a00b1ec18be57e96fc0b87f3b192e2d0018ab8db82c62e1cc01c2dee2d409c8393cd678ca8cc04c4b87e133bcae1d5f55627556d1408 1671737475000000 1672342275000000 1735414275000000 1830022275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-117 \\x12e9666df8fbe36bfe2adc2b1f6188c80a8c8022b70436ec2920e30a171d22684284e7bb89dd46052a56f996889425ba5b37d2b142026fea96776caee753ed04 1 0 \\x000000010000000000800003d142eae6cc9ed3e897f13e752a2cd490203f9993d02a74ffaaa530c155028daa0ba0d02c7d8a60fdfb2d7fcfaee7c515a11a2b9c4427cc5d72c675ed1914eb432972f250f9d45b083c5c35719171e9b311012f74b3b44c961294f78ec6a8ba0d421df49eb207fbc3a1a92fea771fdb4d45bf5a76298c05b88cbf6ef8a0f80031010001 \\x9976928c8d0567b0d7022fc54aef5072b3396036f94a9c6972614400db0b676f3c323317bb1eef735904aa4867c914d60a9b38432f37bfafefffa2aee4641102 1691685975000000 1692290775000000 1755362775000000 1849970775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-118 \\x16fd685190ffd2587a21189a75d822abf08cd11fa46ef205a517ed17a626df9c7ab906dadf85d1f80de2a02f59a098956d8ae96938267ae7342864d2827a0375 1 0 \\x000000010000000000800003a271c666e2f9c45f14beaee9850935f9f43f6a9c096cc5191f9eae968177a6474c8fa57db135cf12cb217e5bd04cd29d429f33f627f51b920cde43bef01f1020623d5773bf3a6ca44ca6195696e1633bfb56eac120467bae53a49feaa24ab9161d64fe68748b7623270538e6f332a9d2c3a725e51fadb23b159fb315ba15c653010001 \\x013d300c78be74c0717f5dea00b376de59b29de8bbe2c35e808633c4686ad86832b2649208a6805d6d3b3a9b8eed091b5a49bfa6669d810f659f44e191d5f005 1662669975000000 1663274775000000 1726346775000000 1820954775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-119 \\x16651bc226bc4865cc66d0d907514cca1be11f7d27337a6ec8ebe5aeca11cd81087052c0636fa615a8ef0686ae9606a2dc5abab005426e7d4550313bf6391e08 1 0 \\x000000010000000000800003b25bb82a92b10f4feccaba089927120a87f9e64a9a712a264c84e16b527e1f601d56b6ce9c13bf814993785ce5b8b9a48840bde968d0cfc9b54bb030c49daab6f9c6bbfe09a6cf237e855d94db7913050400c42b3b97f854dda53a67dbba3b12d51d2e1f2178993c83336ca0f8997b2509bd209050473e45c178c760b995f18f010001 \\x2b3614f30796cd9b52c648878630ebe8d87d50aaa814f4e0e2d9e6c35c7f5a549609b8ffad363a5859731a823fe7aa167292c299359b2fd987df8cedd4588a0d 1686849975000000 1687454775000000 1750526775000000 1845134775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-120 \\x1a71e967119d968938fff2b4ab47a1d72f58fe7941562556b27e42ae5c6f370f51e4c9702f26f2e7622892ce7caa97aaf56fb72587e3cfa0080776045715fcdd 1 0 \\x000000010000000000800003b2a68963d4e5a709cef2c497bd483b2e32532c867284036cda3a2976623361d500b1a9aa8f744df962fd97bf8964bd5023f45e6052e419be62f355a16e42c28f990de4314f85ab66f10337e8cf271147d07853d5f98fe0f0b28ac9f4ccbd85372abdcfab8970a0772dc292c908cc2bbd4e29adb38eaced4462dd42c5017eee17010001 \\x2967bdf7c409d24a69832f1a53d8823b20fc3e8bdf60403031321c87bee957779dad8ecd8c49ee890e4f775ab274790f232a75e1898caa817a4b457c7b371e0d 1664483475000000 1665088275000000 1728160275000000 1822768275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-121 \\x26d9fd059951002d2f2bfbc8fdc821d968eb567ae2d67603362bc73dc3ce94746afe9c29e457fd0d3b37ea5b8436457827ca15e53446d058c69be3dd5f96e1f3 1 0 \\x000000010000000000800003c37c3ff0b1ec97fc54032c9ff4021a825ccf3da8df6e1f208b3557d928882898e229e64d33c54752eae6f6aee69578debd2489760c7365ba7c8f4b45028cb922926b4d14508720901d47951f1cd07c773473d92d3e776fbdf71e0b3779cde195a9d13cacd3b7586b1d35611e79c07d6823cc0aca85e489457af9fef9802bb5fd010001 \\xa229d4ee834b419877be707d67960e996b53334dfe0d249cbb4d278558247e2a503720a27a4dbb1aa87ee2fc9a6e39a55a86be766db47b162f9337c24e1aaa00 1660856475000000 1661461275000000 1724533275000000 1819141275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-122 \\x268972d70950526599a8639b8f024cac833022d817dc4297ea7775cb522ce1288227998e45953dee48b2e1eadc33ab1bf731ee503ca494eb39fe3d63bccaad9d 1 0 \\x0000000100000000008000039dc61ec7777696534c0d63676700fb519cc88bf8a86aabef60cf551bcdcdda2845572e9ecd0a2fea61da9e05798ead3524d5bec0aeb3ee68a3d17e2c5536b49ad749c455fa04eabbadd6f8e6f0195ef2c39c6927a87dea684e61b2821768f54cf116f7c2120dcd0240d601587d03c784d67b8b67716c5ef98bedd20547a91887010001 \\xd573ec7f4cc2d60aae8df4dde0706c2551549946f72b97ddc62ed8a76268262c03632b9570f3b950e04a26b1a5e1e4c15b2ad9435a316a5727fcbd6819d5380f 1668714975000000 1669319775000000 1732391775000000 1826999775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-123 \\x277d42811f50b70da9c10fdc188348deca8fa80e16bfe2a242bda5b403c1f997bb0a578a2359bd8ba0b1b73424d0768810997be0ed69c49a520139c11b1999e6 1 0 \\x000000010000000000800003b23b0cccd458d2a913568f757d9f127223c57f1339645543de7118e63db827bb09b88fe6c6c5ad66eb389f95b0580994d793ff15a0744a4a35d04cafcdd065b37e088c67eefb94b4a8aa0f948acf309ffcd1f6a2be8fb833204548968ec7a1eb8210aabd69dee839ae6688f16c7ea486ad6e1805c795d5f5a7879ebc0ba35437010001 \\xead4f1bf13c54fcdf23e50e020a05a6d1e81cf09d3a0e6360c7073c2be56177292142e6210cc3661c8313db023030ae394df601d35f32b3828d438f0f968f40b 1685640975000000 1686245775000000 1749317775000000 1843925775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-124 \\x2a990169d75b234da75109c5a3fc0435e989375b0381d7e87f2bb0470ca3e1958f97214db2b67bf889a56727e8854fd74c6528f0090b94a3586fe95cff468734 1 0 \\x000000010000000000800003c8b30755d5b8ca75b80b660a619ba5846c91da49809c3d5ab199acfcef6ecb109667c39435834a0eb3da68a3b5e005b85f99488eb748178e714bc6c93adfb086b7c11e9e891e8fe608b16c3ac045d3db1106247db6fe835f92a3b927b0c403e069b084d4ea0a00e26cc7b5e92913cd72a7bfa80a34b532f5a8170ffc404e5a69010001 \\xae9058ad871e3c4473d898525b5035057a8fc0df4794750fb233ced777098db853d35a96e01b9dc2bfa65b62b92997246d32c9166c842b7dc537cca97627d202 1673550975000000 1674155775000000 1737227775000000 1831835775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-125 \\x2bed4b44c726432780b4012eb758c8a89ee3a145a162054b56e9fd668724cda8b10ea4732851d5831ca2b30d5eadecdd6f1589a3a41829823a8dc2fd76983971 1 0 \\x000000010000000000800003c8e58b7a37996148b1eec631d62e17c3a6685038ce7e83ea75e1b3503a72bc4077f39da7d5084bfe94134a31f781afd029ab6cfc4195d53a92da848e6c710ac6da46f43aa872339ea7c7f2de69dfac6fc1d94976502d7b7d59dbb89e8b856789db118b8f81ac8a3dff1dda59203ea96aab9975b03798ef6bf363487c5e74318b010001 \\xa40ca3e487722a2d9707eeaf0f28ec99afa089ece3bb5ac4d54de8bc40930a0535d667e317c9041c26f2957b7e6be169344d36d0a4572e543195db41b4622707 1662669975000000 1663274775000000 1726346775000000 1820954775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-126 \\x2f812fbcd243d48505835f23645c60360877e3a41883ba7792bf292eae0f401a8df8b4578cbc6fbb611f5fa44545e33eed0174facf347b4783b72228f85a1c66 1 0 \\x000000010000000000800003e4888826413987413b0725fbc19fc0d76cc9324e46053ec557742a921a34d1bd97c1d6b596bb8aa38b9d98557573af8d504644661c4853c4dfa73e6f6490726a19332fb37d0ae2899a989c0f124a1d479d6899691bb7e5fd1160d2c63c9e3df512dd4d543ad4541aeab67c2cc7176058304fa86db7e8fcb09786bc80ea141fa3010001 \\xa5f8740381c57f66f6de5f7a6e9723eefdfec9f3833ce8a939745bad1483b72fa2ccc27117d0f90413f4876aeb027773645f3e13cca40e445d766782f6b86f01 1686245475000000 1686850275000000 1749922275000000 1844530275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-127 \\x33c92ab32b9bed4612b26653deca4b3712b40564664892df113a24eb0741a041a508fc14678415b6f5cde207a0e975d9e4810103f925324a1d3898829aed39f5 1 0 \\x000000010000000000800003c701aed38bff0294e074d065005f19c3bbdac62b4e02cc20bcf1e52a5a8fbad68f0c2b4f1bdbfef6fa4a04b857545612775b065a18d0525539abf63cb80661d670ed67556e1836ce7d8931f66a99938cf8658a9529b8422ab072cf72389536e030d0f26d8b6855719c7369a791f00dab1a30e93e0f4569e40a9a6be278170a79010001 \\x537c671327e8c33045281047345d874247247714822ffaf03a0899e333a156ce4bec9aafa6b0b1d0be90d37a42d23281e40491b503735f172943cbfb7328a60d 1660856475000000 1661461275000000 1724533275000000 1819141275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-128 \\x349dd87c42786a1f11c5c1ef3d002053c26894f50a0563516854ddac638f2df1d91201747aa5a71affa1cbae667e6778288e397aa2e040add057f449e78fd7ed 1 0 \\x000000010000000000800003a4520011b962e1d9a4c9b55c2486574a6eeb90287292853326e77adf2bc42c65f63f27bf6866479801b1341ca047db3e42476bbdc2be2d2c8c09e6615b6cf6d8216afcd4b6272505ee4f9be8659c4e10ccc0ee81b53ce7a56edbe5987adcea2ff7aedb44cbcb3c473453e18e01a78476aac4c4f412ffaaed3a06826897a34b55010001 \\xd2af7d483cffc98508c2376408bcd2f425d7799d077265287cf392e9bc8275de5e7edfe0163fe79b9b4abf1ae13a09a8c7c04c6b72f4707ce8c937b613e38d07 1680804975000000 1681409775000000 1744481775000000 1839089775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-129 \\x35f5d204759a0eac50ad5cf635b4338c526049ea23f27ac3aa6096ad7cd201cfaa66d6564a1ba440397b6f9623ad1b167038b24ea6dd70aac4c2c2e44ae8ea9c 1 0 \\x000000010000000000800003d50ab560aafd9bb2d66c7a655ee2a7a5ffa608df4e8a1b64a82f69d3ef70072fe262d02da8a15dbb454167a478476f36e075bad16a08eca73e0cdeb00f10a41735064190092bae48281316d622c255cf50de9ad3cdecba176dfe26d7960e2feeb7f6d0fab63d423d7b92235d8c992ebf65d6b27c222123dd787a1149a76bed7f010001 \\x952e95242c6990df7df61c2d657877ab726f3ab734fc2997ed69046e3d811a9600b32366ab1e343d6a2d81c2f81fad0307968c787f74f18e0203def3b740dd07 1663878975000000 1664483775000000 1727555775000000 1822163775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-130 \\x38b1041f15cdee8fa37f9e97deac5357e73f2ba3c3c3e68a89a82b2330403796e6bbbaf74e288ed6b6a8cf773f376d51fdbbf287b0a3a446acd68bede5047168 1 0 \\x000000010000000000800003ccd7774071c9a35264e9af6d14c8591e33b4aadcb57376467e75ffcc2db1e75ed59b2b4b18381fda5a3eca5989c9704c9d99950200896eddee6aeb6228426f8c142870216ecbd2c10d0c0416180e2dd71b6ed6e2dc41b0eb997508493540f0a3c132f80530b1b6bbd24ea4ec0abc392b7fe45da67cc07382be876e1a761a7b99010001 \\x2c1a8e074acb7dcd5cc0f96136efc3819dda1fc098b875815acac07bf31619bdeed5b1cb9d4ba2ebcf9f5ced937db54ac6a232a4366142eacb1336a36bc1e10e 1670528475000000 1671133275000000 1734205275000000 1828813275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-131 \\x3ec530feba09edc33f356404f43dd39d929ef161c7d044f50d7b731a4cf106324fba1f816119e390ffbd9de4971430e01f0d0ae0bb28894422d9aa60098d56dc 1 0 \\x000000010000000000800003bbc397b29931c7f5053124a8b0ff02db485aa22255beb8be91ee59f068a8e7577fb135cc10fe896162a03b169c71929b320ef5db08acddb5a7e87776282098ee5a46a1ee5c60faa3af99ce0b477bb369742d897c6cdfc00ab3cb7c8bc8f48076d95d086f97eeaeeb2e8149cafec7693fb7a1126f282eff9aaf35cfa6b5ee2b09010001 \\xb384990b5c00b4b8534ae11298093d99ba2c1349188129a750fb680bbeca8093241a1faff66e626e969138f14fd4d68d4e1c93e95193cb3bd04c75094753d905 1665692475000000 1666297275000000 1729369275000000 1823977275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-132 \\x412dbca79e7d0c579bc8e0560b99bf117a7d8d108b4774484202d9120af886ceccf176b3a25a0c8e58808c6746c95f6d4f99d00036f48a8652c84bd8435b8141 1 0 \\x00000001000000000080000399517e981d26a8479f2265ed21402d832b823f500b5876a3b30879c56e37b6642c5b7c20a9dbbcae3e94134933f430655d573c5818c8f2018e738cb1bb0e9691ead26b4c84fbb4b64eaf56a565fb5319bbe5e6b8a996d8f911b9987bfb5e641d495e38987ba39054d34406cc74f56792bd850e9fb1f818e1261ad3a63050eb45010001 \\xc21627e91290fae282ecde67991c64869ace278bd70aad28282158758a3a5a46c8e8f0e65aa53f9ab1cda53d9c781fac2b64883879cba340481e8525f4299902 1663274475000000 1663879275000000 1726951275000000 1821559275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-133 \\x418d47816152233252da50b486e17b42798238e9ba27f6f394271eb4fda8c3d2c02b0fcb5aefda1b4c9f83e529529ee6346603b353c0e54bba9c3a1824753c88 1 0 \\x000000010000000000800003b419563df7cb0620a8a65f7277d38a0f0971781e3048bf302ed60b79b4d083072f784e819ae8c1adf0bb2e32f60914aad3ca8134295cdc3c7744aee5dea92b928687afe88692ef23e0b87e2d006261f73860701655077859d62ad41a6763cf6653740ca5ae2ed44bdb6ac66b16ac7594a51cb9dd9a46ddae046252bf8c6e6bff010001 \\xa00f599b31f36e44ef15cc3f55b6ad7e0cb5a6a18e1e5a0ac49d165a8021fe8222a6aaaf2a4d5227b2140bc1e7fca84ca88d552f29b00fb204944a030d6b0900 1685036475000000 1685641275000000 1748713275000000 1843321275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-134 \\x458911c10be4d2700bd90e071f71531ab6ba37173205d1803989a9a3e84fe0a5267108641842d6c61ee3026802ec5f090e26bf3a073f3d7fe9dbd646ea99206e 1 0 \\x000000010000000000800003d79e3aee2610cc1ec888cc44c0a8fe99189ae0a4b178e027242f83b6ef27c708f9ebcb1b738153c648b36d92cfe89c2d9976c28b29ccfb1ee3797beed21a59795ad53c0216a821f2d7377bcb14514e94e1beab3a6c2dfebf05f63d59d529b4e01571a0cb0ddd107790d2aff6fa7944251a732a53fa85d0021fbbe91b985e3447010001 \\xeb45ee26de2bca822bc96c660e60841753b776665c07328f5c4dd302d73bb86c9f1cd7c36c0359c98a9980c0caa54600ee9d6b64f6f4b89dd98144b2dc3a1c0d 1680200475000000 1680805275000000 1743877275000000 1838485275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-135 \\x4519b85f788991f7245272503fed1367558a10ace4053ac0990b5e6eb8dd23cd1561376a5a113c04cc910605bc4c9a8f2c592cd3a099f94494dcba48858509c8 1 0 \\x000000010000000000800003a297ea31476970db6c780f89ba00713a66a3387da6ae186368d3ebff55aa060b66ed536fbe8c7c1261ddf5044a92393e2bd37c4687bfcf6ba3acc47bdff8e149bb61366eb486f6614bd50a92005fcc0d9d3e98afb754ff6fe8123ec1ac05216a081c36258ead1bbe04df2098004762a0877f97ca522a6f2760dc45e609075e59010001 \\xf7e63d83c3b54d1aa280c9a88e5e1d14cde405c9996167ced78ac6333fb0761cefe59d41e7f0a6af9e163a6516e627cba686b323605bf23cd4a790353a12ab08 1672341975000000 1672946775000000 1736018775000000 1830626775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-136 \\x4611a6f76d00a0dd13ffa1362694d10e5bbe0d3e9873671229fcdbe78844abb77dd9b0f4ba7afd3d890b3e82fe9d02851688b41949e69e4b36d1c614e3c72a62 1 0 \\x000000010000000000800003b7291af38bd9fc67fa1ad574f666f165869bcddcce332e1b0b36679a612cd367e613639fc50ed9ec9428061d653b1b91d75fb8b7a021f3052f826966020701bdf5e342a5ff96d14f2c48343bec8d7472a5a3fab619806cc6b9f6fc77dee0c09690636a9653af19a1e003d3f9bddaaf9de773377bfe09290cce74e4e0bfc4eca5010001 \\x8d0603c529b8bc787880d82af4fc57e6679b3afcc07e71df07ea7bb84190e959a8aa5a59d0bd92a138b0c78be4a7bfb0c0bd79dac132387b3a156afc3068d007 1686245475000000 1686850275000000 1749922275000000 1844530275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-137 \\x511dc9090943791bc6820fbd21828b812232100ce08350d6401b3364e2faf9e806d9840a72b06de0d75c06a263c213be887b867df9c6dc3b96e662db49c3d016 1 0 \\x000000010000000000800003f241260d45e474a9507beef8606fe13b29d850ce9b09d5c38b7d653a97f953c49ee01265fe8abd91b506c98d8cb7eee21298b3df69eb817e56701d0a88be498fe8f8d6ee2d7ed4af21daee5bf7ddab169051295beacfe3eb7e860d348e94a7626636d7ef434623da6017b2691e12085320aa94a04c60cb25fa40784c3304f4cf010001 \\x9f9c5d0b99527c78d406fe2147ec6c5a13a49e098aa9979504b4684c9e64c4e6db87240192bdd2938668eb815f63d263aa464220933dd7137685b66658013600 1668110475000000 1668715275000000 1731787275000000 1826395275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-138 \\x5219a9340e0cd351b7fa6dba4cd754bee805b8873276f245be609cdaa2eaaa86f40739ae6d4f26d9ccd1191aaf9275c8bcf237a642de0cff902220a14a401f04 1 0 \\x000000010000000000800003baff5192b4a62dd0b72073f5288a058d6e7e5ae10b5130736284854f6b9727a9f737c4378f288ef20a2b9f4665aa5e00339c29e4533142eb8798f21d5783d9c0a7268a2f9da1c33c168f7a2ead3dd4f945297b33ce3d78f038e7c2493e504834305197aca1196eb6797e37a65c1b5ad6552a6273ff503447bc4d0834fdffc5e7010001 \\x7489f0e9cefa1ef9f9b2095195eb4ad45a2dc26a8c3607021f9203bc015da12557ba204ba44056f504f0d330674340fab7264802935d3ff153989e9ba228ce0e 1664483475000000 1665088275000000 1728160275000000 1822768275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-139 \\x5221b3342997d2567b6e854cb200ceb40553f603aec4981eeb4d84d6fa4024c87770a89f8cc7e5ace98b82dca2c8f5bf2cde34429b620f1e1a414ef8ee1c5ad2 1 0 \\x000000010000000000800003ce64265221d5c6da34c632b09dbef143f7a83976a165701d224a728e98aa6baffde132f5b8b41268770df536b7b4f7cd25a0fd1fbfec557633a10185f4db2791f4c9c32dd32fba42e825e6d7827b5a2f2b3af08cf6d0fb187a07120dd7518f819f0137cae41d05bfdc72ac6b544ec2d1b85defe96a39d289aef4c61a82081147010001 \\x61a03c9f4411706bdf7441c2b88bda889f5c1944af4884cb85671064e2935d2b47879c01721c328a6a089bfb5140d61db9725ceb27886310d74d177a93af3305 1663878975000000 1664483775000000 1727555775000000 1822163775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-140 \\x53597ceedbd44e1847c9094f475b3ce3f6fa024ea4bfcad97c266a6e477bc8e0eb70f392c13063329fb837fb2648e097305e3ab7ac0dbf2c8bd2068261feb8d4 1 0 \\x000000010000000000800003c772fab81300d3bfa83092e07dc2311f9e45703aaece634bdb550721959c8bec055f0445a0123a8a9e59c0bd85dfeb270224165f39da0072f38b2bbf20b823d350a02e593136194ff1a3a889d8a2d8eabcd81669cddcb218d0102b0fbffbbac173f01cca862798ef18e8790e1ccb91a22d87aceac591d26038a0d8fedfbe1671010001 \\x0b5e41ff5ce9d89f743719b90c28fb3d0a89b5d4e3d6252021b03a2d4e2b986a40a785ba2d01276f1c9fd5bd4304b566d5b79c66bcfd454413b779dc91702d03 1663878975000000 1664483775000000 1727555775000000 1822163775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-141 \\x545dc4f81ca0f9b39d6a5049a46bfba76c06f5f9df548aa0250855f6d126ec0031b69f71756b25bc9438fcd73eb9293760f6c7bf94d6329340eae399891510b4 1 0 \\x000000010000000000800003b9844ecfe2fdddf41bea7d5c0bd35f6ac06640c3eaa66e794ccef43a449cd8e50c5ed32b3d0aec57de82b81b71d933e0254426c4004018f1db6dc3ad113581040d1ccd6c255b2e3f475a244967f39d51e4ba1c402569b10384e1987c0e1f44b6c9caca382d2b2f027a72fba09ffcd29b13815e1a368ff9967fbc3c2104b5a4fb010001 \\xca7ff33950cdd587e87b46b65d185e0a8cefdeb0a59e31b2fae7d01cc75ab84efd093abb77ab64046e128af9d298b11177112297187e7bea8a988ae6f6a4a903 1682013975000000 1682618775000000 1745690775000000 1840298775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-142 \\x56f195f7201cde164df84da899056bc0be6cd1efc1ed9a34bff26488ab74fe82385bd478199d767c45a9ec1ae34f33e00715f453d1c0863fc2f7f9358e062f4d 1 0 \\x000000010000000000800003ddb127f0d9bb2de0b506bcd3858722b6c16c378c4581455c4080266fac64b74c6795e1b2696b1bf386b44ce6a9b473cd811654c66773b45759d047553820d0f22ced13e62f14af9cb652fc093b9a62203901b78ae3bc915ee2c5ddd0bd19fc8a4aac05a85367f8b37e866d27d53217ebed5863ddcc0b07d4c5baac04ec841a33010001 \\xa99d96d375270308bda3dd27be166aa516e85b7bcf4900fc42d472813a0a185255333cd3486d4a969c543f0f577ee27c6c249dfd452b3684bb2a6291b474aa02 1675364475000000 1675969275000000 1739041275000000 1833649275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-143 \\x58d9bef3577b9a9fbfe18bd2d74ef7ae5796c326435fb8f9ff3a91c3723a166dad174be5b1661e6a9eb9e348b31060ef4489d7cfe0a906aa46f9b0360e9e7cef 1 0 \\x000000010000000000800003b618693535c2da63295da37032ebb301466bd0fa96389eabd90babcc0f17d86d8e2dc59d0afe01fdf05fdb9911da951f69c8d3eb008280773a484bc1a19052c2e83c85cb8d08a4a4d48f541d0633dd6333f357e20d467cf9ba87ea5a562d1e23282587f7c187988d67a738814109609491bac8116299cc37a7e4dcf46ded8361010001 \\x31037a0a5df661c3f6751e6c753c80de6b518fbed68d497ccaade28198247faf56995e882599c24d19c6b4616c1a6c12f2f339c484c2002eebfc0d7fedf8d100 1678386975000000 1678991775000000 1742063775000000 1836671775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-144 \\x5a49a746cc1680faddfc3dea767688e4c35feb025b995d76e2cf8378d3b95bb799dee8459ec6d0c51e17213b9e814002e103a18742b5ba25a8ff69f77d3c95fe 1 0 \\x000000010000000000800003bcfebda19be614d1f80c45bcb4e6b1f9f85154e8b6d043303441afb6114251f206700be68a903977353cf734e9a0941a2ed97cb77d056d8b18df818eb2bbe7e03dffa58366b8594ae0a3590f01b9324728f19391e238a27de4798f17606400c212d99761dadacf4a75eb3d626e6653d30a32bd0cd48e77d6940a8f5066a22611010001 \\x8f911753b7f3afafa5bb75431c33826855b257ab81f49b3cbd56be646e7777696eb1954f6dff3b2b43c1d2d905baec4edf28543b41b21dd2411cca2417673704 1669319475000000 1669924275000000 1732996275000000 1827604275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-145 \\x5c1df5bf385e0998ac34facea431cb063fba5896e26096dd90013c43ad710f35457be2573d927064dc7c4cd9f070d20557ed1a2971c713cd32a3938ed7bb15d8 1 0 \\x000000010000000000800003be6b925b58cc7ec421216eef8bde7f866808155193565ff5848a3f299232fd3c0164e44e43dc317201214f482e23d776a3cca12472bdb7402be0be9944c61d7a2427804cc29f4a3a97101667e155e434f1303fd7fca9895ab3cbfdd771afbdf71270ed407bfb21f6d8619867c52f2a03293dbbe41c152b6a38e823bc6510db67010001 \\xf7fa5ff4f7c96e0fa4ae45afff1cdd9cb31f32fa1ac469581beb4c6478626859620756e78cf59b8449c26842770f751ac142a96c5f1149f442181a602243730a 1666901475000000 1667506275000000 1730578275000000 1825186275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-146 \\x5f2128555cefc77dc84342dc16f0620581a8e39bdb0cc49c6308221a8254d942ec2daac2c7ce75f46259d5717961fd48b1f94f071958bc16b798108ee29064df 1 0 \\x000000010000000000800003acf4d190cfdb5c77f669beb60927e09238edd5ff616301f0bb4f536dd958cdb806b4660e78ce7d297f2164331e33e0ac56a7ec05f8d45748efa51b9f2a017e74539eb12313ec05acbc9b87057bdbf2868e7be30e05aef3572f5f4f168223389814523c533627a0e2a62b23ec8d38d50c7955ad2106a639265389cf712fdbf363010001 \\x4b6c9f0b6f9cc5c37de0d38dc181342a3f4a1b18da30e6efba5d3b8099aabfc9cd898cf74f9b21899cad3d8e5630d9fab6916b2d586f0c7c3789da6dc463380d 1663878975000000 1664483775000000 1727555775000000 1822163775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-147 \\x61318abd50e913cdd4af7c866ce4a7270548cba54b93f668303997fb964ce0f364a0be9c55a0d27cdb55ca59b4a3b94acc70e86615848010fd6925d8647d3275 1 0 \\x000000010000000000800003d910b3b3c94853fab55559199834936dbf05816b670083dc43bb3e21953e296152441f38447631c181c9d3c1578a8ea8fa41800d8e1870efaee42adeb7f71e2ecdf8894ed7ca86feaee4d142f31d67f7de473ea83dc9b38a633fdb4fd271f4b03dc0564c6084a0d662a7e366bc997286fdcf738ccc1ba7ea4e9c8bf26d3e33bb010001 \\x9c5a423f5b7c6dab1a01453540767fa505a4311be4ee0d6fd4379cde21ba8f9e1bc1a22eccedce431163c1d44809a605d479704fb7a48ee42035f13385e83204 1677177975000000 1677782775000000 1740854775000000 1835462775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-148 \\x6541b166347730865924033bbd7dc85baab849fe7dafbed52d0bacd7808c4fc7153a34e0fe2e873d404ad127cd9d2637648ecb20925df3b111cfa1e5d37a2b1c 1 0 \\x000000010000000000800003e1a8a1c0c1ebf963fe1558e74932de4690b27da72f5a96467eb680a155d75927a22a499279470f99d431c76bb32caf005fef951a781cd77d7085da48de3382377464cb4e35c73a7b5ece9bf5dae60c2552c67d44e4fd9a98b9112d47d95511ca8ad2218fd17b3e99216e2d8d3e869f04cc321d0775f6f3d1019903dbd61cb63d010001 \\x5e958dfc436747fe8a30b6c16e6341e9bbdffa1afa0b5364d9d00beee6a6d01701bcb594ca1551596bfc4f17ea750fa99a2ff0dca09569e8dd5db6da13876f07 1680200475000000 1680805275000000 1743877275000000 1838485275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-149 \\x682d7c93627af0896907850850a5f02fd520ca2e00f9f1003b49b0836e3473018ad03e49a6bc18ca9f06d5976737429fa44c7b44c61d8270c6629bc60e726bee 1 0 \\x000000010000000000800003c597e111bcb745e5c79a376381cdbe37a1302d80e755b29064ca987f6eed82e9a49836823ed29cfd2fef1e9d6f66e3bb15638de9bbed926f5d6015559c7bae0650cce97e2cebd7beed383cace8de5e8ab1543120d30c21876658b268abf1b5a1086ebff535d1da0cd2fa2fa5a4adc086fa84dad03d66b20d1b3af65ee2670011010001 \\x6b6a35538f66805b4418277fbe76fb1d8e588b281a8beadd4d3550048069445ed980304d9057d945ce4a0b1047aaa2f7c0ea87993d1a91f0f3d9c8e239d3990a 1690476975000000 1691081775000000 1754153775000000 1848761775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-150 \\x6865b16e3b0961b0009e166b304ae63e98e453bc76d712b41e6dec931d5770282783776933ee4db754b5c97831509331e5c512f7d2f5e12654879fd0e4540d43 1 0 \\x000000010000000000800003dc500dd187d77c68e8430a28dbe90a002b9e8d3cc0be1e93fc5fb74a566dcf3bd794cc115ce8ebe12f46863ddb34f7ce942801c37fc3e4cd77d9d9a54617fdff36206e0b8a0d3e726d3293f0049bbbd402ea598e4c80fbed5f10dd04b16858221581dc65b0a92e7f74b514cc72a0b086852a25dc9ec03b5a123b3af18b16de11010001 \\x79293f654e6b4cceb6669c8605c19c2766eb691ff955f5a4a39756bee6eff5fedb884c16038c63e8b8145976ee0bb4061d3fd501bab43e7bb28ef3ae4ecb2509 1681409475000000 1682014275000000 1745086275000000 1839694275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-151 \\x6c314c5b729a2164a24c003b42a015f792861e49188c6999f4b1d1f0a519646479eb1d06b41e819489597e4c790b6f49777d2e211b766d2cc7bbb9cf6369579f 1 0 \\x000000010000000000800003acac16884818e7039ad2a64724dd64ffe0c326ef68569ebc0935d3d5a9dfabb45cfac59153255c1e58bcaaa8d84a16a02f02af5ee97b1ec000788bc46a2ddebdd5daa29be034332fe8df89527d27413515b9a1545245cfa2a93977399754c5a6cc46f990c191b4129e67a03690048b5755d866e78c76602cf284e76c676c2657010001 \\xa3559a1acd58eb2835d395ae8c136005ded6b187bacf8787c0808b15c19f1f932f0c35a1b946d24911c08fca9fa827b3444e1a220bee0868e154f1b706f8e30a 1686245475000000 1686850275000000 1749922275000000 1844530275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-152 \\x7171f237570f165fa0fc575dccd6bd6008905fd522b69e0d9ec3b85329b98629eb59fac0cea493cc36bad205633dfe696a20d6df180ce247a44fabdad492125b 1 0 \\x000000010000000000800003ad3afd23cfa2cbbba19f549a4fde735f8e45f5252462fd7a9cf4519fdb6cdb2701f558b959eeb9d1b0c2e97b668bc1259aa5424519a39af051d2836f23ff8ade3af2a04da4f0ca6affe086de5a72320fb1ceaa1b488f552da2b4c27543bcf84a3e407ef2a22325119b343b3a9bb529295a6bcb4a77eebb2054487ff838042f15010001 \\x746cfa67c52e2b2ebf810c89e4813be4180adc4edafc3cd1ae1363eabf58e0838f761389cccd2ce44f0a5db7dd1191ab300367b882013b64d90dcf0b3b49c301 1681409475000000 1682014275000000 1745086275000000 1839694275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-153 \\x72818f741e2512a5d82abd973dba0471c6872ce16908c079bca7d48853a335778c6ca53fe45d605fad10b512aca68cff071aa57bb3af4cbc8cad4f5b3c9c26bd 1 0 \\x000000010000000000800003ed7dea848c572cbf23d6603931b04e82c33b166a19c449588ab88775cfb241e6eaad6d3bf339db909ec7925812ac1895a89da24b9a34c32512a40213ecde69c42058757c4fbff53074ea9cb5e385bb8ea4fde23a51b3ff2f2033aac5b65ceb32021ee8745fab5444795a5db3769e91ba6aa4d75fe98c00f216cbdf8e793f1163010001 \\xd39c63c23803bb343996d1547ef3d43c04b90281ee4d31c7cf29d871768179cd07c633dfd6336c23ca610733f6c1a946428e1e49ff85a355bffa7c6d5470ab0d 1688058975000000 1688663775000000 1751735775000000 1846343775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-154 \\x74c530c9a7eece51fe91ecc3008feff2d1b3516c23d51cf24c5e93a05fe83e858984520500ec8c0829a4108ee21654768ebbe83992e51aafba2dcb3f49234d46 1 0 \\x000000010000000000800003f587104d9f0f6b3615784595fd2f25195798eeab1e5192b2ef22ceb3ca2b7b605e73afd023925bc64484759621e705ed112aa63ffe261c229f9ce288368fb0c7a88816e25928936c40f54d0825cb48b637270cd5e646b5d8f59018570863ddecb4c17aab6f3878bfcdba40538985c6ce3463ad22a8939cad396ba3bc88ce778d010001 \\x4aeb39e6b03bca58937d1f5498d57e1ae8aea8935c849950f63167628362e5d4da65d8eb087e0cb70abc34a3a3ca5737c3959eeaa0ed8e1908a5b4277202c60b 1672946475000000 1673551275000000 1736623275000000 1831231275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-155 \\x74c1960f459b742b540c52aa0f59271cb1f30ae4881691c6ff0ccbd1877fda2e0fa84763effaddacb45699b096a4c4efc885e0a0d0c5a3294d6326957c767a06 1 0 \\x000000010000000000800003d42d63c5849d6715f1399625663d65b947e19b30cf5cb7b23ca9da19c653b0029d1105567edae6347d697ac1b4d0fb60349206c6ace65295d17baac35c99edcf760c65ced14a909915fb58e6b8c3510acf9c25c2c63cf52deeaea16201cbc2f589926bcde66be545c0b8dfd6e51cec639a1f7664da2c1ef8f54cf4c3e6eabc67010001 \\x102565e9688f697bd20fba8eb3b18ad240c2d6ae946094dd2d7596680e13b75a7a11f6122647e0dc716171f42e959490bd4620029834d07e7f497fe812c8d200 1675364475000000 1675969275000000 1739041275000000 1833649275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-156 \\x75bd7fd7b191ffc60888b193e8a869638a1645f1a3dd54cd2bfb6f9ea8f0f69b7b7ce8ccaad13171c296f1e2c4edb8b1f945ee6190154ab824518277d55b24c1 1 0 \\x000000010000000000800003e90969102ac02e5e8d9591669584f6267cea9b3a1bc0d31285b4aa97e900ddfa46d78cfe8667b2cd821f6b1217573f89d7e39720d150d0f35f649aab03aa014c57523d14024231a2a3ca52262a5bb332c0d6f28622116215b6124d2e975d3d8e08fb196a934b494abfb346fdbc74883230087b2feac3fac5fb3f43159e06a679010001 \\x3a0bffd21974edc821103199481980d21bb674e71563b47bd3a385af272fe6c8681df389a3640e8fa0082f031f33b23985ef3c37d9e2c557a14c1632d9e2b501 1683827475000000 1684432275000000 1747504275000000 1842112275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-157 \\x755176a4b5e35f78f330fbc451933f2a0fd83c7a6aade82b608752ca1d767177fdc1194785883db643ffe8e48ab702c5278a2429a8e06a0932e52c9b3a9dd57a 1 0 \\x000000010000000000800003e98b52587cfb767a352d12ac712ab833f4d0b6d3022dd6f219bc5fdecba8c54570f48b3319ca44f17dc0177486f42665ec41a11e71644b01ec1e3a621eeca66fc62f8b2b77d75f7eb597cb53207582cf31f6f289501647f6500cc288da2da319d8f46f42ab02b2fa5fb313177e777616d64d712d34f38c6ffc2e1c7aa2c65b69010001 \\xa4cca97b4b1bcbf723a6352ab002c75e60f07068510a3bc8c1848a86225ac315fdd5747bd95f4764c4fa3a1b79b90a562fcafac054793ee669dad90b429b1e01 1687454475000000 1688059275000000 1751131275000000 1845739275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-158 \\x78a130d1d6cd2fe2fc29491d9051ef6b1a688767c059c77205308f6db9267255498620ac67f2b265f2d1b57ed1a26e8367c8492afc561b1fd3183cef5d91525b 1 0 \\x000000010000000000800003ba4d9febcaec7ae6e6df8db67430df9ac38c5f92bcda4eae422bd34dca308fdd1faa4592d50cfc722025534879121b113ec16dedd8e5c8400c5814c6497ba528eedacd0f7a8afeea5dbbe5646eceb969c92bd30a5d4a98e735b6bf22760d153de4ee1d276d0a51a33468dd2d8ef1a76ef49b38780d2e9aae73ec5de4c51c442f010001 \\x4428cc66aa01751a5cc384181cf94b63f9a7a2e3d8a59f741e735493e01d0e1525ffc2fa9647c90f1b5b4e9701ef9fb31ce038435b3271826333f37b00ef9a0f 1679595975000000 1680200775000000 1743272775000000 1837880775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-159 \\x7865b6f4e3d6c25c15daf2c860d9cdc6ee3808e5b2531c961fcf19d4d2a19c433f059c4c5eae408afd271e21dfdd77a996aa2c321eb5369198b20f6c6ce39de0 1 0 \\x000000010000000000800003df4beb99d8bc0d8fe0a8f4e7b25580ca9cb6a00971cb5b8401575e803778dffd9d458c71f896936f941d3b1853cf809536bb196e9025f396c9ffd3b6ec5865f961f8ba7f1f15d52557ca5972a23b0e4fd024ba0378bfba72fe36c74d69ed51b385cac7f633ae8c213d03879e81aa2d339db5c2979ff96bc7b8508183a4179e07010001 \\xaac2628ce746451c91bacf4fb5dfb468d2432eb8f32173d71470054f2f416e6db3f306b65a906c4bf50d94fa0018f908796b7f3cf0c9940e70039b009c02b200 1661460975000000 1662065775000000 1725137775000000 1819745775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-160 \\x7c51c1ff54619e224703de0dc6e98881844242a1af8ea4c69820280ec6b988fc4620acfa0f7ab8c5f670e388ebb2e7b98f7690cf46a72fc98c042e303b90afb2 1 0 \\x000000010000000000800003d84f86be0f6f1fda709263aed1dd75a669e50076c1622ed5d95af72f66f4fd27a4e9ebb02b199a255d7db83a3f84a931daba1f6c7053ad6f17e641cb90c571800c1cb3f2f279a8e8d27638f33819b88c293b0ec57533587cede8fa12cd05226992ef19beeb694a1e2cb217351c0311a63255d4360608ae96954aaadb3e4ca597010001 \\xbae2bb16807cbdd1b83c1e886410ca4d73361239124e1dd3c7a97e48f5ef1b147702ac6ba5eb2ba094d2d71f326344903468a3fee9af3c045f264ac14fba8504 1684431975000000 1685036775000000 1748108775000000 1842716775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-161 \\x7cfdc2e85304e189b85b891deac40916e47e2815dc615892b1b788ec433cb92af831123d152146a95c3bde5671253a96091f075890f0f9cd3cb331445b739435 1 0 \\x000000010000000000800003ca8a2e3262f5aac326107bdae4ed849b6cdf4339aec58b2588db54b3ce2d134992858a791e0e15ef17e2477ee0cb5a59f24aeeac0194b4bbcb6544cfafa9d998b4c5fc33fa8521ea957c44709149ca891c2e9c686b008431dcc8eeafe57c8f1ddd38b4fc55ff0191463be659b4eb93acf6eaf6ef4965bb3c316d35a08293ff99010001 \\x92180cea1a63ed79c40f680cad4a552ea9f25821bc7cdb92640263f7a5303fbd8383c0d15c39eba938940df132a9aee921564b3541d867eb0451d42ae239760e 1677177975000000 1677782775000000 1740854775000000 1835462775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-162 \\x7fa12a45cbf687fe58fc6a159c960f69167a55dae774a71fb46b51f5f05030946ac601cb5bbc9689f4b27dce332436c4e7081c2b534100d6ca3320353b629e9c 1 0 \\x000000010000000000800003ea2f19fe46d775a9b401fe80f427ed3a97578d8e931024a9d2775d3566c19f0c903373ea0a4ef1a0d8280589c2ca4be7939c27ec47cd423860974054b6ceab04c6edc51b001b6f965b335401b695a8f6607611740d84bf15b3e8b986ccac308d862d670aa4bbf07083c2d0a3cf31ba6b2c4e7e23723eaa86b441855367d82635010001 \\x00a3f2c5b7431ec32bf0df490d824a3916d464e51f5b637226f69c14abda099c633808db1e9473a15684853362e5ac00360abde6e3f6b623cc5112d1fe51d705 1685036475000000 1685641275000000 1748713275000000 1843321275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-163 \\x81e199c30822bd59f73a5c7df2893fd6ccaa416864653cbedca1a031208bb4358cdebc69db4bf44f56709140b260ec16d062d6ea458273d3e8702c57b74a8150 1 0 \\x000000010000000000800003aef4ceed4f38052a7a7c03d7e10a9f10f1fb4a940f05712c1ae40372637c5708071b51bc3c207c954bb2bf0a4eda8e26303950c963312ac565e48394c86bebab343ecd0ae345425dc5d147fe5136f34a5a25240e9acd9bfe338b4e0330e5b9497f4ef00d96e0f3c1598cf579323cecf331ed6e0896580098ec9e226e9bcfa731010001 \\x8670e7d31229f186b4ce3db604fae10978418d5891ec7902539244cb717208cfaf1865fdc5d152ce6b6f57006582d250262d663fba49f9239c5ba92795303004 1672341975000000 1672946775000000 1736018775000000 1830626775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-164 \\x81e90ff6cf7f9ba72ca5d44804073834d4f1bc897f1bb9e7723b188d1127888786b8e74121a93e5ce1608ffebe539100132fd881524a5312c2483d40f56b39af 1 0 \\x000000010000000000800003b84d98a011171dd37eeaf28048623a782e88ad921cd39795f791d30b2c4e822f905f347eb3d142d3b44bbb77e994cad03cdbc7bba68a2178c8ff83053555fb87fe166b0458f0bc7eaba7747b22a02ac961271e8c45455c381ced3acee9814e95798b06ae04803b3b5357a856b2374fca65f674e4d4cb2c7b15812dd410d11335010001 \\x4290ad20d40cef20ff3a5a4031d2241ecfcfbc275ddce478c7f3ac428ee4517761cf29a1569f278d3c8ecec97482e308fc4b45cd80293b2efba899087760b605 1684431975000000 1685036775000000 1748108775000000 1842716775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-165 \\x83f538344ade57089f7aee31be19165aeb5a0cf26af7a83256f5ed75e539ae70402203a38f71a195a1424e7a577ceb4ec5e4e1b132e0992a3d66252c4582c66c 1 0 \\x000000010000000000800003b02124c51fcc5a9673e1999c24300cbdf2f56760b81811c1a3f6b2fa6ed38d4e5c6ff795f0d5f9e1011f1471592959c3bdfb6739af91bc48fdce93d27920523f023d9a7ebf92aad26e2c83464d5887afdb7e913a5515483acf04d16f96821938fe789d45c46835fcef7e3e1f194f3f2eb774abc13cca1b04030d2388b13023dd010001 \\xedf251d1563b997eff1ddda8c19d340b3e9755d84df733f2f4e3021dc4bdc0468629a48e13702c64d817d9303f970a30c1308c289e3b03b4794322227eb5560d 1660856475000000 1661461275000000 1724533275000000 1819141275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-166 \\x8519d31a4b903465fe60e55cb1ad8c34ed8c4b7ca96851084f7d50a9acdb91d22b5cda380f62b14931d7eb6986e10bc8c7f0b01c8c1b4d892a76d5209618ec14 1 0 \\x000000010000000000800003cef1a2ebf7cf996f7d11b08a3aab478a3f42230f3e3e1015a58cba09b8848cb9f17ae2465464eec1d7f4cdf81d9b6afb9ce01837857b847ecd0a03f691a5c7732271093cc4b36b734fa0ae64468ca7d9088943143fbc22800f2413df7ed28c862924cc77f07f01f2c3e70f9d15714b4bddcf9b3f7aac169dd6b4e37e0d6630f9010001 \\x6bfeecde7d94f71511fca565cde985fc278a20752d6b99558fd64e5cb08f441e2ace6c66c558c4a39d43c5609fafa32baf49b66f09f43687af3df987121e9e03 1666901475000000 1667506275000000 1730578275000000 1825186275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-167 \\x89ad27664e7e37bd684345c88132227d5e65fa2a3eb250f365cb7f0e87f5f899ad8b44c0a8f9cfe1e16b67818056b2e1e750debd0e3f08e7927856251bc4a6cb 1 0 \\x000000010000000000800003b91c83784470ed39a2a4dee323a2e496b60455c92643b757c89c65907696780de992ed62cbe961e5a70215b773a4e1d7e692a7667d6594fc282f3469b74e84f98d1cf402178a0a43b40608ae905e405c5ed220da89dd22be7d9ef55d4211e4c93b2b186985f3ff11b84ee6f01ca890be5a0c1ff88b30ab6f5360ef0ac95cbd87010001 \\x03863cb6bd5ef48433efcc3ada04724342c2b0b416d484612cc71f1663655c3c4c842f1b1ec5a026c3f809d01f34d5282eea7c3440bb8abe887eb5d31a702b01 1682618475000000 1683223275000000 1746295275000000 1840903275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-168 \\x8acdafb48b777ad40f18d29f334a9d2c349bc5dcd991ef88cc79b82b822597a87b28f4c26a321ed4898a569c91e75a708aa71315d0d011d615a546b5b7c897e5 1 0 \\x000000010000000000800003b5be70a39c3fcdc3d58eb8ea0e0b84b336d1610c402c08f5197d11bce9aa1513a609cba7fa196d0674ace4dc1736fe2ff98d1321e2689128103841e8ad7c80e112a533152908dc58c824361c3970a2f9407d3b96dcf61c9d90d17c94d90f700f09e337810ba4f5ed79a0b68f6dd97b0ed15269b76f724bb5ab32b7ac1be4e381010001 \\xe462189147aa7cddcc02b83fddb98e23b2aeb4ee4d1e12d977ce68bc6958f8f747bad28d2205f8eb0a11fdedae1737f69ac4ffd151bb29aae83133833af4160b 1669923975000000 1670528775000000 1733600775000000 1828208775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-169 \\x8c4101f7a0ed8dc13505c91cd30fb766da1c5e2a9eaacd9313e0a90e5d0c6812e2c4815d484cfca298b191846875db7e7418a6499c0e0b3e21f0275e992d7e89 1 0 \\x000000010000000000800003e0c7cb6980faa009cc588c2a934003174845501dff7e5d1a8536788df530815afb4119de93efda5c004cda8b70b294b9e53db1faeb7f65d2b975cdf94c6a3878996105e1ffbe043bc18d22b6914f01e84efc2ca62a1edf4ae95c5816e374d6e63d2e0947e665d07e8b3aa54793ba8a5debdbd818fd88e1fc873e948d225ddfcf010001 \\xba8deb80d023a8cd3e0d6a553fff0c5367953ccba522bc90677e4a67be84714434321877571ee40b5995546dfa58702d09378ed46133c42f00559bf92f18c600 1669319475000000 1669924275000000 1732996275000000 1827604275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-170 \\x8c05d6a28f488cc247507f8a8779fac5ea8a35a880b96d024c2a46dd498abe53fda6d6e377d85459c1efb1f63d0f1699d299e8c0517ce9299a2404bcc1b973e5 1 0 \\x000000010000000000800003b4bb9cedc5bac807e4825fac5300463b4febd868177bf0983d1fa518a74f9ca0a580dc74d067eabb874b9f14d429a8938e03b7fca7a1a0c0e72d761311b667a0255e7bcbe7cb67843f1972560ceee074cf356dd085c9a2a056240e64f969f61dffe43f055454985ac96084985c8f002eaf250f3b906983e17cbfe61c2e948913010001 \\xf0e67651956d0b75c45c81ca3c3e4afd639e0d07cdc65fc5456e506992b37b4338c69c83b3175fba3a790e99b4b7c6179bdffeb8a36e7e9740609750e5bff208 1666296975000000 1666901775000000 1729973775000000 1824581775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-171 \\x8f111189e050f33a8b821a6993c337fc05c5006b0a65f7c63e688e3870183d07dd65b802ccabb15316f211f0ecc525a9ed3e9255038e7950bc3b786354a6e957 1 0 \\x000000010000000000800003cb9bccaf59c95158d6da0d801cbc76c637a02ca70fe7fb05db9f5872081319773cf0473b5cabb81bd87e03a6ef40ae2066d7bd7654aa7bf615229a90457fe52002684b42aa585ca34f1f69eca33e1338469f57a840793ec2cc30eed77b59ecf8a6a83c7ec696a41844545d08c16fe69d7e1c2dee52ae81d9fc471d438d2ad1ef010001 \\xef9974005b0f99dd62711946e70c16be8e8987303fe9a8fd7c7b8696b6e16ee3fd1d9ed112c5e2965a4518a85d52552dcd50e2eeefd7fd3609ab34ea67dcfd0a 1691081475000000 1691686275000000 1754758275000000 1849366275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-172 \\x90a9a527fa42463d69fb746ab90a48ba5e589a6a429494b4da4d731720394898f2c7eebf8a2fcc42dfe916d3eedd6c4e82178bb7b0a987277ec9f91953ca0040 1 0 \\x000000010000000000800003b796c500fcf1ce28943c4b3335b48f871e6b6412ca254b99a1386813a2663637f979897de22809041898f77871ca90ef8fee38a99b0b434555fd6fe00a8bd76cabca62798730f21eafdc62a8e32d04df935a7f68517567cca026db04ff8ccdf7f62ca8598b2aa2347296f972bd92f38875c86b5ec9a44e3575658ec97d8b3235010001 \\x2fd11f6917ec3979274dfeef87e9590d324d532ee62cb49aaa7199e845d829c359c0f1759ce21abc08cf8c89e7621e60facaf86b77ab0a00da505f6e95f52403 1672341975000000 1672946775000000 1736018775000000 1830626775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-173 \\x937d8cf375deecf3e86bd78f4e04d3ff29caa306b133e25cd634d92303484eac80a7a29a259dc4267730b82196768270d5d6e0fb7348cd64a1c2fed577078ff0 1 0 \\x000000010000000000800003e417b17e7a4b85dcbcd8850c7a75cad916c1624c0524202262772f4a21c3043e9c01e7558941c954053c27675ff5ab95b26bdcb6a469366aad006bd52814271d0dcb78d1e32e90ddcbf0e85e5289d31671a945c103cdb6f497f5c515322db125c488ae69cbc6508f54f5de039860e879f3bd4447b200f4a0a029fa9088ebc80b010001 \\x6620525c0f2c9ff4d36ffc2ac473aa5cdeddd215b836791cdffe44852007cff7451c2b2312e161fc74efc55f7b3a51f5bb45920c004ec58d4efaa59d78e4ba00 1677782475000000 1678387275000000 1741459275000000 1836067275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-174 \\x96cd5133e8ecebd11c4ae2e0119e29640f2897f8b69e20c33ca6815faa360eeedf2bbeb239cad025562430f5811fa987b3077860cd447cb4364abaff1515122d 1 0 \\x000000010000000000800003de2df94a03ff851da4dded401480fc5e42bb9be794ecb739bf350981a9ccc6c355b0c38323a7336dd6cad6d8c310b3f430eb92e99a136c77fab75821def07d6894ef970475a326d45e176eb36855d21c637d48f1e2a78cf8f9dfe6fb59bc5809a370a927e640595d81981b219009974b47afb21ee68e0090595cdd246022dda7010001 \\x3cf7d421c48d7187a87b33c00692b877e7e151224742562c8fb4a0133107bf9f7cdc5989b9809234dae921ff554a8d529e424cacf7c44a36f652c776b7a61404 1662669975000000 1663274775000000 1726346775000000 1820954775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-175 \\x9919122be2d6965c411bc7db2a3ea09ea6583c5f11c61aefdc811cac7ffac2b9e3125da6a89809b651935edcdbb834425ccec0f80caacb25e9b0803965a8d139 1 0 \\x000000010000000000800003a6a3006f149cb39628d16f812cd82d64d282afefe769d5f081f9f24cc3da4d30040d0691812cc7cb7553c7cbf8d30a00b444921bf61e17cac4297043ba63bb41ba1e77cd0f36c00911968042ddc67de67f26661641aef9f6bba5707677089eeccd4464c18a895fa792754d139baea4604b03fd949d25f074259a4b4e285544cd010001 \\x435b68cd6485ec0640b146bd92fef5b296834316d2ba602e1a8fed93cd276d09713e2c9f29a6ace01fb18ec263921d354d3abb75de1989dd5004c76241af2f0c 1686245475000000 1686850275000000 1749922275000000 1844530275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-176 \\x9a0d47c238b82ce4985bd32e31bbe70c8b35d009b6fb2c7fc6a8e4fa2805d15a59b8530ed2326e4ee7756feb4d9d0ecf2918549c07886e23e5e3890273c16d19 1 0 \\x000000010000000000800003a794d512df1f0cde5ca0c9fb73e318dd02a4d8ed7898a011d2ecca19c801401174a9249cd3a81958874806c9c906aec838e307868ac13ae5e85d0223f166594f1b1057a6da42b92f7a310e747eb0f076189dbe2907bfc29a183bca36c8a11ea9babadc66b3e2f23b11a96137753b3798b48313111821260ed69347dd0ecbf535010001 \\x9c6b714c73989490966b3b2d47613d1e4624e1f50ba4706275188dcaf280a80f703d5e8648af73519fcbf373e00e8b736b4bb3762773031890a5af033af0fe08 1680804975000000 1681409775000000 1744481775000000 1839089775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-177 \\x9bb5e389c1815d3ce96c7c3145e35ea88b31ab1f2acb850c79fac133dd5e34fbdaedc3feb327ad68aa0a76cd82b0749bdeeed78335445d4f534a57418f452066 1 0 \\x000000010000000000800003eeb43e1b31081f7bdbe7fde72af4ecd0e2f85b5da1abefe1e1fec53d5e7aff2d59478693e20de048f38f24d16cf1d2a5aaa8802e1a5a7935ffe97ea315d62cb9e93fa21596010e1f660fdff137e688024736ea2f73d08092c4add4c82f06fc93cfce88c060374eac7e5e2e6168209d06a8f2034eb864db6527ce877335f5b573010001 \\x4acd0ced2a3e1be507bfcaac4f7ba83c41b5a0e007e87d639e05d6627aa98f8294e780987aef9dd9661e0cef7a485b95495081d9851cec3ae743eee64425840d 1671132975000000 1671737775000000 1734809775000000 1829417775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-178 \\xa0dd83b994a60934bb9ee448601a81b34ee0b47d5cab4d35b285d5421cb58b7bcc7d43762ffbfa12dd6ce0d013ab6266c32b81440bf1fe5812b2b57a6b6f7de7 1 0 \\x00000001000000000080000397f19e6286040e0ba5ea2c16848e843ef655546e7b4efc0f78a6a640568212caaa66b33abda0f6fdf9f1474934a37c6af9522927eaeb3ce7c205487c4345235ee7beeb92ea37298aa9a1a9b1a9ae89bf1473374d0638eb2c5f8197b41597e359efbd82477a0d5747146ff8f57d4d0c0f9f6cbb16e5755e82b15f20aea12be2c3010001 \\x0f8e6d8eb3dc794a481b7f0e6485a1db3237ec39d496613043584d77f1298be802cccea2a49c274e736f8db9524501ef5483a75ff132d3ed9cc9572d6fa70205 1682013975000000 1682618775000000 1745690775000000 1840298775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-179 \\xa2cd6e39383b5020700d40350686dd054a6415e1c76c2e6010dc7ea130cbfa653a856689c1893cd7c7604c95e70bce2e5e2bc7a637410744142a61a9e9484e40 1 0 \\x000000010000000000800003e99cff4a63d19842fbca2d521da68d5b201bd51901b5c7804b3300dfeccd4d9831028b22d5c4be1fd949b5ea0a326aedf66ee59b42dd759ee0236ad63b733123a4ae5999abbc14b897e3f8774442b1457b43724346ba156261fa7d9d6cbe2fdd0fe82645c7a8f038bc47ff555bce0429a79bef9d01811735c7eb2b3c5602e54d010001 \\xd35139a34631b9d947752ada1f3b18ea687f24819dbb8995d8fd8c39728e6cad151e162eb602d6254a8b641a806d4d953a4b832a84482b69f403a5a64dd70e07 1676573475000000 1677178275000000 1740250275000000 1834858275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-180 \\xa449505166859713aff04ffed747368c2faa1d8240e048b5c7340f32af1fdca01160fbd32fd956f111d1b9cbbe69157f0304eb39c3055f8b44c0a9da4a8b1554 1 0 \\x000000010000000000800003cba52020435b21ab5b33f307b2caa1086a24bb3ae622af427963ab712bc1010f9f3cf15d4595296130d594dc21360c331c3c97e898db233d1e277e36bd90309ed9c40f13d5893a77ded464c9faaba57c4422dfaa2da5b3efae5ff76fab28f60c7383b369125755885ea701028584279b39435585231632a8f82824892921a7ef010001 \\xb6f2a9636deb9ff214539e5d11656cc1a1dafc6d049a598bfae37da56c5236d58b97487665a39773e77d466ceb70c473eae260432c87e27178186bc5c8fa3b03 1688663475000000 1689268275000000 1752340275000000 1846948275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-181 \\xa525d177af4a7c4293b96ae4b3d07cd54c38bcdf766550b6dd24aadaa5b680db825308f9604e5f6ed82f84ed37d9d019b20aec1e419ccb8943bdcc9ed45810f3 1 0 \\x000000010000000000800003bf54cedba7de0c77992ebb1a390bc639b894da11ded64803e695876da80550447501e1a5e14bb0ea138926beb6e5f9ac06c5468335aaa5a698abe9ffcafe62577fedb0d7bef76e6a5844e4c1685ca76d8abb280a2ec06afcb6b15b3a015f0450edda1a94d6a05d82ae74407b28152a4a2d978ff5d72eae41d827e2e70dc7e9e5010001 \\x7b88d79518b3f13de70a28fc1b07c1834eec1edbbf761f71adc7f664e3e27bed5c1128c186fa19c6c2bbdcd12c8afde71d51ce8b24074a16505baa9db9c73a0f 1675364475000000 1675969275000000 1739041275000000 1833649275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-182 \\xa6219a21ea5f507001cf3248e445bf4e68bfcfe741e60838e97729af18f5735740ee16095866c787b49de20cbaa4f5fcb4430653483341c3226ece48ad46adaf 1 0 \\x000000010000000000800003c27c7e88b238a47c6e13d67b4d25269b67295f7227a8b6c71bed616739ca18eaa7e107455eaefc79ca47eaa8f58ac420f707e485dff55fdf5a9667c2c496e2596dddb4479ebad3718b0fb7b14610c891ecb8a7744018c4e39585a7b020d6bce9a35e6474b37f352dc93e6149fa379d4e9b1b2ca103d5c1958a3ac136cd7d1ef7010001 \\x43b0620cb26ffc5ba9e1c6dcc24e6f4cb71bb690e9531967fa807a5d8c76537359eaf7777599603a28ccfa3394e32bf1d48accc72a26a7f5af58fc5deb9dbe0e 1683222975000000 1683827775000000 1746899775000000 1841507775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-183 \\xa7193e2dbe1ec7e1ffedc369819575a068ee9f6147bc2e1e9182d18ddc00db5c641ad360a6070600f6c1cefa714261c69d83253b8071afb5f3c963d7a56819ef 1 0 \\x000000010000000000800003a8d4cb8ba73d339ed754a509a9b42c0bf23562d8dec461b10128e2a5f4967aab6f92b93770d59802ee688a853eee6756fc4430097060562e25bfcab03d82c3188fd895c2f70e1170bf3289cee7112e933a92ded94776a9e75c8c2494085e450ba8080cb50ca97434ca7277bc134d3aeea256522462de798464b8d65461adfc53010001 \\x33e969be5d1f26bbda6df80f69a8004484a86e2167b9fa4ca1fe886c53b14361fb46fa68b4302554279b6a65e3c39c3fddd229f8fcda43c46b9c79feefc8ae05 1663878975000000 1664483775000000 1727555775000000 1822163775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-184 \\xa96573d428cc8a0919f296c9c1f5f56f87819657a3523fb6d3be893f41c8313ddbc39428faf207b7abe1e07ca6378eba1a1ddb6ea3af571acfe09f2dbf9455ad 1 0 \\x000000010000000000800003d1a35aa42f80e863befe442da3df5583b8cba216d7c3339d16c2846d7c8e6791940c878beaa904e6e43e56123a47d5824df5310c07793015c055fbabb7c894248f0ef21c05ea9d746b656d389bd3954018072a0a82e0df652f0daff2e9e0b5a85d7a7bb50d788850d772df37018c72ffcd3b8f16af174b5603bc76a3bf7f42eb010001 \\xd33c3f751b69fa4ea28d5bca8d502b4c2210d8c2a385745f9de86254e6d22a2e6f31ed0928cd633aa7422f36b25e865e04b4f9393f793506c6fe20f4e3c3570e 1663274475000000 1663879275000000 1726951275000000 1821559275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-185 \\xb0911e149315f045173e51d6203a68011904cb1f6e7ad35015901ddafedbbbaf1b7e23ab8e0fdf48dfac9d24ff691b3636827410cf64ce5606c2947f676d7dd5 1 0 \\x000000010000000000800003c6f18c0820fcb08f19f333fb5856b49e75df08db393cbb918d334912ac5ba2f6a7021cc092039041c49ce66dd910fcedea70007cf4afc1e342f19126ede65a166cc6f3de7fce831f41287482d9f2d85f46c3c9f556a01a00b2a58119247859ee5a422b7c7d3772e230e6048f7bd09db6267378232127613ba973a60300009a93010001 \\x5820758fa1273d532d41f2db5d3e4788558346eaec44843fa94757edbc11374a5bfbc291c12476285b89d01053c243dd81d33385d66ef4f91eb004a5bcbb1c0a 1663274475000000 1663879275000000 1726951275000000 1821559275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-186 \\xb19194421398855bb2665ef03001dd5ae8f66541d6851badf38b1469b269245965479f41da2e0f873aa065f97b9773942d8b1569543451c9b30d7a886ff24091 1 0 \\x000000010000000000800003a049cdd7ac580476fa5418aae154369c02127d281524786186a8746a8ac9351bf5803ba01603922408bf0b15ddc05bc945699b2694f2a55e4694b3d89521ed6237ecea03fb110629c8b4cae4fd8146a16778cff307b82ab6de3e459b89eeaee2cf8cbab9dad86eaabb4fd7f6183d88cde54441b459a27420765dee30173b70d5010001 \\x5c580fac840fb665c2859ba7ca99da45c3386e35e7007f0be2edaf6ad0333d8c9849314d1fd38d6653d4b7811afcfb37dd23e798bcab8d39f1fe9eaf55f26a07 1678991475000000 1679596275000000 1742668275000000 1837276275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-187 \\xb82953d9058def9307c32cdda219de7362b5d0cd1279ed9bf7d4c8a2312986365daae41bdf2090a9259f32c4808fad5ed1150e8ed38771436b5683b97b8cc737 1 0 \\x000000010000000000800003dfb652677ed347d2be813e9961fdd7ce5382b5229aee69925b81876a6e17c74fbd65c478c11d83984cbb5de1049d92671a51d193469871ed415a3e8d9473da7a8120a5905d8a65b19ce91f63f0e600637780dab304f72d80f88059a9d595417cd956d3c95e668a230b0610df0a43b89d6f3bcf39f19621a5dcbd6e21931067c7010001 \\x8f41abc741183b541fad0699164691a4c9c1c75c167756624106a8b60c72c5faaf8041db01b0759af9f2f892c21664fbb9e93820e9f6d8564dfeff34e6205908 1686245475000000 1686850275000000 1749922275000000 1844530275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-188 \\xb95d742c64d69486a7a1d1f1f690418deee27426ed1f97d4fc399eba3bd5019da1c3526b9deb7c27115cb6ab50dd285477cac27f8b18a4530c6af0630b102d69 1 0 \\x000000010000000000800003b2a74eb39afa89420cf6c59dc2ee4dfb9298474269964dd08937cb1f0e704ac0825e962c4b6f091eb6e30c4cae2b7d122fca2e336f588256430fffd27c6a704d20e816f67c680dfdfb78532a308d983b81956f99999575459d74da1a02ba1d5bcc86e9aa0182a0ffe108cc0989c01c92702367907608d83560fe52e46c7713c7010001 \\x3fa7ac199f8239de809a1ab1f66e38855d85b92c229d229a6fc7393023057d3eee5ab23a3348e32103d85d493cdf21cc81cc25cae39fcc5e8cae21d0ef3c630f 1691081475000000 1691686275000000 1754758275000000 1849366275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-189 \\xb9f973113d5f28dd0ce59116032816a3364b0101a3126efe09a973b476132609fa03c12dbd3b63adae5f8fbd4e882d4b1ca6b0b8f22876552588e8c1a57073f7 1 0 \\x000000010000000000800003beb42b6a6bb512416aaf2264e5098d58296eedb291e7e91974b8538c28efbf9914ea2ade020ab57777b6fda3eca172c73c177e9ec8ff4e9c55662580fe01014112edf2665dd854570f0361ec493ceac0e01229c5489206f728ef6de128d7872f02aae39baf2fe13850af8e0449c17eb9613d7368e4e19a5df01cf501ab67db5d010001 \\x120d0b383cb2ac5094df3f9d89d200e60037c4c4441523d8ee9fd479bbf3da2a739720d47f1f7b073c2791fa57a3f17fee3a719e3396efe62f6c04d90795e309 1682618475000000 1683223275000000 1746295275000000 1840903275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-190 \\xbde51e6bd9bf3d43eba8b19d57aa70abf313bd82ae26c9cc7dcc545d1def6870078000cd46ae87675db809d1fefd01e7903e7d1aec071b42cc0bd2fc361c0cf8 1 0 \\x000000010000000000800003d448640c85e5a3c486670093b9e876be7a47b5c3b9add1acb1f30a42d689fd8a393036f48fd6fa375eeb91c63d986a28a49724cfce773811c2eb9e5692e742ac5c4814067c66202e6158d2cde77ed696a3ba12916ffb9b3acc3edc6d0175345fcc01807346e37a77de21d7be521560e83426e41b7ef0a656320417c422eef115010001 \\x284283d5eda395101fbc2506e73fba8baf4aba384932e42a72e06b216a856b3eddf3421a7d74a6bb363259dadb97899a0991be6e6a26df1f24c7567c4d0fda02 1686849975000000 1687454775000000 1750526775000000 1845134775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-191 \\xbff9c8b9b00c8c0d4acc5a1abd3bace475eb5a859403d87e0d39ab2f0234fa27f7c6f4a52192048fe2e6a4fc992b2a8da85e0cf805860731a385729bfdb08d5c 1 0 \\x000000010000000000800003c8d5f84a161ce988e98807b2bf5a604a54d108b5a0c572cfebeadbc7435f81cc285677a7dca852ec9b7b3f0b82d2a0806194b20e856050eebf3efad3bff98152308f0cac77ec3e92397a63afdb15f8395e58ecf53239fff387b530532b9fbbdde08f5e7d2828ddf1ecab57573c8762a797fb9663319f9185538a1036a730a459010001 \\x324640fc0fdf50498492d8e9b743b9861485014ee4bb9af26a4ce50858a0d6e6da8eb9ee131865cf5cc24c2b0f0140d077d3fbe896b1c16240051c48f3080b00 1660251975000000 1660856775000000 1723928775000000 1818536775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-192 \\xc285a2222805b9cf44a832f155284c6892410a0e0fada87fe3752920efa83c0f29ab4ddece6a15920b6f5249f501b8f9765e8df2b4aa1bfd0ffce0156f1bce94 1 0 \\x000000010000000000800003bd6f01f9b70c71e759a857be3cd5793bcd6296b7c9fc67200e48843f49e336f6994fff9735cae962e5179dfa402ac012df0fcbe42dd7e3671043bc3d9a705010068cf46e8bac0f94622f5f200b831f906bb37aae10ab922dbc19543103d92878869888f38efbd2c535321cee05a9120cceb7201c7fcbd5b9be37083bc35816cb010001 \\x3f0c17b3e528d795f85f15acca06d469ded053c90e9038481161cc9f551dacf1b32e98fcf926ef1feb5d9cdc0fd1a5cc0b746abe9faad03b4345e90ca86ffa0b 1674759975000000 1675364775000000 1738436775000000 1833044775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-193 \\xc8edb3da9fca0606a5dff1c594aa2b68c04050e935b64ab18f66da1f33fc67bd5c8fdeb0ce930a0af17ef229be1f65740c1f2c70dc00c292023337c8af605a59 1 0 \\x0000000100000000008000039e8dd6c5e10ac24523495f15062eb81d370cad8900dc95bde065c3c7c9cc5c513a7c4af1941561de2ce86f8f82a90cc8d5f3cab30dce9cfdb6dcf0c5f80eb3addc456b6943023f54b17a4db004c4838ddcfda66fdeb1caa27ffea3b0f5199dec24daf63aef5109e743d9c2f459cc9316666161c0a50470e13586694dfc12260f010001 \\x85d9009306c17e859311f42b2c1741e4511231d2d0b305ca247b064472534ca37204705db993b94f6b153adb4597bc99a7875963081c70bf3dacf57aeb883506 1660856475000000 1661461275000000 1724533275000000 1819141275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-194 \\xcc49c2c4b3dcbaf98f9e4b9193438668dcc7f8f2e539d8fd8770ef097847695571cef10311676a0a9db58efec632cde528ac777908f070a77e369935355c8d0f 1 0 \\x000000010000000000800003b837c29ea16725011c0b11eafc35a240d9ebd4b8236300250b138f417a2368200d187fb0f746d78dc6fad7520e2c421b26e2860ef0564b1f01db1b1aa6678356d8a2c64ebaccf700e6e401d7538ddd1ba957fe127cfa463cbd03212c27e612b3636986922a95adfe825b1aa7ec4fec463e9b8f8f3f48d80e3626919359e4654f010001 \\x05ef7cd1d14c37d85517d7f4ccc10f51c7510b44445501ba8a0ee8d49f32c7f5c9696d336299a70ab3cd6231080c1b9b13689cf0808972bc7efff6eb873c4106 1691081475000000 1691686275000000 1754758275000000 1849366275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-195 \\xce0554e1bc8bbf1a3516bfdbacfdcbbb7923bcbb2db6178e5344d3bc45e20b6156473a06dae0d7fa3606c17ba812f833490e8ac6eedb24edb62946600912f627 1 0 \\x000000010000000000800003c5200630546fd1b13e6bac17fa4ba1a0e7e51312bb03ff74244962ea0ff0e5d63cb7a2b6fbfc55ee32a2b2bd75020711a46e4ff2e6e3c984d1a26c7a4273b62fab13c004ab3ad47ceb41951ec14f9bcf8db7d65841c29b35137bff69dd833ac2f95a7abdcf62ef73bc257e7217c76517de6ce4ca4b9f2b1331063ff54c207b59010001 \\x98d32ddbfa9aef99d5c83d85fd953845a6983d2204e98ff9584ef7182fe9ecbac0887454f725d9f91419007fd10d4f5a66a3e21e5be76e68fd36ce4b6e7bda07 1678991475000000 1679596275000000 1742668275000000 1837276275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-196 \\xcf6d74e701f1dc2268c9d17cc7a1e0865634bc8fb75c935cf284e82d6e10f7b305f9c4461f674f3795e754c43b2a74f8749964e280899408fd3c3bfa0943c033 1 0 \\x000000010000000000800003e7e75c6a2298010624eeb2e703a0d0f4fbcf41b13a0aed6dffa83e08ac805622523ae91f4af4a5e90dd672874fdd4bbf00a7cec1d940ea0ea74dcef0d2cb598669f60252479ee1752490ba14c682e72d27d263fa5780a4cfcee40de9b368958c171640c56eb3350bbb9258ae7d178319c6a98a5b12e0df2ab6a370782a4c1b19010001 \\x0ecbd3e9cd2a732047ae2572168752beb6cddb6005269691ab57173ee31142892a6469cddae45e643d6bac0c5fe4c048d4880f5a7e8f6cdf7ac09285d680ea08 1687454475000000 1688059275000000 1751131275000000 1845739275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-197 \\xd1f1d9db2594dbf7e7f78de19c3dd3812b4c73f3a0b9a211ecdaf99452bfbf95247c70311e475ed97fcbf204b6496c41a093dc044e3016b2208f56b896319b18 1 0 \\x000000010000000000800003b73e09b1bad7982b70a17b648d606a626554eaea8a82e6f1b14f93e5b18e78acdcba41d2cefafd36c797d29877d3781010eeb1a5898be39fe03bd2b4952f2ded9bc0928756101528c1b987814636814ce030a548a76513f098565e6c8058f0d903080d9a35b1c80d725a85365d44b869e14d720359d5aff0628c6dc2a8eade89010001 \\x0743f865293515ff3fba9baa4f5346de0b92801d5c39d64378b98808aeaf9142ecea0f37e3bb9df687c956c3b0273095bfe935385cf7f8e418a9288211e3b008 1680804975000000 1681409775000000 1744481775000000 1839089775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-198 \\xd3edf635b5f67cf29aa317ebb3e142e8b4c6e4fd2bf05088951a21f81694e81603cb0c06a8bea1a7948bb1ecc522fcc99d10d3c702f7decff89280f1b543134b 1 0 \\x000000010000000000800003ea0f9a5dc56178d2b054ef1d022c1c23fb5dcca830cab528d42e0cc34f593db167024d8b4100ae60588c9158dddaa171b94a3676b897314088018b99350dfd00c9dcd41074e38658cbc797d568b23475c54fdabeb1be4b9e24a017660b9d900d4772c460490f9f768bb4929d51c7b083f5893f1ad571e47e9b609af5f999772b010001 \\xfefd8f8f8a8d810e0e9079caf91a253c4822fb9a6868cac8d17aa4965a5a40f845576d533f87975d4a2dd8be72c6cc491469410d49406296df855352b62c6908 1677177975000000 1677782775000000 1740854775000000 1835462775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-199 \\xd36180657f6d533fe163f2c7e34e5a5c986a4e78f17d9e677326f0afc198c64174a81b3be65818bcbf9576d0794971675eee25abd7736ea23dfa72d275f0b46b 1 0 \\x000000010000000000800003e3422bee3cb04afcd466e8f0c05eaac7ab6a6908ebca57655d0bedc9b1e6cf33fbb72ac0b10f00864f1a5bc25de438ed6bdf943b179b0c50c3a25f30893b4d72d5ae630f82c6598cc72be19bb8cd8b41d57433b538e870679d0ac53b1df12e6462d7c9b514c614a74b3489ff87e5cc536c66faad9d46733c8deece9fc18d5b15010001 \\x251ef5161a8113af6902600d17aac8771afac019c20ccafd35c45b449dfdd5307cb9bf590e1b1bcf56282a2abb37383f830df20021192a9dcff4d83827575102 1669923975000000 1670528775000000 1733600775000000 1828208775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-200 \\xd425ca94823a46be557ed79cecc57e9c6f386422f292dd3d46ceab5a52b32aa1074d516cb51113d7ab6164cf995186081a4d31ca8b997461a29be744069c86ae 1 0 \\x0000000100000000008000039d482a8d4e2564dcf75e88f15b2325385c52a48aa7f8ddbafb4a8bd71d1333c5ed3f662cb40ab58db46beaa2f8b37cc29aced808cf10310811ddc5ee602f77055ac8a6a73c85d91c0ba4b7b6e5e1ff66e51db5ddfd9c76b7d730127f5f3f6ca9fb1f0165c4028385ffbbfe7e577e3422a396b86b183c0b0805728b2b23118375010001 \\x4c8566fb5369ab39950d6cb3c076467972a248aeb764477472b106af3404faeabe61b2ae0616752eba63da37f760f2ae76e8eab580b513b4bb116df3f9f3d404 1665087975000000 1665692775000000 1728764775000000 1823372775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-201 \\xd529fd5002c25b9463df39942c783d4dcf4ab6b90a1cb4dd7b68c5b8ee41701e8bb6d4ebe2fba5d6a0bdc64820f026ea434eedea14d75ff04abcf33b7cab6cd6 1 0 \\x000000010000000000800003b7635733fbd9384f0f319ce87792c4c8efaf0cfb2507088b35c364ea3feaa925671e5051b162e300c184047235cf287c6c392980b25e096cd822a99af65bbd406608bc0a44d74a6bf6d1c2d199bba5ffb83e188107b0ae14db0e3ece62a657d03b2a81da52c1d13af63cad19c66ba69a93107d13c652e9fb5b074551563ff2af010001 \\x23c012c69f49031deecb8cbec2c1b3f6dbfedc389ac480b18dbe80719193d7fd4ee718ae262c2807f3725c88b54423a21b63e248c7931e410f5095a21a821308 1678991475000000 1679596275000000 1742668275000000 1837276275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-202 \\xd5dd933da98545585fe958b0fcf9a5e83403a977b3b22789ea28a3dd6d2d0a76d0e2899bfacb4b07427eea933ea7cd9cbb5075f44b79579952d68f9996332152 1 0 \\x000000010000000000800003af6f488c648d9eaca718128ed5799191543d9884bf20dc3b5218e3aa58b735b5c7de9fd50ce837bb8a7db3790b2840acbf4728f4fdf419369e36dab32e04379743f5665116814f3aa8df4c6c18b120b92fa89a60455c3106a6870da5ee9cda26c4f36e79c587ad7ffbee44d641ef790fe041535a058fad92c07b0e37acebddef010001 \\x8a45f03a8cb6446b71ba660acdc29870a2b10253639dd87bc6e6b5b8228044a4a3b697269b433543ce44e9a69d44ac8ace1f85470f0764a0acc7713fed449c0c 1672341975000000 1672946775000000 1736018775000000 1830626775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-203 \\xd65d3772f9dd8a03a8f01dd3b5fa2f0311a0e916f8aeec0e6bd55541dbe723b41d548c5b9f73e25366ea90e282a6ff4a5190d7715a0e87c576d035d8a9655c47 1 0 \\x000000010000000000800003c3ab89fb66f73cf7a8b14d868a0f97912294fce30a66628fe28fce0424aeb41c780f26fcf432be002972d5f223a3693def319a9f2e08f6a4bedcdcfb2d3db7fbabe561bfd23332f377b51fd62cb8080ed7a9a828da63d94fe8ad517b570f8ae331e2f75bdcce8ec331dafbc6c54bacb11c513d4b8e6bdcc08981769ef2151329010001 \\x9f430ea245bdeac3eb05dfae862986075aa76b016042783250038753def300eba3da1d807c85025639861f8d4fb49952947e989a672b8358471c191e9c8e1c00 1669923975000000 1670528775000000 1733600775000000 1828208775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-204 \\xda29ca9c458b4f8e79dd6972adea9fdd481f79cf7e6f9aaf8c94f7ea1a9e9a365a27f8fc274c26b366bae196caac979ec761827abb73476b05f8a5eed0c59ebf 1 0 \\x000000010000000000800003c227aa1f8f2e53963521994cf8de0746ea42e353513de261308b96ae698ecbceab6c362f5bfb5ecb478076c6a13cb09013e0f5d6a1190ab24dfb44187bba9469a28d372f15f84518cff9ebd471fa9c0c824be93e60e6935e9af12e68c2ecd0663fc1bf4d4640398ee87de4368da4b034c8ed357bafa8c26cb40b0bdbc73b64d1010001 \\xfaf37129cbc56d696a118560e66f5528a1f5acb2739d21606f9aecadb62f8759e01cc772a44bf8497f04dac877c76cff6e18f14882a31bf39e8729bf98ac0208 1691081475000000 1691686275000000 1754758275000000 1849366275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-205 \\xdbad77f4c5f59c608025e7faba6f5ccecb20860b19caa98a0e5fafd039eef26f9117cf533e73e65fcdca091dafe01727de32b1d542bedf1f80432bef2c9780ff 1 0 \\x000000010000000000800003b7a014c22fdfef4b1b62511e6f8f17c2f2f272b05963d3a72b39e5c3c4bcd4356540d8406110e1332ae6e99c3cfeaebc8efce5814d3bcce914070567ab40a0e982133edea31add6a196bc04fb41183b21432b4603aa50857885b5cba0c61b77e69f451b3f63d4bd2d34f4b4d18af613e1fc227a8badaa0a915cbc1e7357534e9010001 \\x835d00667bce24022032876a5f6bb0ed01d010cd2d3e06eedb3fdc2cd13b48cf7746e5ceb370f6d81022accea4fefe0458c68e0b3a2b7f22a52e03555b1f000e 1679595975000000 1680200775000000 1743272775000000 1837880775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-206 \\xdb61ac30d718a79c92074b96476568157a1b4c23bf52179f9b1a06afc639020a9a60d809738a382c2953b5f238dbc12bf4fa5b775d9d865a20015adc11ccbc0d 1 0 \\x000000010000000000800003bbb2950edca6d89b4a0eed89d3a5de6e77abe2d9e8e1c30b3382fdb279b6a76dd7ca8e5fb6937738f67a30ce38f285aacffba4cb7037280696a45b2890832feaaff6cbf2fd9c99b96a917478cf65b7473388937c78ece61f411adfdc852c1b24b779f54a41a219da4c5f7d0a07ca3d259cbd3f0426ea708a4ed484fd6bf808dd010001 \\xe9512b8c6dedb26f39321601b99aec5f2e628141d3ba98a430cd2ed36e0325b3eb0fd5879669bde9db2df94cecb96b2a37885c3d08f4265917ff8804df253a0b 1678386975000000 1678991775000000 1742063775000000 1836671775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-207 \\xdced92c625661c1f19a2a59ceb8fd3d74115c45068e55431391a53d1ad9a23added035454a15a213d52b9276a623c15b313445b9446bac36899203a21c4d6a2a 1 0 \\x000000010000000000800003cbf62fae5ca390ea2c5e36437ba07a7d233b65ed982305a358ce18d68755964d8d87740e54149a5633a9304baabee893ecde70adae6085c09f8b51b67d3e753a1c094fdbb91a435345c9ffb8fc98abd128ad4ab999c8892fb6c99e9fef529e9359a1b20208d53a2f6534b6ebeaf1cb1a6d1d853e7779175e24358eace559b5a5010001 \\x7a41bc8d3838e230a323c2c210062b414785b9e607036ef54a2072e34f5e342cbee7ca5194a05e2e1378b12e3006cf867ce412604a55a211c6350230214ab008 1672946475000000 1673551275000000 1736623275000000 1831231275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-208 \\xe205ce2659eeba06e49891faf14b8bfcc0915dd7d359a75d05fe4e944acec761a480ff34e9a9947ecff44b57fb1e02a4979337cff141aafae20c5e061426f03c 1 0 \\x000000010000000000800003c3e02d466ceb86986e0edb63f4e4e7626eae6bea6e2b44931b4c697e993697e1ab2dc3d1546091ca9b02fa31cc6049c8a8f11d544ca821025b7985d81acb67449a83e043f9da2482c9bc180c8234766d386e7da822a1c481319a86a53005913e6b82365e7dd197e4ed787a6cce250359a5698bd8bd6c953f261fd2c85f694e55010001 \\x33cdc6bced935f3f81d7d82428a2c1601cd02c67fa1ea2b3f950fed5cd0761614f67d364a1a550dacde46382d3b22b8080da3f1c6a09c1b21832f93dcc81700e 1689267975000000 1689872775000000 1752944775000000 1847552775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-209 \\xe231b6566d9df511574bd71e1a0fab7d91e3f8a7bed003c43b9df4dab335ea07375650f5ac3c50c792631df146ef14c8fdee62209f6c89085583bfac254c4159 1 0 \\x000000010000000000800003f77939a2c37c1b17f36c5ec20199859892021249659c39f3c81d0fdf9d7e7830dd57e83d6c14bdab441a0e349fd03ca4081c1f14642e18bae17aed7f6118ba877d9b11378d604eced24b4c28c630886d85f46b0031a3850f1671dbaf46f834010f8ad88836747986de9455592a4e8b44ef1b82667868cd9d23c15bfeaf773fdf010001 \\xc21056d3060144c60e7d177dd1c8d38008961867779d4a67c51edb32f6f722800231f4fd7ed5eb4f04f621ea264a13af899a24816bdd3f74dd93acae3062a805 1683827475000000 1684432275000000 1747504275000000 1842112275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-210 \\xe605bba963e355ae70a36b6fa8f200449be4f35cadf7418f90ad139460ba0e20e381d053de3d1c699f2807f3f0ff7375d7bd8654ad8bdc86554627f29da91bd3 1 0 \\x000000010000000000800003ca453c8d8fd235a66a5065afc979765d7e70f2782c09cfc0c287241f917cd81a5ec30f9070313c496bcefe6c5e16f719d38853aaad936e3986aab2eb4e66e24888dbfb886cff9cf4bc3e6ab770e077651f896330bad909c275ce2338f85605d9b1f176154b4b5b748fbc72d9cf2c1daa096f0b753da2f232149d00bf4b250d7d010001 \\xaf3a2d60b372ece17aa0f83614997afe1f8081cfcf543aa53cb5535d3c11b83da6788b41440cd6c3d64735bcfec0b7da5279d4eebc3411f245af7cdf8d028d00 1673550975000000 1674155775000000 1737227775000000 1831835775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-211 \\xe72da500b2f51a4f5b1f6dd720cc772e58bd5df3714874a0f699d3866ae751da5d6040a4c9bf3bcae886793af17f06c706c7356988bc1c7497c50a17dee38ec3 1 0 \\x000000010000000000800003c47b1f16c56bf34111caa02cf652a3e64d99768249dbdccc058e74d2642448973bc81b96b6c3b358c821088fb5174501b72d3ed7c9541fde1072a4e5413ced58e03a9bdc9371af4c1d031389477ef17631b69aebcae2fed46c8249e02306b9189e1a6c62f9a5c70ddb21da1976f90d3b06a944557edf284a809c0f1b0c8a4bdf010001 \\x73a39d62b6cae5ec97def25d88a567b2a5d388fbf83fd0dfef1806a812d6640ab1b0723f81edc6446c476b1c1330deff04424cea9297370c7c36a95c0c69fb01 1677782475000000 1678387275000000 1741459275000000 1836067275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-212 \\xe9b57422f08a042f45d756d09adcdd7fef9843799623903cf2d5d6e42f3de7aa2d1772ca7b044aa837647b04b8f4fd664f925a460689578d74a8a7604aadce62 1 0 \\x000000010000000000800003ec647710d4bdc7c22cbab4b6427b7242c322c039b48ba17ef17db1dd3924f5e612098cd4dfcb2baf6b37532ba337d64e5437a5b7290c12c81c4b0c173a28fc368539e97899b443025d9c728867dea25f6528bed97afbbd9670df33b4aebf0da9efacf0e1e8765e9f229221ca5f8fe1de486f26fdc65528920272b0037c8fb839010001 \\x2a83f53ad4290fe29d4c82e706bf611b6db522a8adb46cd16a5589ff7cb7d8df8ab9ca048faf6fcfab8bd6f0c7b29a6ef28607fc3d0bb0fb9f77aae010ddf205 1678386975000000 1678991775000000 1742063775000000 1836671775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-213 \\xe9019eeab6ab2bdc0a739e4db6e445f95aa3c1749f87bd00ff10447d763b252dff2f6626fe713b7d33301c4176ad8684f06be89eb2feca4c7825782504960631 1 0 \\x000000010000000000800003bedae7c1459f0159e1ceb9fca409b2366ddbeb80cbe16dab4466246084477f60c4a7243f2b3e4cf507851f3312f01e8d2515595562bbf7c350bb52d57f9aec9183934dd0c05811375deea231e35ade789927c625f577748845dfbc96dc127acd9509af40ee2d84510ab75349cd858653c8663c6b4b083cdb2111e6cb0b726b13010001 \\xee6efe2a362f2396ec73366fda0c82a4df9de277ee913c151c97162598ba7575067c95b53c9e46137a0d83ddbf3b85b4eb967f77b4c003242177d05d0cbf7d08 1691685975000000 1692290775000000 1755362775000000 1849970775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-214 \\xe92d0de47cf0ee74e582d74ec71d7bbb42e7f4e942daa12eab4532dbf96a356aa0ba56ab9a2afda86163070eec7d2817f017c742cc4e5f4b3cb363de2121991d 1 0 \\x000000010000000000800003ef23d7dce7706096d5b3fc287ac488f1f3e5c6ee047d7447b56a70ec29cfa9c73bdef287c31a2273bdeae8e8ee7c1b386f983f516a82543ec0be14c5dc7a76c8cff1a7c9c839ea803d001c9c22df6937cfb86e501c5f1417e1526886389e15265c0851546640f86f51048dee8acfb804045b4b1ee14986e1b2eaa1cb54569175010001 \\xe6efc44ec0021f56698ca1b028fb9a2b570bbf5ee5f6ae522bd4f9a32cb5ca8f22eeacc23ee6268c9d04446afcb1233d8ca87fabb9641930368b2322d23eea04 1686849975000000 1687454775000000 1750526775000000 1845134775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-215 \\xed81a0b5c66129212504ce6692fed3850f00f2d9d11f7bc77e1c98d0281b1488470678c92b1aa5418157cb263dcbb8148c0e6e013e6f39597bb86347700ee7ca 1 0 \\x000000010000000000800003b5cd5a1216b7a481214397f2a9e656b6e11a98df6f5ea80e6e74af76211c57e41f0b47aae8799f8b224a6d59f2398e7c67c0f86c0b328dfb3888efc9505781d6c59c68d147ce7aaf23d270ba65673b2f302e7ebfce517524cb9ee3a8fbe9b3c8fa5e9a9ae8f3db53416783fb3d21c4fa69db4b35d6c479f605dab0656d792a49010001 \\x9c1f9e08014c8080c22055aeef5bae8b1d38db069bd96971745d9b1b9b85dcb635a96be18165c2e00529750245d0ace6388d47929542568d2981a6e3b0337c03 1680804975000000 1681409775000000 1744481775000000 1839089775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-216 \\xed490291277f4f63c1948ad1cc5b1da351f6d6fa20f4acb8eca8932b3e73cd35856900ab3221b5c071d6c32ab34db0a51086158f3a29af9d1e9c19b322192dc4 1 0 \\x0000000100000000008000039a7621a3de84da6fec63741300157ed84f0368d2c244efb0eec20de231ce26783004008171aaa21273037d52095271c2257297c208d67447d56e36af24da36447f42221181af234cdd08a2869ab9ce77614f508f0f93220ab4a466470d697037561a8b9ef40edc0c47e1cada1c0dce3c8bf7cb81b8cdc56cc2b55448830f0d09010001 \\x3ccfa9fa660d6fd596cb78009890ff78727c0d3d9137410bd499fe1c19d7c853d3d2e48cd7234e1e6290809da1afaed1dd55394edd62a70c6b622663a02df301 1665692475000000 1666297275000000 1729369275000000 1823977275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-217 \\xee45aba5d0d531ed929c61b60a1f0a4cd8ac7b0ac1df741b95fc1765765eb317d47e48c5580385ba7cdbfaa5948fbefe1b443ed31d8d08a61a05d0b244315364 1 0 \\x000000010000000000800003d42db3d4a5484813cbc15508a3ab9147930fcdbc773ddddc784be029cc0692bce337a4a1b25752613c5ed6c2565860f2d12d235b6bdf923ec6bed5ab70ec3de03cde559a17af8a7155e29706420f48eabb8a4fc81210ea1746acbd4513ab6bac7b2947a800da2538d17c69d053464cbb0bf49e08c50e8c47a367fddce178df9f010001 \\xba2f9d01be84d83fe8e49b3f33bf9c7078d94058883f41214de766ac3c5ac8e47c209feb778cfad720cfdd7e3509078e7284fc91cdfaffb63b07cbe2b946e30b 1686849975000000 1687454775000000 1750526775000000 1845134775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-218 \\xef89413463ecb16fae8e9564c5e6860535215f4ee5f350064a08d33bb963b5a409b02ea76924eb5ac794e92e3eb9fe7695349588e234c73e017d1a23c43821cc 1 0 \\x000000010000000000800003c5645221829cbd6d39959c9b0aa06b7d30f939189e5cd7320db2550243a43fce102acdf9da39f458a39cde244cd5d65ce776cb9490f53153dd0ab3be0b759ece7d25a4e909947e262da727732c2cc875d16f4ef8f4626e72916111f26299066fe20fd09d575b3b9ba8199e5f1593d602f72b2b96a6442ec67546f093da5ba7c9010001 \\xf590a8265ef2baa333e42e0a62641cdb02449e532811cecbb348ef91efd7e2fa888ee0203d73e66b37aea10e42be444e3c0d9ba8f5ecae5436e5eaaa5044d90a 1687454475000000 1688059275000000 1751131275000000 1845739275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-219 \\xf1c5dc00539250a54d01e1d5d3162f7be8f5ba1c0229e2f8589e147e53fc367eb619f7f07daa893b00796e94fad83d88188c6eac2baed096f03a292de8dacef3 1 0 \\x000000010000000000800003a2b510a5756d7da2c191f26da534c3f0c1fa7dcdf03387bc59a73faeef51aa2e37f1003a3bdf560def333764c60dff1589860f0be5c76a944484b155cb083239c3fbd104fdd061436b8b20d393648a4c6556ab8b36c30ec1f6ce33a2fed243795d58a3536c5ef6013555a86ab6398bab06ae9c1d8d5d2173cc7740aef40d5d75010001 \\xcae34f0d1c7e47839ea37075722b1f2871d3936d113e43b449686548c978af8a2acac7386a721888fceecc9c67c0ae4430bc862c05ba6015200c576b552cf209 1665692475000000 1666297275000000 1729369275000000 1823977275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-220 \\xf275adfdf9cfd46a1ae853bf38f2ebd9fd90b0240aeb1ea8702e2f7d070858923648e66fc2bf51bf3fd0be42ffd0a92f432cf2141a6d5cff02adc9118cc7d919 1 0 \\x000000010000000000800003c57bfe8eb5016a818a95dd3600dcc366f9e21d78ce59bf3105c108577ee2d3e991028f70b02d6d2adc4a237694e961f9e57e4e4dafa3f0390ebecde665061b4819a4295c1ccf785402bb5936b7418a3b04f1c8f9f59c7389db01556f1563d9904e9d4d8d17c7231d1fccecd532ba864a0c16d6be32f5175b6987a8774b45df35010001 \\x8b158b7b131c00b4d1a8e233c7fb1ed4180c3e2d2ea7cbecb2e6ae3be1200398e406dba75901fa25e1787002c5aea17c78b7810448eaac97e7c2e276d5d3e70a 1688058975000000 1688663775000000 1751735775000000 1846343775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-221 \\xf3bdb4e2a5ceb352c3be09768ccccb22fa1fa74ebbf274d7a918273232191485d2ba4b8537cd53653bd8cac89b445c03ce349cc9344111a9611c9f214f79d78b 1 0 \\x000000010000000000800003e0b6b76e0114b7c228522f2183da6e26a813bce487bfd119e8691e0a0500a02f71008836751f865eeef0130f212eb6265718ee03575b3f856a0f5c80f6caf0d15dd3be6b90e61df5aacc630e5761c4c94127d25633ebf815181e7056c66dabec5d6f90cf4d5063d12c2fb73da1c984c3dc2b7ae766c2eb65de5139cda8b10f39010001 \\xa988f064764cf277329b98c5c1cb56c320f9501a7a6fc851e0d721a281ead879da9d069ed912728bbe1279a365bf1008c198aedeb21baef116d903fb92165b07 1663878975000000 1664483775000000 1727555775000000 1822163775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-222 \\xf545da086e6fb8e733221880fc7dcd8fc26ed953e598995097185fc512a98b3d601fe571927d78d6902ca14194b39485dc416937cead2f3ac8a03bf05f005702 1 0 \\x000000010000000000800003bbc97d7b7daab06c34bbfe698033b0c7583498b6fb37252e852996ccf6800abca89af80d5700c5bde54731088645c3aed07ec3dbca806f0d0cb08c13fdd4d94e705782bfe466fc805a76826a9522877ffbfac7369fd25c2700cc56e43fc551909e94b272f78f7156cb2f24b89925eef09bd68e5f3c85287f841467a575150e2b010001 \\xe6353c6d7e08e77f23cc7007a7447ccc4abbfd17894aa9c00fe60ddd9af99a58f73c74bcf8e5ba4aaab25060fc3bfa9358fb7248cf0aa7d50a8fb2d5fe120108 1686849975000000 1687454775000000 1750526775000000 1845134775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-223 \\xf74dc2e8b8264f703ba3b518b0acbc6b0f037fb7748898a62b4d1cee345b71b518d78953b5e20c2cdc44fe88724ee635748f0b1ac3df076df9d62895e1152f26 1 0 \\x000000010000000000800003c24978b21c8738e0e9ccd5870bfe19d6240d7ad83ac355ca2d8d9ba41bae721267bc0d74d51a1c973536b7c1e30b9c6cb7c680a0e0a136944fd191e3ec38062529692981bafa6e37299cfda65b3c6d87a7a942a90dac8e836fcc28bfd9140dfe77519ced2a32f555c5ef304e75edf83d9e5615151859aa694a7ced966dc8cc47010001 \\x5f087f4d029a340ef1512716fb3f600fe345a2ab2cfdc5c72df325f2b95451e08f5f1df8b786534fff9992fdc49134dc8fbf004440ddc28e1e586cca9e418c0e 1685640975000000 1686245775000000 1749317775000000 1843925775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-224 \\xfd9113ccff9fabe206d1971f8881eb8d84d2fb24213c9f7c156bc374fa42b106b4fff12c586e4f54e980a157ef815e44b6587f6fe62d4d068d96d906a4eafc9f 1 0 \\x000000010000000000800003ae6bf48d8a2fa405a7218181babaa4fc67c596cb7285b84854d5e50ce706cbeedc3b1348b1749b47b897f454f0cfd202fbcbb1c6957e73cee6acbbfc4317ca2879bc9c9eb07c12a37b0066759a0a5d542b00cefa07f7235854e00b7a38c67e762149a22bc70963c2c4f23ff948f0d23a1559c110c289328700532ee07d327c63010001 \\xe68d2344372a8137ceeaa55e5e454773fe790639ab475b97ac6f0c1b3a9b312ad66c38ef0ab7917857157b0d7fca76af3c531ea0004414a533b586d20cba380c 1691081475000000 1691686275000000 1754758275000000 1849366275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-225 \\x01e6540c89a6b820b6566e6e25228219241b87cff7f46707e594fcc2965a4f354aec2455aaf019b1dc8e96cbb8b5370d780ceb4b499215cce887c638d16f198c 1 0 \\x000000010000000000800003af2631cf9a9ea277cc5b58896580614de06cfd37561a2e75d791409c6c4f3713a0bd7be47a3ea743a6e214372b48477dbb82dc374066cdb41e2ac022431b0e060bcd780e0d5930bdb3c423fe0fd383f44c42622f0bbe7e76f200f88272971c155a3df1cec44741e3d7642e63631692174fa3f39404818ff5c5b6f55bb4ecd11d010001 \\x3527561787fba797cc65fb8ed64bdb7b9af020afd94b1a0a97d03b4522f7c7b625f712b07880b253c2d23fc9f74075582dcd7833071f9457260e823a7642ff05 1680804975000000 1681409775000000 1744481775000000 1839089775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-226 \\x0622f09c31dc2025280b91584c31af0804abd6d6f63b484a48e4d9c211803f29009c8eb9fc73c822078ec217839fb4b94cbea0e07856d60de00c1e28f903d365 1 0 \\x000000010000000000800003bf41e5155c1fa1ddcf9c260cf2223d42d8558f0a56947a48bb6b7f50ee35a93b15b749ff59ac4051bedff0b80fc843fd49316fddec58b0ef6b0cf6b66cd192d4164854b46c3f12e5bac17167c1068f4b749b63b4fe92abfd2aa21db776d42e0abac8a31e5641227b708bef839752879047545006d95faecf90ba1d9a40601d67010001 \\x7ab29aa66c4871674f5ff2846d485c21be6fec1ee1cafd2a4c85c3094d126ea0eae565f5b5b9cb9ce286a1d62a455238f6c2ce063107970d1a700ecc8489e00c 1673550975000000 1674155775000000 1737227775000000 1831835775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-227 \\x061e3858b536f183577cf1b0c88e56e21d54ea0072c772f0a27996b3793a3eac5784aba5568aab13d3f57396f76561ba44a2bd297ae005f317b06aa99521362f 1 0 \\x000000010000000000800003d6b7231db5e8f771a3a5e8b069c2f15102f4786f202d1db2b22451bb1b39741b2e41ce3e23b7ed4f5b2b3412dd7f14d6e048e24aeddd0141759e41621fe9c15df22dbff12b47199f0e28821441b601f4b5daf7c071fd220a2ae3cd1dc888f0284d6e403fe417c32d68d5c20d205d36c82575687f3afad9ce55fbe18c6e6238cf010001 \\x2ba4b3a6dd995fd82375d450d03b0ef33910346d62d4a646f5fb5ea91cc80b5c73d80388192bb657ba2c500138d73d4d5812dc0207f694233e079081c64d6b0f 1661460975000000 1662065775000000 1725137775000000 1819745775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-228 \\x087a574336c35fb1cd927316cc023117b559729cec02b64cbe9201c6da1b7db2e1b2186c77bcffcea2758303802e25aa81de417cd6595cbe020df2e7d4ec0fa4 1 0 \\x000000010000000000800003991e7599be5771137bc7b58e0dbb88617b339c17f29248e6dc3ae723aef0b947775723d5f2b8b46b19538af3d9e0b7b3556e89a69b5bb8f158e02fa475381fbae59cbd0671143ac8ea1ec732bbe868728fa1e6add5ce226f2df92b6cb2d7941ed2c1b2defa87e5428854e495b367af59f21a85052c7a3cf4f27874de07acb9a1010001 \\xaf9857e169894d90eae64d4d3432cfc0fd7cb4d7ffb86a21a304b4183399870e00a4410a47ba3146ba5f10333e05bac420205d953a0623ce7187e53bf03a4205 1670528475000000 1671133275000000 1734205275000000 1828813275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-229 \\x0f62d55a33d778539a491c21a6a371c8156d26c6df1a739248b8e0b6f54236953b4ce0156f7d6747b7ac77095264ae0f9e58f41f71d44870b7ea52e136fa7cc2 1 0 \\x000000010000000000800003a86d78eb92550df9ddd201e747faabc5e9c609dccdd73b9fb5b131240eb49d76505f5465bf05806de5f26755d0a812507aafcb44a5e840c453f02da3d287b0f6b5c75ea33a0f4ca68bfe9df18f02cbe6791fa4439f064a8f42ba733d6282c35020c19443fc243a141131f83db8b65e45bba24287e0f4a366705ecb37ad78f52b010001 \\x9b232a830dacf1dd074aa123efa65a741270dddd7018f2a0dbc60f4309e90588bd9cc706c6d88780278253e415d8efa7c1e51be9a68f82076e386baff64c4e03 1676573475000000 1677178275000000 1740250275000000 1834858275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-230 \\x101e97e0e36ac01f274587098d2cf9928e18d07d5b8c9020ab022f016cfcae7a9dd11bd8e4b1b36c5455e8640b91f114c70a7813b948194d939b8cc97e690765 1 0 \\x000000010000000000800003be46d66f9ab0531f552d94007e51579e2e24c84620addf6805860641c984b20f31b0cd7f26f99bbda9a494a7f0c1a73bd9b5a36bcaa1aed1961f00fa5fcca26da8fa062b95048118c6e163d3d478f21170f0092100078829c750c5a6ee85084a5658ea0f30fe295c485bc1f3d002a3993132fa59acea8d2faa7f69b6a42248e1010001 \\xe69131a12cff89ed87180ba815833e8056954de969d6f23594ba2bd9c127c3afa90a00644b8365eba83efa3db29317cc39eb28ecf4ec73f12d26951be6bd5b0e 1677782475000000 1678387275000000 1741459275000000 1836067275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-231 \\x107679a22c74be2f7b147858819bdac4b46a7f7b88807ea3753fabb1944812ef532d3060fee61256af5a2747ad74ed580b2e0ef0df53265aad61fd9f8c3626a0 1 0 \\x000000010000000000800003b0c5874369bdf4eedafcf023d24de0d4f8eb5350511131f62c47b5a8bb15c27e6896dfc705d1acfcf2371d0e0974a1e2dec840bac9fe498c4ec0e0d524495e46188be40981142ad25b03fdc739859ecc844a7d3d8fcaed94fde9929e8e0c86f1ad24b855176bf9724a054e0100f0ff291704b1b8355cfade3711365c1d209233010001 \\x989685f38aa221645b8767236d42b04c84676a823c9ab9f1e76e4fb3dc8ecdffaf16cc0c233e09442aaf21fc509aca330f3f687a83bdb4dc96b4964f8be90f05 1665087975000000 1665692775000000 1728764775000000 1823372775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-232 \\x11fe155da9459cdeab5a0a53b897dd2d3773463edb9802e42f7f2dd07b8d11d4a8747d9756b5a9202913595391eb32a7122e7e904544e8d83ef0f407ce883abe 1 0 \\x000000010000000000800003a804d3c02ebe6a7eb5ea60f92505edc8e4f3e1978631327625cc4c27c20edf631e973e4018b2000ce00b1901a39e14aafc5aee4bfcc4a459be1efcf94f4f67c410b3c6af430bc77c290c65fd2bf3066e8c9e52ebafc459478ac5f9bfe4479e1eb4e4546e8eae8d6e31aa0e86368d411a42cc74c5a9202f68ec20b76b519fbc59010001 \\x4db7a7123311f77c162a543b678d57a0d9ba064a4862a30cfc87bfaff532682137361fd63e269e6ff990186c9dc955c9138e59acc979a97075e425bff85c7503 1681409475000000 1682014275000000 1745086275000000 1839694275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-233 \\x1256782b5ef077e0b1ae3c76e17b1ed4fcfb32095e688f014d0f1f1e7250ecf8c56d22f9c4116e9cae40e8e0341c45db996fc97d351e91c48e2e6f93f7d0fc74 1 0 \\x000000010000000000800003e65bf52969a02c665a0ff86a4655098d1c601bbce97750bad082aad704bb9fd0e1a755f025418a88f78bf865e957bc8fff5526eeb197c99f56ad047a8932b085ecc5423a7c85c4d0eeede79e4d523cbca8e5d1a44489f73d5e44a54b7ed7723ae1a99c9629f4a1840162084ae6cdd73ea0796ab2943b6daf0d22e99c2eba619f010001 \\x344294244c77a45cf716c8a74c327fc14c2f3358c435897154dea5da02135f079ea29b5382e25be3f803f09c4c11f2af765b3b6dd464081a8f6fd642f146590a 1670528475000000 1671133275000000 1734205275000000 1828813275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-234 \\x14321558f79d2db56223884f787e827a77f4d998a2f81bbf5c7f38309c62f5435c21e30406da4ac608278ac53da9aa9d7900d4ab5dcd6ea37451e5621bf101e6 1 0 \\x000000010000000000800003db7793d260286cc70ac9f5927eef043477bc2fcf804e28b1943b564976c6b6c471fb1f64fdb77dffb3e2c7f9afe05c9dd131c54dd8432891523e4f57ed6f0ab8547bbaee68fa28780c42195635e3a329b18d3fcc1d1d6361178ba7443f336f8497c679d4c7a573478293f8c16ebcd62ac4fdbef0b49bff1e0a08ec9a35a9f3e3010001 \\x37003315c5f7909f12d91016d1f473a3fd2f95ff3fabbd12791e563f465e6ce7d4a8091656ff53d476a186e9dc1cd456124809bfd7841abcbee572ae00841c0c 1683222975000000 1683827775000000 1746899775000000 1841507775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-235 \\x149aa5d09bbfea8457c510f73d07b48dd6e00a9ad0476a21316863aaeba48cd555e2722d44dec1a92c4824f4b19b6659e140b9b3a0b59123d2244eff09fd2cc5 1 0 \\x000000010000000000800003d7409133b1aaa4d666ec686017042cbc4c6f52c096678ea544642cf8a180f4fa146e2418cae8f78f9e66a10fffe491b13df96b58f4f31b60877db8ef21047d39e9bbfa5b43f63cff330b112208dc48898984760e9771e183330d60cc45ce3ba69f97f26afaefbbb2d965e59865746c6fe46689d7714421c36307bddf67b880eb010001 \\xe4e0920a864c6b3ae1eec22ae84887d2df2783ee8d16b7b713f8730b4b7b2521990971ea36e19e6d7e2df62c58cc50157396ecce90a9bf53f213d08b4f0df80e 1678991475000000 1679596275000000 1742668275000000 1837276275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-236 \\x15d605964f7f48966d7724bf4c2d42aa339298f411eae73055cf9db71b993b9c6fbcf825e0343b0b648c3602c5649ce87bbfdf9b66cc86e283ce71aebf852da2 1 0 \\x000000010000000000800003bc8c2996599809bf21ab35c794fe84e1e9a7415460c04b6d640297977968d209f00935bedd02cb567747e1fd8b736ede1aea73b76ff0d47f54b345d6e63ed665078c590c4e62496fed779f03e364168e9cf2ed3e7c5a55556338c69845f864e5c33184f1aa25131caa97ae6490a8425bf7667156fe3cf474c60e5b953634b7b1010001 \\xf9cda76de2264ffc00be6e9401af77c33cce1e3fc2b9f618b3087119b70d7414ae6e5dcfd20581cc8a3bf3b557657aedbf6a9fbc4a132ab6c26240724c97680f 1687454475000000 1688059275000000 1751131275000000 1845739275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-237 \\x178a4745c0aa9e2e6a326816a47dc5fb5324e5011c09366e7e8fae575cd8fc8ea7e88c9aa0551b88e6c1bcbd71f9d72ccba0ac601c5eff988a8499eb3ec19553 1 0 \\x000000010000000000800003b0ea447f712cb221f6e5cea20c29b04f8b01afdf3b9e1ec888cfe1295448d215588022c385ee4a4be035e1318673385d319f027bb4956012416bfab45b2d88eda7209056e07b00314126cc64687f9cb69e9fe066301f0070c3c0758ddbb4f8fe150faa44f86565e8ddf537c1c056a494f7b39d31ed613707310694217b69c519010001 \\xfc4b18eab6aeb4661191223442627f2b5660a3ea37e1b56bc0d06812edbd20f8c70f58234e5793dbcd25e18831309806fd4fcbb0c078f6cfa02b1b047a47a10f 1668110475000000 1668715275000000 1731787275000000 1826395275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-238 \\x1a5a708182e2b3be3014466dd235c52e1a98efa6e9b75df20e6f3715f3483f034c25c41769f699b9c52f2b9a1f489137e4b7289cbf32a3db9669221b8acb6f82 1 0 \\x000000010000000000800003bc84058a18ea75e71a18e11fda69f840ad6b4d739a85eddab983eab82be29389b3d0a6a1f5a6949be0bf31bcdff77202e2e1212d3c9c65f5840795a1e1611eff3d0a5bfd08c7251379420d417ff7fc0a2bd90a3589e2f58d76b8eba76377fe9989a9dfc0018b7872a4c9264f1d4b77a40cff7054512fea234f1553b71d044b6b010001 \\x3745dec54aa0a7c718e0d1edf6a7f6a0cb9dc0a09a28f5866a3a9b57a3c65e3640c21f99e52c55cab8da869aaf6c8e8463038d3ad0c1fd3c72a47af8f59ec706 1677177975000000 1677782775000000 1740854775000000 1835462775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-239 \\x1c9a8615991a718785d785da0a3978561c5b2803d15f3fa6a3b2d70429b9f0eb76e72c28e8eb21a93cf26f323c8631653801e2ccab5736dbd1290e05c4dfdc7e 1 0 \\x000000010000000000800003a2e69436962a80ad61c7c7afef47ed45b385cf8224ea5562fb2e57945119d4b31606d115876fd950f09fb6cbdf72a376e2d03a20acaab94367b58513a9073f27174cec870f62a9d0a2fb64f3fd469be1342e41c560aeeced36d95e655573afb6f386b024a87384f035bbc0ce9489cb1e2f088d3db2618679fe16fee2380960f3010001 \\x915644179acc543dfb564ba94a9eda838d6cd96fb38747f90abced36fcef9b462c6e059ebf512ec9712f96054f5484accef9950b8000b93461cfc86236351c05 1688663475000000 1689268275000000 1752340275000000 1846948275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-240 \\x1cc2bb00e304e144b7d19015f2a6db6aa5eb504d7bc758702163c3451358544404e2917e40a241b62c5759e0ce6db44ce2854681aa11903bab6a5f8d52648669 1 0 \\x000000010000000000800003c2c31e8e46b0af5fcd174289615a28c46134dc080e846da58441972298eabc2f3fd3b13b1ccd8ec3e47d19c8deec07fbe77446c404787fde780472c1731b617e2e36e9d18145f5265e24ded446b96a4e83ff8375d0ba8263744edac6330728280629553e03837ffdac3aa2d4dab0eb3f0035ec6f9e07a9cac63f8c5f503c3b21010001 \\xa4bfca5fd0595eb6508d31d2704f4f2cb63a33e7780ed2764993fbc673ec50f46e5c5ab3769cd88ca990ab7b22c75c1c4347d042359fab92a72386714ccfcf03 1687454475000000 1688059275000000 1751131275000000 1845739275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-241 \\x23fea179f7c35f1a42024017090c241ed9fe77e90ff5f0396032cea4ee6cdfc1e1f5c6648fceb986ce2692bf7cc79b1465562ee19d17a32ef4ce6237129fbe68 1 0 \\x000000010000000000800003e435a95993678029c7fc6a734d680253bb1fda79bdfe34d18c2765cb1784ba6ca51e38ae26cbf0762a4f34c24365dc9429e08781f4c169b7c2b180d8dc47de2e8dd964655778b556ef58532552562a2fc134394c523cf3b996006d70322629f28bc82580b1270f6b5d0e868cdf448d72b4fbfe0d94479a2ab47b7551b22e7175010001 \\x23b67f431075acbb0d455ff9180619b606cae8eadb9fbffda6fda608ea066507cea8f507af1a40f849c06457feb816f7d9acd4e63399828b1b238c68a6d2540c 1670528475000000 1671133275000000 1734205275000000 1828813275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-242 \\x24024a86d2ce90158e58a69649c39d421e2edb8ccbe3eac1fec6a927ca2b5e27af49c4769ae090172240aeea42232058d6d27520ec28d0c30c6e877edfcb5181 1 0 \\x000000010000000000800003c036f2a3b1cc6f8ee61aabe08c41cb48e2645cc9d2a80acbbf1b83e4153661ee058d707cd8cca120590fe285a49434b59242240bb27fcc32bbddd36c1481d53ac0fe7e47738d9dd9fe655990a091b9021dbd9d7ca865e59ae84c9bb3901b1235aa138e3e7604f88cfa911f8f2ed93fde57f726702eae48ba96ba85047487c93d010001 \\x48afea8f65eee7d43992ab482d9112e8d46f12b1e44709384aae80a1c574acb5bd34100240914c3dbb21431de67eed46b37e3e31c161ab33c7874717dd48c906 1686245475000000 1686850275000000 1749922275000000 1844530275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-243 \\x2482360c2ac87bc0ad55c3f02adff8b7c3b84a7e6ea9551e30ce3dce9af5d0df85e20785484f5056aa028133f279f070c8c2c9c06f9cf5b8605909e1bf28fb40 1 0 \\x000000010000000000800003a5646dd8836d55663ebe42fd35b24c8c0a534802990d1d2e8b969afe8733b43234a22e4e7de7793f744aa5985aaaad976d4f4859b74bcce79cc3eae22ea7366e21ef51b4a097b55df5329a31faf17519e6d867731bfd4572037cc0d276546f42dbad3f190e440acd4eef3c66ad0834579e071391958a0c6232f4c72254523441010001 \\x449a5673c703978be2e7a14a8f05564c7e9d8f3ef271dcc21169b4b5020acb4dce7102316611b8f1f298c77f6ae2af8b5f315aa66e656b28b5900cf79f9db60e 1668714975000000 1669319775000000 1732391775000000 1826999775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-244 \\x253e907a58bf409ee4334b1b21850c12d513a62c62d614a419ce69047a97f5acbb1d3d12dc452ac63d5e6b46a158d66e6e74e48c0b61a88d32912fbef3067629 1 0 \\x000000010000000000800003be64da69768255602b05af02df41e4b6f330f661b814fef1b970c44872268b2af2284fea2189295658edd1c07213b425a0683d5a1c489385adb7955405e387ff248e52ac382d329ffffb54c499ce3a47da5cd42048644589c61182a61be48171b503187c399967fe11e8e4def2d47926b359e6380228f4d9e45114d46f798deb010001 \\x14e49acedea322d17cf948e8621d1c68e53277695055eec3d522af5efeccbcda48aebdcf11cadd11c635b9b8932a1420670e53e68bc280dd9c8d207ec95d540f 1676573475000000 1677178275000000 1740250275000000 1834858275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-245 \\x2a1a6503348470528ee775faf3133accf458529d1e9519614a3d7144753e5c1118e6a93d1c465ed56dc4cfa752de3c9e25a03253e960f4be4b63c10a240454bb 1 0 \\x000000010000000000800003c892ce9045740ff192d9b5520d8f57df081a316ecc083b4082d6023491431ef3de9478e6a9320d2c367c865aeb2826e83c9f4667954693257352f167e554548c28c4192f98378703a2995e82afb8d1980e4456ea86f95295aae607057ee0fd8aa1ade38b8637b1bd3d6beacc016b3345ce2c2164cc042194e4993ad68e1eebdd010001 \\x78959dd30dbf70709140890ac5357607780ace6e141fe4778ba5236afa9c448707c35a91001ec071cf33fc5771e0715bc7659902307b0b9f98a8b48a32197c08 1669923975000000 1670528775000000 1733600775000000 1828208775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-246 \\x2a8ac3a8322b2bd628f1774f029635a00cdfe731792196c5a95a7f8d721973e0d8614771b857f80fd9ea337bf80ac1aa463ae2ae26a67c40296005b285bec7c7 1 0 \\x000000010000000000800003a7ff1a672e8df2004f15d7107f83871d8808359ce27dd7c21b6fd956944fb2335f4c3b0977b2b54595e44c37888f8fa68afcd9ae96dfff6d7e0c0cb09d8a8cece9ecab20a311bb2bddf59d2b0d5f605b3a293703579919712f2d7852e5ce26bdee5e54661cb6d07d1c719d0f60e9b236bbb8913d5d5131c5576c0737cf185b35010001 \\x14fcda147234892f10b670e35109a5bdf619943a4fe6e1dcc3f18a82b5028a32e627b4984b025342f42f53e25f0172d774bb77d901836b120b901ebeb5d3cc05 1677782475000000 1678387275000000 1741459275000000 1836067275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-247 \\x2a827f1d5b24268b0541cfab581fc52534d723b9bb4227417d8f222fad75061d4f10b2bfb266a720da3ed7145a3d32183690e27215bdefa3aeceec04692d9fb8 1 0 \\x000000010000000000800003c8c2df630432bee80d875ac8c598bb8faed48a106359f92d11506b433c3a37a946707c6aa795a535d5e74544d22d3c8952459a369b62efc3e72b4768dcb48a7fe3657aaa2f787ee551b2b9d23a7d19e262b7bd569d2b6f22d7be077816f58ddbea05c52a3be1d0eafc87de79315b43186b632abea60fa1a86058379ab7c314d7010001 \\x7adf50b39dcab8bed1ae2dd5ea078e474111a6dcbd1af698db1c1d37d68ac21c54075a6e9221e3029d835597483dc0609d99df11311a2eb1573687034718650f 1670528475000000 1671133275000000 1734205275000000 1828813275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-248 \\x2b8644f12ddb2574786b06cc36f4ad134fb4f019c7ce33019b020dd99ff85a0943ef9ec00951676f7717c549abb715321bf25a69d3c364c0683aaaa942974598 1 0 \\x000000010000000000800003b6745505e579efc2d95c17d9fb614a66a66e73d47819c601cab68c8d8ed7ea3816d0cdf0975b971b718c6cc78893d50b54cbdf9575d041c1e2f51f0d8ab3df4b30257b8dcd1fbcff19aba8c1462cc66020136cd5a6d9cd34ef275c623eded365d7b936244d3ca185fd0b6704e44d4482d6ef4302b2328ff2901bd2d62a24e711010001 \\xf9caab74c3cadfef26768a795822179f950ec7b6ee3fa6fb4b6b55a1fa32acbbf8dd2937c0c5a9eb102794b5cdd925d1fdb2591a7a12ab33ebfe9d92464b3409 1691081475000000 1691686275000000 1754758275000000 1849366275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-249 \\x2c92ad1c2df8d157766e785de6007d2fe8a1f4b721449c4952b061b294f51e4ecc4d574cdd3a288da311cd6d7859653834c6da414d6204446d0d578516d12df2 1 0 \\x000000010000000000800003aefd83a508edecb5caebf06dfbf4f871edff2a0b16941a16a2f1af58cd2ee702d447fb9303fc374facbad1cf594c1edc52b218ebf3653f0c3a254f3ecfea73a61f8c37a14291fd9f90b1b5608cbe1a649084ee3e9cdd6a51ab36c8dd15984cbd0dc11e5d7071a45a235c99c863d71ab0529729418e9ce97efeea05f8797788ed010001 \\x883f09076151c8b83557602abcc3c36bc5838e744a504077c5d14e69f809d2e4aec884fac161a631af625399c4376e115f6d396498bc60c0567260665ec49500 1672946475000000 1673551275000000 1736623275000000 1831231275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-250 \\x2f9ea516531f53c620ef0fc02e3520eae9130958b150bff3586a80cc411fdceaaed475ef76b69c70ac4c2838f378b7e5f2630905f65242098d98a388270bf76f 1 0 \\x000000010000000000800003ca9d02560288c83065c8b2760f98ef10ab07da77632808777baef315af47f13bccb70fe82251cbac784348507ac7740fc8b2ee7b594bce3478c497cff7c9895efcee11b7a5fbc481e17bb9c1fe357f372b6909e5284a9a1020815d3c5f0a4f015fc1f273caefdb3e0437ac086d135bd4d6f9f9975af83f0cf7135a1259000ba7010001 \\xaa211813b8c3d2c9163b1d7b3deb5084d3ea05641e31b496acd7af6718bb2e017e5f0f56c07d1e266226367582edbb7ec5dc39f51548ab50c9b4b0c6d0a24805 1681409475000000 1682014275000000 1745086275000000 1839694275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-251 \\x302af7316fe581b53834348640193db4a10a716c5dc67b7d694d58c71a2c19fbc845cbd2272d070a63d256545cc66be58a3aeb61ebdee1fd43902fd3b9d74e8d 1 0 \\x000000010000000000800003c2b752aac3e782ec3b15677345eee8ffb9baa2b92f7bcd3193f1ca2c7957228f15bdb452ee8ef3e1fae7976b60b7c47fea0dddb77daddc4b13d6addb123b79b697d98fa52b738cfd6794b832acf6365ebc9ac4c57b9cadda36b8e05a528eec9879b60e33a90d8ec253ae627d28550959b2c6875158ec9bfba3dfad5e8a940cbf010001 \\x36b0d79f490454608726bde49fca168d3130320ad496267af140e60684bbb8bc2deec84606ecef515785eb12b3c51fb083407d2a2d37fdf551d89625b14c0700 1663274475000000 1663879275000000 1726951275000000 1821559275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-252 \\x346acf2cd17c4a53a2646b698e71825ecdb8238a0904187e1caec71189e33f4de126d23bfa25321712f9279c83a9d275365e584e6f769024f3b469da129ced84 1 0 \\x000000010000000000800003bd0a19738892c6b7d4be9458133d6d8ab465b40917b3e2c2cff868acb1ced012163b9e2e9ae768dccb8cf04864b271ac0994a25752e8b612a419570c8f93c41dbbea0843ecc67b8bd4333e3f7008f3fe2f384fe10613f781d032bdab9ad89ee47314b3ae2cd65b58ba22e6a42303268c97ea24d1613f0f168d1889bfba1388db010001 \\xcb5336dc59576b1156dae8f7ea7e53f4c06479323ad6e385a3cd632625be6897bfa58316c147f98580c74b4d086b1767e51cb3969fa126aed5c2290bdcb34a00 1680200475000000 1680805275000000 1743877275000000 1838485275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-253 \\x34de9c5244262c3fb8565eb2200ac21cd9e03dfe7310708e0b1bae21cf250588bdaca884af4282d3f67d53df5704b6e7e94bb95a5e148d5e6a97639572093f0e 1 0 \\x000000010000000000800003a3b7b495b859c37d7e6e29bd41bd4a84513ab8f22791501d9ce4f8d18a6876efdbdca4a32dc2b8628c945624ea7dcbf47821ad209c113c1479baca9141e7a3f3db7c120b20665c06c10b78d93f06cd532aec6a0699e5a5b8d06174f9b4f7b4cf900932fc843a182c29567c34548779dc360ac96560b12e2dcb6105c3536841bf010001 \\xac4b940b371e9d0827fc063867a5bd8923a1c124a5ce1782230d6cf283ae145178b4de58915808cfad6070c30111dfdd84a008081dc2662fbc9063972d86e007 1683222975000000 1683827775000000 1746899775000000 1841507775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-254 \\x3616bb6d3a25461e4227f75605d39896e8a80d22a87d286b0bccacad0757053cd86ccaf7c4516fc2edbe6f8c758eb15a5871b1a7952b9594098b2dbf2e13db01 1 0 \\x000000010000000000800003acad00e7c700733a8df847559ca1e1080b6466d58f01069775ab0db9bbb7f5b1f9c7bfcdee90a1d8a1669d94d2dac18dc0a19674327d4050046a970b81bf7ca0d275c89b114a1fb6db7fa263336457b96382b5e8f95d8d5a3f65b51a3346cdac8c2829cd0482bc65250cbbc94d90dc56879635b7a634dbaa4f2cd566c0696f05010001 \\x4a4a00f29a8afe5baa64262b70eb26bfcfeb7344a72110587ea5cd1264cf72850e84e7f46da4e11754e269e9d5a00eff9a4dbee42bfb9024d215fcea256a5d06 1672946475000000 1673551275000000 1736623275000000 1831231275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-255 \\x368eac26eb191c5ec906a2de905a0fb4f9a3c56560900b3e78181c782d1178dde54fd03100a1251a9da451ee1499a6d9940b24766a05256fdd676a7963f25af1 1 0 \\x000000010000000000800003b62502b4c76b68b91c3d3072c7d5847e7a3cd835afc09c5f6089b855b5da817763d069c5f830ac1f3ed9277373a315831590a261bd271f7f1a6a9757fc7ac31d548f5601ba406a88cf9522476b9a8f1eaba9494ec82f6f94da46b3818a938a074fc38cd9d1e02feba509d70f9a96a62f973e5aee9c5f6c2f8677e0125ddb47c9010001 \\x5cc02d41e24cf06da730d4173df2e113ea89e1f423aa4ae6a3954ae01e2c38a75296610f57c075109e3b6841243464f91d2f4e21969d21655b5a4f9093f73b09 1662669975000000 1663274775000000 1726346775000000 1820954775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-256 \\x379248b4cf089b8c3550875d47b20d66fdc0a6efbd285b5e0b0d25b2bbe5307fca5ae5c2f10b22e0d0e0304461839397d81b97b159043d2387277bc2f1c21718 1 0 \\x000000010000000000800003cf3a1ee725aa4d4b63833ff6a5d5ccdec71c3b31e6efd203cb50f963efb6d2c41475b7a10033d8522a38d356bce84cbed8943c204fead5889aab1c9d27be49a8ee6d01b3c7f9a64a2cd3939d9ca850aef7187bcd951060dcaa7b7a77a9398433412d40031899813006d079d4510164d9ed4481c67f4722c4f6e245472a036889010001 \\x595efdbe3022102dac228fe1353553625bbd7254c9f08a6922b4b23de4884933657e80f50d2ea983eb1076ae078ed1ad1ad11f365a2d785bb0ef5fe6cca8660c 1690476975000000 1691081775000000 1754153775000000 1848761775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-257 \\x3d92ab9363c9284c88eaae3915e685bd6bf850026bd578b3fc6f464700cfaf16478b5ce3f5e841a691676f4605d95de00efd4a82da227f770800718fd9435d1f 1 0 \\x000000010000000000800003bc65931b397bb3986fe31f662e89678d5442d71ed88d6ebec3822a22b3feec547253270182d1eabeec48f69e2dcb73337facb6569c61721ee8a06d5c4b58ec5569fbf6b66881e10e4f5ad6ea1297921f61cb6562794509fe38041a34530b34508257013c9b2477938842c971c3cc52f8a9d134d490aee926eee8ed85750120bb010001 \\x85433ce2bc889cbb3ad0660590b76f14768024ddd0ac32ef7f1fb8969fd2e892cf2c380d404d9d7af6dbe9b8cbd47c2b3d1f0150254d2527d6f6b4d9fbce8606 1660251975000000 1660856775000000 1723928775000000 1818536775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-258 \\x461ee55a3c35ba6e57bbbd870ea1be96a66abe8752dee6d010a3cbf676115aa2cf2a4f9be3e963b3361d85c1ea171322334f5008369fe43c469b546d0ec9878a 1 0 \\x000000010000000000800003d1cb215834bdfc9e53d51f779c798552af3de52e0fb5286ea592592768e787346048eac5ebd9b21a9636a2d423d4ebc2aeec53b33a32fb58c962d3e29d02594e39a76c13c0e45543d39735ad56ce63d5bc157b2690485bd69d8c95c60678c57fc330965897453b70573275f07f58ecb56c6186f853d047e0e551dae825af114d010001 \\xf4449e502cbf21a7e56a848c9a51f63eec52a320f87a73860b00f5bedae27117d7d516f8c73cef891f194414936ffa6b5063aa134339fe0a1efeb6024c7b4601 1666901475000000 1667506275000000 1730578275000000 1825186275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-259 \\x489ee709fca21646b24e131e2e694071129fc1f939651895f8f5b2a95dd32f24c0b0c6b146d510f165cf502ea94b95de814b3469eb1707ef322a611ab42b5108 1 0 \\x000000010000000000800003aa5c246324e0bb15124e26bb71a3510c8f9ac0b732b46901eaddd36efc2ec6c6fda3eb47a5ae3c3780d3a5fea900588f970f9342af7f07d49c1eafaf68aebce4a2a6d4d54f4be2487ba041b4c83ac47ae834cd6f223275eaf2a58357321ef1fd1e30b548d076384e6aa5b0055cac60d89f297734dafe8ffcedf8e2735a482bd5010001 \\xd1bf2e4aa5ef888065e1cb02df9af50c453b7a12feefa93e11a02a072166d789121175ba009b016dccfa3f0bb272cd85966b82ecaa15e645ad1f5a0781fc0a00 1688058975000000 1688663775000000 1751735775000000 1846343775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-260 \\x4b0aac54a5dd4f9f2e6bc1e4601fc5c2c843e9517f28b00c14cc76d0b67dd04bbe3c9d198a86352b6e8dc394481f2e1c4d70d5b7dfc15da2034e6bdb2b77f78e 1 0 \\x000000010000000000800003a6993e2667caf9353510b7c4790ed532a58ba92222fe8b76feef6fc388f65e345c6d80fefb9b19e6c62ea6c9ce3d06f854683a88c0de47dade511abede5d7ad2ca156ecf8ce6cef6ed2bae9473839a3a616a3a9c6a433ac7c63e2317bc3b1e9335d4254cf99d4ffbc5ae0a36e8b6fa5fd655d034b6574f06f4e2c1f60703300f010001 \\x0b6214df873d361e82a43ee0bbc00397b3bd49b14815e0172ac9249bcdb2b1f730f07d2ec563affd22acab46b3ca72ad7c1d1ed8e3040a060b0fca80db1e1904 1674759975000000 1675364775000000 1738436775000000 1833044775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-261 \\x4c162fd32c21fe1a26c44712d4570baceb51bd22abdea5b019ce41efeb2bc90b29542d92949d804c60da3836970d616f80e41290eec2f39282a3897f9fbed471 1 0 \\x000000010000000000800003c13015b78f5040382c9b8946ca83b39d3c2245c4e9015520a6544f7673535a72593f3ff58e0101e6b5d8fe31fce9e3ec3e34c17b506c5ebabc98464dc19310f28b494ada7e0c3fe6dd5e8371ff293c0a38a64172ec8fc207c6078bf1c9680e2ba2fa1f864fcda5036b551b9bab680c64efa54fa237af1f3073032c3d207f50c1010001 \\xf9870c6299dc330a8f4cd3445255f47ae070b69d2f67f9c2ba672898a71eb8d8b12138fef885a17cdc7fb3e05c180042845268d5b116e7f744a16f541f13b704 1666901475000000 1667506275000000 1730578275000000 1825186275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-262 \\x4e3a46d33b851b2366fa4e19dca4ad0528ac994a4331793aab75971c64b5d8c67b612793d230f23f86e4cdd5eabb6a9d1fe242bd25fd85753c7267103b057c18 1 0 \\x000000010000000000800003b46699f7d7dc4680a248e33720a14a0ae3ba25d2169f24c2c78311d1532c060a333520023db2bf824d3923ebb697836a0729834cb42f212dc1000370d296da351d7a956e0fae62599ef75b344fd0f17b28a734bb4c2576464761c398e4cd8cf87f6f7d2ac27eb9d04d44b2bca5792045627b3609c895a853b4fa05e7ffaecf87010001 \\x2670d96de919ec08da6d126d762ff9ef69a5cb1c00bbec5daf0aae024f1b70967b60d3b32739538dddbae8271d5f288fce5425291c35321d1d7fca984fa7fd0d 1678386975000000 1678991775000000 1742063775000000 1836671775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-263 \\x523617b351e293cebe6f587705066ea4a8f5c8ca71c10764e3c447d7b9a35954bcccbf52652904f0d9bef72a42b50507a995221e8b8e8e7c209344b625ee0fa2 1 0 \\x000000010000000000800003c0228d97cd433622cd2399db1a1236e7060b39422f43b628828df8930ac2b08473fd41034e20b1ccd2ad8a8ddf8848766b43776a37dceee0cc183720bb4e399a8369515dc64d8b587a392383271420bcf1ead9133e7e4a6bf9682fc1bfa6df6956f88ef2d8d6b108d8e5c8b130738321a6c4e8e133eead55bee14fcbe467cc65010001 \\x46af7255e737cf18a23b5b54c34fa229a98a87e986f740d44d3c8dc8906b0f146c3c52ae89c269e4343e1b532b75ad06e8373a3553363418711ed2636a9c3504 1691081475000000 1691686275000000 1754758275000000 1849366275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-264 \\x5296da1531f247b468c434a2831a1f16a7995d26d195d6ada5ad406a4d6f74453bf2fa7c00c007c0483706b760605a59117625b5540025e4bb7b1fb7fcefd7f4 1 0 \\x000000010000000000800003efdd6862938f0049b03cdfc61ce23194f788505eb9d35b4560d03dbceb41c098dbaf94ed007aba187886ec93f386e9367a560ee6ef1219668d4b35a71e96e5fffc232760a7e8d1f06f15130643477e966db9fd8df610102ee10cfce6161a036d7bd45e07e330c92b93e88b11c43956747dc892deb3a7c633414be61a6efd65dd010001 \\xb4d893b103cae7f0bb30840c9ab8129cb397271455be91dbd8e29aad207002b17e2e70c8b39ac6c14e174c73d3f846a88db15d4f48e242abbac52dcc41e46e0d 1677782475000000 1678387275000000 1741459275000000 1836067275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-265 \\x54fa81fbd00b3f432f7ca58576f62207d87051898beabc82116d7d439df8fc4d2edbf26356a15a51537ab5814d2d57611003ea0490bb58d4be8d939d859bedc3 1 0 \\x000000010000000000800003cdf944fb92a04712f602da3327b565ee6534f88a635bad5d528fce42723a2b55f459be84fe0a0f04970667ab978447acec1d63096daffa9882834d6ca8b652f4624802d44bcafc55556fc5c0a23ee3dd3f66904107806d817df5aed8a9f83830d0a02b0d25f989a59a9b6a78e6cac455a7d501128fca4aeb0ad11eb8592865d7010001 \\x19c1fdbde99f615e9b5857b2219ac6cbc4651c68e73a692478b4ada26331b264d433197e869983d0d9b22e58d62cf18e80b7a1594c4068687fb97a670d0ec106 1662065475000000 1662670275000000 1725742275000000 1820350275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-266 \\x573eb74ece1f885f23ef61eeb7c03352f79cb6b4e904956de4be0e561da06d02d931722960ef83ca81245f957b730985138ef90eb889e0f9c7c889b40436969c 1 0 \\x00000001000000000080000399adbf0db7199dd79dbad30823d5a00449521819d1a238ccd3ff93fa12ad23e060b3e8190a8f5f3c267ef81f1a8a35696ae01fcdfe4d96920916eaec15f7d9adebc05e2e28d0f1e2db16bf60e8fea9b3af7c8873fc86ec8067a9c71f4c2b820dcbce82db6e93cc62d04044497b5a8b2950916361329b5392622863f4983dccf1010001 \\x31f2c56476906be6748a3c641516eac870192386dcd4e367e0f87e727fb212d259cbc1b04a10211c4b2a3358ec2a895cfe406db4bf62ba539904c33da9a6f60c 1667505975000000 1668110775000000 1731182775000000 1825790775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-267 \\x5a8269f55b3370039666487367a97209b2002b2137984eb136ee50a9b55909e63e6b6f96896297bdcfee31aede4231fff9cc8ea653b0157ba3383c4dba6bd470 1 0 \\x000000010000000000800003c2eaca6593802e7192719318f0c809224e259c69b1271c9fb51bed9d8315d51f20438fa986cabf661e742e74beb7ec603a68e0700eb21a4765747561d3f89d18a8af3ae431f2407fe6d43cc92bf358d5a3f717a0b4cb69f4b76989e410ed6f19b8d48c04630da37fbdb5291c3f7e934040355591e6b6481d5492fd8dcf397f6b010001 \\xf880a73e0d72bbbe4f33c52925c3e14dfbc55e56acc334bdef17bcbf7a46a45c7f2d7b9c8cca396b7b1a98a192442fffdc983e8fef3d6e1a7af413a92512cb0e 1687454475000000 1688059275000000 1751131275000000 1845739275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-268 \\x5e8ac1976761eaec7f665f36a6a64a99d57e281937ff3d79b71d88646c6e5a09cb0d14dab806b4cc36b7f06a20cdf7b7c9d4d1a167517e121b1b49d58b7db263 1 0 \\x000000010000000000800003d2c7e02852cc50c2f57e50dfe52173a715b8a0f0c8abd6ccbe2c114cc2aa4f7869df691b00ba0faf90a30bedde30897b567d0b3e3706c1c48df49d6078663669d7fee265a6ff4f616496df5d1f4b2af4d681bf19629f7ab1bfc53e96c88d808917c23b02a6a2822dc00b41435794a089e837f49256dfa9ac1283f266b0284bf3010001 \\x9800d68cdc87e49cd044373f7f2010565a6995be2787b9352f980df225b53f1804e1fb86762c491f4d9345b19b1c06f33873c8d353fb4708e0b2310fae7ee00b 1678386975000000 1678991775000000 1742063775000000 1836671775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-269 \\x64c6bad91ad79e8f3534b670f4d327b10d7f83deebdd10cb31836617935622aae020779c58f7462649436bee883ab13c02e53fe590b5c2d0b941e74b711d114d 1 0 \\x000000010000000000800003aa0418e71c407504d9781e872951a9c297ed3326d6aee16bec18e86bf23208c60fdd0379aa331831ced5dc8a682113fb3d9f66f7ad2d7e6fee5f115b55028300df9836ace88e85227ea6db7986a7dfc15143ed3421347d48066d69c924c2fdb85da56a0a9a82876f0416dd888cce1c30a41c6ea6af931d5195231c952504032d010001 \\x302c11ba7227121f819461d488207e13b42f62d540d9b63f8e25ea4cbc2a0315109a8021e72a648fb1e798dbeef2bf655d62f5fba8246863c9664da8386e5e0d 1688058975000000 1688663775000000 1751735775000000 1846343775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-270 \\x65ceea8921b08269fbc40e2f78b315fd7ce14087a3f07991936d4e155152ae41ec801e77142cffb8153374fcf2bcca8dd48fee6a58b9546080320a42af617785 1 0 \\x000000010000000000800003a8cadb1e10708ff911aa699ebce309041dbfc91774640df1c3de790b2885fd5cfdd17a2db42983ac34b3f7719896f812f1d201c66870b215263207fcdb6e547609b023270f7eab019dfa6e729fac8588aee6fe87772b7e6327f7f54f2f3ddea0bf939dd0bf23d13906bb305ffdcbfb698856e7359c541da5865f3dff86507abf010001 \\x27a541d0ba379820e183440a0324fef49dde355978ff9b4bf6afcd902e7af8b6da2ef43bfbb7b25b1419e17bcf5a5382085d9b234f6adab7f27d5b62a8675d00 1689872475000000 1690477275000000 1753549275000000 1848157275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-271 \\x66be9b91960c56e1afc753cf67b705702e8f66cc7004c8600756b3e27dcd4e4b4c50907b1a22832e1bcac257ab193cd3e55b1b2a3f73ce71b604c72e5ae9243a 1 0 \\x000000010000000000800003bfebc556cd912f88c1d87abc77ada30c6da355a9073aff951d51cdafb637c11093b0c073b834ad8c5541a97922ae036ce75c78e90a29f82a32282f9bb8990848b90d3cd785f32e801029427a4a7eea8dc86c3948434c33821fd8b6a4909b9c748a769390599c72cb8d79cec91f609f8cffcfc353686c56b138f5e56cd4c45495010001 \\xdcdfeac811aa32e310ed22488fab6937d733811b138b3b1b4eb91785fea23a2319e1383612c021c2a3807acea4daf990cef06635778764ef81992c7bb29b980d 1665692475000000 1666297275000000 1729369275000000 1823977275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-272 \\x6afe0d411818f4db0e4db777783984b94eb97e928b23eaf42f2a731b9326e3dff94e05cfecdad2cc3796598dc4f1d843ffa093fbb56e792938f37781b920df6f 1 0 \\x000000010000000000800003dab8e8ec74b585f69b727b075f0f70b9aef92fd2d15d4c0095c4bc724b72a3eb12f467341094eb3027ad1ec8cd7debfe4327b5dbbbacecae7a190d9c117a214a2375c5ec5b79957e0bfab0dbf00c57701c1a8c147d69eed3959d576a807c7967c9693a501bb2f2d36770e262f450beeb229f86e1e1c12b26934a547bfd2af4e3010001 \\x64d39a570f281bdea6708a2ab6c54b2b065b7ef2c470811cdb265b5fd27166940f4b8dc7a7a5cf5bf32d559dabba984bc22e831a3b13b418cb3b2774193ee009 1674155475000000 1674760275000000 1737832275000000 1832440275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-273 \\x6cd2c153c39b57f77062066f689d05645bdd5e2951e42776fc65ec9dd81a8fe5530e0ff232336315c224dc71151773b725349a724791ddd81075b2feb29e94b8 1 0 \\x000000010000000000800003bfa594d49f9ccabe191b4553ef2a43f1eed362dfbae7695250cc3517e413b539fd40b3fe07dcc479aec61d7678f12d0a30a5a1e55fbca67d86e9f21607c886ba33e5efa0a9f3e74ec201cd1228f80112411a5cb94dc1f7b934f527f9d7d6b82a95c6f37ce22b7ce84ecfc0879527f60ac259454e35e278fbbfa3e5f951181f3b010001 \\x5fb1dbde675fe774d5655ab3959410913dd808fac0e232644c8ef21e2d423128a39233d3ac959893ebda5dadefe34f53092f44afc849c0125e602f66b1288e01 1689267975000000 1689872775000000 1752944775000000 1847552775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-274 \\x717ed9fc9bc368b2c19d327d6b7118a4b294875bc2ba37ba5777799f4a4e3845ef47a4f1547a9e1de2a3bc92c1a91b2a7e7ad30aaa5f5b0b469113b636da3be6 1 0 \\x000000010000000000800003bbce074b05651844414ebaaf788c1314384951974edfa81c47e7cb9f3664a005ee01eef9c87fbe98932c1a6fb90a6485d26791d749f7fa6db65651512d2965e3a502ac997819fc567dcfab9c02bf4a84cee10c5a4ed10a2269234a22f41b824bcff9551931266e10b441b52e40b958ff06fcfd12f9e78e0e7c7588d71a0c75d3010001 \\xad589f10300a5c76e2efa8913cc075b4b30d2f13bfe383514f610215237a4f26a2e6616ba1580a11cc6a3ece309aade9d74b2140960ee436766b84100074b104 1665087975000000 1665692775000000 1728764775000000 1823372775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-275 \\x7bca0411997dda5e079a5018ebba38e5807b5f39b293870b973114a161d1238465815cd79d03528902fd9399aece33fdc8ea9c25e9cf935fc2f55bc28f584e3e 1 0 \\x000000010000000000800003d629fbec1d17960edaa135f8c42ea1ad3891ede2628508c59a1d9b4e3f57013105f44ebd8a0a211ac62fbf4457c3896d48aa2ab0b41b3cf7d417f2c521388e96c058a1b1923b28e601826e2f8c6080f55c4df0b09f52e9dcbce6d0964bdc816eec315a8bc8d8ae9169104152c64ee7fc52ca845ed6de53689f16687e20c2ace3010001 \\x8524d17dc365c7024f0a044b3154aad2d099cbb7b724046baa442da8d9649830a2dc712eeda4a14428dee44798e1852cba06c160b1bbae65850b1acb5e800505 1685036475000000 1685641275000000 1748713275000000 1843321275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-276 \\x7bc28712ea47b1455d4afc19cbecf25a7a9735ea8e110de0ea479ec258c27b1e282d51c4c446a6a6c25d7edb8d21f906a3717116442e18bc185ac098196b348f 1 0 \\x000000010000000000800003c686747119c6fde0f60be8ff1e0f8a7683936164f35c840ece114025179b871725db8d39baadce87307079ecc3d6e72c8c228b1f045c035f8ffb8a09f2decaac388138bb16aecb0cd1eb8eaa85f8b988ad11710f2973dbe889c2f560a3ccc48a9f2009f9a21551bddc9f8f8ed69fe3ea6b159356014a79a82d2a4c240f255467010001 \\xc5a121bb712d35288f5441fa04a0202454754e1700999dadbdd70ae13367d016cad320665a0060b4012484da82d55ac3b2a49a52fc012ce0616d7166886ab200 1677782475000000 1678387275000000 1741459275000000 1836067275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-277 \\x7c7ab95bac299bdb9308b0fb75028c29776885fbc6a070ce646992fa08e50e8704c8a7caf48dac6b6bdc7da9f210f64a5f3bf8f1c9fff957c65a15d041bc675c 1 0 \\x000000010000000000800003c3f03de75ca4b025f88e54ed6b51506ce76624cee31214ebd4b9fb0dc09d6d0232793766fe7b743f6e9d4ee719d9cedcf38dff49c8edf19d3f6122d43937c537192bfe8aa92721d65e273d2134bf7971ce917ea2498f9ac6a64589e1e34b9880bcc7ac4d20bdc633e33cf140848f71850887d0228cfe70200f65639daa82a3c1010001 \\x4ab6624fff4d003d5ed13b5b0e229123faff3550c9ceb17ad548592d6ce466215a42685db9608904a542dbd2c1f33cafc0398bc98eee65783e4f40351014e802 1675968975000000 1676573775000000 1739645775000000 1834253775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-278 \\x7c62cd2933f2d6baf50fb2e46ce9225b7fc53a1decf7885fdc66fa3c70c79a2e9f3352a1b037305b3c564ae60c2685bf7fa4dead1bb7e499ce11270ce924736f 1 0 \\x000000010000000000800003d3c5052b0b5df99a2468d73891363e6dbd8dfb6b1e38f52aa685eecda7826b5d16ddb3c02c8d511c7155b58c870b773c68f263d81b702d6d80bb563981dedcd7403d3ee13a330786773355cf234f70cc730b568f1cafd0169e544a195eda100b4be0d56e5a3940e22f80bc544a29a6deabd5646e8c53f08088090eb01add7d9f010001 \\xfa9ad8a69996e06b8881f252e31e4d89876f157167c36e93d78a22685c1adebf7938e0fe7561df71ad6d7e0b4979ac806ee65be82f768e82668e2cabfab61b00 1670528475000000 1671133275000000 1734205275000000 1828813275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-279 \\x7d562efabbc5061df62e162b69391fbf62aa1ac6bb4ba6105b36afcfc7f790d2b7fab3f41b653ede8e31a852c3746c9acf0ecdab4ebd6ab51c8b3c27748c554c 1 0 \\x000000010000000000800003d8e4e958b70bd120d560f91d567dcd6901767e2a58d7ab80c68e851e149b33688e1d22a5aedbc289c8d2c0ee229055c873941f1a53e6a00ddfeb0f34a14b7f972260841893195b6b95b511d25a2dff42a9adc29d9641f05e92ca8cdeb778bb7b1e5cbc12f328220d5cc2d3d9513a85a16742bc1a1dc18177d638e53f8e3dacc5010001 \\x1f12a146e8a53ee6eb3adeb47a64f47bece2fd3a6a51326f6ca19f81e253132d02079bfdad1698ea5bbe300de87b61071a1c0d78d6f1a8ab28057b102752ba0e 1671132975000000 1671737775000000 1734809775000000 1829417775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-280 \\x7eda9732196690149afec5c12acbf6a325a91a804da02bd6ec71e24f88e699d61756068c2e40df5aa9d7492041bf9151b5b1f63a2284948503d0b9d8d35d26d9 1 0 \\x000000010000000000800003f10dc540314309118fbfa4c2f37ff8758c9e134214139549db268a88fcd771bf1f2fb761ca0e5623b54b51bf1a406c4a057c7be2fb249f65281f95a5c0e867f6bc824b1ced0478263e5088b17076926fb8bb59e15f272e251a22b99d23d2c869ca2c67db8d7eac4286c47daaf2c7845170b19fafb9f7143ba9768fd08de3ae85010001 \\xe9a6724ec0682cbe6f70c6ddb4dcadec715def0516d30f45ab75b44faadab077732243ff9de79009189b96bdbed8eb068081529d00715bb4d3861ae2d2bfcb0f 1688663475000000 1689268275000000 1752340275000000 1846948275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-281 \\x88fa7b671a77c25d9723ca58248f53212ea5e0a39ac6ce459164dfc63c6252d394ed4b20c41908930b02602a39513ba53fd9e3c57498ead70bddc03514c49c21 1 0 \\x000000010000000000800003b471f16eb0bca4d16d290b208364dc946ef86bf6c8f0914873c337f94b635580cf4557b941ca6ad757e2fcca7309f731d33b8faa463b830873cf956cce6b7b032a2b43fdde168056512fbe849b7c338bf1eeb9a26be5597aad739278f5e3496fc3e7bab46b949607926b1e342fc6b1e8113a8b8045a11a41fcc503db0b269ec7010001 \\xe62b0a8c57552f265ba158095a75b7fde05a245a92f8fbfa2838a5bde59d53c597798e2d376a03fcbbb126b93d3f9d9c142080efcd9c95acbfb06dca0bc3690c 1683827475000000 1684432275000000 1747504275000000 1842112275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-282 \\x892ae00322bb2b194dde129980b40a991c61333ed2faacb8679e30e8596c9a3e02b348bf8b40f384c5d0665d1189d56c2abf75b013612dd9edd1a96fcf2c8ed5 1 0 \\x00000001000000000080000395f7f3f1231ea566afe131fcdac3c4eb3857cb4cef17e029cdceeb55993b1d72fa778037bf00a3e6a4fba7b67a9e1236a825cbc2a333d74fd60cb7e33c0cb3d578900aa728b35337a4a2a924e56f4353a7be163f74853e4bc2e4ec5e37d040cd9200b20db38de19b874d75f13ea0d764951f0af0d01631b4c4c4fc347fae7f2f010001 \\xbbcaf3bdaa8ba6fb39202c6449eae9c2150666a8734de725c4630b6a45b5235f34e841bd8249a562bb62fafed245e0cc80ed5c532a9694d3ef1637b2fd0c9c0f 1667505975000000 1668110775000000 1731182775000000 1825790775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-283 \\x89ee63d24f2c8693204d9de5c143fce3aaafedd5d4f2f678b20690a650cea64dfaf89fbfd4f35b3a9e2f9a0a1982c83b82f9749f401f6695220d745d41d0b6af 1 0 \\x000000010000000000800003ca13d0a908579b57539564e58d32b19c8a3b36f4a31b06386aed0bc81558019135fce897e6f14279a9507d99702a8db7f4b23fc8437a4a235b8d4132d16af9be558b3143cc1376d6f45ce896defde55855efebc1e1e9ec7d9b94d17d9f42ef8c6fdc4759003b9089e307ae57aa8d6059faca4de8369d11df92ca6769b5ec9677010001 \\xf58dff7d42311def1e84ddabada5fd10af4d4f6ba346b2b74b877e02c9a736490aa810ae9272f8804e325e10fc5b6300956ae4f7e93cb06c5cd144301e771d0d 1688058975000000 1688663775000000 1751735775000000 1846343775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-284 \\x890e7d9d60d97e520837b09305e7dee526c9a91785ac62685b220ceff3dfc5db1c1eb972d9ea0a75d5babd23eb6d34a28b46e5aa0daa0b1058ee3efc16f15613 1 0 \\x000000010000000000800003cce9fb118daf1b5ae4da3df6febd31e1243780c3be31bde9a414be3ffc874619d87ce5922645a1fa779f30d055048b3115a4c7d394e8a1a8db4c8d8d6cb88dd684471726f026b8bd2276d08e1dc1ab7c478ceab5fe2dcfcf1628e3291667731bd4e674faaad72c3ffe72765fb720ae2392266a3167c7cf1ae75fd2ca105993fb010001 \\x902a9e6168ca7fd9d816562383e834198e3ffa665164a58ac56892f1e2986ff3de66a14b858489d33ed1c94e7dfd703b54af866cdda8a889b401a99d32c5870d 1668110475000000 1668715275000000 1731787275000000 1826395275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-285 \\x8a229da64f0b015dccaced2f440cb1805a840dc571e13afbc8843f186dfd7c65c08dff4bb4096d530df2fe2925c0f3e8da283aa3bfc66e21f6aeeb978f415037 1 0 \\x000000010000000000800003ba14c437a25d13e559f3572ca24ea69341afd53de44a9ea4a9a1aa1760507bcf85e9dc03127a78a00fa6eb47aea22606cd0e3f55cf933af677d6c9cf983366471303cc55d33e0df3fb50a8fe8121cbca59352d903bcc1adaaea55a3b5ff3202fff598c75b30d8c3514dc18795ece3c7563aa2339ae98be7feb7081210e8f102d010001 \\x2ff60ff74d1ac37ac5f64206277f47747687361a68577dc562519432bf020c00ca22d8248a227853c9c7706b4b74659e7f361ba1d4f42d3c7bb82465c9b56a0d 1684431975000000 1685036775000000 1748108775000000 1842716775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-286 \\x8b6ef37244a20ae57c1390959c48caefb2eeb40976a9f7b377760fa3bd62f277e225b68fcf2d36b1153c8a9ae1c85fca03422b8a455967d043fe83637d61adce 1 0 \\x000000010000000000800003c31b3b612c596a0fc61f20cf2fab0f68a0fb23f48da9a7f40ff9c90d5254411ae7cac68c9f7e3c290a54d04b201e0a254620878787c0670adb29fa72903a39895105acaeef1b4e8463b941a593d11b2606ba9cdc9d33587fa8ea387e8e4c12b37b3a1d8bf685d5730d5b0f104a3475beb306fba9fa09b275e40585c4de56e2a3010001 \\x582658c08f94969bc17c5ef0fa264e9e1cb12e614d3a62898530afb454644fdf46a870083ee54dd6d069ef93b37690cf6af5edd2b00bfdcf3d0912586b49170f 1665692475000000 1666297275000000 1729369275000000 1823977275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-287 \\x8d86c62adbc2b83daf8de592cc7abc92a873addf6539f40179382df3f8663bb091fcb3fbb219e1c9d6bcb99dcb2c3d6f9d417c524ba770f875321d39e6ca4980 1 0 \\x000000010000000000800003b3d020cd42f965b9ab2a0fa38a32608b4591f23844a15911aec4640517397e535bca7b2269e61193c730350aef5178bb338a9eb9b6434ef7746b566db4d285c471dd858a9847e9bfed40f02345cc3b9c08a6842b4afd08551a1240363d2407168a90c66eb96077de8f7d99de259e1a4b77aa47cd993bae6ff5cce28b86c67305010001 \\x146caddaad5a1a3476a51912d15980381bdb8619e6217fffe7184f7b9a828228a36ac5defc0f1c3db3d1a66b5bda41a4790f7dcedcf17c1153996937f2bdb606 1677177975000000 1677782775000000 1740854775000000 1835462775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-288 \\x8d76f713bdb14fb4c382f23be01c469816882dd6d56da462fc7a8e04fdd886fc6f15ef287e1d2e0f01bf8035283e9955c43f1011e62e6b58bd04ff9637ef22a4 1 0 \\x000000010000000000800003d40b250a816534c0aaa25bb06d496ef40d2258c945d175144ff1bfdc540365468d9739537fb3b77056676e1b0a306e88c1404b2683d211dcebe7a9fdf5ce16ba40512a8e30196b6f1e27d8a8c22af671403138ecccf156a74778e9cba7a0e7845e83d7ccbf736f28e3ad0658566647fbc971bbfd0b3a773a79ac2994b8463fbb010001 \\xdeed7f8b87e60563411a7e76183c63e7e681a20deb5dd8caeb0d09c2e7d7bb59b376e1eb394a6c429019c892763ec2b548e1f16642a3b953fedabd4bf7eab30e 1678991475000000 1679596275000000 1742668275000000 1837276275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-289 \\x8e0684e0a5a46fc93a6ed7ed990114d2680939237c82fdddcd515d1cae959c9b7a9cef5b91311a40daff2e0dd6176af512dfded4265ba82c6eea3796ed42aadc 1 0 \\x000000010000000000800003ba591b6617d5d9ac4904f849b00814bc4fee254ffd071f6d29e9baa927e1fe9b3414b31d6b15e887f18442d61efcde2b34bb86db9069f13ddda4524369dfd91e17e81c52c270adf6914a16f85d41e93e68d36ba33dc5bccbac847dd659d2fef6181f9f9e4d5749893acb1ffe37bbc4002298f2ad7cbf61b74c8d8d0199dfe987010001 \\xb2f878d426b15461e9bc92ea85d0fc9427538f1f886b26e7d18b8f789261cc1a3ccefdde97344219bc2bf7775bcd8e5368c91e975e031e980d78b6da03c89d0b 1662669975000000 1663274775000000 1726346775000000 1820954775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-290 \\x8f62ae8dde1fc7596bbd4b093bcc38b50ca6ffeb1d654dbf3cdb99ebf2fe81c1e0d1e8a60f2ad46231e1c9e817f40f4c8ca08c6f488f66d415445f6273273ae1 1 0 \\x000000010000000000800003b0104a6202f76dda74b0356bd8021d106d28d793d16fb07d281c923a5d724d6d833dd07914cc9a8df0803e04e81e35acdc144710470b09089e8cdc81517094e63fddabef41e56ec13b4536b4f3f16745f1871fcd94d1ad05bf5a1ea43b377dea07908c112bc3ec370ef362eadfd5d76b438489a324d224ca2688e79163817f8f010001 \\xd26272625fce6ef94f669ce833928a694678d2d5912bb877b292e23b14c11abf55c5a8507c6ad47b9e4c48ebb9a6fa673dfbfc72e2c6c3d81114a5fbb5fb760e 1686849975000000 1687454775000000 1750526775000000 1845134775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-291 \\x90b6623ff20ab5266d90cc319c3828f5d739b4f6f8510416544546cdf283d9de8ddbb478ad8f62bf28b13dda329bbce92385778744c642d8507b59587bde9ee4 1 0 \\x000000010000000000800003a8363695f0ee35048f3e7627b55c0613bfadb85f8b9be1186f3cc5c2a40108278da64744d6e96673d1e454326bf1bf7c9d87894e722fa780b392e5e594eeff51f95f9d03a7b48887e84c834c9077cdf01f11a6c5310e228a72980c93d52d3015ee7151169ad855ece58ba74ed2dc15af8e74bb5bd244da21cc8718d9cfb7eec3010001 \\x564be39f153d4a535aa9ffd9c86b972ceccff11bcc90c6d7f54cecbe0b93b91d3a5f2d891ce78b3f2bad5635f84ea12c4a31613875286e5901617aeae04e820f 1666296975000000 1666901775000000 1729973775000000 1824581775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-292 \\x933aa20653c318c7e7720c9ccc5c4f2833d060c4be2470811d19d61a89506a7d1d8dd75129b87e9d6505ee183abad38918213abdebb1b24f5842bfd4de2d466d 1 0 \\x000000010000000000800003b80b07289a0c083ef5742eba3ba8376c53aa66eaa9d05922a63e3042202890d0a65bc864f2662c3d1868c580f75db93dd864fefdc385c368e8f63a89cb96d3042d250a76bd8ccf7ad7c820cf18c4a49c4d271176d8a5421a2f008657856857780bfe69c014d90dbfd471cfb10b7410ffad177bc3e896dbf9a464c2c2943e73c3010001 \\xa5bbc6cf73e8c8eb1cc5a78f8ffa8c22ce58a1c2f76808327756d92bb48365ac255c334ca40909ab8515e27008e71a9ad7a69357a366ab9f129d2bced0dc4f01 1679595975000000 1680200775000000 1743272775000000 1837880775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-293 \\x9a2e5ae6beb599ee41a2cddfe019cead158231c2781b3fd276026823eb65cef4ddf6ff9899aa5226920c6aeeefe76d4ffcde569bbad7de833d80ae032246542f 1 0 \\x000000010000000000800003bfcce646190afd3737a29254ff55f9ec37a55705b405942930539c3b2b9e96ee9d1d4b0600c0e2330801685c718992edad803b4fc4c3fec0a9ca160479b4ba66804351315a228cb116922f730c79ec40083adcc0d424b625b9f2c12576e6a905d63529f638e91d0dfe4a2e2ba75931934e50c3345df16a7c8c85319ce9d82f9d010001 \\x1739997d9c710aae382d23f896ef89d5e119b819eeeb8d3032498ddb9e158ab5ceab181ce3d949793ef914adf3c160a257b3308313338751176a24373f18a409 1679595975000000 1680200775000000 1743272775000000 1837880775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-294 \\x9ab63478926149787a5023b18461ca880faf5cf5fd94b1828e8a2a0883bd8ecf3136bc2a18565ef2233a96c9d9e7043c7d0c52d4d32b90614c9204737a53ab2b 1 0 \\x000000010000000000800003c284400e03a1da6693571540125519ef46b58ef6f360bf0b9ed5f7de4388ee24f80f27725d7dd3cb76375a13dd150f49d9420c0442240de5a597adf66207d812a5c7de07459d93a6dd1e87b7ed742624170ddb1bf4e81f84fe40f3c9d7480fc83149453cad9479e1343261144065b0ecefab5d5b71c3afb82e33d0ddcf8fc92b010001 \\x1adc7bff23c012a7eb2f47a2de893e6a580e9d412ead5623ad9e021b7c6c46f170e7869bc118d0f03beffc0f80bf303ef41f85efee09051dff120d3f7f5f1000 1687454475000000 1688059275000000 1751131275000000 1845739275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-295 \\xa38a7e2a5429e183afd19577c8a9f3dc73132dbfcdbb98b8b1a3d1172419d8864ca603a081bf6ca1c944f7e598a68beb77253232e3a3fc427aa69bc290d647e1 1 0 \\x000000010000000000800003bad82de69b1b491d131f85bacd9b81472201073f96cf25eb85b3ea10c6bbd680e98ace63afa200a63891bb7d2c834c407a71ca0b0ceb89d7c15eaaaf5c0dd89739611abdbc73f23a0f385785f0a24593e92f04f04175d7bf3358225c01e5557eb61cd061b37edc85573e240c0011aaf6b0cb5eb154d5f506761c9553a53aa393010001 \\x4dfd3172cf7788c12404d6c9df98e9f6c3ca0620a7ab5abd4a3b3c33ec870688c84fda3509519f42300d2acf51ce13d33be61ce802188ae11b0c5c81dce9c609 1672946475000000 1673551275000000 1736623275000000 1831231275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-296 \\xa40e9bf42bec58399b710bbd8a9c9dbe1aaa1a3262385ef9c01a7ea336a56ef69706e66cee853c8c95ec5c8331d1c8155c7d22c53bcc28b9c9f20067015a2cdf 1 0 \\x000000010000000000800003c3771eb664382b1a17936ecb78726ce772ed7183129e4f062d2565592e6e020b8d0aadceb26034bcbdab8604eaf15e84604b1c4c8b0ba5570a1761647b0894bb97f8a056d5584f96676f0c923233b52628e8c585d42894bb588475dbab8ad0064bf6e64821345c989dfea58e62b040d2f2e73361daf559f2b69f9636060aab6d010001 \\x871fb464283c5a6b316587a9b57bf3eb8862b1ca70766cc973e78b2f6cc99473e7a5968de29a904f23368b5954432644c0662a6660e4592aa7e2ba6d8e9abc07 1689872475000000 1690477275000000 1753549275000000 1848157275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-297 \\xa74ad58f773964f8260590f395967ebf115cbce036320f88742e6c9a42d3fa541c2de056d4febfa7fab1899bb431680f0016cd183052dc79c40c909794e67f5c 1 0 \\x000000010000000000800003b22995706f538a13734f3c0e0f2ca8c09f477139b4ac1cd5df176bd99cf3d6102a7f2b4deec68fbc084e55d8bb1518850d497dd253c507fb7d74dcdc511ea4c2a47a688b0bb721ba68c2d78eddf4b643e8bb49993dbd617009c28e8ceae9fb0f1b1e11bcd8dfacc46eea967b30cd05db5a6d67aaf4dd2e0f7dac2089d7c1da85010001 \\x99938ad22252d0567fa60a360ee05a33661bb76e9f32c65270d5b36badc924958912494af53f0b832b68f2bae0f0c35b3412541d541540ae736eda45bdda4806 1662065475000000 1662670275000000 1725742275000000 1820350275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-298 \\xa87605b93b83303485692b63ef638ae71e9694a775335beda1b481ba169877a4ae21c83efdacec76bf997ea4343da4a72fac9aedaf9142e34e3d9210329b9440 1 0 \\x000000010000000000800003c46152e5b4fcecba4c440531e8275e5ed7b53de190bcfb1e0405342a0da2be8c492f4dd4dba02a3c6bf763728f5dc344d3119401dd032bd5657d33840e92b578e8a8d721de8ca12de62de92bbbe04845e4c972bd7cbf3fa8d8a52696496d7666a8ceb42347572a831813fd48e53eaa4ae52e589e8ed7e039007f0012741c1fbb010001 \\x03c486bf8867d426932f11a25737969385ec0edb8faae7dbe2b2b0e5fa3571d5025dbb7a8888b556b0d4c4c65e4ec006759aba58b2c7559d74291ff58dc3150e 1669923975000000 1670528775000000 1733600775000000 1828208775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-299 \\xaca66faddd764d176c6a64d6d2097fc6488a45cb7e945bf80ee81cd9bb06681607581841023bae7969285c3b69502c05b142bfad16ce128f3dab7eb5b278530d 1 0 \\x000000010000000000800003c0524778f87653041f9425a50f4d927a6208595e00effb6421c6347bd05fed133f8c0479d5a32932dceb20b6fe766149cf8c89a3e426f63778e4ec4e008bc8be66f3cee69bf3813850df75b5a34b9e80bd206e4ba6e130c34f2430995fec38b6bef6a595f12a6d24a09ca9ce4cc59a82f12c11dc7ed03d330356036509c750a9010001 \\x1141eb0cb778a1d5be5c1995eb0d6014c1868ee907b3beb057d60667d2047deb3929a4dc4de4290e633069d15e4ffee1c645a736771d67044d38aa6f84b8cc09 1674759975000000 1675364775000000 1738436775000000 1833044775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-300 \\xaf82f1b6532153b00e4bd508b92696af92df2a1cf956f48f8f71f34065868d80b19488e87e6210ce42b17b6c2183fc01dcc4d913db68d9dda8ba6880950c798e 1 0 \\x000000010000000000800003cccb3ddd1bd31f56d937449c352fefa9d6b95070e499f152275372a2bba870d992cf82cff254da189e381488982a25b18e480e926b817a17251e77bab5ff042583f57b3d24038077a114dab64ed63a85baa7d8416867fec6f6587cb44159dcabfe6f6bc1e39032e7697cca43ba2272d68381a1c246a430b65a9a431578877eb1010001 \\x193f74702ed2791c1b7cca7cbc8705952912e59f9bb0821ce54ff730dee9a0b453382a0fdc8bfcaab0875191fa97af7eb881f22c734fabb0f7e826b6154dd406 1671737475000000 1672342275000000 1735414275000000 1830022275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-301 \\xb212204a1495128d667fef26d784f8edd1463de35efc03ec8483a51d8c350a76e6d4d43ab37775140eb82398a4291aa4fb56d61225aff099dfed923cafadc89d 1 0 \\x000000010000000000800003b72c917a753f7bb2c5b7f90749c4a239b1f2cf3f856cbd4b7a9811027a8cead346902997a3009c340d83c356293f40c7e105d87ef49b6bf81734d92ec8cc99ea31412d12134ee3b06b49e9b0cb9d97eb4308197d913b7e262c47313964576764add5e93c7ec292680599ab8fecac7359d4837280b5a5a28fc0ab0a3331db9cad010001 \\x938f5b13447bb938785aea0276046f79b1ea1c2d5081ddc02959b7d5abdccfb7f79d7ae2f243a92e04fd0ad641f2996acd1205d0304466a668380b3c71f83504 1667505975000000 1668110775000000 1731182775000000 1825790775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-302 \\xb38677d6ef3d61df2dacf8dcf668945e6378ab913f5bf36804a69b5e8668ea9c999f021c391961bb04e46603118e009941587353ba889748fc0b6448bf89e083 1 0 \\x000000010000000000800003be2c00218aff9e6b50ce26fb28e37c7521c9789ee1eaf690b4a918bd8a367a78c4b91c94fbfd8d05bee35e2100781af8cfa3ce6cd934ccc2ef7e787360731e25e5b2860f9d43e66c10a38666d718201217ca838e050ced2cf5b057a8550072eec0c32e158e56fcdf3a6153d41b667aea7ac8e8287ed6198b22042f8ceae8930f010001 \\x5149b83d8e92ca73eb7703e576b8a2d7498b4fdbf22533719323ccfebbde07f4add84fee90b1a3a0ae03970cb09a9738fd5ae2e9ca0d3391d0e1e96c0701540b 1672341975000000 1672946775000000 1736018775000000 1830626775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-303 \\xb3ea5e7877cc97a7428cdb82757ace04a9181d14b6c14f41514fc4519f48ced5ce347596bb2d4ab9a9763713096eb809af8833b2c19400031ac05668434d13c9 1 0 \\x000000010000000000800003ca07dedf2c9d520877162639d9849df67c4b2d10193d3030133e5c10b57662e228aeea959bdff9a23db09e3986ba2bcfdda82658aaeec7a81008ecd8c91e0c9dc4da268eb3840470e66352322a43a36bdc4d5283c8ce4125df16b5c369f8aa516058791a4af81c0dd825a88262106a378b9b731e0f82d2da5cff33ff74790617010001 \\x6a5e6177fc025fc416d9488cb42e55178b65e84ed5ad1afe9b646325e292217a5aeff87cc08df12c1d89a5cd3cc0a296b5d638527e8020976c92d26ad0488f0c 1680200475000000 1680805275000000 1743877275000000 1838485275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-304 \\xb6722db82fa71d199a3f05870a3882f0129fd073762a3f5148160a8eb311744e63ac92bdb78a436ee5917b68293630ce3c76ccdfcd9781273e6a92ebf5c6f692 1 0 \\x000000010000000000800003c4283fa3bac50f0ae157b40fb3eddce36e882b1e9bf49c5c77a63688e65d4f19a6248af774d256f651d6610b0111978f89d45a9340f376089c4a44003b6189dcc78efa30221f68140eeb5c41df04592e3f0557e547aee7c80ee8a6ef83a3712de76ca89fb031c5b001acc3c756442a1b7e02908ec220004ae776b1d44143a683010001 \\xe93ad9c377ddb1084a961bd97f3da38b01d125525dbb0bf77adad93780bf16ead36c3e4a1526a2b0df9d978e567a0feaefa178618f2bea1f5d518ac23eef0604 1690476975000000 1691081775000000 1754153775000000 1848761775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-305 \\xb97efb3fd76f22dc9b41910cc01dc53954581504c4c74b97f491e9b270aaf69cee192c2f98e366ace8a48041a8ab6efe2f6a35b51d1ce8257ebf80f9478f2466 1 0 \\x000000010000000000800003c01d3a7cd9641ea27463d8b0702bf9406ed3791e5d4818269ba23d5bbb10e81cda73d1217403fdcad618d2306f3687f191919fb68cb653de860401e685a49cced269611b676fc3ad7355b614c35825e252c26dd32414a4f4b627fff470abda163a5a2b124631b1f888fe3ae6c90f66a49f86674233bd44b2a602120ee715150b010001 \\x8c8af91d880a9388da47a62db73cb275c23fc979470f47b48fc4d0912ddcb7901b98d4df29640ca5b2c89d65421d044a179f58ac3633e11d10a86fb7072f2706 1676573475000000 1677178275000000 1740250275000000 1834858275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-306 \\xbbee0212baa0fb68dcf6f877708bb3ac8df14b37a559b05346f0143bf402e029e0e2aac57e0bb796c13c8d2bfbfd8baf43ffedf4abc2c69517f9ca5b9d956406 1 0 \\x000000010000000000800003c3f7036c1b2fb4fdd635c08bed2dc5a70385889ad3fd53ba3efc55f9fbb1526be753f670e8751a7f2afadea1823f3b77e87c514efbdb12407e9361814940bc3f5e57a70f52c6a41b422cacdcc2805680e04020c4257d0f7f138ef22b112d1f20c3a15fc060307ee9183f5e886737e8d71d1e102374b221ae04b87abb99e68419010001 \\x568f639d98c4a94fcef5fbf84dac3764b372188f83f29a2bf5beca2e6dc09ac26343e0991344e57e3ce28be4d65edcba86d3cdecf085f5f1b88a6223c656db06 1660856475000000 1661461275000000 1724533275000000 1819141275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-307 \\xbc92502ceda86763475a743747dc2cc2d626490a7c6cb1d4a6bba08b688eb86ff0b34960d515a05686c18b9b4b56044f13df5d82fcb7fb6244d589eb75176f44 1 0 \\x000000010000000000800003b0ff1321363e8062455ab72f77805894417d6fdc16fecafe91a9751d7b6205a977f6ba496afbe0439207ade2a880465ccea61bf26f9fdd2880efd08117e401fe6cb4d1146a22edea72c320952aa2a87ea59c0767d6aeb5058d7afb3cd8b4d25ce761065bb24f9dc2531bc412354aba0e750ccaf077f9a77632308d89bf093041010001 \\xf0917e76fd25611ce952c4ce5e0aaed0f298713edbd38040d1d56e1d29c98899e6e6f954cc36fa5468cdcd108545aa6121078a6aeed0e83fe459abfeaf8ffb0e 1672341975000000 1672946775000000 1736018775000000 1830626775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-308 \\xbdd2da24c2840f7cd709d8ff53aaa56723ffe95309a4e4d78b99ae554c9f51f48ec62733bd9c2a2ef3551b45c991042753c6b68aafb02d97fd8763cb237f82ad 1 0 \\x000000010000000000800003cb08bcaef5ac39794919a465507100445668ccfe0c1bb01750e45a42b21f29efbd3a95a5f0367a868d58473cf8bcef0aecd1ebb44953ef23d7531548b4c11cf0adb30539bb6f92617b206d8d893abd18ac553a68a9dd854223f76ee1b0c2ae3b22bcf1ad58846a4bc45ab2954b5cbfd4c9207a5f204ad8c04dba696aa3cb9ab7010001 \\x30952c3aed40f963301b91927afa0aec81592bb6aa705499bf9499b0854358bc1c9e8e740b2e51d01c27de1283f0ef2c947391a358d7a6d63eac0ca1dab70807 1672341975000000 1672946775000000 1736018775000000 1830626775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-309 \\xbe8e1703562a41f3ab51bed38b822808137ee1e4b779917df3e0ac1865c8b5a40277ade8a813d634892f875e0109d8e867eb34818d1294a9d4f2beb28cad837d 1 0 \\x000000010000000000800003a1729e1d937ae4837220e88ce610aa39b32d3d4cbe7d731b055bb0a6272188c2a0bfed3eeb0c7201ac5ff240243b4a885f6c1887940e503eba8d6febe7baaad42a65e3e7b9583ea8aa3dc5cd195b32fef02105da2031a0b7799b3829b1c05fb04d46c21bc4d24c34b5c696b5aa109e55241238db36591bb12af54e7f75d6ce17010001 \\x2940a1105daebc4c565b3a00bdd4383ac93f31db7af3b2a2e657afe4ebe4ab8ebdb9104bd29e7f3a274d9743f7eafd3204e1339c5bda38cacb39fda258d06a07 1669319475000000 1669924275000000 1732996275000000 1827604275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-310 \\xc5c2229dd2823a73d3ab4556b213f9c77b11301f5c61db6cde16b4bf95f93f1a924a93fd3e17ae0fa38f1ca1ce79d09b8a78a559a3ea316aaa91133a28830541 1 0 \\x000000010000000000800003c0c9b70bcd6c6fc61e2212b18c730f19ddee2a29795cbd85435536509d95c965a45256b85a2f519c24423740fe739e6003518fef35b717db5da4295f60681e6e5cce8dbc2090fe02ca7df791ff74e605d16147b01f52b73c191524e6078f2507b5a30ad406c042d2b910cc7bd93a6e410696564642ce40f30b7312a3a2e6e87f010001 \\xac0d414fc7fdb32405cf60ea4efdd0d828482bfff90dc746589e8a17a1b1f507b99e43139a9db5dc634668711a6265983f578125b2c50c455f70734696355d0d 1691081475000000 1691686275000000 1754758275000000 1849366275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-311 \\xc57a4646893d243f4539d43e5f5e98d09c99fca39c8b965b06a2597c1633a69cb80ab44b9c7cf1959e75d59d9cac85559fff8858c70bf1ee50eba0c49b699645 1 0 \\x000000010000000000800003bffdcc328ad9c17306e535c65e236d2037ce1b26d5c8dc1400b4693d405c0a2ec5b03b695d0103fbf8c44d8e3e8bf2d41432280b80f41fa57ed2dc2be87583187b96199400a90fbc80b5825ccc0ff5717711dd330975cbd077b48e32279aae0446a6b93128cd6d9c9a9f6e0712d7be830a74f910fda2ef090c942c5afde528f1010001 \\x652c81728d1cfc1feff718d879311e477ef85bea74066498a41e66388c28975d106a672d3004456dbd487530ca8c2f54d05f2f5e38f77032fcdf3855d9ac3108 1672946475000000 1673551275000000 1736623275000000 1831231275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-312 \\xc8d6de22ce220b84ae5f7b4d6552ba6a6f28be0d816bb2a09cc244b0ac4a249d6e4a84af651585196e259fbdc292820079cdbc5fe309ddc09fba584f3f907905 1 0 \\x000000010000000000800003b993d3b03fa2a409b4d40f1d27fbb0447c88ad897d160d31a7ad8d1a41a3557b8dc1c10850ad1131d90e651ae9b56acf823a704f8fba572dd7f5688a3cf8bf46591a63fc5526ec1764cf862e59996aa144219a2da419aae66228ef318cff450f754b9671c390be1c5bed4b8d9f1eace857d24749d53976e9511fb854079a6de5010001 \\x6bea3006bdb1addee5ed91c9baf2a474415458e19cab2a2342d1f0272d9dccb2853ee1df02c4bb5b020bff65b7eb86c48da3337e0d5a7432a751e5a8317d8b08 1662065475000000 1662670275000000 1725742275000000 1820350275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-313 \\xc8dea77fda95a133e56b0b0b04c103e7dd1b37f772f07c1e06a4de289aeeb56d3f506f6098b002b0277a76b5c0491450cd4acf4beaecfb77a764e75bab2c594f 1 0 \\x000000010000000000800003b3d1a57d07234933b017c14fdaa25b997eb6dd1a5142895c7a354f8db1f863e50de9f879bc3f76008659a0fb5233361f9c09e8a8d093ce0776fa4321c5951e6b4caa1fb1a7662744cd1754e44727a5dacba5872421c14935ba46626445fbe50cc82d2fbc98404b55aca434324e8226f0520935020fb973b085c3ef3f6ffb0023010001 \\x2a3f153183ca079305c8168b5849ba49b53dc11c79900d7a279300366e32aa38d395de24ed0de0917550cd77be16fc67c3180aeb83194862e7504fbd8184c50b 1684431975000000 1685036775000000 1748108775000000 1842716775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-314 \\xcfda17ecfcadcc3ed1fdb9f935b679585dbdfd367713651b78c5afedef122cc8ff129d9d6492f4c5dc837525708d930a9c4875014ba54e698665dfaef2a98278 1 0 \\x000000010000000000800003d2df8788307ac105b9461ec7dfece831c833548c8992095debb7190a757329c7cd1dc36f8353d7f5291cfce16c04c9878849a598bf92a22f757ad7e2b0a14ff436f7e2197b74fefc9718ef8a6def34f1b9b9c2636bfdf33391e70f479e6ce075fe670abbef393890de9f28eb4390b94f74bbf94e4d7f12757383615ab2b9beff010001 \\x810203e95cce94a84fe608cc16cf83a64516cd8f8a96b1e955579d4dd401e49b87bd55d551220cd10b6b9d33353c233175833c8a89d91f74d8a5ddf1bea5820b 1671132975000000 1671737775000000 1734809775000000 1829417775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-315 \\xd242f604e4b6e206fb94e821ecdd887f1132518e2c365fe32ac28e3601d570b0b57a94e69721fe10e523767db032c344febd2d115a29325947dc30d1928a62e4 1 0 \\x000000010000000000800003e75253f86cf220f303f110a511229ec632d949ad33d3ddf11185c7abe709ca1e3918d4941feb32c89ea3e72ad5b0e97315d2372b9a4569a21754200feca18c8f6e85a55d231434c90559c9c9f452e1e992799612762be16b6c7239b8e6be4a8ea162cd98008b162dfc64128b8613dc9d356d633aa1c8d68bd900fd7ef3267cc9010001 \\xc4aed40f11acd8c9f981f5dcd5c217b081631d543f0c90031aa65a6d7a620c1493ee715a20b5efc05327172871b580845924fb3ea42af1a609d4ed237fde070c 1682013975000000 1682618775000000 1745690775000000 1840298775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-316 \\xd94e16d174f2074862172d8fe436a9084abf4f489a622f57db0a6ab0308d270a4ab5fa21600affda5dafed529651bb90c972509c0303fed3d4d10d0c1ff400ea 1 0 \\x000000010000000000800003d61e8dd7e5b907129b4e17433cda95ff18e7871d63ee8bb180fd74a62ba0a7d477ea95d45444203ad6d51d73544372e8498543c4dccd4206f3553c33e7224d85c1a43e1e4ff07bc52fe7fe80184df5cb65d5bf16d37589149c82d2629700dde6a6a17394fad2826781669096357f600d84b7c98ce50cef697019b4b8af9edd7d010001 \\x80cf64beb8fc5b38df6ce15b00474b4f9507e1ca05e30bb8b4d6b7e571a6847ebf27c2773be513496e81e084ac4837ce12f5c67233cfc31a79c5a4eeaa34c702 1682618475000000 1683223275000000 1746295275000000 1840903275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-317 \\xdce664676e0470aa4596d21a338a25c633ae045e4c26d2cdfcef3a6ab4a89f80916b2bf4527be245cfcc9d5f58afd678930e9456b9e67591fbce977462eaf4f5 1 0 \\x000000010000000000800003a03dc395e2288c24639edc150ec31523ce36978f83e2ecc10412cdac9e36420c18ffd2f87e300fec5b004ad750c4fbafdf27e0b7b85fa2334a8bdb727df68cab505a2832972488ba1b2b5d402e0aa59e253dc11ac8bd8787928ed40ec740a49419c1169535cceb8daae1af9c6d73ede2ec7dcb9fce6896c68475f05022b82775010001 \\xa2827c8ab4ea15b018797ea3b1919087a138d19981dbac1e64e2983b5e54828216fea96059ea956402d78abf1d340c0a41c6d1bbcf561b6b37b4db8bb66ad602 1672341975000000 1672946775000000 1736018775000000 1830626775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-318 \\xe7badb05e13e27ac1cd15385e489a045f2a5d517ee04b61f5244fbaedbe18f7f0640609f1b50d74e739cea432a64b60175b6b31f4101bdeccd7dd7b686c31276 1 0 \\x000000010000000000800003a5f05ce656e18cc8ab25537f654bbde2f045639bb4836e33179664a9f5b4aea1f72707f62ea6ea689ee5dd8855e2796726cb496ab2da6794aab3082639c146dfcd76b0e33a9912f322876697f7d5602db5b8ddfa356b93c579cfd75d397b882ad33345a0cf806a0f1f9e984c8c59bae071b8956dce16537162bc6315b4da1477010001 \\x41382c6aac79c312f294b41314dc08151f2999af6f6c71cc00670c1bdaefd2758ed17293c39e6c08c19dbdd7cef2201528db1ee738dcc396ebd61da770e3d105 1683827475000000 1684432275000000 1747504275000000 1842112275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-319 \\xe936515d3054db891b01056a8e378993e5185e2d6911077a3e7fcb0b746a242c647d767c399ca28dcd5ca52a9f4489b08d32d27ec70332e8a3eb3b9a65c95a44 1 0 \\x000000010000000000800003b9ca3350050cb762d6e83a08e04cc25fb7c9c30546c02fd8a8c72a2ddaecb844a930e4c861a0d412217f0d5bc7a546ce7017962dd052150c39105a73243e5a403e0792f8f09a92384f0327056c49f910957fbfaa0538055c4fb29256915d9a42ae349d3509b60392c617b6401f450ef737323b86473109155d741171823ee387010001 \\xee644ce1ab2c5bcd5d7954de898f7a8e91dd6b6eeb9773aac19c3d4bd565053962b7b5eb8320e44eb8527ef0bdb31850a7587bc2abb21bcb2298674530646e06 1689267975000000 1689872775000000 1752944775000000 1847552775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-320 \\xea4e969f01f93eab1b5b5f6003111f13dd5d0038edd8452c7749dffde5e016ccfc112572370745095042af02df059e5351f6d9c1f9776aa9b439eca535bf2d47 1 0 \\x000000010000000000800003bc5aca721f6bee671d3610264cfb063b775d5724a62e8c0d9d5bfa895e5532b89166ed001a7a0f826cb31ced0d00ba398f4d23dc0c9e1dcb19270173c4eea641ac3376a2eb2bfed9d171a8788416257d6dd2cdc161731f34b276b3c5c04ae9b7c4cbfa3fff2992ecc3fb675182f7d6962c5063fbb266117c90924f13be17add3010001 \\x0c76ce34de6c0b291e7a00dbcedd654f2648028f64409af7d8e7d05937bbbbfdb29c26fda73c62fcef84597b28d6fea4a79f6c98c1cf6eedafae5d0dd6382505 1672946475000000 1673551275000000 1736623275000000 1831231275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-321 \\xee3602788d53cfb18d19328d77ae672e37c721e408a37fe5530c6fbc86bddb68e640997314fb33d89ea6e471726125fa840aff1197b22ff186d500e9d58ae24b 1 0 \\x000000010000000000800003984b9b93f74e147d8aa94598418606e7e519ef628ce0b28fc10d92a7274e86072712723ba7d8c0bf20751c475818c2d285b87fe1e85be99cf65ee19ee175aff82359594913ddb44ce9f53d13fd05e326eed4b44970439aa315c3dc61e43fff31f154e59eccbde572371444f2909d0fa52ca06847cc1fb8afe0825fb3770b804f010001 \\x47436da69f7ff652d8d2420c99a94d888a94ff20ffd978a2dddb2cc06a78b5e6b33b6be5b202671210f09b96da4e43bcc7684864a6f575a29a2a853d5f547508 1665087975000000 1665692775000000 1728764775000000 1823372775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-322 \\xeea23101df6cc76f91e16b5c94dc71c7fe9bfe53126e4a3e95950c2b5700aa939ff231e8082e241a231d355e691c895d94a7c7a1b703b4e3291caadaab738ab0 1 0 \\x000000010000000000800003c9b4c6b05f883f9ecc41590c255a748315c120608ee286e0308c117670099ea6b82c1c2cc873aad2d75787865e7a9ead22b003ecac970211ea4d1ca5cc1b5152ef737b295678f1e319944df1f7cf4bc404db6bc4ef1ddbfe4800dd0052b5893b31d1934f5ce83dfd20ccccafbd176592cf225e179b8ab09c60a3907c6af87709010001 \\x3befea0924cbc95c0f6aee78432a0861dc3385d87efb9ac580ccaefc414158d9e14d6ba3391b4278d1751431c7b6e52ff38649c6e89129ae5e22ed70a74e2a0e 1670528475000000 1671133275000000 1734205275000000 1828813275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-323 \\xf07e3454421cfa918b71232f7c2147091c839b7f5fe4e7c08230911c3cbfb30321cd3a8b5236f14685826194f117741174a7a9229fc46697174eb4241fb20e3b 1 0 \\x000000010000000000800003b86cbc5d7db8c63324cc2ead35e109956165e6e32def23131359e9231269745c2ed9c688c36cff26b5d5494035417a8a85d36d8f10b96183163a22ee9cb941b31b776186b7e905b68aef868be09ec3a265d07ff8c98b39ffea536297079e980bec853a88c55469f661b9f49f4086017dad69138d3cc2d81a1939335967ad868b010001 \\xad9ac7cf29aaf505303cefd04e25d6c4f64affbce16aa3268cc517f1e6d330a3842484d24f248845398d3aaee7047930a51c6a61d5525e2572803407de2a7407 1668110475000000 1668715275000000 1731787275000000 1826395275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-324 \\xf016b7a5cb594630c9e0a5fc3a0d35d550fd9d6342a0fb87adee80f28af7ee8c0e5520d04d5ac55d62bd6b46c7053129b583dbc23a4b8a09c4dc215de2724a51 1 0 \\x000000010000000000800003bba41e69c2cde1f0ef97c957ef6dd4b9ba089bd9f8fa06360573bb65c1dff9520f1ac53e6949c0fa4e4630887bba6d69d1a8f288263a9a1a8294e76532297a7f76969710a794c94d38c036dac3f8480bf5430010ae3d69ceafc03d0b5aee4f3bf2c0dad83e56a32b708651bb0980d4e741373c07ed7cb16db890394bbefe6abf010001 \\x7c0ed298f4a2ff2519c32a8f3531e3a348b5da545880ff57ae44fa43c7729013574824998388172dbf949fc99f2d6648a256c599a6f75228e744346b80ab7709 1685036475000000 1685641275000000 1748713275000000 1843321275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-325 \\xf44643cc37af79f194999753081f094f3142e8f56a2660ac51118844421b83bf2e70758e2b221886d269b0848f7feed707c5efac1ec1c2ab7fc12d4042997a30 1 0 \\x000000010000000000800003a61c3860ed4aab80d50a82989d51b9173f8d30819a405a569d05a43dfd5f7f0ea80c395e3668de603d7f727018e1e13afeea66b8caaa75caf9358450d848f6d65053ebb86cac39a13bf36b1af926a9be641d46f5205a3376afe2ccc26bcfa0ce916368e6592157d2748fd80ce36a834d6d9e35225643018d29c56ef45bdde16f010001 \\x9b079e5a6064315946ff12358eec1aee5acbb76cfcae5400846aa5e330d3bac183eb1316c62d7680ec010ae622b08167fec5ed9a265720b5cfc46ebeddd3d502 1683222975000000 1683827775000000 1746899775000000 1841507775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-326 \\xf9f6e895cfdb7ae7fac2d4a552ca00ea6594525894642cd52a54d171b1ce172b0d7e4e652e3f26f1306fb690b60f34d023febc462a1e32737a197aca8c31fb57 1 0 \\x000000010000000000800003c30d05e19ead828fdea706803f90fc3d1e5030f1d358ddd100ef80d7d10fb922c1aee2ca6ace0301fb223f0dd9b48ce693f0ecb202c85ff221d2ec28b75b53c0dd4b4e5b3ce0cb49df5e4da11fc3837f05651f25cb971c49f5c37bc4fa79ed6d41ec99ec26f81be3b748fae012626b1938f1f284610dd83313c6e82cb861243f010001 \\x9f83c0c5c2433ee64dc33c9fbf74044f1ee1c4d69845c56dee32bfce4ad25478d8b2f83ed82690f6df0fecb265ab28b852082ca0cc6f176bc27a017780d61f0d 1665087975000000 1665692775000000 1728764775000000 1823372775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-327 \\xf9c656f15cfdc9da1a7a80375a03981c85072edf093f7f81385f0a3e7284eb3b5a8a1801fa7204507489f95fbed4585ffefce0ecec8a7ac12340cbe041395963 1 0 \\x000000010000000000800003d2b2889c1f31862eb91a888556b6f2812042781ba84b4436c31afca615debf4bdf58abf9183d6ae24842dfb9df97cf830a3d06a49356c815c9eb33d831aea0defce7a736d1fc887019d3ce341fe1de4e23c067bdfcb66bfdc33b3dad857babb22b493df1d8a773a4806f37359a09720d974468ac01c495988615f71fac633faf010001 \\xde97107da5736f747ae4fbd1cf7ada37769e39e42999ed5d59a9e8037d9aa175e2508172b28e08941c8b262159c991546d95d034acdc5784d51a3e47caab4a09 1690476975000000 1691081775000000 1754153775000000 1848761775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-328 \\xfa8eb4f25b05daa1de557b84f499986123767df4ec2a0b1c3e53165698fe96bc52fe47a5c57a15ce83ad37237c6b6d3b34fba659c4fca3dc60619bd61afc94c6 1 0 \\x000000010000000000800003a94164fbd1a745d6b2a8c07ec2d7bcfffdd15285eb2114a2fb044fc4e52283ab0bddb842b06d39aaf26b870d15ccb021674b4df86095845eacfcb3165bdc8c1ae069aff12da41a0ab338d4f7ec420fde1f4176ace54f1c2b8e7701ae8d3327da37f806b8bbddf2965622bb15a881be93fbcb4afdc0ab00691a276cf1d79314f5010001 \\x3f262834bda0e68a3c16cd50f947a0f8b6203e870c254fa52a53de33365ee1c0bc866bf260c884524054de10aba5bf351fc139786f063512d466674eb9a4d90f 1666296975000000 1666901775000000 1729973775000000 1824581775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-329 \\x0033d16b8f0d63255366db7df1aee44c45b67a3d823a35a34f70d388eb8927e4903540faafdbf100dd2d710d46f868006da62c9fddf370211ad5ee66919ca872 1 0 \\x000000010000000000800003e7edc72ab250b7abe16431341a053492a8a3d54ebff0551096d986d2b38baf35279fbf5e814d29feeb541ec66284689c23616bf7b7137a65f610a5d968be810a10046e85d2bb3c86aa534d65c4b25c015664c0a532fbf4f1fe86f0528f77a2fc25270372278b6b396421421c3fdddcbcca5749737b7ec4b7231ca2969bd98e9d010001 \\x257f2416f89044002e339834be903701eab16f0523add6a8874a07e302f8ccc86fe22fdee6c4e16a9d94d41fa8d2ad66448b3dbb921355cb27ae87d7c3c08a04 1662065475000000 1662670275000000 1725742275000000 1820350275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-330 \\x04ff08470c370061254abc396b43f7f6b68c447950e51f38f9b8128d11c66128c757896c356d2a6cf5c0006eaef02a9c81046a32c461d967b8d62edaf493ee72 1 0 \\x000000010000000000800003c9f60575c5045f25cd7ada86d11a68fcea7a751288f161dfa451406a0c567a3a69feb4865473246e348c21751b0229a6c8adcb8e0ade45f0085939127a5b58a69dddf29f63449a5c0f2495b0b331fd515d37f4ce3b2191b4b5258b4f55948c0885802c7f0e3270fcdf4c656f71be8d26381568bb3a573716020ed91d04da0b83010001 \\xae9276d4e1659abe98c9a5d8836565005caf4335053274e3f3790951b38225ae3bc0977f173a7358f6a82c66b75e38a46c8de91a0f419bf7a9f0748396dcdc02 1685036475000000 1685641275000000 1748713275000000 1843321275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-331 \\x060b1e64a9dcbdb76eb0c82f6555a98dc3e72ed8746ab81d45771953830da1a1d237f9d1493cb90d4276f11492e327a1467f5b5b82c85dd6f81bc0412d851228 1 0 \\x000000010000000000800003d324ee07008bff544ee474e7e5dccf3e6d13bc842006b554f0f26b3153bdae4da7111ae16d6d63840013ba398994370d018489982ca8fa25aecb296e87d7a5dfc6981c11ae7331fa840ad8f280c968423fd55fa19981781329efab22fbedf3844b0dc12dfb6d921b952a5fe5adb07cf3e3f0d895556c3db76714144187cfc3f1010001 \\x792889c948df1009ba3b899a26af0f446333e448db6dad78efcbb9079effc59409599ca9b82161023246901aebada289f3bf6abb5eb6e5cd5dbdc9c8bf6c460b 1684431975000000 1685036775000000 1748108775000000 1842716775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-332 \\x070b8d711f7550280855b4ff6cd71c3ad3b01f40917ec1e94dd87bb2a45ccffec9546fba1ebef284169a20798427f2dce6e68c32031fa9c4b97fbf3e7d8a8928 1 0 \\x000000010000000000800003cd9b43ee0e182b766f21340d367356ee3692f454e82bb39e6e467b470ec0538a279bae0633508b2b4fb26d476bbc298777faa745101f6a9c63179318674294ac99f91b905fb6baaca3344ba6de9de9ea921d95ada4eee3fb2166a5f127934aaa102639817a3b09be3560c0f9e5539d78da5c34301d22672a1bb4ab80d578cd61010001 \\x7a43cf7fa450d4643b7f885b19298d3fe421117432fbcc5a759fb51994054ecd31890410333a43c3685ea4d69cc8c10c797bcdfa05345cd2ce7833ab6fe98b02 1685640975000000 1686245775000000 1749317775000000 1843925775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-333 \\x0a930fc3a3b017a5cfa1c9bc906f9de698041fc1e828944edb2c7bdb7b74020e8a886cd9e9bb4e2e75be4e3b371825306d79e696f6476f8e13362be651b533f9 1 0 \\x000000010000000000800003b9cb5a3ac8d76a0a050e1fca49a43df4c659c4f326f96fc6f1a81fa3fe258f480f3fdd843fad5c610cf397541891bd1f576822a8c80b6473b488ec21fa3ce404d04b82a87c3040f1632fe32a84db53b9d9de250e7934de81c4f95608c0111b677ae43c7e7599efc50735b71fb67e65db77cbd46cb2b16d42959636ef59b55be9010001 \\x46d3e940c48c5d3cac2848655ec02b015074bf2ec4e659f7eee150b2a784988285bb1042767122ecca288ee0f5fac4882507b6c928a1a9b86a00da3b6e87d502 1672946475000000 1673551275000000 1736623275000000 1831231275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-334 \\x0dbb9f8c7aabef38e7f3e784bed528c25e1e72929c347a9956b2b46d8a12d3dd876539f2f0ab8a2434e2f9805115bbd5da755f6c638ba953572c0213794b1bcf 1 0 \\x000000010000000000800003d896a7a7e7ebabf2f3eed46568e16443005471ad17ba791a94ad9f603ad814fba66f31ce4757d5789b02a1ac1fb1a2d9ac72a6c5f917012fb21036fb974935541da8311ebe0c23bf21d5f6cab9cf594aa22214bcc9c3b9ee8a17ff1c72afac9646125d370def55ca99452dee72d0aba689415a3be76d20f8fa3cc39cb25a6c87010001 \\x10dcc66f7238a61dc8bcb03f072e72f0b1ada11885163aa708569e1af6538c10ad0a0ec29de959cdbb9a4cf796dcdbd8303a0ce4c22001176b2a958c6a9e1e0b 1661460975000000 1662065775000000 1725137775000000 1819745775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-335 \\x111b2af74e0334da2db0a5032b15f1a9a4090861343d220dd4fc37fc478458e3c5e80a0b266497a8fb86f9ce6ad52933e57d8a9d0fd7d73d7eca7f4346d15789 1 0 \\x000000010000000000800003af1a41490678366e09de9b26eb7a884bd2c46f5b39e7edecbf8c4d90386e195786e0497eaec9be729e154485f19128973ac3ab0fb37328f74159b84bd7940e2cc87f98591c9ad462b93609906def5ea7eb9d8e4b86a490fdc4ba90bf382b67ef3c4c4ac362d0c26f9a510b912c965c9e57695ee887a31c48d03466b6e02b2409010001 \\xcb4bff1bcd36e4bee25ebc01ab26aacbb22212c0e1a55691385a142c1f276a5320971e7f1d7ce0cd9acad9fa4e7cc14c0f0dfeee872932c5a51edd761c25550a 1682013975000000 1682618775000000 1745690775000000 1840298775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-336 \\x129b8048a030bd559a4fc6bf4379c3494187223d719cf599ae51d074780f48cdc35d5630ae24dfd375d9e61352434d7a69fd47299a16163c5f21f0f2e16995b0 1 0 \\x000000010000000000800003d739fb4703883d17c50d63530c6df4387fac67f963b1298ee8c9f6c4f86736ed75c1923c27ca854489018b9f35c8a0308891fe5844b531a4fa65ca79a48e78bea1ef55bc2648707e7ee4d5a842faed9c542242e724916f8ed16003f13c0484ed3cbe5b0ccd9c3d42ba74f905ec3f688126d225ce140ea820e5249ccb0d9302b9010001 \\xa519ee593e9a4bc3b3b7d582b2a94e80f2fd72aa7c40e0ab9a6d0dc8c91e6328e0e66aff3203bc8bf9d86203732b1223980bdd9bccc0e6e76368119f6a508c0a 1660251975000000 1660856775000000 1723928775000000 1818536775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-337 \\x127bf3d21ebe09006dcc25213a85788c7a20a07812d227547db33e787604e0ca82599b6c9bf78afbeb2d15f517e0547f16e7930ee0f64843a0eb64d26b1f2c7c 1 0 \\x000000010000000000800003d5355a6b7c087cef07e4a03f55d0d5aa2ad4c5570a2983f0734546006cfaa38f6acfd0b51fda038875fc39b7a5870f50bc18dcfca1e52a10af68daa96a4e92ad372c50e85beeaac7a4f8d70a0a4c5706942d6ac0af45d8a0c327ff65b9154e5d0cdd8ac562cc9b73b7c750273309c7c27868676e5e938556dde23f8d0b6efda9010001 \\x8499b43fd715451d7e8f1a392a126b0db0ab6c4b599a39ce208fedbbbdfdd41d6606f2107bd890d867fc23a8d091db4fb5f03bae55096283324d6f0c1aabb409 1674155475000000 1674760275000000 1737832275000000 1832440275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-338 \\x146f3f286cfd7d4c78494638a86cfc74ef8776f91420907ca24920ba793ba46d7d662109783dd9e7592f5314f6dade1a6dbe4e6d0a03ad116798b925cb8895ae 1 0 \\x000000010000000000800003a1b87248a73dcc002a4864bd1216249888226f71f43669f1499e9f09128f16fadd8275d496f94b2275ef10306168df32ccaea72716348150e25d9830e1c072c62dbe509a640a2e1fab7c159dca739f4b70efb72dba0d4a52d4c4bb21a9f17136617e1a976822f42767bb61e77d1a7a6b0d00de141846b93a6c6377d27c3544a5010001 \\x474289ad245f27d13aa0f30a2403ddb7a8c488867fdc4c23ebcbeab680f118287a4db381f73c45d6cf03f65a7ef3a24d1b0067de594cfcc4216b74f8ef055c02 1666901475000000 1667506275000000 1730578275000000 1825186275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-339 \\x19df0a3468a712f2406bc7514dad297c1772edf3e1a25057953740a9ad5bb022207ad45abdcc7ddb3dc54a59d4a788991646ffb4a4f8654f6cc6cbe5182e5ba7 1 0 \\x000000010000000000800003ccff2737932b2854e0cbd0195f2046fbd9b6c97c9aa5b9071c43d3856b2fd3e880f27a7eaf912da06e050c1bf5ac1bbc633f615d3ded0771629c050ce8366fe52043a84ab4bd300d705ac2beecfd13fca96cdfbfc590089fcebce1b692b4904bfd0929b01fd2ceccca81e9c38133d161ba96228842e39fe3106d1e6b6cb2d7bb010001 \\x13ccfca759f4dcc27cfe92a2e22d5053c30dee693c50385554d3ea296c7c0926e6e988a01ccaa88aa7917cdf6d2af3b0157c45b911b44d2f89c0839b5dd1e601 1676573475000000 1677178275000000 1740250275000000 1834858275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-340 \\x1ab3cd56cb99887862cbb3dde24bd46a9188b297615ba0de0a55a3e1686219bda31bebdcd3a85bd8207a546a656d32e1d16d059e1644325e6f135e7c8ce6daff 1 0 \\x000000010000000000800003e8e1b346871d06710352c78f32c3e9d0e622ed33f6efc5a84cb9a76aa9bd924c6ceb8c5ccffc38378f3790591c2ad1257eb783ef6b0f22d7aabc734d325be3bdc83865c18ba00813a2124f494dc4c0147271736c9ddbfd5b0e4e7431df906ef5a0267748db391e11b73cd5195b08168161773ad94f283cc215c541368dff6629010001 \\xf533e6f36af56e66a9b130d2bdee76853749cbd1f611d69910bdbed64a244a70a181028f252a358d6c8b4acaf43afaeb1545f025e9962b537326e6d60c0eba04 1674759975000000 1675364775000000 1738436775000000 1833044775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-341 \\x1b3fe4b8a7d75c79f80a534d57b8330bac7dc575c4192e4b8d8ab9454f4aedddd2f4d5375eb073cf8276d3edcc89536a4acafde2e1a32673760e2ae6f1dbf92c 1 0 \\x000000010000000000800003cddb1778b2a5ce8c3c514cd20b82ea8f3e5f65fed2a3c143bda89417ce72360119a321ef034ad43dc473d107e1f3026aea8bd29ed0bc1494c546ffee6fab362bb3fcc3c3ba0f3f121627ef4e5fc3f0e87e3d1a66f31d3dfdfd772aed0ad0347348e71dcb8a45fd3930299391fd3f55beb50f5e1d3d28bc81aec9775839a992d5010001 \\xf09226afde6225fe4cf514d4d6df6105515c78b3138556d9202f0408bb2067f7a9413306c357216e35b49689cb6b86c6bf8d7a8b1c56cf30ba92127bd5487009 1664483475000000 1665088275000000 1728160275000000 1822768275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-342 \\x1e0b26527188cb17abe3615bedafce82c7c220d3ee604cfea904cae0efc16be6908646b8197486d1f3aca60204058db8f8c46f8cf6d7c52059825c59500d26c0 1 0 \\x000000010000000000800003afbc80c81b67ffeea1abf3a2fb234c650c84d496b29336e2763dac81f10c8393fc69c3769e3d4f859112d3ab7537f2bb4d0247548f1da16baaad74ec5909f3c681416256b1e30cbcdad94601854caac82a8ec819ba4142530f942bb002e2e24d56125a59e5426b3e94e9e559c52dbe15800f2fd23c3e3d3e568bac43b35e3337010001 \\xfeae471709ec835a92a0284054432b5cadd026fccf2167200ff064132915570ec95e5fa0783ab4d158ff7ccf3330b6d55193fd3ce8d691795db1bf06fe74df03 1676573475000000 1677178275000000 1740250275000000 1834858275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-343 \\x1f93079b32b4bf42c1d7863cb8d6720ff7c5e2f5b29e487ee9d155d069f71a75d804b81136eb68a871eb8e7fdb7d0038105200def6bba7e8a2fbe6d60f5333a7 1 0 \\x000000010000000000800003c8ff74cd7f50b45f4d6a85478b453932af0b87918c833b25cdd79ec9f98c66e50728a5544e92ff013f3bd30b2f016ad8c335b45437db73d448fe3ad8563bd3756a5839a1703b2d4131a95f44f803ff47d15e2088a46b53a0caaed908e72980d09911531ee5096eb91b28598c3bb5306683b90964308bd2ee02213c5a983feec1010001 \\xc35c76bb3ac44fd866a9b4e1e6dd495c30498fb84eb2a62883e6e16509f477f93d768397c91ac4781880e4b719b5cccbca6ddddc8fbf95e7ba2405da18d6d502 1673550975000000 1674155775000000 1737227775000000 1831835775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-344 \\x1f533872d26712255eb6cdd3e9f9af7faf242f414c22e0a450362fc33e33374a5d411cf850095068cce7598be1f3ab1f8c98cb82d9a7195e8dd0b20a1f73ae0a 1 0 \\x0000000100000000008000039f13563ba310f5b1edd26dc487b869f4e6a52bb35e3b61a20d1eb9e04791969ab7fdf0307a10e7c64cd9c3d099d45af08e507bc020c67d70b3a4512f41abdee998c192ab633739b1aec78026ab37b836d25c218d89ab0fa0de413eaf99a87caddc9c4662a479b94ecbaf05cd8ecdc61e588d3472cc0cf701f3407da65b03b97b010001 \\xd8f4970f5428dc9c05804c1cece262f3fcc6909523f0b65940215a035bdc1d538438d9461c53f746d14c70bb1c88be635fe39491b55be9b79ec2dab45286f70d 1671132975000000 1671737775000000 1734809775000000 1829417775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-345 \\x267becc2db8b5aa8ca0eb7cd3c51c509921e61c806d49ed9574bcf6a4bec4d95376611d4ac684baae9e0e560237bff9aeded1c7af6fd0879cef22a16557afea0 1 0 \\x000000010000000000800003e7cbaec6b26117212c16dbbbf69910dfd0d31b2e018fb7f8c327d3320ac74b1cfd85feba0d5a8279335facfeacba6b7cd6300cfe13ed1061c970de5f2d4172c22b21562c11d419026bb408ea97cb94c2ed76ef85717c8ade6833336997a48d53a9f452e9313733ee899779fee6720393069a9f8b101426a3ab6347facca63f6b010001 \\xa3c5be8c407711e4adf454ebc232085ccc9553997a5d00a8644e2ca2e81254225d51c7b9af05e6f5131e78772160a1bae4d86976d04f4bb105da80b60e2cfc02 1675968975000000 1676573775000000 1739645775000000 1834253775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-346 \\x274f162b62b4c7ff02264d5b091465f623ff50df1692f5c52906aa8894eec854a71f60888e23922da477f2b8f54b2324a220389261d33eb67a999dea2ca1ae48 1 0 \\x000000010000000000800003bf1fa3bea62286ad757807b823f63ccb7f93745cd7063a832a2f98472197b02aeec372be73eee069ce8e96fa17fb624cc560f6684d4d9188461e72353bc06c254b577f6c1a3cb0be484e92c162888aacce1f230d7c267caae573a2933b42da7e8d62c1061270fff3606f099419251f2bde4b8ca96397a3bb323b58590960e25b010001 \\x3579057ee36a27fbff3833b811ac2badb47e176ff3fe63f25685ec35724f3bfb2789399ec1ff2c003e83cd96700165003d32e4d88bf6069e0e22246568b54f06 1660251975000000 1660856775000000 1723928775000000 1818536775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-347 \\x2a37408303db7e213247ae6fed51baae8dbdaa4ab7e67cc0b47c0dc6b48758b83f4536c5cc08af45ab88fdcd065c30ab34a62224918780a872beabeb6b740dcb 1 0 \\x000000010000000000800003f0076a5272e88e45379e21370feabac7799b58bee4f7e7433939263e7efbbfb81aa12f4bd3ddac329f552eaffc2e81317f506ebf2a0e02f74a64424c555b08b7325fe4d46b051860f59d5e969fb514659a789a1175a248e3793ced82d2d7ffad6315903909dc405bb6e069a80281774e7d5d69588b7c98f7bc4da5de9319ebab010001 \\x46d96501b731d7f1231e9493978a7c8828e35975b9d3344366bdbaa53fcfa820fa89fb3360fd74321c956a040fd35f719a4e75b9d3a790f4de2c85333a932707 1685036475000000 1685641275000000 1748713275000000 1843321275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-348 \\x2def4b22e7b0e95dedb6e3c3fbe3499f9f1d1b153b8a41ddf64642dbd393daa4109f378fc1f2e67190d2f101df6b20bdd83ccf55c5d28c525b653403836ee3ff 1 0 \\x000000010000000000800003ced24994be28458a376952db5749afdbed7afbd4e4c38ad811c1bd6f02bd3835a57d5e49365e06c68bda46b12853ab802170960b240538ea00932e6579e6cee90579b3bd107e1b36f91bf6bb951d33a2b34a70552da318799b21d4c01490e278ad203f0c0ae328f5e8abac9dad74abb7342a236a1bf267907992b76c54d38d6f010001 \\x39a2e7cb0b0b255891e78b8a2415acf7e60812e2aef31c9b07796a6a0ddddb0c0e157225f3fb3a77283908a49e829971fb5e359162bc99bc98f8d2f7d511290b 1674155475000000 1674760275000000 1737832275000000 1832440275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-349 \\x309b035828bcdbe2becc031aad7fe14856a8bf900a6db98fd2b4105e0138592c4fdb708a76b92bd7a8ea7779879233e670bf9158794d00e8e8b804cf2191e1af 1 0 \\x000000010000000000800003b2618eb24d731e1b6aabf861fec200a9dcbd9cae6d26ca36229e7ead1d38ac41caf864c2e71c441351f6158a9ba7b1f03f1c1bda26840d7137397f637d2d7636ddae74e9b68b906a0f43458153061848d9e4af7f630e97254293ed721e86a7067738a8f21edfd28eca7d5c4e2d0a8db41a95b4d6598b469933726db38d9dfea7010001 \\x00983ebbe44920b293a3cbd573525c578c4629a947d6700f44f28ffd4fb5d0526c71cd512074a848e5dccb716aed5bc009ff9a834d670d1583eba85a307b6409 1661460975000000 1662065775000000 1725137775000000 1819745775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-350 \\x30fbcefed71790750d967cd50137354e88d06ad033f5cf2777817a35170eeeec1339d371ed4652a190c8979e1a722da7d0244d772af482fbe68a7c226c0dff5b 1 0 \\x000000010000000000800003d4d1615071eda3043d91529b71ae5a9742efacbdbe80374e7903228ec687e1a1b84903fedee15c12ac086f0c9b0d898949f002bf2589d750f938ec7db6435c49ae0c02c6f7697f491f4069e5869c1a27cf20ac3982943955ff97d813f6effc99f6455991673281852e3cf4175681dd5063a160e553746d7cf363123c2c35fe63010001 \\x44d4cd0d0cabb634b4b012c609aeb10c3fe9c7e45956a154658a48491ab2157dab3216e98f18a05610bc1955c643d739d3f578627f5929063b11eccb3abd600d 1677782475000000 1678387275000000 1741459275000000 1836067275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-351 \\x30634599b703b7c03fed5fecce4d7bde0c0ec92d8801690a4bb14082e33f6c7a83037e3133088b98c68ee58b4ec590498f0ace3be0d82a86e92b07925eee66e9 1 0 \\x000000010000000000800003d81fa62e00eda20c0a8a75564470c8d2cd22ddb8b50f743d7ac9955be676d6da023a3cd6529554da61900ee0b3a1b466f2eb59942d655a52d2727b38a3f2c6e69256535aad4e4f9ee9e877b15a03ac66efbaa36e85c385adfd5d7316a817e2c44985bcdc3e43467d6a897fd2abec6b3489cc3e5a1053d8accc4dd206320eed59010001 \\x14427331eb2a94608430c392effde50700c5d0be1cba36105252d5b09ab2044f1af75dff8790be52db06f13d0f1e1caa68817e6a99eb1025d1108a299cb17907 1674155475000000 1674760275000000 1737832275000000 1832440275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-352 \\x318705b897daca2cf57ac720919769970fbfe2f5d7c23cf43736bd73c732514417efb0e4317e817fe6c63c5cee605aef8a1c2d8bb0ac00d7ebf7517d31064d44 1 0 \\x000000010000000000800003d3a62fc1f6919b08d625b58767dc5b8aac0baa9dd7032409a3088c760efc2e9fd1a1f70a5256efe41e04ef1e65baf16809de1369bdc391147344aec21b29e5427f73bf157d86225d28e079d605eb64ffe5786d5e918afe2a93b2462523b23ce61002b4af81e6aac3231c58adeeb5ab459cdaa2a22ad53f51c63d9783aca3d915010001 \\x1081d59403f6ab4e1f46dd8220c58b735d7b78d299eda91638d26a184a90a792febbe4aa5a5911e2d613543a7f10e676990e6a3e855068813195cf1af1faf40a 1669923975000000 1670528775000000 1733600775000000 1828208775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-353 \\x320f89d249e721506947590d34b14f2df7d925f817018f0ba7690b613685428b21b27c3f7cc2904b153f882ccc62912698797181737bc78f3798ff4e221a8c4f 1 0 \\x000000010000000000800003b11dfc0b17c69a7ab53bd804bb66c2f35ff2030e7084f90725dda5e2d6be4d2a8f2827b0467f215adc2e5628ee844d909348f66e3a4414a9273fd2012089f308c82823986cc27df3b47861afcc68b12b63fba8f085006ca6ebd2957fa89ded40de6b81f548a2ff4f9fc1647db5d4a7cff52e0abfcd4e9ad560ab4f9277c0dc4b010001 \\xb83cdd8fa3cb074b2f14da32e915a9d7639a489d9dea8c9020ffb662b743804143e1ffa3ff69bf49e73f96fe104502d196d02aac827c72e012817c7f783fe50c 1682618475000000 1683223275000000 1746295275000000 1840903275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-354 \\x334fa2cec4b537e48fc80a1109b2723328b1fc1e1b38d450b4fbfc14ca63782435d88cdcba51e4f1d4d2c2cd88763d0a409f1a41a15bd901c67abb46646c90ac 1 0 \\x000000010000000000800003a9eebd75bcfad6e41ae8d033c02405c329213a48bc98ecdce49312670cc4c13332481b969c8b5bbcb0af86f6da4c94a2edbac635a6da107cce69a8be8f2d194b7ad96d49fec5131227847534b45aab0ddd87a368f2cb53ccab20d0a859b1cf8bf84b5195384791682b0b0fff5ca28b7271486bc3fa517f342bde98de5936c18b010001 \\x14755ed5b5c6f5ed1cf9e79b0b095fb6cdc098378d5551b76a07839bd1d7ef362d71bb3efbae9c123d54042138350c93dbbb64fa23b6a19feb78934efc286e07 1689872475000000 1690477275000000 1753549275000000 1848157275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-355 \\x34836154fd1e75cfecb7965b3381a66671ff1b172e1521676129d83389ad6860459f5cc100ddedb1bb7b17b52e85b0a434807eeba1f2c2852339104d42ba14bf 1 0 \\x000000010000000000800003abc2f69026c4bedc61d25837a24a2a97f3128eb821941786c491ddf5d414e67efdf95dfe26009de155596daf772f496fcf6f63ca3acb0bfa610d551dac2ed12e17f4a02aa91e647effa393a565cbeb3681458dad152a221b85704a458e766d0bbb11f63a5e1f9eca1711c0ba1281a9fc9715f5bc9c6777edc2a07b70eb6fe259010001 \\xc8567591fff0da19f40febef5706a9b08f9539520613ba90d7651159d09c5f4ae43f8a38005af8ba398e463fd731c4fb2039c1627891046c26bd6cdbaa98c90c 1665087975000000 1665692775000000 1728764775000000 1823372775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-356 \\x364bcff3ad9db34aecbec0bebd71cfdd38d2679429919ab8086058e72ac6716337d5d301c9361a591017bfefe22acf7ba7a98d53ceb05258ed356266f28ba7f7 1 0 \\x000000010000000000800003ab48217dd3ecc67838083f7826811cd3e5a6b0c5825f552a5b240f02e0195aa2cb213574c71a1b4eb59c97b7b35ce1b5250ee4bf107768f7dd34cee81a359c7b655a4d181c097d38ba6f153e10906822d42d8e8f949ac16a454f9ab7fd21e88dab3322ef5cf3adf79dc8de571e7237df94dcafa9cb45fbcf8038d8913c183cb5010001 \\x1715cab37ff5723a704cdd02e03c4f4f1f5db9291c039bed88e9c3d3f232a26a9c6b9890d23c8aa0bdb09afc80467c1c39809f2c11bd03f4cd4b5669f6b78a0f 1677177975000000 1677782775000000 1740854775000000 1835462775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-357 \\x3827011bb8ff78897f418377a6ac9b1c5d38a6bb05e658258aba64a92e93f918576732e86411c74a71f8a1a6482571379906ffe034d97c30902478d2556e3815 1 0 \\x000000010000000000800003bdbfcd0e77af55200b97c9e3ae7e369d8c37391b10c7e5ee3007f8350bb6fb3b1e098b70cea602075a9164192a9395b0b439bd7a3276cc15d981f768dde4494e20e207bd8ba714fea56d08369d7b552ef56a13e626ecb2cc4937fad1e18a4e6314d71605b824c9807a2fd59b37a857954ffc5ad77bc65ce628de976e5888db0b010001 \\x01d1eeabdadd24461fbcfee987d39ec8ac6652fbf7731300acf2b59f4b69aff3d14985f9fbe06024067ee0e91cdedc4ab92a22103b592b5a8a6f9cb2f1641c09 1666296975000000 1666901775000000 1729973775000000 1824581775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-358 \\x3a5b23a245296e315114d4dd8e6a564901f0df9b7aaf03add9d9dfe55b20c6c484e2766fdc6b1a5544bcf3d0fe79d7b4b9e61dacaec1842bb9567b4f13bbab2b 1 0 \\x000000010000000000800003aebadbfc68ce3bedc8549fd5bf78fd621b47636e072e27838b2e97485c92027a80fa3e7e52f231ec1f237a3dc22e52fc9224b2211594f6de3fe82ce818d9483bced0fd9dbc93e9ffa40ced61874a890df9a648dfcb968ec213cbd3e9b4ed93ef44acbfb4f1133fd9ea83ccef5e25d68a2c9d105cb5f2a88df33d3a7c25db93a5010001 \\x97dedaba71b1ee4a8b6a2396a88e9c791e3653f8edb8874d3e4b454fb8b06fb9f0c31a6e69511d2de914016d5c95bc1e4e6b6e013754e871295a5fcb8bfc0e02 1680200475000000 1680805275000000 1743877275000000 1838485275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-359 \\x3a670761db3ca6cc41e3c1f356e352c03751995fca525d62169fe83f4ced753cf626cd6b1be90047e3c2eae348f1b4cff1a14466679d33d48db0d084070800ca 1 0 \\x000000010000000000800003d1d3169e4af13d8aaef5723c8fa94b4830dc3d97a1eb38d2344352d476bf8f20056b08c5972d791e7f51ff4ca8ca874ef5b487a7dd48822a4ea10bde51775db773ed75a59f617732c7826ebce5bf6cb1ae5c5b0cbeadf040283031d6e5a49017fb2a3a982eaaeb1bab88fc14a1ca462865b4a58ecee173580354681996a8d39f010001 \\x22522a407b3b319fea55d2ffa9e03c3e21ea31dbc2f24b518191930f42f8e2915964b383646d5b21df609a9c5f8af69e61bc59bec1476de91f69f7bf1e4df10d 1688663475000000 1689268275000000 1752340275000000 1846948275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-360 \\x3d23204835d65f1c1cfc837fc0be787b5b42609f9d3a23ade80dc0c5743d98393f426d5cff800c9ab4cf9d15b2d1de50978865024090237ed7b3ceb999023f37 1 0 \\x000000010000000000800003ccc9c1261b5bc7716867545c01e084a6abc295e532092830e7639798c413816ec8baabd8583b04f90aa3f3286901c49cb1a1f19a18e2ab9c6d970fde053747fa1b37991465ce431440d17ec5abeb98e0d7f76097fa040727dc9c2c655d80937e747da454e9b3f98610c87de59df7e2ae3954109e9ee26eb8fae82261b246a4eb010001 \\x3beee05bb1dc804b595caf6c84664acce1596881c69922e6fdf148a3df1e8154c7c3e329d1cef776dffd3ca6bacd31c9031a5bb006a962e743f51e12cc26d600 1678991475000000 1679596275000000 1742668275000000 1837276275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-361 \\x42271e3fbf420c42ad5190666eeeff60ea689c02ce555dc23ddc3668dafcccd718b581660a01b0ed3f82bf5682563b2c2d3d7727c2ab8d3f8d548eb9356d64e2 1 0 \\x000000010000000000800003ab6df71574390c6a83787bec34c110acd87570c28b8860d6ab99b53d12056fd927b9d07cb64d81cd2f493e62da37d6e635ff8ec847fdfaa5031ffc5d001f80c54ddf32ccdf146f93dded94679a4472a590b380b0ac38d93cdfab65f98afa9e8df0abef440e0c2caacfb44d314f557467ba85d6973dffd9738f3b3036596c2547010001 \\x75ca753f4c959fd853902e3baf7c65e45287c9efd4121dde09d9563a9412151ee5fa2ad6006727e4b035afee26ebd1c7ed076bf784173310d5c198732be6f300 1690476975000000 1691081775000000 1754153775000000 1848761775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-362 \\x421f129e4102f695c953d0f5dd9179b2762497caf764aaf3eabcb9e3670a720d9bb4752ab15afd7e49ad798d083222361e51893108b2cba9c56b02566a3df3b1 1 0 \\x000000010000000000800003df1e276c8059c557b4ca34d20026dc6f201ea769806b5fef0a256e906a98176a6db71669b523167ab26acfee158e28c06b312946f6828344b17ef28065ba09e32dae43c93c8eb08e9296942bf1228ec6ee62176ff88b6f9c7f75d576692b70dc140b4bfb5c6dde08adcd86567f79803327249c9df68e8017650945605e1c50e9010001 \\x02b2e0000af55ddcbbeab17e4e12006e4f3a44e90524101f39b00299c87586f8bc82ea7b5d5f93b6ac51b38a71a2c92e17bc2cc247448a95d56ef6fffa252801 1689267975000000 1689872775000000 1752944775000000 1847552775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-363 \\x43ff8e5b60c2246332b8a77de39cf70756f0ab6b4bafda64010a179924b4da35706e77f32c0ebcebe25bfc77313880f8e99a5df0fed7b975ba2077af2525461d 1 0 \\x000000010000000000800003cef50ae893d8e42bb5788d7169b12542503b384409c1b708ced3e38f3ce07e11bd7263885bd23d46ae0e0abb834d3ab2903dbf62b814e010b131a84ad21e683e951f1411075f8fd8e0d938ef78739279573c401fd6c7915f6e56b8b3145524cdbaf42497d300030c886645928bf28f8aa97153daa9fb251bb41758d4fdafa651010001 \\x1edcaa69792d2ffa1cc2e0ba65797aef2d1fb10435f70124ebf1f957dd9074a21738e0c399b9b85bc724147ac49f564ff8443af57b0fe2c18ce9585131bd7b0f 1675968975000000 1676573775000000 1739645775000000 1834253775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-364 \\x48cfa19a4c6d7bace90178601709932ce1c70c52c0741d59496ecfbb8099420273956fc7318aafbe0338d5e54233d2ee5905ca3557ff59903318205e25b4ba61 1 0 \\x000000010000000000800003bfa97fe3a5551c311ec69d7ff015cd6d06a431d03c4da8ee30c423994e5e3c867a78ba0bda65c87e079c27708cb82ca2c1e81ffbfe04c998650474b16ac7c81b2b44a1835eb91cfa088a109696083a93e38fab417faf1212939f10e3073dcaa2347f0c5bcbcdf818eff68353702b7aeaa996adf591bcb01d28fb6906d23bcb3b010001 \\x3f2cb919e22fc228fc397982cd54d7ce39de1cea7224420e4edcf7b46df09fa66b4f379021cd76937384deacabc65999d9724fac23fe064acfc9bb511b151409 1675364475000000 1675969275000000 1739041275000000 1833649275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-365 \\x49e7ba916d77819bdf85b555a7ec37fe72cc2c28057c3befacb5f6c2230bf3ab2336a83fb7d986e56b7ff9e7ee685ae1d15448f784b155dd5b95f39156321210 1 0 \\x000000010000000000800003c2b22b5642cd9508119a5c27f9e31db9e79d3adf843cc2480b7e7bf231d9c9a64c859ce8711cebbad8f3e730378a055ab27974fe555eec41f981f8c59706885b84afa6a28b7bd1108ee85c50acb40a5500047c28ea658ec77392e44ec7125a498da456e75d0c617bdad53f2c062ee984d2344b6d6a9f2f773abd0f692b64dabf010001 \\x0dc941d89508cc703bc0d1074ce46a692c3f05a7a9be1a148e73b8ee17029fd1dce5c57f3e76e6655b27cc537523a7d3ebeb78809a199c89755846748a77bc0e 1674759975000000 1675364775000000 1738436775000000 1833044775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-366 \\x4d23726e64dba08cca08072118f49779626b8b03f1769d055eeef0d4936af72ee2c5c725ee99c3d08715bcbcb8ec923af96675d1ba9eb9dd0b158f4840a1300f 1 0 \\x000000010000000000800003ca1cb7f432b376bdfbfe19d52674d3f30672a010475af79da959baa703a728de5a697438cd8e127e212a6db1c0cf3a13ce493910f88c66b83f1c4ed542cc1e19e9f678b251f8a1da01bd54216fe9506127f60b2bfcedfabf7e9751d063b281246c350083e15555a11ad1657106630e990b171c1e58fa0b1099fb966ca8c0edc9010001 \\x8381ba1d04cc19a8f3cdc9752807d12c4c3d4e2632c693be8529c8dd3a8ee9ec50bf1ecfe52ec7b3d2321e1a6ee36b0531e490b9b9eeb29c1a64f5ea1708e609 1663274475000000 1663879275000000 1726951275000000 1821559275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-367 \\x4f5bb574016fa36f888f36da679ac4b8fb88c9838194bb026650b00d53de71b51aa302006df93459e3957fe5954a426fd320346bb615f255a4603d2e2b922f4d 1 0 \\x000000010000000000800003bf8050bd60ea9c61208296e5e4e30c10788f8d8222b6bb82dcd212c21bfab23e1f5c8fc2b00d2fbd956ac87748e594239aa2ab5d8699540115f9efef2b11aec11d9f4a096855ce73e6a921e4cb9b5382480f1a11799154b0cbf8a58fb5a1af6c33451e8584c718eaef194d51d6652fbbad49b5799a46061615315d0bce874e77010001 \\x511e5ee024734b8eff32c67d475607d9245992bb303c44321daf310dff6e261e8ff5c66b886ed7fbc7e812370dbe84db2a6a0d3574ed0a8e424d2b677be83004 1660251975000000 1660856775000000 1723928775000000 1818536775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-368 \\x509393128dc90504e1fcdbe9b7fda8a9c4528735d412badb6d9db64ee91b9752360196f52d1bce39ab5016d1ae4fcf42473d6688faafdfd8fb498feb2b91e6a8 1 0 \\x000000010000000000800003d4f61d0b39330014b8232371c14b0d02e44a8bea2f1a7d7562fe317628378f496ff6f6cba2658505c28d1d6305cdadca10a6a9248318e298df803972ad4b8e9c5ac436d1323490c1dabc2fc04378ea8b9b15f0ce31cb52b9164e7fab28ec8193e1d73a9f3a1c3e05c05d9ce40e4cb7ed805b7530163d911866cc65aa7160607b010001 \\xee10b310590fe17aa3dbc8b03c46f309daac6f04279c6184cda019a2bb027203c2b05d0b7eaed0ab0b320b0cc8a22a2954e0f7848eac71f2bfb52ab56bc7d30e 1674759975000000 1675364775000000 1738436775000000 1833044775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-369 \\x534f10a5c1df73bd4779034ce55df26d23ead02c57f0a1dd50c97b5537598e6ebbb7768ff10a6b6b12c3ab290f469867c710171358d01dbf482af17d26bb8871 1 0 \\x000000010000000000800003c547af10b9791fb76f5b361584de6775102df09f2fb35d1cd049fc765a0bd3d787620582aa7955896882762885c2decc35105e68f0b3ca85e7d5c4b57502033259f4ca9b2be437fc5032b4b5dfb4ef5c50ec6942996252ef7316ad3f58642949ac6fa2a2408e7ec0eee34dbe3882f023e885b4a4d8fdec76977172e6386db69b010001 \\x5aba2110dba4eb5d72840cf36221ba98f30fd4ed07f1ff8017f4ddbf6c4090206ba78da37eed992e4e3322d85fc86d947eb4e119eb7d30813c4bc18b3a4d8709 1680804975000000 1681409775000000 1744481775000000 1839089775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-370 \\x54fff0a19f3c274544463fd6c727bc695212abb3e75630a046b7052f6a157ba7f0de3d1c1369cf2c31b38d9f90e432ca0533b1940e41e5ed33121e1095c21bcd 1 0 \\x000000010000000000800003f3b7523d53d28a6fac26d4b73ed734936e931e21aa4e039eda98077e93f8ce6b16069b75fa510563c6f56e9832b5eaacf0453fce34338252b1bc762bbfe571fa8b80806ba2439f5582d50ae2cb8dbf1b75cbde3b3ef1f64eed0744511cfd3ee3f4bf7eace221386034ab5b8fb9bde81eb0d718c36ac63a763b893d7c9f1eab8d010001 \\x7c37d13d5aee9cb751514a9d7f1b547e62fc9feac9e11dbcaf3edeea157db332ee5046a9c569b97a300bfa5568c4f99f25566a66a9660582e66bde814c5ec50b 1687454475000000 1688059275000000 1751131275000000 1845739275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-371 \\x5717a606dfb47b934a7fb5b8e189a6c1e0de25747f4e00a68bcffbdc7d53053970dc88cf116063b5aa3fc38dfd4d0c5d635466b04df7e544d81a2d546ba9efaa 1 0 \\x000000010000000000800003c8bebcfa5944b3411549dc50cee3ee7478e854ab84b7d0bb286ac0f7234bfdc458b65a568428a1674c6ed47b08edee6199684fc8bf99be043e6d38821550e7079d045bf8997649f9ec10a3a3037ab07376e79d34b6ac3a3111b544ab9878532f79b56066f362a48a2a65b7aff75897689c7dbc6f215e8c684794704f233840f3010001 \\xfe4c148630731280928aaa9e11f4062b32d10fae7e950c27851cce3a072eab6b18d96121f08b895c921fe1fe3ab2c58d4c17fc5976192d97ce5e0fe0d02fee0d 1668714975000000 1669319775000000 1732391775000000 1826999775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-372 \\x5e0b2e60581984f22c4f4c4b54d14a6e512cfcc906d4776b28a1e20147342e190991aef344d9bfcdd654fb0d077046ef3332fd94ac88ef302f0f6e8f4365dfe2 1 0 \\x000000010000000000800003ce53c15a45fbcf40b92ff0f632a142100ea84c6cedd70ab1a0ce533a8f29a39fbb36e309bd9a0bcbeb4802110af86065075cafe1e873471affbbe6e25de8a36eddf10e02b200f7c20bff6f4780250a70b102c1da5e1b9b3a3cf483803b1ee601dea14a29ee923e6094fb4a6ed6d723d0ccd5ff7bd0c4a2ea8a1affc9c00ce559010001 \\xc2a14254e8e97a0e23eea0cf737bd3e08f10ec77a769fe43981ca9ef6476052819eb81e33aebb9b23bb13ab439d5d97a4a707d5c324022201c6eb090bce44105 1683827475000000 1684432275000000 1747504275000000 1842112275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-373 \\x5e7f9b0cc4b88ee5cf32fa26b8d56610570636222af8b27fbb659c7358e255fdc45c4331fc0627da34e77d4f684ed1b6824deb9ca160fa0248e52eb25212faff 1 0 \\x000000010000000000800003c06ffb83f1bf011d13d0a913c78549ba3cb92fefd5cf5ca386906e99c759e90f1b10ae7b202250dc8f678befdec5af4ec7025ee1a230209b2dbc011b07f42b6536c39bb274036ed87b0433e85825895520517ae26bc79a8ddcfa5be3e1ed74cfd199147a5520e9fcb3371e5d5f278b53a6da3ddc8d12b8bed1564d1465fd0e13010001 \\x037d362a3da47fe350d9ae0922c004640ee82eebc275d5bdd6e0d4479595191c9d1ed7306b17569e5884489b1185c1824c15a47a715db5298f61b15ecdc08f09 1674155475000000 1674760275000000 1737832275000000 1832440275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-374 \\x648b9a5abeb74186020d618482329414fed52a132501491a35fbf2dc0810b95162ea56851fa2095fd460456d0fef2b7dfe72aa58c176f1b7c241ee1bcf1fefa4 1 0 \\x000000010000000000800003b5bdf5d8add95df81eb069ba460a6eab4745c25d607539fc10b236553302ad17b4c03eb34684b292e57a426457cb9b76c1def27b5130d849d861ea53a9c81b216b6d11ed9cc1b5737072a24ad673eca0b39c10688b861b120b8e1775a2ebf5de92dc12489135f7274f7ffb7f51d9cb9aa98c0f6e3c87e895b4bf37c3560d36e7010001 \\x0f063ab5f5ab00fa889210d088d7707a9f2e39f318701b5b598e5a98254f849c10d95a4266490e637cad9874d0477744e315897d7927546ed0ca8b1c3ca45f03 1681409475000000 1682014275000000 1745086275000000 1839694275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-375 \\x66837de78fe0c73e9c437cf34fa85882e788c6c748e2e13010aa59ca390e49ff85dc1cd1c79301d1860f89361a2bb5fc2aceacabacf3bed7e61aa07531a9698f 1 0 \\x0000000100000000008000039bca19e826b3a43f6e3c0f89ae255c1adf13bace31be75d4b0d179e04ea9eae40f152019e5795e2d5224d0041b26efebb93f61df0d02e509b12aa1fc1c77942eac9a3f8b36ea770b8f5602e53318adb52446397436be4fcea294f9ed8c63bd024c837972c6d52be5765f1eab530afc4b376894002dcc94f0e8af4f44d8576989010001 \\x012372ad38dc3050e359cedbe337f7b7863083918c1bf866247e58772be751ba7305551632824ef02794eaeb1c86210e888fa82bf683b58779fbd6a688fb7e0c 1673550975000000 1674155775000000 1737227775000000 1831835775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-376 \\x695bacf5051ce94189a1a559297546c139d5f1727c3ec0560aa4ac4b462e360fd531fe1e38ffaf114034de8bf1f06ed9891b0ae5d07bf0f34ee4a6d01a3e0953 1 0 \\x000000010000000000800003e78364ef109ad080c77fbf10e01c2cf70eb0f0c18bcf20b13754db45e368598d44344890b87a7c4a03f02e6ef14f9424b019cd5983b7604144aaa45aa6b2bf461b9b2ed6be905605eb35cf4fb5e76aef9494c1feeaeaeee44f5221aa55df72cdcfa694302b595ecfe70c581f35ee2cb6f9c88e043861c94e5143648601bc355b010001 \\x547771f830ae65a21ba938925812e52ae245d276c74f2fe2bf8f95249cc95cd2f81997b680315af385d7d6c4f7e1bd58a719a52c979b3b5b71ae3fbca7b1e408 1668110475000000 1668715275000000 1731787275000000 1826395275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-377 \\x6beb31070f09f35be05c5fd0e1a01eb48fd7e500254097a4d193498f267a18ea96f52452102a5538dc0e97a5b1828e053495d43e7d200e5fcfae2cb2f9b06a5e 1 0 \\x000000010000000000800003ad589de2021c336152b912720ffa1729c2ff190c660916ee2a25f13781f5bfabf7ed83be061effcd7588c16bf7a6580998f5a9cb1a9200aa0b3876e9bc02975481a0924d8c6713e73444d4e9ff4d7ae4c0ff5b93c7745f13eab8876f7c8b67ce69f3720ed03773880924f5a8e1d45408217183e0ace2c83dc6388fd7ee9a7279010001 \\xc93017554b034cd87cd431c9ce64d1783f16d644ae567ab0850cb214680cb3a2dba1da8eb5e235240c33434b972199aeb28e9974c7b976ef2a0ab5ee8f3bd002 1661460975000000 1662065775000000 1725137775000000 1819745775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-378 \\x6f9f3b4aa6819784d591c6734185bb4ad4a57d16ea025242bd8e7166cdcf8e43340c43d22b37d810c2aa041828f15f0925712d2b1ea3a7edf4c6992039abf23c 1 0 \\x0000000100000000008000039b97435af4f851c3ce42111ca9338a85aedfaedd3bc0bab61ec983a06b2bad3113f09ab7556a270e665713a90930930b781581298c6f478633d4daa90fb81c3ea841ba1d21544fa61e7edf92b3b14ec25fae4d65b01fc2d8573bec0dfaebb200b2565374b78e6323f91269e049e335910109beb9fb0b5d313cf51b3dd34d5ded010001 \\xf3dc5c55a36d9e2a70b5436547a398dd67b3f94006fac366ab8ed1c113e7ad1fe8faae5bbca27aa0cd9aac41f38c7a04aa9d03352d3c9afbe0ff2497fbe1bb07 1665692475000000 1666297275000000 1729369275000000 1823977275000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-379 \\x74bf78df21cd359c9a30ca53484e5d42530ffc5fb37e5528f074f9ca6d57d087ab0781edec64012e3780ee827375d9ca1366102843c64a31a7a5ca51b18eb5b6 1 0 \\x0000000100000000008000039b425dcdd9880001023641e6081671b01f61d06d8149d7885eeb0e5ddb3e3bc3ddbddf12a61814a55a9b3c746fd3eeb12424c88d07d988216bbb75744990b3900b82938f714c690806eb571b92ebbdefa8ac09be10871548c5836e0c56c900a082316e058430db2574113691613782ad1b6966fb9288070902b278e5364494a3010001 \\x600cf4e4ddb930f586f7797cba239dd832fa69df28c5fb410deb2643c6c3138ac31501051b2853aa672024a0f84b28fddb7c11588b9ae27ccc374d26254d570c 1663274475000000 1663879275000000 1726951275000000 1821559275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-380 \\x79db65ee0160bfdcf5e71344b0cb09b3aa2fcae4eb48df07b83c223a87243119e102bb06da519c0c7a79527fd3d460b5cd0ad0bbfaafa54404902e38a5d5b6d9 1 0 \\x000000010000000000800003b0fc975aff41f68b1977d5850315c6dbf12b9a61ac95e1564aa7a2fd37540a9f27aa6b0fb78d0f6b269ea82aebd52c4e151bba78a59d5641e6c94ec03614453fda16defc03a752b13b42eb87912946a5a1daef41d2f88bd53075a7735f42a299d505ad64660f9962630a2a520f9d8291f3bada76ec72fffe328abe758c6d79ed010001 \\x922d2f9a292916085367faabf440bb3198051476f1684cefd24d0cfa9c20d79be3c013ae880b9bc42e5b8c7502354ccc4eeaaf0a6de10cfaa1de82a09b71a10b 1685640975000000 1686245775000000 1749317775000000 1843925775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-381 \\x7f97e1affe1bbc0f4afeb6f44a77c5aca551f7eeee82f5fe79eb0a0d8ffe2a7ccc48d7147c643ecce48210034084115003c4325a2843ca816cd5956c7b75fd22 1 0 \\x000000010000000000800003ce930418e547beb6c95c87f7c30c92eca7a170e4f286ce4993352acccd4557b5e3e91701171703cd03832e9f442fa1768f6a194874ec0ce636399f2693e5dd76ac7f5e70bf9da7b4573ba94ce817ed916a16c11fcf39fd98c25b0c0b8ccce5bbe477ce6d50c3a5446877d6c2025cf0a28b06e4a47b26a72ff98cac9fd1b8815b010001 \\x79a945a9b7c31a94aa1ca2ceb931aaedf2b50e842b6463cad3bf7e835501eac006a7447e92d492ad81e4c33f576f9f204b3d953b31a4be6567b7d33f06574c01 1665692475000000 1666297275000000 1729369275000000 1823977275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-382 \\x804f44d77656ca439d555a82f8242ab4a3f51fe4e8b9de248e461f647ca69506bc3e9df07244dbdfa27bd468d963c90359302b1ba1054b7b04f94e285b04a09c 1 0 \\x000000010000000000800003acbbb2a3c464e517ac5ee91c2b11ec0e0327d1a0bdf7f535e79060ef91ee7e778b74c8cea47412256a62d6c0736c4786b1f8d2d2eb76d25ac41e068ae96ea378f2b80be5324b6b826fe08665d4cd356d634e5bf0a3702ae99f18e3395871aa9f26bcc8862673ef8c543f66254d15c0d778c7144eaa9bcc13c21cda561bd6c8c1010001 \\x5a76dfc298b599446ffd754fa580f038908591a884f31f3c26daf20f34c90129e7e34fe15443ae4a2a0c5936d986dc9caa8f87452662d86cfd4603eb02ec7905 1688058975000000 1688663775000000 1751735775000000 1846343775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-383 \\x86d7f2d26b77d7c59c01d7f37a7505d670c71ac16f4381ecfd965955b1f7f2d99af4143feafbefd9f1f3b23066d3df60e5bd834c4f5f72215c80b9fb0c41048b 1 0 \\x000000010000000000800003a0fa3b504918d28a32b44b7b2e11ed8f70f60af55833841b50e1371b10fd3321dbc420de8f11a7e2df8b298dc8c590c9a327652b73749baee426df4fc573f56bd14258f8cb0046966b2852f6b42236195dae8a68927f6ed42f6059c45213cd95543efdd47931786ea930c099b6bae12e58e0429f216e9c3e494321780d57e1ed010001 \\x6e57055c2fd5eadd9c2c16d112ad7f0025f87b35bffa4311f0222f942e472c919c773c233e5aa857a8877de154fe18dee5aa10afb6ab786426c03a2b125b890d 1689267975000000 1689872775000000 1752944775000000 1847552775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-384 \\x8b9bb733b5b6b73a86462d05cd61f582f9db41f5c0aa2dd803086f2171f41777856b38f3eab093a875b595f5d689d8827a2b971647b3d423185e87f48a70c2de 1 0 \\x000000010000000000800003e1201c60990056054152592167767442a655e66d412102492eae6aebab44219eb5fd78a92f336e2c0b3ae6afc4b4d7cae1f32d33ce9a78de7c048b3b16c71206464f4544f87934154a2f1db93abf4f40b27f59060014690f68554ac04a3b13395a75311cdc66eef0cdef05dcedb5ebc6df3003df088cc429f5f2014fbe0bd585010001 \\x28e83ec8e9530774d0a5c1f540b33a45ccab69383b81da623d26d40d2a3b4d4bb7edfd206e9ddb66502b2594d2e33d6d3e3a7d76dfe10ed9fb6d9e6d3cb9ac01 1666901475000000 1667506275000000 1730578275000000 1825186275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-385 \\x95d37a2595ed3ec72185c2e0722b9880cef5f091b7bcb67d665d1cb4c46b07e83cc5bc6cc73898678f4ab768a9652996b577f06336a56d63697422aaf8fd732d 1 0 \\x000000010000000000800003ceba33db0a64e0336591bff61d6fcfd086e8e8080454386a70bcc3fc3851b654729ad9c8ac0466efcae318f5f0f8573a6ffb7f5a476250bbee9173cb1def4f2e24adf469c836895dfb9ef4e891ff39a1491f09483a302ec5f936f2a36bfa004f3f8419aac7b73c6f3e91d366b6798d2a0370ef342182149f925d491700a6c4ad010001 \\xb2eb494bf46c2286dca927b555d5ca367c6e9eefc9093a6f7b495cd7a052d2ef51d7cb3afa46ad7be566cfc2e5384c868e79a38e0e5ad52151459772a283480a 1683827475000000 1684432275000000 1747504275000000 1842112275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-386 \\x9dd713cfad0bf56df828f2eb7bbf29b89ddca9e06e267536ef5df0a47f4a22888d342222435ef3ea174755e9f0a5b82693ae8b6678a70acabf5c766df305ae47 1 0 \\x000000010000000000800003d38caa90a7f660ab1248c092c7f4f21f36ed024f84cf2ea75bb256dfc0fbaed00262629935b1bea87e981e214cfc4e91f60fb759808ac6a05e042a8c1a5fd8fed487f7c6e8a26ff725f24cb7c35dcf408ad05dc653d2852013b086ddaa3729c34b507c62a7affe7ed788e67e8ac69c5f359bfbcab36537c8ef77580061a55bc9010001 \\xf48807ffcc988608ece42e359013b2d74da4dc85205b4fea3c7b0212ee4812bb5eaa2c1c045edb66752c3bc1aede5a959574c54ff12eb25ee3b2f2236e5d9b0f 1691685975000000 1692290775000000 1755362775000000 1849970775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-387 \\x9e533bac17454d15c4193352ee20feff3ac0ec407f82bbde9404b795cc4583fae586dfab154451a80345e79f0131a0481a415c12554287f3e2ebf11d4f92c094 1 0 \\x000000010000000000800003ddf8a1616e98bb7a4ab058f72a8a270c9bc0be552c5292997efa93163ad96dde98f0f5f6da7ef25b505d20a0a7d9141c354a6f2563b68069262c50a1c1940be880716c473ad0a729b84e4f4c438ebaced5c69239887f1e9924bba1ee705b4d69cbcfdcc061adc35f2ed6dac98ba21a19b2e2ce77ea7964a6c34144853177ae35010001 \\x4906f62561fa8ae5255b9f79fa694cc90aeff391678474fa7dbfd3e88fd5e4521e4aff3f7ca810fb6cc987e33283531ce6cacfda044fe8304c6655d276c0ce03 1668110475000000 1668715275000000 1731787275000000 1826395275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-388 \\xa0d770b3bda0b97cf4418881bf38f16c54a235b34df4d84d3dba9a1cfc33ed058ca51b1aaa2086460a2a255b2935e9b14557ce572c5a93c2aed94b36964be968 1 0 \\x000000010000000000800003e49e9ea967b4e67ed8cfd4e20ffe928362765dd340e31932e64a0a3ac211364251a40e4c94a3a05f562fc04b0698ba19c46f23ef3e363058c1bdf6aa67ef90450a8bc3100cb30a30f3fe2e2cb7cb30b166850c1d116dc24f0720d6e0e2e27cf4c6f3b78fea3c85f33e0ea404852ef8763af5fcf7f4057a868217b2ac6fe4a39b010001 \\xc513db67b5e28f206e03e199e656d18793b789efcd75b66fe053ae896889f666f0349bdd00fcff8b11705f12e51e395ca659322fdda18710a31880f7e386f90d 1669319475000000 1669924275000000 1732996275000000 1827604275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-389 \\xa0db8ddb1f269c24835cadf42a0b2c231e80190a13c30a910e8ee7badf2a8685e714944a46831a63af1cee4950f7f948b9c730c6d3a387f24a4da89522f5c6cf 1 0 \\x000000010000000000800003a7ccc2843974894b67dad6327e8efc08857e0b90760192fd704c6deadfeae99b3070e16180c5c301f4fed10e1494e7cb9849455a0b420a2e3f762c2df7115d237c20c25834266b8d6adbcc910cf24db4dc54ce71d555a53fbe3170db15e479603f10e5543259c77b770d5b456617823537d555ae86e6fd53c746244ad30f43cf010001 \\x15796f4096394f4ff008af15644949cd854ff839c1aa43241b77d6de433705e88d1a958d60fd8490424d802279dc5c33e42c06c169a77ce32b12c5752bfa1205 1684431975000000 1685036775000000 1748108775000000 1842716775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-390 \\xa077380affd4a0105956141fe4372a246c58fbb77a5a1045da9949798b05d326ddf0fb3c98b46a473c79cca5275d45cc63fb12c153de3f369ac32df730aca769 1 0 \\x000000010000000000800003c19b5335bf15a63309a1a86e33fb04a797761e24b803a58e88270f1b301cc7aed5a70261fa2b1dc66a77f0f0bae3157bd6d4f0e1d25c2d98273ae05432d88fc034b557235fa96287a0caf1b37b527c3ff39d7cb5f34384ebc9443c78f628e0c4dc60d3eaae62b95f66a60fdeae8897a910e89722b5a89dad84e2894bde06b52b010001 \\xe68bfcf2c4e1d7700c723317adf52218a7b7d49c1513a0ddd335133d8879fbb3c97e8de14ee277f1d3ffe9cf4a055f20fe947ccb181f3c1906ac73c32118120e 1675968975000000 1676573775000000 1739645775000000 1834253775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-391 \\xb26794a6db847d457ace2df2bb2fbe9c4a810ad4d3603ffaaea0fd9154a0f421a911ff1bbc945ea64a161e63ff3dadda9acf531cd3e28436349b176d4f5c9bcc 1 0 \\x000000010000000000800003bf8290ad81d01ddcd2e64b8ff1537aa4ea6f7af531784c6c408e3bff655f8399051bbed56636eac13c33cd2da01376cadbc3bb8486cb7dbf42a7be026f4d3530a6b881d83f4246c2a87d4e27a72183b410027df8ea6f412b61cd7c242849ff860c62e9819ef5dc3be5f5bf1d51291fca3b64fdaddb8f8483b329bf219ac5a0d9010001 \\x0e434fb778364ef341610786c326948fe3d25cdf80ba4653f4dfd467185a8df8ec0fea59a8754dba47a23fa4a6643a76af16ef0c726daa6a6fd2767643cc2503 1688663475000000 1689268275000000 1752340275000000 1846948275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-392 \\xb5eb13c57bc288de86ba798c5de7c13905ea50a26d33225b79d6319bb03a0686eb9ede0f6e9d0144793175442ee208959efcc440feaf274390bc10a071be9fdd 1 0 \\x000000010000000000800003a340acbcf05e59cfa7c82b9f7b0b8340512976062fc43140a83245f76d5d412c8109f7702e486bcd238fc417cd1884fc46d30e6e284ba831f09554a6b0e7530fd3878af33d1c6465d725c792b6a37e2d19055822624f51fb6f7c4e719aff0edf12c20913d929cfb797138bfa259ddb8f9605e30fe4304e782cbe271ce25cf73d010001 \\x50583ac8b96bca2bb714d491780154074426ec8454a03dcaed235531a292cc54334f237e6aebee6edf5e149f6494e5458cff5d18b24facaa2474872766f9040b 1675364475000000 1675969275000000 1739041275000000 1833649275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-393 \\xb993d9e6e917ca1d1200ba74d310558b237369211382f0fcedf8dd9832f9ad974b46a3b8a6e07a37f0a3fe2a1aedcbd935c399442c3cb5c301835002339a3872 1 0 \\x000000010000000000800003d38d8d736fe04d8fe21be04eb80087deb87ed0d0a363a098d7e3e63940e209e08ca74d9491c6252500e052fd4e48c53f27cf97af3ceb51cabf975794cc1f6de3e06659280e263d113afb6b6171cda63f9035c13c6186ae9ec9a7ae2f55c1240351ebb8f1bc2c786dbebd70c52ded0798d42b20a22cb23908617a0dcbcca8de9d010001 \\xe72b86280af6b785fb36e4efcf695a4ac18061f75d8ce22b6605b7672dff42fc7d8ea3e6d59dfccd69a3e276e3ba2324ac77db1a5a20589052eb1c23ea3e4402 1665087975000000 1665692775000000 1728764775000000 1823372775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-394 \\xb9938a31cf8f2df386bdc30e3924243d617b63dcc8529691c9856fbfb5cc2c223b1006fdfdd80581befa8b82c301931c1044a9cee2462f2241393103eab7ebce 1 0 \\x000000010000000000800003b35b7e11d39af05a3e51f5222c66cfadfba56a667a05f3702b64acbaca6159e6df746c081b8f925061b5c072b7b599bc0bfff389e9f278185a8219aa7b46a57f5786f2f911433e37e9fc56a5f2fd1c10726ec01c7031d40a473b10aec4eddea09eac7120da40364c5a6d94b6e132f4bc0b7ef788209029a2dd09cd967a7d898d010001 \\xa91aeb931f9b3fcef9f89db82d7c4579e7ada2b3a33f2efab02a1f117f194c1e5ec5d3ec0ce230307134e87b64e8fee613bb6b9657f7a76601bd1f7d712c1300 1674155475000000 1674760275000000 1737832275000000 1832440275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-395 \\xba47fe7e21d3622ab656b2323ecb8d9b6ddf97aa06ab7983ec89bd4e393670c1935b63524d130db28195c851e3ef2de12290cc207022e7b0e0f177cdb8d4e019 1 0 \\x000000010000000000800003d40a7da4222ff888ba2dd2c057457ba496d46fa491a850beb495ae553f1804e7ddebc70893bd941936c4e7826205b5197541fac1e4e9babf9c6baa6d4913fcc43ed126a2f882ac4c60ff2f7074bf7f095f9a126a097c99307913942dfda5b75f604256f487ee73974b5f9794996e224bcdd3508bb16d4fec1dfe58c4b11954d3010001 \\xa79f387c1889582773ca180f28f705ab1949e0f542b22437008ec06ef755478a1a9e76975454f6e6cb4b43865bbdef42a51243cd0579ed541b1fbf548c09320c 1671737475000000 1672342275000000 1735414275000000 1830022275000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-396 \\xbd93fcf1234928680db7e5de1961c34f96db8cbfc28d7f5f2cb04e9edb09acd333659bbe322563f3614b29ddd92094ca7231480b40d4307875389946abe3ec92 1 0 \\x000000010000000000800003ad3e0bce744326621a4bc0bd16339e0137d90becfe64d95117633c9c2df3098ad82eb6d4e6ab7c995dea06ebf034a5a741bed71b283dc5a8de065e78c03fc2b22125e1ddc48749551d76ce44a537570b324e12a8b92a9622c6340e2689844ce56827985ec1f69b280fe6fd712107edf41119ad2e3a30e9be3e1340ed36f5df79010001 \\xc33087a87c2530580e48faed71c57cc5404c90694d9d298fb656b8f8f4e717660005552e4333ce1554df7d83d9b457af6e4f3084f8bb71134231b100b52c1c00 1678386975000000 1678991775000000 1742063775000000 1836671775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-397 \\xbe7b9c576fad48e1900e903e5746e00c6dbc401dfddcb5e09d9e6c6c7387c666803615c3b2e093b6a4cbfa4ce5a549fe8fcb52da0df85e0da4f303989a388b65 1 0 \\x000000010000000000800003ccdf9b7101b03912a08e94b59788e588a49d759923aa6320b93f1899406f01b2154198679e326750329b913f7514dda659a29975e4b6ffbb1ec476a1ce0267a2128c683cdee2e4ee7588f97679cf8cc0549a81d580e43f9f0a368bc83c409fe1a10ab1efe66a11b0384ad22ebad684d30e1a0cb12b043d8915a066fff9128e43010001 \\x76a0f08e1601df10c9a615b3edfe422919bb72f429d1b988985eeb7fafc74efdf470884596749a2e99b1d910a960a8c9878e79c5d4dcb423c145b40240860d07 1673550975000000 1674155775000000 1737227775000000 1831835775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-398 \\xc1fbbfbd8f8e0a40a6e4662a3b63a4e9d12cb777331bf96f62766de1df59c90b35d6302c89271fb13ca6822d4cc61653d6043b83289a098fe5ed130dbbc41a05 1 0 \\x000000010000000000800003c9b9a00aec21d302ebffaafabe7bb0cd8ffa7bcc6b691c46ed26840dcbf0b562eefdca2e7cd8a88b139804fcaa0bd32ca9d862add0531d344111d1d1ebf0b23ad1a1da44ad849c75bba8fa091f3731f95fe82ce41e21d5dd80a60dc2f71f9ec776cae16888617d457e66a6f41dd6bf27886fa0bebb6523e94b674b79970f1ef7010001 \\x94b2ecef0cfb12ab26a31d29553481dba37929ef846b4085878da4feb1a7b152aa12ef0b74232c8aa3aa6cf71593f02a5d651d0821e755598264281770193a02 1675364475000000 1675969275000000 1739041275000000 1833649275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-399 \\xc8a73453137a38ad5edff54bbf75ca62750907aa666ba6801a70c38dbbcb640305c24ef7c01e9658d27860af44591187a190f3b6b9f763073f3cc20aa4590e7a 1 0 \\x000000010000000000800003a3394677a612406cdc3d39bd86afa65b9f8440fadbf50e89272980998d9e2fe31ee10697958f5b049f6b68415ac8258a9c09abbd71c6dd75851ade8987a2a1a70cd2984cd414e27e1b7422e24a15ac8b1adee9875ae3e4ff791dc91cb1b5f59b67a4b93de8eaa6c905bd44aa1d2b52c4a21a0c25714602d066e9c58e1e798f45010001 \\xfef1dbed04142f98fa345eb83f65f3560a3471a73ff783958cb0f6c32d8624e7773fd3130fc667061329631cd46e5fe365701d0ae264f442e66ba26e9322c409 1691685975000000 1692290775000000 1755362775000000 1849970775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-400 \\xcaf760b5d9155563bd76a4d3b4b672415c5b5f6ce6ea20408e176d94077064c2f2c5c681234b8c1921496875d4d336996857a13e14d9cea13c3421bb2049bc46 1 0 \\x000000010000000000800003b1ffaf1fdcf8a3468f16373b8d216574513c525045d89fbaca279043da634688d7e5507e18730004d79dc9922db113e9028e01bd0c51c831ee00b885699ca59eea745cd702f524840d421db64a09071a22811ec16df064ee2518ab10337ca7becb53da9ca58a03998de26b3c8cdf7dd21abf31c7d3aa68ba64e7acc90fe624e9010001 \\x01ce5323412f3e0a6b18a5b96036f281f474540a7bb795ddd35429683d92be9c482b74652f5f07ef999f2add8a7d4138fa19862c3db2ea1bf1bb6b226abca60e 1664483475000000 1665088275000000 1728160275000000 1822768275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-401 \\xcd67627cc73ea68891706bce6cde119d8218962af4ffbca8f57080a6bc5abbd9009ba36280bb71b438508ed6f10a669f3016e41dedcd2cc987a97cca63458a3a 1 0 \\x000000010000000000800003e1c7f2abd642cf5a9255fdef859a655ba0a13856099adf44c967b2aff842096fc50be08ee8a33c2cb3e1b449d5d2a18072ddcf66e6d88eb49f7ff428dbfd75685683a53af8e7b0d6d37b0a04aa8e42bdbde0526239e500f7f8ebf98b54248334d3736215601eff814702a4b3a57eb3c482e221a592aa3836fe33e2f83fdf1ecf010001 \\x77125661e3a7bc687c95850c64c2d75c957b3dc4d3c24831bd43778a20628b892b4778fd964f564c9c718c359709ca4293752f6e2650db73926af5d95f389301 1683222975000000 1683827775000000 1746899775000000 1841507775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-402 \\xd0e3edab00f618a2279247ca9fd29b6865e663bb03591e1e8f5c2f16603fbebf8b9654b1b94a77f0f4296af925af32dae3dad3b3c9993a5f9e26a7b0811cd0a2 1 0 \\x000000010000000000800003e55912786cac0ec2d95babdd3fecd059b5154e352865df1b6f9f3615d1d1c1b43485788189a5f78703c121279b888d8b33b3da8c552f4228e031f258be7edb889712973d42649980f42584309db714471081acc46ccdc165aea0b346b10e2e020740bbf52f0c5e3fcf0008d50eeb8f9e5899c9a37a51983afc9c3fc4bf776fed010001 \\x25ac2c76d81dae98a88d3c3f23b8e72a4ec2e463b77d3b114f5bd03f8d0896dbcc8bdcb83c56ef7371e55ae455464f29ca6f7bf04b3553352654cedfe3cbdc05 1680804975000000 1681409775000000 1744481775000000 1839089775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-403 \\xd39754a835d4c9520048a85241e13bb3449a6460977fa9a164bc9e041a0b36165d90cbb1387cee32269b88feeecfdcac821a791d805ebb95097d056106a45e72 1 0 \\x000000010000000000800003d8211aca2ae49371d6db09ce790250cdc4518bc599afee3a0e4c436a5b10f352842b06445c79cbcfd62bacbd19418241b8fce7be5f978e76ad4e01dc32d2148ae690742b1ac064a9fdb9c8bd2b09bcecba75c1f614f968e6e59f908a8cd711b231b80f0b9a94de63033a26de83942af855d87a5f7ca8df4cad14f0d8ac362b2b010001 \\xaee2362c181abc5bfc582c16cc093839da1db6e61e2437c9ecfa3fa37b938691b2dd397e7f20da94a12bfc216a70a73f7f71de8a5eb6d0022d0cfe6076535400 1660251975000000 1660856775000000 1723928775000000 1818536775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-404 \\xd4cf44c78694185b45398edd0191832ac7a43b4ce353bebd3cc906d4238f08f9a970288fe9f43e9f34ac7f9cc124d18ee463c4e60699dc01dcb646f9004a5f6f 1 0 \\x000000010000000000800003ba7fbfb219958ae6b496506e23b9a822654170c17d73593de2b0cd9504da135345795f36e3e755aaf27eca70c5b110c7f0ee42875a3a8453dace1bfd8fe97395190c092860ad2da940a7c0d06e322324ad46b5916b141358a0f79c6db6bb62b6091af425ce9197f45984b454e16bca4335d2bde86911691b9840973de034b0bf010001 \\x5bec89f1dd85b744a33d8686ea77dc91785134fb76fa55eceab8407e1840022a8a8fb8c4dea91c9dc65f5dcee86fe539000fa5cefd9fb3f513bb85202555aa0c 1675968975000000 1676573775000000 1739645775000000 1834253775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-405 \\xd59b94bb61d7ae53f29975a5d4227415c787d2603c0c5335449fa950f308f3448995d9d6da4b539dfe682cab42ce660b1fbb95df104d0472aaf4dab1df5a5334 1 0 \\x000000010000000000800003c9aa3193f696e4b2e4987862f1a674d668d3574f2367c4b51a347c9ef592ab186b9bce636caa5b9b19a03cb54d5c7d99c1f15d081746e54c17b15984297be29077a4fe7360a8bf1edcb58c7cd83aa7e1211775e2bd1de9218cee5a73b2847711da5e1936ac923189cb468120aa621c8e227b377a4cfbcd534bd90f4b67a18d25010001 \\x3f580e7f724dae33d892c917865c1cdf66b987b70544999f63dfdbcf443ea86f0cb9ec570ad264fe918b3542f4e56aa79a1cd0eb9788ff5a4a5e77f332d61c0c 1671132975000000 1671737775000000 1734809775000000 1829417775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-406 \\xd68789e2343dcfeb5c504ba66d9894c30f43e1a7941a2c62eb7925529719b7be2ba25130dbd783ec3758984f8df5ec9c250d9e70867b0a706e62f4d588fe2e4f 1 0 \\x000000010000000000800003b0e960d76ef6abcbd384cce4ddf7741c16804231028d4d451b7eae87564e5591e3908ee2e2ecd259a1fdf2b1fa989d2b7d66aede3ca00e63689cdeb41f9be2d6436465c34c87f71e3ae5d45fcf5e8626f53ae9fb34ad56160a4715c95485fa23d086fa00b238ba18eae0a8b7880838d84c7ccdb7db081b0d3d2bb0dbbf192acf010001 \\x01d910cd7d1a4df723c6f7650c3e5f73c15d5f58521092d558e69a6dd02705acabfdbe1e61c75cc744b9ef928f2b40a9d1c96422b00c7682a2e2632ea2f4400c 1671132975000000 1671737775000000 1734809775000000 1829417775000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-407 \\xd607c11a2053cc820f760c992eca57d49afe4b6cec3b0b981ab20e3034ec2472b42d8c2cda4c972eeb614f4abd56e2fac0142a2f3f7b4973baafd5eff06ab7b4 1 0 \\x000000010000000000800003c1d19e95cd82ae97cdb57bb476a147854f7b33ea63caa5c908a84c0867ef0d7ef3a021dd93705abcb4eb8123bd62a5433f22aace187dca32ed39762bd6fb6cecce9ee3b6044b05aa40d95ff27c50b07cefab216e2941769ca9cf0f0e0739539e95798992b69ce52bd961ccd9372a39994c055eacb8584dc553ba7118e8b53d51010001 \\x1d1b0d76e4e101f309f34968c48a6e46541080ad9edd890770e8ad70386a7f727e240bb245dd72cec810017c2547599d316836525f913f3cbd722fedd337a909 1661460975000000 1662065775000000 1725137775000000 1819745775000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-408 \\xd7470a14e2efe2f6cc06d6e21fa976ae25ab81c2add166477c656bbd0ff6e1bf8df2ce4baeada0183e0d3e4e76315b50d5a562a25d3386a1bc3e0d4f888b57d5 1 0 \\x000000010000000000800003da0daed905a7ce46461f08966dcffa1ea0f5bb09df7dabe103a9dc3d11eb3ecdd0c33610dfaa47dbecc2a53185b718039a2e09778b21037c7f9cf5c40faf3c14ac0cf879743d845cc2c8c3eda45ad66f4e1396d9965490092c3d350895b86537aec7e48275cae7d42e828fdf1569eb8eebee3f0ca9b4c158c20d22d3c66288c9010001 \\xcf795d2454c426439a1ffe6ff82f8a207b58dcf888b57b404b03b13d0942e5650d53186f8d4127015c8861f341962694c483ae85b68a7e0906bc675727280f01 1685036475000000 1685641275000000 1748713275000000 1843321275000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-409 \\xdc97b1938f547a826c55d04957a746e123143210b297dd9d24c1839cb8ec0c6dce7214013a1b58b10aee29f31dd24823e3cbe6d8cecb9ea5af00b07515dff89e 1 0 \\x000000010000000000800003da4e3b1dde251eb978be205eaa0086458abbc43b2e83b39469ceaea6afee190490f91f8491667219f7b3bcfd07b3588df36c8ba4b5656212af7d3d8037daf235a6f4fa2a1887c0eea75184862bc1a3c2f6c4c2acb37f2f1b76a723c37bda6a02c4caa9b12e8808761b6173893a90d421761581855b47279b9ec1f10031c6a2a9010001 \\x212a8a1c611b73ec799db23c6b65665ca087925f351c44c5742045721dece66d095c94740d8f2a829a606839635c1931a62a6d7321f746550052838f55741f0c 1682618475000000 1683223275000000 1746295275000000 1840903275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-410 \\xddcb301a40cb258223576897f127468ab150b57b07c27c8ca2687bc92821508d515c3dd8c69d9779d128f640e0631d2adf73737c1403e7f6048144027cd3f7f0 1 0 \\x000000010000000000800003b11410ae1a496ae1b88b98615ad2e2a9bb3a104c273bd43c1cc283bd380ffe880b5c99b01fc9cd0bb902b5ce5165dcd8d9d1aa40f7c3af6557abd1ed6a1df42397925803833f5b93f3f680f973b6950130a32eb167e11d8c00b150ff23983b8b54ab79139a9ad52a03ce2c077dd5086c9991eec1337c1b6ea22f14c43cb6fb2f010001 \\x0aa38b35bc73548608d62076ae405b4d6f6cacb02dad198c9a0a0ff92aa5bb85dae4afa849eef1cceeaabcccf7659198a74773a12e067d69a7f04ba5fec4fb06 1682013975000000 1682618775000000 1745690775000000 1840298775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-411 \\xded72a80eabac22f22a1cb17ca40821633a098f3130ade772e81fc5014c257eae7c6deb84422f4c6c0eda43454cfe7e9161b1b3403e531ba07cd7a8c4c073592 1 0 \\x000000010000000000800003e521f0d2789d7390a6bccff665b8d6203e66fd2397ffa2d748c8173bd8cd592fae071b61a7b265de17dd0990ba6858de4235efbb3950756adec0d6aafd59ab6bf2f2c9496e0fa835c2092c4c33aa7841de47e756ddc753cb2a51519d6580ee1e25b58d35f9096ac3be28495c0d86afc0f18d629a75a4e28fcb3dd306f30e569f010001 \\xf84a52d9879e486c58a6812ddb8626b1dc5af624c6a65c2f091edc42d453e2233824e8164bea2f2bffd36ef0d18ba3b1ebe5d01e25313d1bc23bb792ddca7a00 1688663475000000 1689268275000000 1752340275000000 1846948275000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-412 \\xdecb698cec15bb60a05b2ae4975ee3b550611e12ebe36e34d8ebffd40dd13031351f58ca5423c70062052cf1ad686cf4f270b9067e56462e467b2b0eb33515bc 1 0 \\x000000010000000000800003d63b7c3e1b9ffd691ff9f82749f5bc72ae45c5003a6ec4aeae0560f0b90f66ced9454b7b8e62466ae878d931bd59184212e63cd76d3268e833594139d5cd1f6845254f720c9769f673c2f8fd74820f4a597d85cc0e498179cc97260b0c00687ff4e9881a0a85873e59f0e5f6f40cf11927f6755d4dd86106ef68954f50490887010001 \\xde8f9a46eee410921811c20d8881b045be8952ef9880fe8b459b9a859018ad66167c887316177fd766731b3c0a169e16f2db2ef6b3a578500ded75f3be381106 1678386975000000 1678991775000000 1742063775000000 1836671775000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-413 \\xdf6744475123a881838b72fad7f58fb134645793a8ba1d37c8e66f8626fffd1e303ad580c340b9647ca658d1e8a6389c74bcb9c7dbf96aa92bab4258e6639ca7 1 0 \\x000000010000000000800003b9405f35c7fd7b78973803e4edad8c77170ab8dcddac2c854cf05b11c0cd31e6f26abe82387ca38b6b13ab7154a4b06e0bf4a577b225c91f8f5092337f270db5b100fb41229cf230b40fad9ede1c950b859852cade2067e708b1f20d79bbbc7341f80ed6c0405d55b98aab03075f5cb6ab8977111177e0b1a2adcfd1d623d06b010001 \\x230f1ce715287ba0c004b054c1ee1aaf8344949b971b055a3846a218e92fbdf4b9249d161d153871cebe61e43162550fb578a1be57a9f303787e0a46b619f409 1689872475000000 1690477275000000 1753549275000000 1848157275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-414 \\xe5c3ce4a60a6e8136652d39281aa2fffca9e9e29d84611795ad6917ddc41fc941dcd9a575ebb91e6086bfd44764950c82fc1509bf837fa880db04d216f71c173 1 0 \\x0000000100000000008000039ec446b70a3fedb713811f8d6ec810ccc4fa73ce2ff11c4cb7b79603a3dd08391f132d2496a3447502ecc8665c8ed8db9228719f84326f65e976d2800bea8d46d78ea1b6e269e3b7e6e402dd9d1d1837f55dff263f810d0e349b0dccf956c2a92ab0077980261306e82ee3976b86bde2f683083ba413dab8b2fca926fe60ef31010001 \\x710f45efe645fe35d6b93ef8e42002b09f956800bed62b4e689048741df40bfb3cae49fd83d0e48c3d6ba314812cfd3c4de139ac5efaaa3ddf61b48eabbe9b08 1674155475000000 1674760275000000 1737832275000000 1832440275000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-415 \\xe9efaf2fbd62a0ed90f77fa7afdb577b0767145d46d518d03a097bf2272f4e84f8aa0e15960831ceb594ff3950d6fb995e56cbd178b8e684f96ee4530d215995 1 0 \\x000000010000000000800003a15d533c82739b64ef3c38d9acddfa9a33e753e5844c62ab2a429809cc7d25a5f8463c6b8a12d7d0d4b50db8520a7d3a0122fcdcb36d258b253084fc22eb59b7f593199645d4e585d196c826f152e2cbde43cd92c57aa7d6db996eeb0fa6e69b743de78b526f27870c5dc35b8c33513945eb91b58bad2dfd564cd02e4df8e343010001 \\xf935770919b3d82c76b4f15c8385ec74642e5b50a6c527f7d1767a475b04d79a2a49ebc2ddb6423b9648eca2431b83920e35c9b2835aaae03ec154f05a7a2404 1688663475000000 1689268275000000 1752340275000000 1846948275000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-416 \\xef4fe2b3d6ca2c719dbc8dacef998421b42d6cf2eb8b3febca56fc196d266377d9a3cea18a85c89e6fa50ef8e69546738e466b09f128ddc5156d4f1f5b547541 1 0 \\x000000010000000000800003a5ccd0e7fb3562e604442765901079fb25af1de993d680ab1a4ee4741a2e6292de02272431043cf91398a3f4131b9bcbb8838a9f6452bec9015ebfdf9e1f899decd5103841bba05144b9836d1c5452f27981b36616232d29078bd7cf25fcc97116f4ecbfb9779c5587fa5f603a68d120ac68d6d2d30c76b193aca46ad04438a7010001 \\xea096c102eba82e7efe7b98c0327d45fddec3c0ab51ec9d0c19aeac11fad9c87ebf6f922ae7109f55e68b6997c1076a37d5527365df8b821152c08c86ebef60c 1671737475000000 1672342275000000 1735414275000000 1830022275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-417 \\xf2830b6785a3638f0e8f062fb4bf773188ced21237e79cc796b846d560a6760464a7c957a25b8f485dc9e418d8865a5056ad50f0d15dd14d8b58637bd69e4e5f 1 0 \\x000000010000000000800003a0ca1bff8df60cdfd25e7c9ceec61628195d5b0277c4f5cbc55a4114c091323ffacd1747ccf76c18ca2d38ac8dd13f1dfcdb8c6764c77a0ac788b544b63ca53bd98b173c5e4e0eb063e9077e2df4192e997ce1a04041b0d911ae9ad4ceee13781fe70804f6470aa6c5900b85849f1df3be7df734fd0f8e532a36d0d062df82d1010001 \\xa61dc8aa278041e237e03e715af08ac020f16bc00dcec9961f0cf661e2ec1094be01c346c15202eb88e34a57d096460a5b84b2b72995bd8b3f6771b978202207 1663274475000000 1663879275000000 1726951275000000 1821559275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-418 \\xf32b6bf20f7237897f7379576f087fbdac94e303460175f0c72bd13ba6e4dafd22b0f08345bfc569e256662576656a0d7fd2669dafe21994206a7dcf4daa5954 1 0 \\x000000010000000000800003bc48d6156929096db389f8ff14256f797a65c848874bf4c41d2548c1d3d42168755ff9fe42aed84a16291e06890781840b33d9252dd3ac245abc15c0b00eb359e117581465744267dce50da6a7d62545ed1dba4c6ee819d7f9bca3cfd0f6ee798c547b7b44821a156001c5cf7245e1ea2e9fb16812b19734b275ae53330ed165010001 \\xffc580bdc08dc7e152e4d6da91ce6afb0d788f194f4077d491984617175ca8ceac2013abd57931863484ef999b74d750089304d8fd0e87db3d16780e21cb9102 1666296975000000 1666901775000000 1729973775000000 1824581775000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-419 \\xf3cb65aa2ce7da166604d9668383225755fa9484f1cc5084fba3d9690ee13c8b06071632816ae004000def19d00c791def2bee2b39eb52e7e8f395c5086efe12 1 0 \\x000000010000000000800003c280230c0895394dfde712f5a8f86cf998b5e0178a6c0451624f314806109b6b3c6f96925ba54a99027e0097a01f785bddaf511114e2ba87a6e8995f87b7c3f244036e23d2c10a14cd679506be4cc99e39b63d53c810996766bc8290e4ccadc6f995791e38c0dfa9b66a14a1934e2cbaa719ed9dac18a24f477a12e6e2692215010001 \\xe829bf6fc39667d61740c9dabe5f81025135e7b05987fd285acad891ce5335bfa4df0e480171790da38b80afae85acaedd799f045057c8082173599696910707 1665692475000000 1666297275000000 1729369275000000 1823977275000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-420 \\xf55b974b1caafc19ee3d14a2df2fb7da9586c38dce0eb8473f74f1f64b34218b20f51af92dfd8a6b9e6c70a8342b637e1788566d32426e4a4f8b5fb28642ac34 1 0 \\x000000010000000000800003cca4189bc487b8ea150620aeca0f77ba93c970abc35ffa39dc7c0c2c5392b9a199f9cadc35f2209732470aaa401b2dabdfbc366bb5521fecfe51f1f81b5aaefb9e10db03bd0ee3b356b4f485df08cee780a2236e57184b5f57d5d1995a24aa6ef641811b457a59af7a7312537b9c9ff6ae61fa9fcc709c4b0882d9cae8e00a49010001 \\x3eda56482fd6b4b5a9c1ed17d0467bf2f24668473d3137b7db3e33a5f31b281dbaa2fb5964c23bd8ff603b52f0080783a85e7b93933eda3b28be96373a3e810a 1673550975000000 1674155775000000 1737227775000000 1831835775000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-421 \\xf627ab64f27d9a2c96bd60a2ff87f640078c821c98a4c9674c824e356c99ab27c36777e730b88c34b9db198e499418b12fdfa1aeea93a3896ce4eb4501a56f78 1 0 \\x000000010000000000800003976086d63fdd6635fd86d83c8a4712cd9a34870610b303c70e6114e31efe2214d6aed64cdafbc93d796a54b7e2f2d49e3bd533e35560bd2b3a30cc5fcdfba6444e62fc13c3cff0e131667cec2b87d0cb120993fdc782659f5f1e261e6e0bbfbbe31f9965fe2f1a1c62ffbcd83867386211b34eb501bec16b3b841e9d043891cf010001 \\xde38286707777cae2f6e6e1941e45b11d77b992a70cf691ffbeb2180d7bda708ee229b7e9b154b35b291873b7c114cbefe0e8562dfe7dc56e577404e093e4601 1686245475000000 1686850275000000 1749922275000000 1844530275000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-422 \\xf83f7f9e78c5f7da1dadd0bda2fb7344a278af4a5d0c6c5ce84f107ae74a42c5bacbad11844c06a6620509dded74e36acb6848b37e888698ad13b00de6b7bfbe 1 0 \\x000000010000000000800003bd968a055b682d3a7ea26d7f81be1f116279c6dcee1c4c50413bfd5d981ab70b11303fcf79ca471162b372c0d36f42848a6a4ad97074daf3d9065a5e440b3c41cd8d8dbc9afed0b4937ef2b4fe074ba7a0c19cbf23de7241898f4b2461d4233938e64337d85f0c2a90c717ba1d258a0fe14976537c695d615d245839f2ae2289010001 \\x004420b99e3fe68b5372172824af2cd340df980cd61a75f3692bcb90b2c85496932f5289c942d2d01c3e546b0b8535466e0b57da35eff1ea2e9fc3c7dec4eb01 1675968975000000 1676573775000000 1739645775000000 1834253775000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-423 \\xfae7e93cec0e5e0339f9fcfc1de060538470d4197b8925dd1f625cd3cc4fdc5f1251f5facfcbf34b7a8c8f25e1ee7158af5746287127731640314b5f84f6b210 1 0 \\x000000010000000000800003da1f53badb5683cbdc90efc9bc75adb6e44bb1b898e699b29b8f7014d3afda66440c3e31fc946c7d08bf40dafc6bec36f75fdd68ec79f0ca7d2ffa95f35040bf44397d77d7ac8667702e83e9067bfe36effbc2c83c2d7272fb69cedbf839c2aaab8e321ef6034eef3cba2f5c6de8f316be140fd15a85cc55e39eaef5699f50f7010001 \\xabcf6aff690027e74b5b81ba5430954d3f8517e9a2d00c1de0eba1bc7c5657cde76462fa2494910f6462f2b08de7e9f37d68166c64763cfd3979d0bda7bdeb03 1688058975000000 1688663775000000 1751735775000000 1846343775000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-424 \\xff2bb516dd7dd14150f84c0f3d64d0e64ece4d825bab4f6793ed9f987614ea610b14e4302f64185062800cf0f4af953c63ae330ce457973f9f3760c0c45fdffb 1 0 \\x000000010000000000800003bc4f3535cd17084abc073ee6b6a8b04e8f52f624326735a43907526080a3e13cb70d6e276aeac0d114fa2a226742cc1321306514f1ad91f6523dc613839a026df3049f87d92abad3d38be60cf498337b1ae3a8e1fe5580494965403f8977f7470fd1ba00b1be10f900317bfe6b6f851ba5af1765fb39a9e94cf04526ce64b5ab010001 \\x974919a9d10d86bd2709be1ee7b89f8873d093f36407153fe625398f28991c901e343c185bf046ecdfd2bc07818f9f06ae86017075e7394b8755355a2eca2207 1671132975000000 1671737775000000 1734809775000000 1829417775000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-\.
-
-
---
--- Data for Name: deposits_by_ready_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_by_ready_default (wire_deadline, shard, coin_pub, deposit_serial_id) FROM stdin;
-1660252903000000 36447903 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 1
-1660252935000000 36447903 \\x017ffcb450284349856b997a0936f632297b24f9014d29a8e125cafa62343a6a 2
-1660252935000000 36447903 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 3
-\.
-
-
---
--- Data for Name: deposits_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_default (deposit_serial_id, 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, done, extension_blocked, extension_details_serial_id) FROM stdin;
-1 36447903 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 2 1 0 1660252003000000 1660252005000000 1660252903000000 1660252903000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x8441fd1913c230ce67352d8eb45d6c172a1b5e5855d8b46b4697557670d81e8dad19fe10cb06f98c00112665d5cf514100ff77d7319c87709f638c1a91092ce8 \\x612642465e96af3f6047fe5cfaa9040338e93c62cbe6249ceda8c89a9d7c87109c92b98486868e4ac160aac7b2414a5ea2ea735ab635112b2f7d0927897acf0b \\x79baa0b9272b661741bf49d52101f098 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-2 36447903 \\x017ffcb450284349856b997a0936f632297b24f9014d29a8e125cafa62343a6a 13 0 1000000 1660252035000000 1660856839000000 1660252935000000 1660252935000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\xd7b5b06be021d66ce41c6560f4717a47aa0b555d40e5791a644bb0586713b09286338aa317eb152d53e5f01914f565c98294bd0e1c75a9844760606674fd4a07 \\xb8e621dfcbaf5231aae7992e4cb252290246d155b59cd396a802be1dde9aca446008935e8a7594fae9dacd02bd1c12f840e533fee09e112b7e146904b6cce701 \\x79baa0b9272b661741bf49d52101f098 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-3 36447903 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 14 0 1000000 1660252035000000 1660856839000000 1660252935000000 1660252935000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\xd7b5b06be021d66ce41c6560f4717a47aa0b555d40e5791a644bb0586713b09286338aa317eb152d53e5f01914f565c98294bd0e1c75a9844760606674fd4a07 \\xa3fe6ec3305448fba768061059ddc4f41d1c5444a346d1c7511392a4a638583458ec7377dd7ed039bb5ccacad9c9091ab60f60cc5e6820756ebbe112addc970f \\x79baa0b9272b661741bf49d52101f098 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-\.
-
-
---
--- Data for Name: deposits_for_matching_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.deposits_for_matching_default (refund_deadline, merchant_pub, coin_pub, deposit_serial_id) FROM stdin;
-1660252903000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 1
-1660252935000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x017ffcb450284349856b997a0936f632297b24f9014d29a8e125cafa62343a6a 2
-1660252935000000 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 3
-\.
-
-
---
--- Data for Name: exchange_sign_keys; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.exchange_sign_keys (esk_serial, exchange_pub, master_sig, valid_from, expire_sign, expire_legal) FROM stdin;
-1 \\x61e9b7de014621a1cdd10e78b3c370bc72a9364b5d33ead64773fd2dfdbb8301 \\x4a92c272d749f83bca847f714d0e590c4458b9be6e01e05e0793a5aac9d73d64d1ba72e1d76c3b2a50125c529cf6b95f867ccd6046ca2619137e7ab3cb02dc08 1689281174000000 1696538774000000 1698957974000000
-2 \\x672f96a79906416c79911983f7f421ea7601768c5682b00c0182e6127c394ce5 \\xaef46bdc9c4d567dbd397ec55797c87379aeee60d6756af2c0d32ace59e32f0afcf671521ad58c69e92b2e06c6049f01793c7b539323c438483be063abed8f00 1660251974000000 1667509574000000 1669928774000000
-3 \\x89e5f703eb5057280ec41ac2510840d1d81edeafd57352ce77a78cc6c736d020 \\x88694d8e88dffe78617bdeeca7b61035d2da33266261ed08adc84e6316900e57f0291c0c323c9b6b11daafc85b18b2fb6365d657cc922b14cb558deac5a76d0e 1682023874000000 1689281474000000 1691700674000000
-4 \\xeb5875214f594284c855420dc1f8afd8126b03e06d183ffcd41432f8d9781acf \\x53ed5d6466a2783f2d1e481995b1bf88eccdfda4bdb72b61afc01c29e7f5ec9994cc11da508b1cbaa8a874b7988519f9fc88f9d089860e4531a0c958d9c19603 1667509274000000 1674766874000000 1677186074000000
-5 \\x5d4aa2e9a1eaec531b2b2d4a927d284f869c4d4bba27935af9a341ca01ecdc76 \\xd66763e65a8b370e300bfdf32df7ca3d026046ad643d28b95aa73d40d90a85e61ae81b2ba34124413f28720f8e64c65208c88a18e6b0ec3eb10ec0b4eee69f00 1674766574000000 1682024174000000 1684443374000000
-\.
-
-
---
--- Data for Name: extension_details_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.extension_details_default (extension_details_serial_id, extension_options) FROM stdin;
-\.
-
-
---
--- Data for Name: extensions; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.extensions (extension_id, name, config) FROM stdin;
-\.
-
-
---
--- Data for Name: global_fee; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.global_fee (global_fee_serial, start_date, end_date, history_fee_val, history_fee_frac, kyc_fee_val, kyc_fee_frac, account_fee_val, account_fee_frac, purse_fee_val, purse_fee_frac, purse_timeout, kyc_timeout, history_expiration, purse_account_limit, master_sig) FROM stdin;
-1 1640995200000000 1672531200000000 0 1000000 0 1000000 0 1000000 0 1000000 3600000000 3600000000 31536000000000 5 \\x1ea103d006a7b768c518c9cac012a919218e0b96933e1c9c3ce181c05554595a1c681915de083e2ee9107eaface5a6635c29c6368eb27176341a4590d279e000
-\.
-
-
---
--- Data for Name: history_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.history_requests_default (history_request_serial_id, reserve_pub, request_timestamp, reserve_sig, history_fee_val, history_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: known_coins_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.known_coins_default (known_coin_id, denominations_serial, coin_pub, age_commitment_hash, denom_sig, remaining_val, remaining_frac) FROM stdin;
-1 7 \\x9777f24cca0e05fe1b875f15451801dd5fcda0fdb9f484e074b7b4d0b9286756 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000030be8465d924f5e86a1ebd686a675d549c3f5a8df83711ddb8fadbba716150fdbf5bd7ebf13e8839289bd98cd23f0bb92190a6ff8da80065eb95ef8198bd813a6e7636618dbb3eb1782c1be901e1fba8a91907057149bdf639f4db02ed02581a4789323728cd09fa885c94e767fc332b1d7ae1d81c7db0cd628e8a8277af9626 0 0
-2 346 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000009c6d11d4aa17d223ce034dbd1305fb912f55d5f23dbcb7d1905752c145e97254043ba86ee618ab3ac3e86a2c561380c9e8cfce1dd099d46ed15eaaba76632c2df2f491fea85655ef05e78d42030eb1eb5e78319b824b212bac03db978a3cb094c04203d6a259971952fec2b34888415ec893ea35e3bd3319940b09cfb700b560 0 0
-11 193 \\xffb5843b29c27d3fcf76615e461b3e287e13243dd3aa0e8d150902eeb1797151 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004d1f8c471ae7adeb39a65d1dd3385fdc39180c63384d4fbd82e73f67663f81c14dfb7cb0bb668fbe1fd170de72c65d53485b8ceabdf496a598a86ef019ad5727c448e11074f0a6054da8b0530ece62e687b978f89344db75d7bd97d843290c12462503c0d4c27587c7880c14f0cc0442f0427ea13762f932e7cef8a24a07fb56 0 0
-4 193 \\x05584addffdc33692785a79f92973f2ed2c244218b94d74d227c45f430416e37 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000020374066bfa4733157dd3636e8fcdfb72647bf8d4074bf06e240aa71d8f7751a9f6833ae01cc3bb63c081dc85be3d8ad8baa12f77b4e2f6cae5212287994be464e35363f39a242fd0ed64786de27a7ed5ed2251f9b75a038b1dcfe6262b45342700343ea2fc2a97a5ed8842f9d956867f4931d25187df5d4c5a478c1dc6795fe 0 0
-5 193 \\xc9d78435043484673481287b8c66f1352e60db9c63816ae2a8554fa8e0b255ae \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000003e6ee7e6d11a457a1cebeed434c0e85f4f6b7202fc45c964380afdc8f1a9842144d12c0b5cb7c92fac13a3e0ea3ed4b4743cd6ecff7d65dcca6a476d024c2c4b6cb307f18d192127bad78fa7ddbee5d9444f9f9582f38c52e75eea156327256cdacce3bda37f0b02aee1e8344dc453107fbe739facdfbb3de47ae2cf3cd28596 0 0
-3 367 \\xe3fc05d4a6a5a54b8f0c9b5215a95b5c36098be9431781d02b7ed0a38202ba59 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004d1932e3cfd6cfdaea2d0a1e29af8121e80677b61f7ad6138ad889da1c0c3ec6dd701a33f5602d075c6a0b9bddb8a8f3d2a5ba34f3428273bf19450c3d426edb8d60cebc318bbefa0a99c1ac9c43fb1a7f291b356f87d430fb70db3a0c7515e2b192bc0d66b93b24e0f11ab3387ff0dc05eacd6ef6cc08c0e81de13b28a5e195 0 1000000
-6 193 \\xf0f3bb8c5fe31831cd9c7c76a24c82fcc0ce575c4249e7ff14be4c414659cbea \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000031ba782f7860e96f28f650d7fc95bc0eb79d4f4000e8ac2acf7cc2859132e7f5e2cb7a52471694a2fe63cba03a1e696f6e7281801d0db04f60fb8e623603d6efb640e306fa166ec98a5a558954d6c3c0c0eacfad3f42510e4a4bddfc976dd33d8ff23f95df67e6ab7543ff4eb7968431e4f410e78450d062d0245d67ff3dbeed 0 0
-7 193 \\x944055a5f68454ad9cd07da2797bf5f77c6a3065bc83de3f4a0e17511fd8e0e7 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004e95001ddd759845c5d669f00c73cbdfdf1b08619932333a53d680936a8032998a4d8bbc97e09d64a3dbd50476f182e2e29571d6ed229e4b3dbf3ff47bd4ae23984b7cd9e9321af0281b787751caad681938e932aaf9900543a8cf80b88befc55e7579fc478560d52c67423f546971ea3750cc8884054e2742096cfb7f9eeeba 0 0
-13 121 \\x017ffcb450284349856b997a0936f632297b24f9014d29a8e125cafa62343a6a \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000065895f9c79ef01882edb7a1cbb02e34ff8e6c6eaa107fa53df06ae55d20e6baf9dcc3229c1689b4bfb11f6464144bfd86d9642cd9ef982d50e42f83fc4f7850e60d6118464aa1ac6cb2d282c440da8a7db5b0fe0aba097df3d7dfb7b56d8afe820f4a0b3cf003d23934ecf3f43a0e4480431846cf4be81a9850426aa7dbe6f8d 0 0
-8 193 \\x302dc8df69b93f7e993987010d32a4318618ca30dfa0fe3fb1e924bfad57ccd9 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000044482dab2a3e736ada117654ca98597a8430730d1550eddaab37c9fcd83c5f1ed75c022d01253239063c296967cbf4cbcc37c3b4fa0a4f6bd095c9ab66b0005abb4f5d9cfaa772da848cfbcca60725ed02a6d5cf01c2f78be2b13ae3e5614df4c8d3aa841261dcfe15b39e23f4e4f205a0dd027d90b7bc934ba01e2a8167bfc9 0 0
-9 193 \\xccc79ba6dfd55fd585d838691ba1dc3acc1db40bb720ca957143aaabaac440f4 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000000d2cea43863c06b6005874531ea3ee5a02fefefa4bdf4bd340b60b36ee543d3df042bd2eb80be2276b041a1dea5322bce194fd997b4b8c36d5c2e04ad992351b159c7defce644ccb9554b0beb3cd24c24901fc938caaf466c1c81f31a4d80fe47a25e2e9935273cd000dd8223d6078ac1c74bc49c8764895b65631fdf30be467 0 0
-14 121 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000000f21f8182504ced07c42ee4f6edc6402c451ca5a8a450dc4818cdf6cc5b6ab09db8453bc95caa5352bd4534631488922f746908a2c09af21d75c90b94dc47b98adf4deab2f97e64e5e5831e947d655b0de6a83b4bf44b9b61d213dc563d2d60518c402fab1adbafce09605cd57aeed53969e9d4eb853b646e5fc13621d3c9515 0 0
-10 193 \\xe37783abdecf5e14cbb3ecb58c3700c25e4d296c7f9a890730cdb1a52528723d \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000086fdbf7e3874a1911399856b69a724782b46f78971a47d0b77b9add6a4e4274e25bb8f648cdb53cb2a1079c705e646e9d51a102780d53670beecbca6d05674fe76348931a17f113703fe24c9290924fbbfd76a68155fc12a18b26b1b6eaeb22a17d7981000a10d214f1c3dce53dcf645da2f40c3ed8faae9fb9c55dbb45cf0b7 0 0
-\.
-
-
---
--- Data for Name: kyc_alerts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.kyc_alerts (h_payto, trigger_type) FROM stdin;
-\.
-
-
---
--- Data for Name: legitimizations_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.legitimizations_default (legitimization_serial_id, h_payto, expiration_time, provider_section, provider_user_id, provider_legitimization_id) FROM stdin;
-\.
-
-
---
--- Data for Name: partner_accounts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.partner_accounts (payto_uri, partner_serial_id, partner_master_sig, last_seen) FROM stdin;
-\.
-
-
---
--- Data for Name: partners; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.partners (partner_serial_id, partner_master_pub, start_date, end_date, next_wad, wad_frequency, wad_fee_val, wad_fee_frac, master_sig, partner_base_url) FROM stdin;
-\.
-
-
---
--- Data for Name: prewire_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.prewire_default (prewire_uuid, wire_method, finished, failed, buf) FROM stdin;
-\.
-
-
---
--- Data for Name: profit_drains; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.profit_drains (profit_drain_serial_id, wtid, account_section, payto_uri, trigger_date, amount_val, amount_frac, master_sig, executed) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_actions; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_actions (purse_pub, action_date, partner_serial_id) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_deposits_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_deposits_default (purse_deposit_serial_id, partner_serial_id, purse_pub, coin_pub, amount_with_fee_val, amount_with_fee_frac, coin_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_merges_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_merges_default (purse_merge_request_serial_id, partner_serial_id, reserve_pub, purse_pub, merge_sig, merge_timestamp) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_refunds_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_refunds_default (purse_refunds_serial_id, purse_pub) FROM stdin;
-\.
-
-
---
--- Data for Name: purse_requests_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.purse_requests_default (purse_requests_serial_id, purse_pub, merge_pub, purse_creation, purse_expiration, h_contract_terms, age_limit, flags, refunded, finished, in_reserve_quota, amount_with_fee_val, amount_with_fee_frac, purse_fee_val, purse_fee_frac, balance_val, balance_frac, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: recoup_by_reserve_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_by_reserve_default (reserve_out_serial_id, coin_pub) FROM stdin;
-2 \\x9777f24cca0e05fe1b875f15451801dd5fcda0fdb9f484e074b7b4d0b9286756
-\.
-
-
---
--- Data for Name: recoup_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_default (recoup_uuid, coin_pub, coin_sig, coin_blind, amount_val, amount_frac, recoup_timestamp, reserve_out_serial_id) FROM stdin;
-1 \\x9777f24cca0e05fe1b875f15451801dd5fcda0fdb9f484e074b7b4d0b9286756 \\xa68bd3c4b749126ec9c9dd4ab7ed721afbcc202a9db66a025433357dce0e80aafca9b422b1828217f771f69d6802a89c6cefe67eb5534dc7314279f1cf36480d \\x74a907cd97f6f6d359419e53280b4657aa244079d6d90e73fcd5fe798a66aa46 2 0 1660252000000000 2
-\.
-
-
---
--- Data for Name: recoup_refresh_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.recoup_refresh_default (recoup_refresh_uuid, coin_pub, known_coin_id, coin_sig, coin_blind, amount_val, amount_frac, recoup_timestamp, rrc_serial) FROM stdin;
-1 \\x05584addffdc33692785a79f92973f2ed2c244218b94d74d227c45f430416e37 4 \\x54cf8a9a2fe75fb56f3f9e22d09a9bfb37a3d4927180032c0caf5114baec28b07ef47865bafba16e35be41e9a0ff824ffcee6be235c4aae25f532feecb2b6a05 \\x2feba45494e43c86132ad6c08fe9845a6c596c8113e5ed2bef94fb2ffdbc5934 0 10000000 1660856824000000 8
-2 \\xc9d78435043484673481287b8c66f1352e60db9c63816ae2a8554fa8e0b255ae 5 \\x9e969f3efd3d4af31f18568522afd5414e0a75ec6fb2163a1ce439b0f0c6b9f1896ee4a2d15180b107127baa1a7857d85a029d7f45b6715cbe64b0ee615da306 \\x43240a555735f461deb4edaf9050cf33b1d234da8f38d6f4f83534ecd2a86d9b 0 10000000 1660856825000000 6
-3 \\xf0f3bb8c5fe31831cd9c7c76a24c82fcc0ce575c4249e7ff14be4c414659cbea 6 \\xb33d29b8ca0cc90c5af96175f55c0c2455a6efc9f6f17f78f72b76ffd2ce84c2e99065061b7393450e216dfb69a67102eeab34f5e127a969dbfa81fcf25edb00 \\xb1bce1388dc97d4589682e6ff2375611a7fc2ab4658602813d3cc9e7f08ad5a5 0 10000000 1660856825000000 9
-4 \\x944055a5f68454ad9cd07da2797bf5f77c6a3065bc83de3f4a0e17511fd8e0e7 7 \\x4d7df8bd7692147d85028513ad713dd700c1bdc6bdcee9a046929ba0e2c3982421ae9b839e4c8abc10c2c174e3ef5e52e167210a36d09903f5923179b4bf6d09 \\x766c972d567cca3ba541a94cecf7e54c3136b759443250cf2c43eae210369cdb 0 10000000 1660856825000000 5
-5 \\x302dc8df69b93f7e993987010d32a4318618ca30dfa0fe3fb1e924bfad57ccd9 8 \\x62e85693f4982951ebdecb33325d0efa2d0e794ce27f75c6f0d9ce6a84f65209c0ef8507e18290f66ba73854e693481f4dc1ff902dd6c0fcea86ee528e2b1607 \\x73021639ad10daf42a00e5f754c195b60cd87482953f57d0d2f492154cac6942 0 10000000 1660856825000000 3
-6 \\xccc79ba6dfd55fd585d838691ba1dc3acc1db40bb720ca957143aaabaac440f4 9 \\x6ef42048131e48a957f5c4b6a6e391ee57fd429391db307a8535685ec977b0a9967b7330c43c606ed9c7ad13901c32aa7c845479a79a2754eb37a413b8e7ff0d \\x244d0e32deba601920c6391bbcace89292de1b66e9a0291ba4d8a94574a75ef9 0 10000000 1660856825000000 4
-7 \\xe37783abdecf5e14cbb3ecb58c3700c25e4d296c7f9a890730cdb1a52528723d 10 \\x7e6def93621d1baf1014c18e53246f57ff8cf75a74c3bf9f187f3dac07b791082a29c274056c7886e9c51addd89f3c9404d68c7e173c44326f19487659bbfe0f \\xe29dd80b5237e017b361c210426d5f1dfccecc300d4fe3f3300d73551b18f55c 0 10000000 1660856825000000 7
-8 \\xffb5843b29c27d3fcf76615e461b3e287e13243dd3aa0e8d150902eeb1797151 11 \\xcfa06cb32f6f3a7dc6914b6d5f5c3e99ff971349e9f78f4697949efed0695b4767c036d47a960d3633ea680ab4cfa45d0d418bbd8cebf6724c17e107734a6408 \\xf7abbe78b3544b53ab9f7428f7e7642986cb3b6860325cd1ccacb32f492094e8 0 10000000 1660856825000000 2
-\.
-
-
---
--- Data for Name: refresh_commitments_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_commitments_default (melt_serial_id, rc, old_coin_pub, old_coin_sig, amount_with_fee_val, amount_with_fee_frac, noreveal_index) FROM stdin;
-1 \\xfba5715e44cadcd1c139f5915a76350a11ba2457d1d31d9891322b900f9226f8caed861638bf15bb87705725fb22f50072160f42432c6255f446c529cfd2bbbc \\xe3fc05d4a6a5a54b8f0c9b5215a95b5c36098be9431781d02b7ed0a38202ba59 \\x9a35ddc9c41569a4b36ffdab60cb13bde7b496f8a449667f5d2f6b23c098c4433be4aa317136b815e48a6698f740edfd20cd712b0c46ee5d792aab765f4a8e06 5 0 1
-2 \\xf7fdd06bcd2b3bd1981e76d67ca253bc13c6f904fb1aaba5bdd07050398a9da9d888ac82ca69724d48180ee5f5cb7af346196dd3bb8976c4ad7acafb7b32de3a \\xe3fc05d4a6a5a54b8f0c9b5215a95b5c36098be9431781d02b7ed0a38202ba59 \\xb434daf67ff385b4b99c2cff684d03d1bdd147a13c1ef881a239ed3f5d4fe12be5f6703549fb3aa512e3e1310662dbdbbe7665df1b2a1063423f42b2b68c9401 0 79000000 0
-\.
-
-
---
--- Data for Name: refresh_revealed_coins_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_revealed_coins_default (rrc_serial, melt_serial_id, freshcoin_index, link_sig, denominations_serial, coin_ev, h_coin_ev, ev_sig, ewv) FROM stdin;
-1 1 0 \\x0ee50132c43b3c4781a382754c9f2251deaf8f8392c48a1088799e28b8bf0dc1952a7128a1a51759bfe7950b06d8a70bec1b95fbf4660ca09a33efb94cba430f 100 \\x0000000100000100a7d5ad774df1ed49a810ba07f36972aeecd652b369ba8666928abc40a9a5681b12cf3a2abdfc221942bfeae9341c72d8d9c0313663a17b68a6c91e75a3d6e4c3f3d03e87b734f145bfa8dfa1a0acac159da4982bff06f6ef4e2f8da1dee73e16c44017b797c49c80c01063b4cb3b36fff4f251153ffbc0144dcc5e56edfcb741 \\x58dc07b770fbd1e6e253a3c4bc18387c150df881cb614b56913da06ac6aaab1e0c08784fb13618705a8dbeca7e699f0310cf3ce739e7dee0a7405466190ddb90 \\x0000000100000001837ccc3451e2128874253129a14749d62b783b100f529469c735f8296de92a9aa0d410d6f430e89f4e24d3adcca399c0a45dccc902da622237b36c9d95ec27b64baf37fa9eeb15354648fee974b2aa023127843ec8922a4c91128416431502b894ef94630c6a464ab84a294b8a628ecb79b877ce634055b195a4c85bf10c8abf \\x0000000100010000
-2 1 1 \\x124db548a74ca9095c8a69968c5342435d0bc6fabf722a491509dbf76d9c9259cfc5709dc63562334864e24dcf8a97ba04822fd7cc45a79d7719057ea3fb6702 193 \\x00000001000001000a8d1b588f2bca4290ade95201278be0ee48f13fae708458e4908e69d605c7ba7dc0aa8f93bad48f05e954c58c92dd397123a5f360ef44a0613e6f3c4372890681e835ad6a8f57cd8f35c809187165aa4256ae2622ffdb456cc887b4dcc9b9445e9bb592cadb994e5fad39cb653ecd65afa2fa7a99354598b3a8c142e9f55592 \\xb0c0b0b9a2cc27c465c775de47d30c3fc0037818a71ed4dbbb7a5033d0c59a3f4e2c7a6bf27b97a5f056caba3e737a32799cee2d3800ed637a4d3037eb2f94ca \\x00000001000000015f77c30bf9d3dd08ce16cb65eda4c310eef3a83f862c354dfb85cd35f164d2ff1f7f1bbf476a9bc1f1de0bcd92b98980e82d94e0f2c1abf4a2bfb1d7b1af7d52e342b662365b784d9110ec9e439b5860cb49ad8c8bdf7202d227f21ed627d7f111062b3d04329a89620404f127a9bd0a2f09abdc8a80eda03c6ace9177deca45 \\x0000000100010000
-3 1 2 \\x0b11e76c52150306b2d5823099743869fb355ac678c046986c0182a62677471fe00ef6959246d491f3b73502ff323114eb0f669a732a697244ee26ec8babbb00 193 \\x000000010000010085cec92cd059c84a8b0779a359a517529f6b216df2038dd49de06868b39828a86e8381bc7dd96a3db09d2e6d170775bbb5547469ca794f2f1beda2b4473bdf9d9bc70aeaaa928a8d2ce5343fb3fee38302c40f8a16442cf5c7634ae02fdebeb190233afa772d80e42c65ae15d420673e45f87ed344c4ca19aa5495efbf236a79 \\x3f8817487191d382da8b91026852fe27a00de0d60bbc190378835954eb236f2eefb010dd06f414565eaf449fa02b63b856cb68d280530279f5135ef219ccc81a \\x00000001000000010fb04f78ff5302122c8472af829e9303d7ed050d6622961cf2091286e64cafdc60d9acdc7deb760ba4f7c1f68bc49ed5a8922e1f5b5ec57733ee29feb721f30e142a4bf254d2b9ee66f1197f82f57da2a13b4845199055e37e21177c6e75071c05abf2333e4f1124c342136a6a48931fc484b6df048b404d06daec94ee6eb99a \\x0000000100010000
-4 1 3 \\x96adfe5266bfaceab8af69bdc60a8d5075377386218ef1fd1fa4e72c431364f19ff501b09cde8ad3078000b3e7ab669a02be8af7415b6a57b55565ec5ef4420d 193 \\x00000001000001001abf656707e3afe28a6d72c2786b69a572ddb232eb90027c0671be64f686c3e963d491a5569aa55cc80b4e225a99c2ed266d2c67442dc1f0eabccba16ff186b5b552d5210cefdf491aa0b3b2f1bcdd3b35b7930cb5f67e89c62d249f2e26df48961c54d29060b7456fefadcf660bb97c3f02c1c7d4496035c3c89f81f1fef394 \\x5c1201e373476af13b0205d96084ae0cfa693c0b6c47ae3e96e3f647ca367bbbe07f011396b3c21b8c358fd9b88726752279f923151666fb0fb224209faba779 \\x000000010000000112c8508967f3fb3bfc138988dc2a801f8e1d97a9112622bc8bee126b4b5cd199b2bdebc4957e49d81ac3a13db8017ce6fdef17385cc8bd20c48f1cbf530f2c55c351c1fbcea2c37c288f8054070048860964475b8e70e0ccb52fd40ed8b4abc47548698b7b4b26e5ab84fb43bb928ece99a229e789f58694fed1fb2512048c09 \\x0000000100010000
-5 1 4 \\xb3550215c0c64bc07473f5044e5c6edfde38f85c89f5b611551d4a664ddb54602e5b25068488dff6c3e2e74af564e6cdb818b7fa7e35baa6e8824fbfb4ecfe0f 193 \\x00000001000001006ab60b3a353e8c5f813fc4317b1e22fdfee3748bc6b94467ab301b43fc871663fd308a404e11d1c14a7247e4b50ae3201da196010eb8493394419667e51876d67496523067ef68bd5498e0a86b8f895b0f1dbdcfcdba6c20c574512d95aee527640be66ec59d9aac1defaabda95c39a9ea1ca7ce9181108a31633982026e4b48 \\xb95a39b990f11f1353ad9c5d4abbbdbe3d3d37c048ac6762203f8ffa2dd19b5668311a5f04e9385cfa6f1991dc07a2cebd25ab1581ba80a5b51c93f5356e3ad0 \\x00000001000000017ce5bd413933aa4d13c3a7b9a923545e75727013121d0701010e57d7a302545176a23eda6d998eba8960e4a9b084df1779766823eaa6cde5aed3109b269b25b8bc8b0fdb825d5772f36bc447cc1dda3d0af5056936a5130f5c9bc6d439d74b1920295428c27a84c0c3c820f09d353b1d6e0ac2426f63d02f8e5ab71205b1d07c \\x0000000100010000
-6 1 5 \\x07d82176e6dfb20b9db39947de7e3d49a68e82d42cbcca255d62d0963e9ef8c61f4f56566fe10fe9d379a967577f9fa4c7e0e38dabbb05313060f0723715060a 193 \\x000000010000010068019c1330b91955aa056790c272f9ea076ae7dc3eb832ce4d3e97c46dceb1fd775f7422a95e4454ae16d27f17cd5546454fcd3fab422007df74a79b6c1c192a1e2355865b257e82dfab1aab35c6d074f921a3d30a9184f241dbd2944f43a2c99419ad70e51a46fe470f037783a5751f9a147d6d36006133cc202368496b83c6 \\xa4d11c321fdbff7774760715d2b344bae786491b073689a7f5fd0c56bf982404b9523263f5aeee37396d08db91b36530bd89f35642b72c3fee638f41049375a2 \\x000000010000000198f7235e7184e23b719b3080a08db1d9d4b531685373c02ade840411bbc6723009cac813503f5489bfd3f2cc63e964ca1ba907662e45ec2cae0725f0620044682866de386e6c3c866574cf57f247dc4ba5a1aa2168fc2de48e928fb5741312418eb751ebbc0db6cf0aa0411b9a7ed4f68c412235df6586604bd0f2d8acb4fb6a \\x0000000100010000
-7 1 6 \\x73ae9992421dfef946ea08477a882fc2e1c2b414789955ab1ac4dbffbda42fafa463fdb9fa6ee866f87760091b60bab50f283e7e2e18c4cd9939ee2970e4bb03 193 \\x00000001000001002920d56ad97072f34ed38771adb29a10574e3745dcab13328a84a48772c4f48a9970a89475b15e266a04301787ea5fde8364136013cf3d48c3c58f76a29608f816d462a7c84e2c944fa90c969c0a6f4a8b98bda411eeee9f30b0b31bb025b483537bb34d88bc59dff4f5be100eec018cc7b732a2e57f6316cf783b0e23a9ac11 \\x0e271da9373cdb2ffc8e0d321a847b045b9ec9295215be324c1eb423cad8ce36f6ab8a5d05bc592cc66705ba2c336dec51b998001341d4b9b8b6c9a397ab487a \\x000000010000000188fed186e7cdbd54d2237a769675fe1fe576a9847b7644cbcba5312d7a86a9340e415ed2ad43105a806408b7b32507045d1d27e8b6f80dc9b67d22fd11220940ca78dc3f9c1041d32336dff9d14a2e133ba8fdc5c2d79f1eee1319b3309493d989881a63ccabe8481f2bc7258d8639de38fd4a044d9eb796f86291caf0927cf5 \\x0000000100010000
-8 1 7 \\x1de5274463c1c43a193491191c11c02a70a1c39e966632e903227e28674e55f63f45ba8994bcb0692e83e4e4fd02fd5661b4f8726bf45d56555ab8cbde58be0f 193 \\x000000010000010071354f5df9c451350fa7eb3805a48cd6cec6f1a10baf4550287acd3a4c64ffe2311eb70cfc48842a1ad8271ed99d210c961ead0247b09546d8e02310ef1bec75dbac7a426f569230c390f7fc5f478e56398693b569bd60d6e698b0e3530f72371a3a52632c00ae6d776eaa4e4ff1a3345c3c77012ecc7cd3b217791d03fba9a6 \\x2b12c0303248e31985d8228b264b46a3d2dc5493644b9942fdc8d9ecbbddce59e71667b480aa7c8b7f71f07e726e78cff5b1d6f0a3cca396d82d5953c52dc89a \\x000000010000000118aef7f145d0f300c25fd6b03176d7208f4693cdbb8d6b354a21fbbfd30d4b0bbcdae1ade6d4f47711151956288bb758a441db4dd4ae88a57730c1c3f440066d013c3b86cdd12fe8404142ed4ccfd7e52d199e4a26208e3985ab26e639e94697ccadfc841052641bf8349230dfcdad2e57d15a4603610da5e4025fb7c83b0f20 \\x0000000100010000
-9 1 8 \\xd789c88d33e3f723e5f58f24bb15f94707f4841ee399c3d65551d66312c6df578d91bbf07a140ae44a0ba56a46d9ec3f34dd32e00890e219e71489a93c0f2204 193 \\x00000001000001007dd428085c6a18c5f8d6a9a1a7b83f71be2592143fa4038f17b500c27a5f3f68775872fe5a53ae39205117208e22492d7ab62fe9ac67dda3394119ebc257354f26d20bbcfc2f63e74c9c04e474daaff532f9fcfb37369f48e53ae8fc74faf668e69b3925781c643084beadca47afe420c5a3b24296f049641215d88a200a3221 \\xaaba3575a62869d3a1d83816f62c6b92b0c582bf24edd18d4f36f0b3b15995e3e17093c3654bd4e8f6555fe89b3b1ba861086cef9eca37ea0c7c8b51c81a3b26 \\x000000010000000182d33fc5f789b6a9a0b0f9fd36156d604a110bd7626c6dd3056b5bc5f6932f313881f631265e9d16936a08b261da2bc741b84445d5b540d1b21be6629fde6a608db1bfb82e7aa26cd783a57d52879fd95c04bc9ace93fbd55186f5eb7734e8f2317554d33b2d922b7a897ff9c0c87561b55d34e2e9a55515cf34882f59229366 \\x0000000100010000
-10 1 9 \\xfe2ad6ab210c04ca047d49bed38d051e7d293b2f5d60a826f898213e302da3f3e4547f6cc13fa78575f39449f4c27dd05b95666e72e32e4462144a58c862db0a 121 \\x000000010000010027d49f1ced7be536bc03c1a86bf94dcf34dfecdd9885b473d6b643b0cbc12d262642e7321268e088ada49f555a81c7f6da32ee021816262c68944c76fa41cb07c63bdf273e24aad765ff6baa12e3c21d70058a7300e7aca590824ae2501c806f92f591bb321c3b6ed35496ff177b58d4ee57960b43f9c4dd98bc39918f62699b \\x3aa065b39a8787180c41eae30e7f7f93c1d3d8dc2f7f1b5e081696c907a3a16b1d12bdd0a5d1d738056d6b5bd07b9dd59da08b8ec22d27fffda0d4537c816b9b \\x0000000100000001bf8813f4565514c0288191bdbdce90497c5c0ba234690dd98ba4904acac26bf5c573dbee60f2560204e4cdd1fbc2669ff750c820b6fca9f5449563d7e34a493e2816da6fb3b86c21810b1cdfe49647d031fb2f37643e322b4b4638fcdeb34fa1a018678105ece702774a3b528329c1fd4ec28c003d934c37830ef5d2258fdfa5 \\x0000000100010000
-11 1 10 \\xb07f7a23adb0d6b8c854b33e0346efbe5399cb78841a414985de6dc50baaaa7169a8b9a7f82d576776e7fbb7c0ccb5e3433587a62d892e9ca872e04748bde006 121 \\x0000000100000100191c8eafd1a060a6f85d78fe27e314ecfaace5a1512f7f2a904258d0fdcd5d31e7827efe46aa9d7cb5f03884519db38d0aa012a1d853c30a775c3c7dffe640da0f6f6c758fa8fe0a3342283b67479f0f1d966280623b98120a7494b8756311e050d708e533a5cba2e95b6e6170fdd25134977ca8e975b694525ab08b33fddbdc \\x9008a2e19016356394174062ee797a47bc8bc2ef9f04b5cff5da14a7b5d1e4ee5c4c49692d3c5dd16e46b7c476c2ef4fb945a3c14373f39b6f83725514d5f517 \\x00000001000000011f942af266ec6cb3a1bddfb27388dc5df6c482b34df6cffd770c6c0301790cec95db3efbb9c5fc86ef613c18268be8c49ceeafd17662afe691d06f2d9dd60ac6f72db8d21af01ece65d4dbfb5c9631d7af0a09f7c60be90053f88ad53efe1b1510c3b2832dc1a247e9e245679d05d0659af662bd68d953eccd3d4f10bc0447b3 \\x0000000100010000
-12 1 11 \\xb342c3712c70dc000cc503ea71cc073d6bc214e0132b789440351f925b076a2695b513394fd904122dbab08202b23d2aecfeec372d138e9bb420558ad1392402 121 \\x0000000100000100a0312c1333aa5080af9f0e87c26f8093bd214f85233d678bd8c6d4d273fbddae143f8918769b666372e712f40141eaa74723422773941cca4008ae35c7d25973b3ff2c71558490cb25d102d47d417b668e4a7f42f119be6431b9d5ee6572203ed0a8f5c1c2afda16394e7e1c72769eb5bad033f42199d641759eecb59071cd93 \\x5a566e2d4f59f9c0a7ee3a88675c0e4ed82d314158dc749a863968ba0230cdd819b16e27236744d726e2a8ec820ec116ea23ec4b8d773312c11a91394f886ec3 \\x0000000100000001768d9a81bec681c37bae203bdd6fb5c5812225f3006c563636f39b0738c3b643e85652c629b825228c9c19c11c96d1ceb9e18608780c511060925089cb21cf5c018b492a8c77890d2b149820c1cbd2c606e8960b36b91e8e974d60ae2c634a205ce9aeaa6f0686f96ec1f020495265b997e469958d81ffe66be8e299f3cd5516 \\x0000000100010000
-13 2 0 \\xc7e74a99e08bece17a84f5864ac2c7a3880cb8ee3acdc54f13d8bc6746d6a0e92cb76134b0c2f15b73fb5998af1d075424a4f264bfc2bf7887228d5be47c0602 121 \\x00000001000001006754e5dc587b96919178ef68e9f959ed98bb6a6a30e9a0a6033f9406f413930ec68521c3936ebca5f2ced167249372cf7305a717b7b550f1d11f99725f1f1b1a1f32057269fc91c32783d1abfd4f29ba52e0b661bf90160a3c02a6551e9d3fc9358814334816af8690cd83a997bec8ee1c0969c6560e3aafcb993c3db93608cf \\xd757430d6281391a4474a25a303c4a621780c365b39b9d8cf87fec5a48bb0e197da489f20818e7c3f5432ffb49d128b765e6f7ca5b781359cc04bf1c51c54ef6 \\x00000001000000016feaed3eea8c788446386d5f9e53d39002ed7e2f8816dc41fca2e823ce324ddc556d2817337a39c5651df5f4424dd79c8bb8fab9dde85d6f61d9eb7de8d64d2b525b78031ead0bfc31bbe95d6790397248b5e23c08d9994126788f31ad1a3af048ee39effc437e9948ca4f61577983c80485039229e21e32bd9c823aed1d3c7c \\x0000000100010000
-14 2 1 \\x4d3fed0b4531eafd35e03dd80c3fbbda1e0359f037c0e9d52a67ae81218c1a70f26fadd1282bd124b424b70466770d0d97363e7666fe89b097730e1bffca8303 121 \\x00000001000001002f96a8cd48231cb98a39b6053f537ce21a7a95953d3509cc12bd5c8c6fbe24d6984386f91e9ce30389c0ec210f74738f2cb9214ee6a2ddd736201b5c89b99ffb4581e67554c713a19fb1f94dee07edad8a996d6f7bdd69bdaa90332173d26a78b58485892dce9380ed8773e0dc79d36bc775e65d2907b8e527b5cff1ca2000f3 \\xb7423c3fd77b446bf52c4998dbfdefa03641295f7301017d1a1f35fe3776e081f7098c039c8b651b53e0beed20283ee9cce58589222297ee373672b84b44002f \\x00000001000000010e63e6875d7ae11a1b42abd6d057ad2e5b89c836d1d52e72c10dcc4febebf3453a1e6b2bd8b9bc5577148b48a3137efbe1c63dbc97f857beb7626cbc9890b7a75e104475404ea87a2928fd96c26cd737ccf091bffccfedd587a18373cff9d2dd7cc5caf2c172fe60ff9842de80128126e0796cf951c295b793ed9752f9120ac1 \\x0000000100010000
-15 2 2 \\xe85ada2bedad2332ba7433b35d60d9a354817255c3bc6273a8eeb904644545d894ccc8d351f4fea0f2df07a51e99a12a8bb6bb005115b36e418e4b78515df00a 121 \\x00000001000001008169e5678bc4cf6b4fb00f8f87064c38003a54cf1cc25be450bbe82d58ccb40d46dd05a42387bd572c6a8a935044854a2317be8aefb4540bd35ddd8efbc61730914e1e8d9dc9ea4d3ddf458da029f265b6a78edb440ba24ab4a83c11472ad0f0aa9586d83e40828eb72af299a259091e4e9d3fb8ca545ca7929345d078d32ff8 \\xef0087caace06e7ea89aa864e82f5da47ae02079a31d49b3dd147e4fd746686a1f007a529cb4da1f2c3714f407bffa0eb6577811e3041cae28121f201de9d273 \\x0000000100000001968b3a36939a39295c65c5dec95e631144de4c1eef1a2893450997ce06764753abf3104e39b0902f378a3750050b892bebd1c3c507f7dc2c1f439a9e8716e2551461a8f2d66a0a5ef2ca50958101ab5dd510c7c7fd4891b6c4404a5650f82bc0cbd38125b34c31e8c00ea4a8b89014b3a503419904f5e2a8213521c2b3648003 \\x0000000100010000
-16 2 3 \\xad8c9dfd895926a44f322c47ed3493d83a265e4718388ef7835a9e97926dc09b503d108a13da4959c4cb3823625f73307bc1768d449f7089674e078143150c0b 121 \\x00000001000001006725852675b6dc99fa8d97cded624fb59b2523c8e79b02143225e71d738a050d93e73f26cd5ea650831dffbba8e786275f00b2fa12625a0a5fa9403cfff8d9887565e54b730c0cc1b2e8cc3eaf7e97edf6fd273e805272a3f7afa7c302dec7158bc4e66e40969b383057e4c86005f4c9ad1a0ad6133e6f3a05aa63fa30a0a143 \\xa0b83274bc6505d409cdc407dd55be2155a57a082ec65351a66f7b7278aec0ff82182e32bd3ef2e7909b2402f7dd0ebf9d7260b0ffa712d656a8c581269c8822 \\x00000001000000014995f69c83b8f5ba78607ca8f7f81b25cedd3dffab657977ffbd751fb7d0facedba3efbd1968ff319c2425a3d2c92492ce5280af02f8ce6a9674b15924e6b1723da2063988de8fc499b5722ebfecaf782e0a9be8f83e1477a7508d19ed7c0629192f9fe0d46b0aa78f914669e3e257b4693e92bc3ad418082132eab879ba8947 \\x0000000100010000
-17 2 4 \\xa6b806d386eccc3265e93fce39f1d2613f71d579df0061d4bc206d42780fc671ebaa729b43083dd46d66211af485476bffd8705c248845851c8a4b7ff08e0c05 121 \\x0000000100000100afaebe2d6c04ef72ed39555d05a51e521f149077f4c1f0250200a8312b9de32c83b450d3dbe4f2c3f3b63e507e24bf009c2b9879e9120e28cb529128913cbd8cd5c3f0ea4b9d3f9181704768d0f4359cd09738d78a549484d7cf034307a2bc9715bf62aa30948c1e7a4c4369506cb7934f4580884b7eccd690e65ed6bfb0c90a \\x5753ee32362ff9781176bc1b2a3b8b9e6fb5c2e47fca1208dbe1ad24564895648bff87089dd492079d93fde9f1dcd86979ff4341bcd3b262af6fb9bb2eb82136 \\x000000010000000124d51d2b4b9d9b240b6e148d96e4cc3f7404d40e649f2d6a2286f345275be0375f3e671b85623edf9bb15fba1b0b3d844ca31dc5e31e7986721c498c34a25f2e9b091a6f887aaa1b27210488c915a7f35ae0f953068c76d482a79f6f98efe57bf759ef9f1fd7e6cfb6c819942442dd183705b903166f51aa811c9a82101e413f \\x0000000100010000
-18 2 5 \\xac23989f1670743468a7f2138a1a4a1e05008e7fca6144cfe1c32c066aafe40d462c98ed109d13207d13e51e966313779cc7dbf48afc1eb9b6e3307b1ecdd303 121 \\x000000010000010064aeca422667f39f0a0a062a689147adff5369429441d6f1fb6e116dbe3720feaa7ba16bf3bf9d118667697daa50054b82b8b02d302c16854062d236158e2dc274a122c857f7b837111bde177682bdcd49b1c410eea24e0a9e8a79236c1af17d04f26dc996de79ec20bacbb1f7cbc2f68c5580acb8889c1a4f548bcb69abca09 \\x8b4ab810e5734dfadc13127eb27bbfed343ab97f814ff9f9a699c90522b5cb1e10e1455fe85f0154198b6608f2a70ea6cd714f6588fc06417c1adcda6df6e658 \\x0000000100000001a36f33df105dde3ed027aedc2820bcc5bb57f7ac99b6c1ccb3c7d0f1e32895a7106974a42b3dde3a08c38a992835d4b4b4d65e6187148476fbb0eed75f05b1e56d3cc373966223a5d5522acc9e319607b083fea7120fa85ac0a373a7963190e30abd1f1cda5db57e9a83ad9e7178352c13f029bda1d9361183bcedae9506d7ab \\x0000000100010000
-19 2 6 \\xe7e49157f48ec6aef2e67f83e184c7d1cb47638aae33653399b50a86f78a9d243ed2d3d39c9d2daed7c4b311596ab9db90bd6bf02dffab4e985777a00c22af0c 121 \\x00000001000001004834ec194619c84e3654f6ef68f2637b3e0461a3b7827e0dcabdebd14c3ea124395a36ab66c7473ab4de603f7e335b91e04b924869be5d3e384f9cdabab150c834ee2181345b366630232bb88311b77f764a130c5c1745c3c909073f873888b8ed8ca41671c5c15395c8c35f757577e13449b7350b228d1eb9e6d395d8a75190 \\x332e4e4dd2beb8fca8897dc353bd011b3fd923523268d092f746c5b188966d5c0bbdcc686fb2e01041dae74b8ccbbae13778e3ce87a3b74dba9a648147a33c5a \\x0000000100000001265916c06c078055d2ca6ffc8c4d5b18c85a415b1c891e631a40bc99fdbf8f389166a44261351bba459bc715fd99571b54c0e6793896c6757d316f850e3b7208fb781d0ca65271b85acf443661939991cb3bf699eddd173b67a5ffc66855cdf476c06e42bf76dfd2b8888ea9e42b7d4149554972c0b9a8c9a71c2112e65be3c9 \\x0000000100010000
-20 2 7 \\xdc8581f9110de2c357956da2dd873ad304ce87c2647671c797a694d83417de9e31557673c8634ebecb1ebe8cccef6bdb5dc3f48c27cc694cec7196452af6ed0c 121 \\x000000010000010032958efb1f0ef03c6791239307813bf4e7175af59ec4982dbba42df9a5aede284bdbcc19fc94689074b19501f90c29cfa16d9ba322fe830792c5c6077b37900b2076b01cb0420630c370778ca1fb1ab196453dbb22c2bd03032b9399282daa450d8b26570a3f8013fc704d927c38bc6fb03850c7f8410f3d4eb6660afaf6325e \\x00067c9dddc4c55b359ccccca9b589c79ece61dd5f621a5840fc59a5a31d216e659b571bc806a0280b6cd9dd9df87da0ddfee5e6d3484c0cf4d032864648b7ed \\x00000001000000018a66c2adcb77469a5bd7003db87a23e517ad969881fba465d17b29c7aefa0a214470cdb858b5a196067a0d5a8b454851e0d43f3b5073fbbf7dd5e5025b8c00be95221ae1a0630a3492934a7ceaef93a554a491665231c367d60f5f6114b9054d2e182f9292351faa042c01e1020db200a3e85e55e6406ccf10a945d4c5993a15 \\x0000000100010000
-21 2 8 \\xe68784b320948c2b5ae368d12d66cfdae72d09e4ebfe3edc2d6d068f082da34149914db488c2c6be9f61f5bbbc022e8d24dece07b37a688b8c96b41009d5690c 121 \\x0000000100000100c29aed829eb4f66fdf93453322a427cea51c7121d7365a8f268f4e9cf27f88b3c42cbd0b797ec614f5f87be98be0b9567321fb8e515397b3dde645bf8e7bfeb9b7878b41cbefbc2daaf3d2d940022f6841e2fa85aa672afdc577b2f95c293076a50a61942e2d20a9fdf771889c6cc9fa6ec96df6c33c849bc57705a24eedc329 \\xb8241a8b4aa7e9581a7007a9abe008a1b1dfef72fd3eebf7c3e2bcc31f56d9cc2314b91bbc4cdcd3aa3a7953ad8456d97ddb410d76b06e59d5748cfffd9b9b76 \\x00000001000000010f5f1f6b3ce86d3eb60412953de510852a9f0c75062f49c9091e4b680b20b94f48945c1e44b1661b3b65a9c3c8b6825c84916a8905f6d7e0f6a9c9c6ed37e4109e17902403a640139164c5234edffda2de5c5c7dc1f92c20bd110098ae2302f03070bc06d72162a6969c422dabd333e6ae3d980c1e4ab263b29d1214c6dee47d \\x0000000100010000
-22 2 9 \\x05841a0150d509f9eed5b576fc03a459b384737a54848b6576d9f59d8d6edef3d3e0bb86e92e3313437241e8bd38a17e17b46cc299676c314093667516776c07 121 \\x000000010000010020edb0de9177d47d7bd42dbc2a55685d925edb17d002c1298f487fe280346d9482e605e9afb2ad17596f1032d0bc958bd69020e0418d7bffc86cb35f3b1c44c4cf2c584012b14711d06ea257afaed34554022c541802294d6cd0ca57fed93630157d12098108284ae032213f1c5a1e853c019c2930aa3c56bbae60e2c4273940 \\x807606c7f72fc09d4d0569631aed80f94f14cb23367c42121d89be6e012e79a8efd41f9a68a87b440dfe8979ae783dfae0015e7911b005caeef3329292b46d81 \\x00000001000000012b70fdec4a6d8c8498f0b2b0b7237547a3d5ff6bcb88b401ce532e57fac6cc08381e6b22408a50fad26d5492aa3e4d96db2bd7573ad2161ef1b48dc0da21af05468319602b0c9a0f526a3a359f20e60317255139781a9df5714a37ca17d1974c4261cf060125f51a98c6474e1a35328237f2ff053ab349d001df395af7833aeb \\x0000000100010000
-23 2 10 \\x53ed89ddc610887da56b1c0319fd480410cbebf81ef8ca2d0a989f3550b6bf88fa7ca42aeb0ec70cc843e475df9d123eb18e02ac1d168fb50aeba8a385d2b903 121 \\x0000000100000100c323c0aad0a0660c10fe27e0ae684983a1746347988aa4a5dadbc9ff81063c0a025337cb4bbb3bfc69efddc01b97d0ca05e30642ac6990ccbfa39b514dec0445e2eab46cc20f9ebeb3442426af2c23c2205a0c8774cb31ac2d2410c8794e333134d9fee1400620ab1b2cea7111cf3f0b3cf0f3aaa9ae0617dbba481207d2b8c0 \\xdb87460038489c520f51b57c1128d6368797fd2058ec154072d5e433079ce9d363c6c39e83d2f79be3c9470b945295b3c3274945eeb4a3f53bddeca0b80d932e \\x0000000100000001960741771ede6d33283d512dd2b6ff171cc30218e24b2c9d497cceb888b4c8a064cf583b0b520163baa0143ed3f6438d8b4ca49f22142955f999bb8b91de30f07f3bb2d8bd5ec5e78864fd8e54bac72ae033fc81f89941f2a6b4c8395460e3697719ce6a15a9b7901a7dad07c50290b96bd19d5bbd34b4700d99983108766788 \\x0000000100010000
-24 2 11 \\xf3784eb7b3a8735e351ef695fc9cee82cddce2f542eb81cea67d773b8abd6221febd85b7f457a0913293cd7c062b775aa60442152f748979e29ccba32b900707 121 \\x00000001000001004c480fb6344819a7c98c4d7589a98f236dfa3d3765d8889608117c04a00581a6e59c35060d5748631f6acdb20e6f07f84159e35c597da8b54d8adfaef559b3189f6eb372763b7b0ea7b150f79ea0552b947bb09a3a1d41fdd775db835669cdbf4b8c05fc61bffcaa5443b8811a37b70a4951ec0a59f20b81023b290ad1ace1c8 \\xc17b5196a48ddaad4ab7d2cc362672eb9a44f5f455145e06629e2ef3e831df89bc4e0ca6ddebfa71a0373a50558e908ddc8b7c6734b7d783606b578a1f07106d \\x000000010000000143b6d26e450873723d486037327bdbb889e2456c549d5856ce53e111919056c86b2ab9766b0e11972af4d7b9ecbca0990f88f50fbfcf1833c5119bdf9a009fc216b2b7e216dbf5b60ada65a03b1a6f3927583b0acfc4d0d1d96686d8613a3da34c77a7442e0bb44c3ed724ba02f3d934bdf52c2d26601649743c04fcfeef0f3a \\x0000000100010000
-25 2 12 \\x4c2b83e0142870cf135c996e37a8bb8bb1eb3e633ea21dd8da4c208155760d77445365c1775977fdf3d7dd9347430d760ea92b5b9ac42b036c2318254f1ea402 121 \\x0000000100000100b4ec7fd19ffac84ee18d57d91efe3201fd6a59d78efb1739fcb60f01d0eabc5332c0d376f9fefd3e7b4ab72bbce717af5850c95c22b8539c1a270cd571f10c9fd19383a1d65082bdc1c47971aef0a2061208a56bbc1bd02e3bc86e1bd8dfcdbb7198d1e2ff88397475209d13e145af5226538de889303543d95cb915b3788aaa \\x5971ee6e9bd450fcdf673b7d35a96b15c9a0a2df1dacfc57f828f80ab62d31e883bb662966fdb06be7e9ada82aa9dcfadfe6f7fe39f27402f51df01f601730b0 \\x00000001000000013f159bcbbfb5ec78476b5cab981c12bcc93aebc4fc9c601d2acfeb8860208e0d5bf92896dc1b2b2809cf25ac54e9d95adb4a8d54401b16ea0dbeb78ea930a59bb7db3719013728eba7c853fa9a99460122088b3f612ddd8eee4d20596c3a0efa355ce7ee1ee0315147453983928426dc9b403fc9fcffc3736782341aa0ddf08a \\x0000000100010000
-26 2 13 \\x14a638b11f60be6e4d08c99e005b49f1cc050dc8f7abc243e54653a83e5f4b109e22e83e2850943fe1f5fb3fed42673fe8d41734dea5d3805e2964d35ef13b04 121 \\x0000000100000100590b602980a12d15f840c87a5cc807243ca6bfd8679a786f17381c4d141e7ff37e84657e498bc04fe7eacb142d6a6477480be03d53f7292612859bf2937b094bff813997b57e04279fe59828d8d09afd5b03d31959c6a06f1d1cba4faed4a07100ce0ac8b5d6e81221a4df5bf0823f5ad792c0d952da8f779c64edbe6bcd0b0b \\x79ccb3e7a9d8c7d346421a75fe2a0ad975dfea8c52f9af05e58f1852ceafb6706ba54ad5c6ccb03a06844a3282793d65f2d883f1ba8aba26845b6a4f645fa560 \\x0000000100000001140d5d697de4b42a6ff392fdecd0378bbe775b1d294cd40e1917b6f1379ae0e17993fb23a71bab7cb5a6113681355a56b9adf83a7a18440041371f64ffe7e02606deec7d00bbe5bdea384ff789a0b3a808abe088ae7cd3668e966b6420c3539888785d8adc4b5ae95a429ecbb4a31675fe5d1da5b3a67a1d55402edcf684e7f6 \\x0000000100010000
-27 2 14 \\x025c560a7ba906148c1ce220d223a5800b4a0f16bc4ae6fce03c911b7bc84209e11096c567ef258158753f9168f48151023fb66be58b756e23a0028f79e4df05 121 \\x000000010000010014785e7296d51667fcc820c00b52b153dc553272cd624f96d05e0c3e39f12930fbe0f8415f48ad3685c4cfe2fbb022dab3d9ad4047803dcdbca38a61518afa073c5e3a9f3d3039b939dbf29d36144337b027f558495823d82cec66d4e13bd76a70e02dc1e7b34883fab66d8e838fc70489d75fccccc0c3388153dcc20f5a5d38 \\xe2847dc2e0683f01e41bd147f26311e849d0b3f738dcea9aad5b3f38a9106aa8699e294cbe880951ae0adb91576cb113c33ef23d61859ce4a9e0be261823454b \\x0000000100000001c149fb1b7d6f7883a74e1ed35fafbbcc490b3dc735adcbea81eeb9d05e8c60dc3d8df377064e6e3a1265af1a3d81a6d455e03f6dadd611809bb912de239712f0590a0a1ac3a4d77a52dd30007afeb3c15ac8b48a0d8a80a2662c7525cdc1c28335c070b0cf58587e326a73c49b4693bb25464015c429a4daabe4394d99b29edf \\x0000000100010000
-28 2 15 \\x6c666ef11c923487175e71fa31a53da5087eca6fcc86ea9422a7f65736453b46d2e0949cda5f80e5eb52eef12d202f4c4a52f3fdb885d53e7a5dd42342513f0f 121 \\x000000010000010037d44f7b8b73ad977f31f2317723af805c672e33a809353cb493432b6001ea71be0a5b2dad68b0e0af77a39c898bcc0a61a10f9abfdf5052de01d236e5af02fa6296ca43814589ab69b5bccffcd93e59546668714fec2b9fcd2bd682b3a1ced4ac511d15d75bbb4aa9e1ed9a4f519331e821c76997d7004b7b07525b4c8c4145 \\x392e88182cf5ac52489a610ce79947c9242e7164dc4754c98ebe63b4f454e34bebf6c821c5d998466130836a6509f097a18344f5315d9073eaad57d78bf7acc4 \\x000000010000000183cfea8ca19a4b4c11e5783388b30a9bf3197fc9f7152ed88591cdb487c2ef5acd464a9deea38e028c4d208bca4373bee6ba4542de28569d9eb4846340b645c6075196ed7f2f0fc41046931793d1e492e3f6c33eca8486faa0392b63c02b91ae0c930b8dc9447fa5e6b701d34868d3026815376e422db83563d182809cb06f8d \\x0000000100010000
-29 2 16 \\xe9724182d82798f7e2f0179324950b7d0b8c644a7f3286dbf1f84afd3b8703251006b79fa20617a46da9727d6c3998c8d3e5fd8a4042a3774a0d31c0d7901a07 121 \\x00000001000001008d2062484b5a1d8282e1048193e5aaf10feb3d1dda78add998b73fd61e3f6bb275b8e2ec461727473de41b728b69f9d6fbca9dd49ed106a691cd539c5e18dd0799fa4852c3867b0b3a24962efa6132deff790042c672b27a4ad7f65b65a60820c06b5f75a09f2aa2e334a8082e9fd49de4e5969efa1879ec80beea811f8be00f \\x5aad2e575e892f7797c67b2a4e10e394e7b0b032780c3f8f3114de892fb51aec3da47c5733911d6a0c4624b38f829d7ed28968ca1b261c07606764bc57f08528 \\x00000001000000011c41b2ce98a70a63ed8070beb45dbc3fb12030f38bb6ad53f938d6fbd937e60d33aba040af19de091c6b8789555b2c0e7dd9c3fab399de06044ff3025397e0d7b60a38c993ed9b6aa80850957cd25f6c19c58f7083721c8ee554729cfebf5dc721214093d69b0580bcea6c82e4f8e7a0a733b68116478ae976cf10c7ecbdb062 \\x0000000100010000
-30 2 17 \\xf13327e67a48cbecdf29a0b1c2759f60f7d745f8049ae1305e31243ac52342b404b3d84e9743c48cfe770b5a7ac0afe96f7dc8cb8740fb1a892105787e4e9c01 121 \\x0000000100000100a627d731acfea13b27c4da87e0fe668c6e49b8f0bf14001743d8c205dbb466ea08c25c4f87a478ba7792ff4c9519d8dc21f4ecb347a5318a48c9096496f82a33ad19bfa3ae5708fd498474e3bd50b5e175a6c44a5833c44662459c4436d65c5c85cb5618dbca59f45e13567da0baaa2d70916e114227b627048bb1c93fd9f6f0 \\x67f6fd29401b639d0cc058752541694f79278d5a56c2e5ca08dea18570f6502b16fdf78fcc50e9699dd39bbb2c531e2b3d06b10b6ab68a00a99e2a86aecee3d3 \\x000000010000000106517077ec264215b9e187fde2804b172bdcb30806b62d174797ec3421205f96bc92c2c656353931b16030da08b85084ab747319a702e5f6012339a58d9316d46290648fde650ae99864c28ec5dee59f7b56e91702886e75b992c65671aab03919ea6c9f0bdab12e070daf6217c4549c81a2e10012321381b62f3cafc2909ef7 \\x0000000100010000
-31 2 18 \\x97bbf9258ef37ef4cbe17b73696b46d5baaf265b28d2e9341b7fdbb9a68c8df93782524849e011e48609e86827a5aacdd14d960780f48a217ee9ada2a1402500 121 \\x0000000100000100241484db0fac6c2c7d738b5366e3834e4d434154e03885222652166223ac7917e3beec0f31e5ebf94bc6e388fcc424f2ac0a863a1b0f1ccc8d45c9f5bcc26fd42f948fa05c2fa30184da01153eb8b7a045ca42633a879477f31995f0c2497077508beeea64256b55785df9bdd725f3cf85da7a218fa046c5f3577e779a14f817 \\xe477cd9754ee028ec9a656d85fdd87b6f95889c8be66d03adf011aeb4712ec9ae95a9cbce769b2d3a74c5898480baa57c2c26c5a308d248b4d11478f8af4dd18 \\x000000010000000175f5a85966cee3e85bbc5c3599dc98398f8453f697440b216fd925d6b0b81e759999f223a589eb39b4abe81db9d8c455f79711bbcd0e065282a4b9e95268254a0ef8589aea3ff025f62665b904d6ef0625736d671e5335a7757de9f586df6576bb5edbf6325f11d8c2d41a2e7298a65768ec92a88e82bcd8f6c9a33f0d0d483d \\x0000000100010000
-32 2 19 \\x1f158f21d077440bce917f70edeb5bd0a80d537ab56ff2fef7a30c9a3fc2444c44274cc74d94f6f80319d79176ff4da00d211fc756532ee9216f778455928307 121 \\x000000010000010045bc3937031b9862edbbab6cc22478fcdf343116a3d72a012ef6272789892b9a3979183e399db554167bafe297aca989d24ac7b698f5ae40612e75c5f73e2f92f4846b1e47094ade36d7a619a4ed7c566c266766f97c7bdf413bf1e55ee7f6e22ba205080fefae498f0b343da2c54529ff3385b9a390d188f1d10a869d05dd0b \\x58f9290a997dadb89a4bb19087b714faa98d23b669c5d9c24585d6ddec9b7e92da55d316bf834740e0a01f0143aaa4513c8b2ef8b89189cb3f71df85fe963e1a \\x000000010000000176543e083b88b88a762940ed80b0d7f63919d632d11734711d36da1fb80370749ec61ea20589a6cefc5293d5a38596ef16544daae816773974b8786f58fd36b2585504a2956994078da99b442d4f49c248660c5536287c31207dfb48084e2d593b0d2cc1cdd66c1cf5abcfbac9f23d1a8063e7d3d3f2e23ee7d3b493c48480e3 \\x0000000100010000
-33 2 20 \\x561e1067794746bc5c4eb4fbfac47ada24740702437277b24de320a6689e344e2de570f533ce419cc21d1405834dc044757fbef36ebb82bcf5968974e530ea01 121 \\x0000000100000100bc30d500fc54b5464444363fd7f06aa37c50937ae99698ec0c9a7151b969ffdacdec38528addf4e10e8e9abdab12179bf4bfb09f2c05ce4f58d265b87cf9a71398c58e098c47dcdf2c902aba88f2b7bf98453eebe856667622278d43b6bbe6370cc73493ad64926cfb35e64f7cc8fdd31c9f29f424a966c9e608c84489eedb2b \\xdc813cf42befbb23a7f096a11e2e94285619ba03b98b37b629fbfdfda84c0c440fc48539bba96ede0024cff207bc8bf4b85318a7f255051815b06a30e13435eb \\x0000000100000001165dbaceab6f3d83243928423b95497bbe9d5a30aa9fa790e862db64454c2181f69fc18ce096bea82ffccd4be987da077c7535391ea1ee344bc7464997ca17cd8616d11e286f8fad97a53c6c57855eac0e0b547e4db39d67d8b4fdf28f8cda9e02bd557d3c4af65d4aab53a059f34f0f424d046688a9a720098ac94fc72875ed \\x0000000100010000
-34 2 21 \\x2503f3a35931a927a2f533873b7fc47a8c1f955438c5b60a88228792f6d42c419764ad486ca2e76edfd318ccef4a48bc775b69dbfa3f3ddf5aba0cbee2ee0a02 121 \\x00000001000001002a21c0ccb34dfcd1e58a0261a2666a768ef69a4622722b8240d8ad57fcdb1017c9f86def6a38292c71f6597adff5352e7067eed16807b59ac6ae5b1b7d2571c373aaeca496ba1066a33ceac43ca1097c8cbb1610cbfc725ac40809018d7812630222adc13631ac34e77a45c7b59ce4d538f8ae967f9486bd1143451fe68a0d18 \\x29076c6ef6681612beb79e6757d281e2cfa6d26ba3f7a18d282a182f33b33c6d1b7237f1f22160c768a7ef5663655f305e43b6e130dfeb64cf1d38e553076f71 \\x000000010000000128ebb719ea101d9176df98635359613e6cb95c80f8fe73f46dbc3e3901654e5516d4615e581f628fb3507b2418edf6ce4f356f419f0f1f047cb25286b6128c43acd0127ec08ee9c31f596fc39dc98872ff134c0f60d3b88b237b71a0ba4c9815d82476497e51f29d4dc48ba18b1c9b00d260bc97b9dd899e86bf4c1ff4277db3 \\x0000000100010000
-35 2 22 \\x47e83e222a81147fabc74f333e85a821ffda81f5f9927e19903e99f5dafbe40e768b32f5eebec6d97c12c2e7f15ed9e018ff1f35a17e2e7ed111169abd53eb01 121 \\x000000010000010057312305d4a1a6413e3b6958d3460418b39f738b03c41a2018b32339117c5e23ed16b84674760d7a601390ac4f66bd1ffc32a200143a89d5e0796dc383e086c3ff64002cc79dd08557bd5a0f9d1244087fcb2dabb80aa5b3b196bc57023aa766edd5350b63f6fca329d8ba724b890ff146b0a1763f2e310d683da6eb602650a0 \\x0c8fac97181abe8d21e780893f624d49978ffd2f390c176d7ab3c61a67c1126e87bf50c7f5136afe05860e9817e4c1e66ca926ff91f71b85ef3a958b84913ccb \\x0000000100000001b953e5867dbf8e8bc79538eaaa4577d33c096968d76bf9f44241f2838b8921aff37e01988f85e9c8386020c276c9ea8a11461b33cd1b83d2682b3c0c7371506d555eef34f7654849f425b1b35ebb142640df060d5debf6b836c2a54b4468705d5745289e5d548033f6f193c85eaf65c13b03fbe4a273bc782fffe603f4031278 \\x0000000100010000
-36 2 23 \\x30ab4f830e17be77d3eba23a8d35befd7e521f396e7953dfd20c080137c87badc8838e45ebf98834c8d3a96f09b03c1d2a4cdc32685a2f5d38f6007fd6ecb60a 121 \\x0000000100000100af4440c126c6c926b7cff5f5868e4b0fa72202a7afd2f23f795984c48c1b8f6397828ec3ef9a72f81610efb580b78045a13e3245b601a944350f737465eedd300ffef89a6cd2d2969db38783e2960852314d41c845a6f274f36dbd34287cccfad1dd05c112405b23d29987318ff839e876390ccb4e55840687ee0db819aad09d \\x24f58a9b66ddea0ee0d5e3472fbfb87856a389745c28960263b8bdfc07968fc6657c9e174a5dc84ef3b9e5f76bc1a4846936c7d99e57b0669f86749b1cd70d82 \\x0000000100000001520f12c8c2ac534d47db8868e3349f31ace9381c41d46e753e336d19c68b4281c7b7515251fbde37a8db944458a9f8e5ebd35520bce25ec03c7d02e821ce8be63c00e5de41b24ef4b85591b2f836b0829966c1de69aaa52fe72cf9ca3f9a95f0534fd8aeb809f6431a7cc8329a7fee955a2adbb8b4d0c958db8f8c96adef4d8c \\x0000000100010000
-37 2 24 \\xd3ccc9f1e3fb505d2d36ff060e87bf6cd08956cfd49ca7b3e178e6d8a7077bf450cd529c2067afb4bc10156ee9793df6d682f38d359db52c2339e196a00c5609 121 \\x000000010000010025ea04bf48e0a210144dd55d7c385416ddc225fa5260d58be22ed59f36ac5aa47a6fdd2876f2f25fb82803ce5df39680b8c3503b62604d9b1db458b5b4922ee45921b96e6bd6f3cb42f9b9889699f3b680282127384501bb0fefaaa71ad4130a69b1ce71498011e6295d70790beabe131973a8de6eebba2261018e803e16a5bb \\xd8caadece3e1715f2a9ea28e1c1810faf395729108c0283ba755d3723a8b05c3471c55e839518cc8dfba3501205ab9b64efa8962aa7c96186a343ff258cf03a4 \\x0000000100000001a9c85852a9c517da9df91a90bbca6346005906240ce0fe79294d07c47d27e67fee8f08fadc68049dbb00e053db539ecb86c0c88ec3759753f52c7a2dc6c72346bf4870e1936adb1ccaf85f9c4d537084eede44ce96da6d2080c58b5f812a5235d2ef0478665a452f3b74065599b35e98dea93633e62c82961c347e372ff0d1f0 \\x0000000100010000
-38 2 25 \\x35bdbea5bb10871d799cb4632a1bbeb60e66aebc96d46f70d5fa6dbef19ba4c8492eecad676fd3fdfba97c27adb2cabf88b879d9db8efa75dcd3ca1e0f11e90d 121 \\x00000001000001006e4d51b3898a4ff7e5835b9cd50020e61aa1ed5897e5eb469eb963668dfa3536460e077570e4aac716987d20f28a2a3b96f152c8fb7a0c9a233206665bdccb4fac63d67bbdcadb911d9a04842cc2d2e2dd32c89b951ef64f97458154186d65627234bf08e5c42f2e730700f4bc9bf0e26429505a8ade9299344bfdaa086620f1 \\x0e208b0cc73f5ad95ff1ab6347e164759b5787cbe523e2c3855f0f3052677fc61e265315c51d5df1e52aee0243d6718287a637df012d1458abd02be1dd1683d2 \\x00000001000000012fd7ee34eaebb4b6924074883b42b6844b9ccc7f4a0ecf643c1dfafff3e976c50622ffe619e19ebe571f5de6489338ba34a14c164d96ce9cbc4636114a8998ee05f9458f889f5e480a77cab70cbaa88eff57f928ea2b5677172d486cbd8839efe5df5e8fce2483b1a5e8a30ba68f869a2d21d90982a81284948aeed1e1b42456 \\x0000000100010000
-39 2 26 \\xae07cbbcf56dd9234d60c462c80d2d97166edf858c45ff537a3f5224896c78398691e1f4da3cd23d6a0e002ffe029d8b9486f43113daa4bf50ec9537db471c05 121 \\x00000001000001007ba131f613eb3f1ccc6650472fdb849600fddb6c1ca628e8b1d365ce8d23f2b725c6ee2aa45919304f99b1d5dbf21d6ac783ae263ba0e95e63185ede0b81cce5365eca842160c915a5147c14d06370615f993f90a487280563fe14edba7490b0c9c9b9775d3ee686c344a96ed06c78e7fcde6a3e87a73ef7a843c3af59604368 \\x99d43428e94beb322a6df9c2158d4ac83b55df9a754fa2c2657dfc4c7c553209fb33aa43497aabd8f897522d448f98bd9e6ce763c67bacddc0ade7e74f1890be \\x00000001000000010a63899342779893eed38d9209172a4fd54a6b2c541a32e8d1ae76a3c102902b8f329c433e2aea34116f2839f0b614961b9494e3d413080ee6c6950ef96a0101fbe3b2444fbc0ebbd9f3ed0ec48aa7d25e6c0a5096df11f683020285c769ac282b168d03f8252e9e5ae302e533cecb4beba5ebfacd853350a2ba886165fcfee7 \\x0000000100010000
-40 2 27 \\x38bcd0589c8130adb0d08f8c16329b5f01b6b49a4ab00512db5403d800a29f601035e5bd295713a0583e00d20fc047035d6b4cb6218778978080015e73d41207 121 \\x0000000100000100759189432b8b32fed282ff0d7ae5c891a6736b3fad220c204f59823336ab3474f7c5b6f724dcb9db82f721a575a1a2f5c1a123b98f431783dfd35f63b79d34a4b2ff6effcd79eda7e17838302004696752c39af3265644b2046a9786ebf316076ba0dadef5e0bb78727302a5d17c8dd6183ee446d15adcac159167d57dfd9c96 \\xf44023c9edb90af38c39e1144c151e0d9271514981988aee26765ceefefadd4ba3b116aab015b54aee7670ec69c8504e7caf0ef51f3c9fe94260145f3b063a40 \\x000000010000000126800f99f4959d5b514f8205856274a4d2b3928e83dbf44164a9b2661fe290378a2cc360127309ae9d54d476301a9603122e9d3e3363dae69a5b9fc3fda95788515d7e2409ccb91c45afa22aec9b5db3e7566d023d6f91be0683c0e5236a7d4a92574bf9bc4161da04e3acea3154dd56a7917c25bda7bbec1dc90f326111d157 \\x0000000100010000
-41 2 28 \\x88683f4953a2a9db4b95677bc8dcdfda03a3efdbace39e6ca3fdab1375856f4e0ffe81053a71135bc6fc0f8193dd952d978bb72636a18fc860da541e28483307 121 \\x00000001000001001d46919e2d1715b83ea0d583e7ea0017dfe9617f9591cb127b56e056392c629b5a8f32fe56bbf59a824b24890c974061bf07d47f4f1037b900e3fd3de72621f93684f92b090d8c306f4a1b37729564af43697b2c97681a333ae2bc395a8e80f2b8188a288813b91323e3c47f5b304dbae6fa92204afec64f7e28b7cbd7087e40 \\xabdaff44cd8d58ce77679a4519cc20b971ca1b6e7375eca971da2ea06d00e60b6da61f74916cc86cba765abd33b81f149448e70638e4134f3877cb5cd69a0899 \\x0000000100000001ab955ac97125216370f30856c24fe99656987e78e03c20fed28d8f88ffa3be77a85605e8aeb9e56b136bcf96e2bcf477c9e87736d3f62e87b58f5ae2c700359b94f55711c93e2d7a04ade45fdd73e7750af1505ca5d87e68677c315aedbe406f72168bc5b131853f15979daf6a3134bdc69de3205e1d1a9726b18a0334c2fd7c \\x0000000100010000
-42 2 29 \\x1d23bef7dbbf2f5f1118eaabcb22f82b8272325d543e7974acb2018fe10c00bb4694d0b2b4f2439095f8fd71d126944207d80973e559512f767a6d4a2bccd205 121 \\x000000010000010058c7487194b264beb41febc681de10f98648521c9403cb4ff447083a4a7a47503a955be8daca09488d2224e1c21902d35a69b79846479d352776bf2f26ac54b41bda6611ba633de69725315c86a25f42ba7e1e64da75bcfba43bec157e96d50301138e69680cd2d5dbb7319ecd6ddc80b35f7ddd5e2cf973b359e051e94efaec \\x064e2fed383f5d8b0d614a7a11a5d15aca01d376ee5b4fc526fc122d1a5869631309d1fe25b26954f03a5b9294728fa5cda8980b6f40f5dcd37bc78913ad711f \\x00000001000000012331e5a058ebcb7b5a1fe913895679eff96318c1df3e32ef9c7729d3d5c7b3e4ab8f646d8255fa342ed0e7ae1d6b3e5e1a23b03c57421ea0be8426e9701863c1d36608951f088356168f4eb1ccb8ecd85da2b074e26675f845d63bcdef4032d2e4ef6980774487b8f531bb547a3ee8fa165ef722b6317dbcd16e5d7426141346 \\x0000000100010000
-43 2 30 \\x992734a69140ec30723df413c18a742436d552434c0d352ff170494d41fd23547db047757f91d13b05dcf1fa1bb7f2a225d6d7da1d31a424f6940bdf9fdec904 121 \\x000000010000010015952a1a2d068caf485e39b3fd5a7d027c16102eb6e09b0567dad707ebf61d4d289018f797a4ff2f460d838971825b5d4f7fce4b847589af685d9c0f3ffe3121981c968bded8de390e64f4301a92840a8799b0d716aff03bf47b076b57dfa471059492587eb228ca83ed3c766c0d7047fa7f2bfb7561d17acf45237acff11035 \\xa0c175eb8afed26d34cddbce78bb8fbe872960b56896ac2e2860aa9625c5c0c5918951f3e97617fbc55f12fc2758004f7d0406f68b36ec681c36fb2011225f21 \\x00000001000000012a825cad625f6ac3cb90591577b8cdf17bb73742941a8ba9e4ea2dda2e855226fb32d85313d5a4227dd205f0ba0646897b7f798cf1e51e94c768fe7b7d1830b03dfafe376be2a2a01cfe881340a49e1c13303097aebca5d1f9db14949f74de982948d5b65e26a2fcc702a20b9c83aa59df4d08a4f285dd999af55bf4e4ff4642 \\x0000000100010000
-44 2 31 \\xb381fa9ecd0945afbe41016d4a9cf1d768df33e5a77423bd944498fd1395a4e64ebd0a1c5410fe90d842911964f4cc5d135dd0ffe6b07179456f445e0f9ad703 121 \\x00000001000001008f88c5238bbd75cb759be23d46472287bae13ef206b75f2fd4f87acc54f6e216a0b05ef286021b6b5154738534e6fb054a8b4397b3df3edf69b6a47241d7ff060b5f084cb26b67fa1f3d8e624ce64539f76a31707da4d158d031b3ff6f28fe8d8843d66c9d6bc596974232c139e7672b3c0420a5a7feaef88ff603a47c09bd41 \\x1bce3b2930c5a68dcb16554aabb03b9b5d8e0837b3ba678ac6e85a4daef1b19418f650b4bffbb89828ddc2d899adab89ab6510a7cc6a5dd09350cfdbc068ac4a \\x00000001000000014394d456cdc2a78815f2a70b8790fdec8408d4876aed6e4630a73f6cae5fb709e61dfdbbdc50384cea1e874b7174b6f82fdc242bbb989a07fddbd39b30d988251dd3380159f319875a6f42a5e34bd6502f09f6433342288c6e89bf6065535508b5606a765524e66561a3e4221b2370bfa5cd45e1ea37afb3c20d22d6e8d8a155 \\x0000000100010000
-45 2 32 \\x23d567d8a22ceb1a146481c1f206f2bb04fe27cbab3829042751cd964287c45993a1175771705e191019a7bd852e7cf22ef82f2be65785617c5162c5e8d48805 121 \\x000000010000010032d31aae6549bfa37eca184f81bcde8466ecb1c770fcc1c9ddc4c5f6cbbb963990c5875ee893741fad15d63504848422ce0f00515258a45c76f910b47bd4b5c4eef8aadf61f4c34143578864de6052fe25f81505a51b97aad88123fc9bf828f3404adae7092df8e7f73c6c40f933edc802205a9a2a3501410d51c89d40bb9f32 \\xd4c85f21dfbf9270a9d880489e7e5cd35303d58f3c82a700a76b24cb9082d9bd57d51315c79171009a821568346334b2350a355ad1a85f6cf5f0c42a7c516b4f \\x00000001000000010f794aa244189bfeb89edec93b7bb34c1698121b0afdeaa842eb59eae582e6b4a7d11ac972818c8c978fd43076e956b25ef4e9b3ec5261f81c13e81444320712c2675b2e0f64aa5918de59fa724b0e4b3acd55afc959e6b16a56a93d0f9ea65ac0bc10431b1591f5b2b25fc012a20119d9ea9053f2d36d1037e30993e7dd20c9 \\x0000000100010000
-46 2 33 \\xe9943e27fc0083de5aa273f146c0be33f3ee8e5aaaad1d880b793dc81752a55e458f09e3a30322858a1f5ac43bb851752c9c0c36a0972e086123b20e2f6ea607 121 \\x00000001000001002f5708692ac2918e19e98409cf0927d93b68b8c166c0a1717d17085d650630381569deeb090b968fb704b898b1e7f37a5253cb68aabc65f805be557383675f2f5ff3be154a0f6225b27690b7f7202ca3723bddca19a7600d1c965c0107f6bd76bf75edfe5b73ffd3df8767ee1cb216746b68c02cdf8c446ee10dcabde895da3a \\x33f639de269da2732b7c4a27467c3c6487b401cd2cec3c52132341874fb21f5560996d978ae9d77c7a6d5803ee68d61c83c6b39f210fb2b4d92ec9198cfd17de \\x0000000100000001991231136f7ea2e0b66246201c70c75286dc62a5be11ba42257da0c11c28230c5441f2e9e709dce31da4570599f8d3d2f6bab0cabdc060f985b5ff9a24a61890a592470782495f86a5c97167253a8d6222e4e8b8a4995ef386c0f7b5d6632127de8b4e318a7a3c3360e7233dde99053eb952aa320a554bb82a23afe6be78706d \\x0000000100010000
-47 2 34 \\xf1b9636d1a2af383f149da30e92446f6e006f74466c4c5dfa3657a15e966e2770a39808d2c5be211208c26f1b09b0fbad0c738b4d24ab0cdfd1111ab6e233106 121 \\x0000000100000100342cf7004c04fbf94045f081fd21a9503ff7168162b6603c745752d24fd5d65057d2d561fbdcfab7fc8370fa59ad857deea567097b85ea6cd1cb0d5d6bbdf866a16ca3a8da1e8c200cfa5ac43891cd615db787c35c8f825c3877dfd8b5044f8203d5366fe560c196c45d53dc400a6fba2182449b00c958f595eb1b1ef8ccdccf \\x92e7d4245027839c36fd6c6ac1883a61a53be3dcd0771b3a9066a5b42cec205c3adade130964c1ba6a1a068ec7e33922aa8649234a47ed40371617181c2f294e \\x0000000100000001983a86bc00379c65b52275c2ab2b46ad747ae9d37b277b4f45c769ac43ed42750e6c4bad15432157cc9a5c6d798f22858aac3ac845c54c1be3fcc6be4f436306464e6442d631182a7c02c3a637ad3060f28862d63ea1707a9ca85f62fff7dfb8f3ec1bb1a0a7483c721224067fe19ada0614a7029497ad28094f88748c02648d \\x0000000100010000
-48 2 35 \\xd71225e21168036d1e7185d3da9384ec01d68eefa2ee52f627bda914a507f3e34a61768c573714664e86fb47ae3de5e51b912562508cef6c60fe2d16fcc8d40c 121 \\x00000001000001002471fb2488c5c67643a46155adb7e8f72bb74bf6b8cd261863e710883b40267e8ee55d0d3f159ff62345d17617c91859f9d45aaf7646bf82dda9f396d34a0f682e6784060564191435ed3f0b78d4f5c4a57e0cf8005c163c0f4b53ea6d22211427f0b7ec5a2e55021e686497232be5f8872aabd9e80c2339b4c1e7f3afb7bb7b \\xa1c4807613cddde9b71b1d009e13ff8f0874f3bd62c9d0c5ba3c739ba4e1cead8a8914f53e7c464ba70406c015bfe6b1f781769cfc7a22335a54e131508616a0 \\x00000001000000013b600c65469537e268fdfb24ada04c091da5d620921a70ab3a36f1a54d5c674940384980ceeb362d4cf5238958d6121b4136746887bc7388f1e2642f40076dcfe0f21f19d0af86ff788dba0469bf506392fbd409b4ccccb46b6cce8e16eeed90fe12ba3daaff263f5c771445684e918d44fcc01d5adf7721398ce148e0e358bf \\x0000000100010000
-49 2 36 \\x8539dba9b4997db39eb85302a8e7bb6c2ff2c42430388afe3fc38cd59efe260d831da56861470d0fb0d2eaf04d3616b8f284fc178d30c33f3956d2291edea208 121 \\x000000010000010013dfe9732e532ac2f331306a4f8b71b8fb6ffefa5a9006797dbe21d22376d37e96dde11b02b7fe34f96ecad6e4e1bbfeeb630289af388f39d450ff98d3ee9a3ec3a232ea7a027b43d9a8a13d9f1e5837ba5fe0368f96c90cd46b1ab371a23b029af4b228455af90f9dc17c7f47fa0485079b36a4cc9934f1a47861713020618d \\xc50f27c685b45983e10bc8a9c44dd30311d576f2d28a9e01c047c2dd94194bc1df78995f713d8781af1063fdd645070dd44e1d563a31a9a75af21e85fc403f63 \\x0000000100000001bffbfb08dbde7d00179f63579f7349c47709cefa92952316f542d3af47c147df1994a01533d1f169c8e6bc6cc75fc39626ee62a8b71218a5ec1771e5add0394420e1cccc5a6d1d77b63513642d91f585e44bdda231c860be45e6fa74cab2fe91208a31d575a9deae2e5e59d74f53e44293d4dbe3b1f77bd514486f0901066216 \\x0000000100010000
-50 2 37 \\x8f5dd8bd1543e49455e59f150501bf93966d2e2a2a86e76401664e770c3fa73d9694f003388f3098be2c0a4ec00edb78a7a115e72e8eb30bf476e3acd016ed09 121 \\x00000001000001004121c01d7b05859c726d1cb8449cd8fe2396836472040b30edf1bca01a928f591ddf5e99469adaab1f2f8a8418b882bef3032a8290c5d614d63b5caa30cb090a96273cd5e793efe6d5b61b277a9945ff02f6f358c8821acd6622571789b62fea20cff0f2e71d18cfc7486e702d02c4d15987c445580112e5e9e3569595f97aab \\xa949e9ee9c9a8169b7ae5e18d25c1ea45b030b58791b14faebd8f9a51e3bd69ceef56670b6176ae9090870626c48acacce47aa9f963632475d0ff2f96ae9446b \\x0000000100000001609820edebce6fd5ef89a03565f21db5004ec5ea8df455f62cac8f63b5998ff61400ea386cce8b491e9c55a90c8d8f1771bf8540afc89d77eff67ef0d0c8bcc88180a3505bf36e795050b2533fc7a97ecdd8605446d3316d5b2b732cb1f46ed16bb551edeb2a851a0ccdec5dcc9e075f93dc7de84c4f596e35c60b0ae44f3035 \\x0000000100010000
-\.
-
-
---
--- Data for Name: refresh_transfer_keys_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refresh_transfer_keys_default (rtc_serial, melt_serial_id, transfer_pub, transfer_privs) FROM stdin;
-1 1 \\x22f6d70d2903796bef00c71d333396827b504651aa1b9f3696b6823c3d540657 \\xffda15568e4169e7c8401b7fdb4397ecc81fcd1c9063178eb78acbfee5a872d2dcc4aa1054e9b678a06c3026a3d91e572eb93d14c93d77d35dafeb404daf6829
-2 2 \\x55ca700ec86e005bf856d74d81cc0745e2bc4a0959ce94c48da28c72f93ef37c \\x7d230e916e52eb93f4e928a0bffdee777f4a8a9230bdb9b5f3e60bd37dd905970ca4c0c7c7f5e53b705d3d8d7681e436e03e03313d68aebfaa0aedcc0269858c
-\.
-
-
---
--- Data for Name: refunds_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.refunds_default (refund_serial_id, coin_pub, deposit_serial_id, merchant_sig, rtransaction_id, amount_with_fee_val, amount_with_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: reserves_close_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_close_default (close_uuid, reserve_pub, execution_date, wtid, wire_target_h_payto, amount_val, amount_frac, closing_fee_val, closing_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: reserves_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_default (reserve_uuid, reserve_pub, current_balance_val, current_balance_frac, purses_active, purses_allowed, kyc_required, kyc_passed, max_age, expiration_date, gc_date) FROM stdin;
-1 \\xba0adf5a41fce94b9806335673ce9283b15ae5db368eedbc7aed243225f0d3e1 0 0 0 0 f f 120 1662671200000000 1881004002000000
-\.
-
-
---
--- Data for Name: reserves_in_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_in_default (reserve_in_serial_id, reserve_pub, wire_reference, credit_val, credit_frac, wire_source_h_payto, exchange_account_section, execution_date) FROM stdin;
-1 \\xba0adf5a41fce94b9806335673ce9283b15ae5db368eedbc7aed243225f0d3e1 1 8 0 \\x75b009a95c776f463a8a9f5686a05a39a61e4d65458d1dca21f5789940107491 exchange-account-1 1660251988000000
-\.
-
-
---
--- Data for Name: reserves_out_by_reserve_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_out_by_reserve_default (reserve_uuid, h_blind_ev) FROM stdin;
-1 \\x9ab634bcf02e48dcf8086dd141248373d705299bfcf3132ee339055819eb80847c6755bd2f2a812b9ce0e5846530004e11854186fe5f6b1f35b223e7c4a409db
-1 \\x2fba6eebcc0647c21e291cda7cb1d827293b205917f99957a847e8e3b2a048c26fde27c5ffb719a0235e74dc77d4294f323cede4b27887873780e93ef16c9d67
-1 \\xb20ae87ef9f379b23a48234a83d6edcb308cc4bf7ffd2635e96d629610b6037844001b01461c7bb6dc9ed7313afc5a18ce5b6adfc0aeded8b01af063ed418824
-1 \\x4086cf401b712bc25c889019d64537944a9ecb117dac70525e278065e4eebd14915a1a6e7a9895395be5c181641a71073e13491aaf38b36632553ee7a95cd8dc
-1 \\xb2ecef9aed21a5da2a2d9fa944c0bbdfe9899a1980a5418f6873d879405a81ccbaeee6df1e5a1fbc3f7707abcc5bdde956138c8137204b05a276d4da36cb4d5d
-1 \\xde15d8f0ae8b1ed926487a869fb4e4eec4ad304eec557294fbe1ab04ec2fce16dd5a9e29d642c22062e624545c711fc352810c6bfbca9dd072e271e4a27a4cad
-1 \\xa4cd62721fbd36ffb1339288631745e69c5bc2b972fe516d1135844a6a7bdcc62e48d97782ddbbb6af45ef1081f5369d43031647cb7c1a7f26a717c6790c4012
-1 \\x3e0d8488bce061680d7b4bd75ff59329f1cc7a3c469ebaef0496716fdc3a188581df9aae9d7a131e8a29a7fd441c4781b66d45c81c846ae600101f2fc4ce79a2
-1 \\xebba2eeb69afeab4f92b58e3a7e5883ce41bbc4547d58202a0da8ee564299607911f5929f57cddbb8cafb7fab96c46845308ad52471fda0d92f495063517544a
-1 \\xf30e8f02041e060f28c7cd9a08cb895388d9e434198140200cd62f87d4890d66ed7fee7fe6eae0e9b84805aaf3a4cbc80a45d9af05674e1d0f933869a5d63fab
-1 \\xfcc930ef95e88c19a345ebcd42a8822e7c5bf1508421b1943f9d34c23ea5fbd28334fb69be1ae2c43bdd86251c101fc8adcce060b736c4dc131054f0b7924361
-1 \\xeb4d76137630598572bff82cb326e4a0d21bd55473a8c237848bd4578a7fd419a5561246cae11a7c9cb289bcb015c5925aae1b5a9d04b93e463c4fbdde484006
-1 \\xae25621a89c1264de21e2366fbcea4e7b4a52d220d177fbf6afa4a5668db4c88d333075082f49ad6a7372dd2b1c034d4dcc5697a60103a0182e0d2440de41cae
-1 \\xb8b6579a1c6bb49784903822deaa23070f3bedcfe1276b44a0e8b9440d6757af853d41be57e5b5f4ce5107bcf87f53ab7735545360e8d2fed32d90aff1ae4ea1
-1 \\xd26b1bbb6c7b0711833cb9d3811cc181ca46c41c915a145fa781b70971e8c12bafec49c0f0214aa335573a44016337fef16c00c94c38ad6de4464a90afdb02c2
-1 \\xffee867c0bc096ed56bffded86858e4eec4e9b59a93f01f04768ed137e3a77113e7f28131eae308c4b9458a3dc9d502c1ec62c4cc7777a92688113742faeeaf0
-1 \\x9fd3749566bfcc295044ee015b2e765ad73a8db672e77fca78623861d326a26940e2caf190376cbff5a294d5666bdf4827824b2fa3f89f9f4f75e44dbcbd5b5e
-1 \\x2b681d589277493cbf7e393993083df45aba66b0d24f2f7d30e20cb8e03ada0ab302f212233e39c1f687539d64f9fb97d6d96984aa3ff1129ee1d5e16847f352
-1 \\xf55bfed8d97986b91b9402be92d2e071a744ecd29e0ce67d72b3fd84f7ea3f5e3654ba63bbbe415d8e20bd3894b4beb43aece35da9dff4b1940085d44d4517e1
-1 \\x0f762b8f363d58353b86b136f25591548af6e04f65c0d740e9d09c70139b9df628e60c705e3ab385230721f71782af89edd4a5c61be19f5c848f6d78c416e442
-1 \\x14fc7a95cf87bf59a19b7dd528bfa3878174168c0e7217e51b6e00186c72c4d01a918d947fd3e812099c76d0827521b8e4cecc059635e20f3190b3bb4b42cee8
-1 \\x81a8fd47c3bf204e86f36637f6b5bfd83fee39a3b8ebe8b90843622176180addb5af00edf6777deae33250423c54b4e89c366f726ad8fa0d413227d223abbeb9
-1 \\xa664465b942b43d139f78067cd948fee40d55a1cadd695902a420703f4025e15d0e0a9a1eea777a02f20ac64cb423fdb002bf4e0991d15ccb64486c351533139
-1 \\x2725f5402becb99f9b88c5b70ccbb6cda96a68a505c75e0eee283a4773477d22c07c17baad42363f0e908bbd333dbd46a82773f435fb42c1d27c0d65aa632d1a
-1 \\x0c8ee183c59064303aa6e37faf4891ecfc4bb903bbeae0564dab530432fc8eb0e6396c68fba19ee4fc65bec76ecf3d85330c203696ece3636d7abf3ac503ef71
-1 \\x07c866917cca939069d3ddbda32eb54d3d681fb8d43121fcb9072d340373094fb26438336c4305b639d418547afcebff7c7a067c2fe53fb37f0b9d761b317c8b
-1 \\x7fe07d483d5c7b877bdffea29da031acc88127bc6ffe3a28ea68733e20a0f46d16e9ca840c1a3de34d60934faa733997bb13cf97c0d88769af946c32750c2336
-1 \\xef009dcf258587b2b0bd60ae5cb02df02051db387bd4e272e86b70b8785d62ec97aa6ccd9b412bd71a1bc8071e09267c216c98ad6c4e988ff6c1aa7cbb03de55
-\.
-
-
---
--- Data for Name: reserves_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.reserves_out_default (reserve_out_serial_id, h_blind_ev, denominations_serial, denom_sig, reserve_uuid, reserve_sig, execution_date, amount_with_fee_val, amount_with_fee_frac) FROM stdin;
-1 \\x9ab634bcf02e48dcf8086dd141248373d705299bfcf3132ee339055819eb80847c6755bd2f2a812b9ce0e5846530004e11854186fe5f6b1f35b223e7c4a409db 367 \\x00000001000000015071be8f4b08121a7946137361a5a53d4d2be0a73cd4ab13911dab2172575802503bb41b601195c323008dc83cc221ea1ed97f020cccec089132bc98fe7921ba907eb63d6da6e1fc3798fd73b4536ff4d507ff9a75214ed479232c8b311df182b27a1c224bf9fda0d5b8d449d8e8aeebe59b0c182b2a7ef67eb348b3fcb22785 1 \\x799593f0ad5ea7d73dafcbd5da851417f485585a5b0651787a4a56b3d0c7ad0c5655a4895050836830c9b3a3c10b03948b72cac190ef86d9a3828f183108de0c 1660251990000000 5 1000000
-2 \\x2fba6eebcc0647c21e291cda7cb1d827293b205917f99957a847e8e3b2a048c26fde27c5ffb719a0235e74dc77d4294f323cede4b27887873780e93ef16c9d67 7 \\x000000010000000155e0279ca3f475030566cf567dbcf912a71975e928876c14f66e6c15d62bb3a43d1cedfbe0a090435685c0173c84e9090c5cd4d7db7541f16f446b4169f91c836247baa678106d274a23305414c33e293c887afcc1de4876845faa2db73f8f7817833b653ada581e607c4506de2e90fe161e8cc071aef08178ddc8e2607f6ff5 1 \\x8db81fa6fdd5162065387733b95d6a678cb0e4ba4d73d627c019e1448d1542c95708a07180945a030a796a74775e8834883dd2c736bcb85f01fd135106e0210c 1660251990000000 2 3000000
-3 \\xb20ae87ef9f379b23a48234a83d6edcb308cc4bf7ffd2635e96d629610b6037844001b01461c7bb6dc9ed7313afc5a18ce5b6adfc0aeded8b01af063ed418824 403 \\x000000010000000180dd620e85c8ed047c587c3085372d4564f70f168d99442d229282b357999d39998acc4383e96ffc1a34250ac4491652bcd6cf0ae677d74832e5596cb702cb4ce6687179680602563dcaa202e1acb16b263e06eaeb4acc1f208634d5d61d0f6a84c1189fda5c31dd852a3bd51ab81ff497347f323b6d3e3e5d2f6dc98c1fb907 1 \\x6c9626db2da447bc842eaa5d4422474a34df01e64ef0a3b56a2a93c732096e1e2cf80091d368aa7594d24a8e2f4946c98d25f1adaa790515802d972827a91505 1660251990000000 0 11000000
-4 \\x4086cf401b712bc25c889019d64537944a9ecb117dac70525e278065e4eebd14915a1a6e7a9895395be5c181641a71073e13491aaf38b36632553ee7a95cd8dc 403 \\x00000001000000018570493692410f2ffd985f5ebd123f8652ebae6ff6433915bcb7566aa50b66bfa130ea40425f2ade143f1c866089356f7e132bf5f0224f56ba4e2159fdf7a4442b538be138817a7ce24ae231adb9c1ad0e27578258ffb7ea6587df283d804c8a4b3e7ca15f860f426a5aed89095feffa26ca4f98afddc68447d0b15fe519bb83 1 \\xf4280385541d4f129b55ba8702398aa46f33d6c00e4d335f9e281b9060a632155547a006af3bd69353bda5adfb66d78ed577a7def2d385dd725e2e0fef9caf05 1660251990000000 0 11000000
-5 \\xb2ecef9aed21a5da2a2d9fa944c0bbdfe9899a1980a5418f6873d879405a81ccbaeee6df1e5a1fbc3f7707abcc5bdde956138c8137204b05a276d4da36cb4d5d 403 \\x0000000100000001a9e96c64607df5cf9b8e7e3ff0de89933acbbc60522dd6bb9d051c1d28ab79e833725273422fa95d616db38241a8c95fb449fe7e3249aea3303c242e66ddbcb0d59dd0d5f4c7d9b223fd3edc2ede3f6fa1c20b5f8a1dd2022feddb85b080bb99da2c61bc9b78e78816f54c6c1e2354a7ff8ae44261edad36a82556e8832a65be 1 \\xe21727f4fe2d1ebf51d147f7c31ad9be3d155892f70fc2c7c57001c0b3be04fe0e3cd28e4d9856f598f16bad2978aac6987d8353bfd53dfe356df81d6e187d09 1660251990000000 0 11000000
-6 \\xde15d8f0ae8b1ed926487a869fb4e4eec4ad304eec557294fbe1ab04ec2fce16dd5a9e29d642c22062e624545c711fc352810c6bfbca9dd072e271e4a27a4cad 403 \\x0000000100000001b1eb2703cac4117b906a165fa64bd1b1298ce207a9d1e9a16fa874b10f4b7327753861c5c33c91cc4c847b10cc85d06069197fcc7dfc07a7d35f97ddb874206787d3c54e16d156f7236a95748b07012df25e13f0d5721dd2049c7f58889701f722b3985eb7ed973ad7dc596fa49e83f98e3a5b588231c5fcb9cb814288bae3a7 1 \\x5194919fd3a254c089bb96e3b9f111df6b1396ede863f7b3ad029a366063a91e337ad3819948b22f5284c47d1a4d86f81a14680db14ddcdc29155b5f6e8d4908 1660251990000000 0 11000000
-7 \\xa4cd62721fbd36ffb1339288631745e69c5bc2b972fe516d1135844a6a7bdcc62e48d97782ddbbb6af45ef1081f5369d43031647cb7c1a7f26a717c6790c4012 403 \\x0000000100000001616410883e42fc53f14ec6345ad5599c079c2cba7b6bbfe6cd14df7b7f6af6285382b0759579006f0c405e3fc5b63a4722d27c2e83c6a06a78a41b12c68a060967464b98a21606e8b96bf9a359009e3a5f5936f1a5a801ef3c85c04d8856df888bb93ddcaf80913381fd5f440a0f6af06b126f9dcd8facb72d2af3b1db67d24d 1 \\x676fec64ecea73446cc9966e4b5761c1fe11c5a0e7c3d402a568ebf1341092ceeee8953af27b57891f323324a4219d53a12b613dc5ff41c7ba2a23afb43c0a05 1660251990000000 0 11000000
-8 \\x3e0d8488bce061680d7b4bd75ff59329f1cc7a3c469ebaef0496716fdc3a188581df9aae9d7a131e8a29a7fd441c4781b66d45c81c846ae600101f2fc4ce79a2 403 \\x00000001000000013f7b57eb168986caef40607d1d309ca5eb3136813a0829e0fc6a7820b722a530f8af796b750e0c17e72f1f3b7409fd7e89a8b17780af5434511c7afa39a77ae3a16c07fca4b4868099262d6cb730828df1c861b6081b955159402d3476fc2dddb582673c0e06922d56755280e34a58d15a8db0dfbe02d52c365250c225524ecd 1 \\x7e155e9bc5d06bfe70ff805ce422a9845c371bc6ff7309c19fef1931aea444191534641d2e37279dda75dcb430ce17b7ccf74457dab80b737de3aaecfde3a805 1660251990000000 0 11000000
-9 \\xebba2eeb69afeab4f92b58e3a7e5883ce41bbc4547d58202a0da8ee564299607911f5929f57cddbb8cafb7fab96c46845308ad52471fda0d92f495063517544a 403 \\x0000000100000001101a2dddf6a6210383514e2ab353ee0354e00919f072550f235ecf4772b8152e7b39b9433cd9785486fa190bbdb53ee6d4dd2884cd1f2796490fb9ae4d81de3c854a7dbd877fcaafc443268ee7d44f3b0af9554009253d9b64b471cdf990a938942eb486f0e7c0b6f7e947d2073dd9601c2d0b04a75c06826d5ec02b4b8ade4b 1 \\x0176b447e9e386e70a4f81304b88ebe10f3e04005c0abe42c5e73adfc79d695f498a60da74c5a084e7b8fd12e44c07372466e7fda738ebb6b236c7d25961830b 1660251990000000 0 11000000
-10 \\xf30e8f02041e060f28c7cd9a08cb895388d9e434198140200cd62f87d4890d66ed7fee7fe6eae0e9b84805aaf3a4cbc80a45d9af05674e1d0f933869a5d63fab 403 \\x0000000100000001cf4fe182f58ada78d68c5066c1d6b0024fa76d431a518c6c44c81df43ad898a73e3bd62dc48f62f37276e93801ca9c34bf83a6e7467e48ae083a7273615d0707862f4c597886bd0f9e735ff3ace3d6a94bc19c68d6499dab7f22817643c830cff827dbd935511ab98e404247a431676ce45583215c12cbd1d1e9ba1ea1e50e5c 1 \\x481e564d15ba492b7190ba4f344eb21710502956af619b455692efbdf9d9419828ce154ae492df315ad2e8e5607f2e4f6c4b07ea361cc1ac0aa2598a2cd7ad0e 1660251990000000 0 11000000
-11 \\xfcc930ef95e88c19a345ebcd42a8822e7c5bf1508421b1943f9d34c23ea5fbd28334fb69be1ae2c43bdd86251c101fc8adcce060b736c4dc131054f0b7924361 336 \\x0000000100000001af45c9360d76a608eca18ae8c06ec4d7ecb25130a9fbad2c57d85cac0e8b537f828d528d5fe65e915c7b269e966baf7b409f6b8f247ff986be8f78d77727ac32d1f5f94c9aa666913998c01a562e48036ca68aeeb20e15616e2dbce0544ba68855146416cd913e6d5bb3777cec20da226563170cd9bed17d0c1253c718ebac9a 1 \\x506c4b9173a850f8e6ba14ad28ed50ae96f52c68f0b3434fe57d4d9305816e7cd071c4ac908bbfa1c9c070e0efb1580df7a069643b314d8c5f6eb43c48a1b803 1660251990000000 0 2000000
-12 \\xeb4d76137630598572bff82cb326e4a0d21bd55473a8c237848bd4578a7fd419a5561246cae11a7c9cb289bcb015c5925aae1b5a9d04b93e463c4fbdde484006 336 \\x00000001000000019c1b9b5a5954818a0d940e029c18069ab30122a5b4ac358a81e1d150d368cb48c8e8e91b12a89a5948ae8bc123b950cb364899950418c147bd5cb3831370018a2dda6ef65f2882d9902c468179e55dbf30c375acaed30bf0c36bf7db916196d5570e352fe2709999f9b9af923c3a8c0e56035fbc83c4f622dc2a27a1c674eab6 1 \\xe84ee6c326a459e2bba35640578620bdf4c734fb3a0b88011d6d1da1f8f69844a7f0fe28fbca6955377b7c60c58209906995d23aa4e636c7e5107d2c2a9a7c07 1660251990000000 0 2000000
-13 \\xae25621a89c1264de21e2366fbcea4e7b4a52d220d177fbf6afa4a5668db4c88d333075082f49ad6a7372dd2b1c034d4dcc5697a60103a0182e0d2440de41cae 336 \\x000000010000000145237e2eb488a1bbca0dc2e33a4409b660404f3ced242f1f91d9508f8b409724e1e5de670aa860fe1adb6e649b6f62b85a46f08bdc3509b210c05269ad2ef935f84b382c9ecb376facc30c961ca5efb6b0c0412156ada7416c2810548f8fcc76987e57211655a793ca7853f0d22845940e908aa383192981d0b1d6ba150abf0b 1 \\x434ad916588c31888c7b3a7cc07be3fef5baf160c1bbb495288114a3307ee7f727a85ad0cd49629095d37f76b44d5fe6044bf0e11fba90c465533348741dd80b 1660251990000000 0 2000000
-14 \\xb8b6579a1c6bb49784903822deaa23070f3bedcfe1276b44a0e8b9440d6757af853d41be57e5b5f4ce5107bcf87f53ab7735545360e8d2fed32d90aff1ae4ea1 336 \\x00000001000000010ef85e2f04fef7891f5189a24491a9001c11b7ac1b8b2486e6a8c7c59c16ffbe019b787a3a6f0eb06a55773f982e2f12cff168f8eb75561a831061e21b209b823670ca685769b3057dcf302645b0234872918fc1b4a2c154641df9db3bcb81b1e96d5c26d76d18bd65e664b1f20899357b0cf7e2a6d3d70a9358c30019c80066 1 \\x22fff5f9c935b65c06e65f8deb114c744afc1723bff9a92ada78111aae5288d58e892eaa7d9814825c51252df93b197e5eeafe9d7f779cea6062da406733e405 1660251990000000 0 2000000
-15 \\xd26b1bbb6c7b0711833cb9d3811cc181ca46c41c915a145fa781b70971e8c12bafec49c0f0214aa335573a44016337fef16c00c94c38ad6de4464a90afdb02c2 346 \\x000000010000000108b2a4ea9c6b7dc8ad590cc74821105ca13d13c256aa1b3751836e01c072cac80e906e83db474b8255857077e7bf77384e4d8de6c98b955c20a88d39d2a9f16938ba06eab0b14b7b51a08be433d0875ecf4a551e355b1bc4be98aed676266bfefca87cd02fba63206b3ee70e85977729e29a19692fd857e3fe74392e79a8915c 1 \\xe8eb2d13c4ca8acb9233f361c3860ccdb6dfaf18fcc25b5fcfc4b9c941d1054f88df471259a72ccdcd293e4346e431557ac98b59a4961d64d04652d2019f9305 1660252001000000 1 2000000
-16 \\xffee867c0bc096ed56bffded86858e4eec4e9b59a93f01f04768ed137e3a77113e7f28131eae308c4b9458a3dc9d502c1ec62c4cc7777a92688113742faeeaf0 403 \\x00000001000000017ad242cdc3518a6813baf363e884bea1bcae141200eeda10978d588f27fc14294e2ab04d18dfaf2c2412b2f8291754c16992c568077e5bd2400e70cbecaf3aed9b852ef23f7e9981abacff716e35d41bf34460b480b07b7ae36da09df8836bb4d45ca6fc929ac9b0d38707d4f2bcdb4c34e7e785a0c53a7646f20d853c4f6443 1 \\xe043c96599f684ebc3d7a0292a84eade4e0339b5539d04fb4fb7e9728dbcc225b4c7755f09a12f3a28f6a05a5ee0bd0aa102db024d5fa6b4b4b36d0c65d44e09 1660252001000000 0 11000000
-17 \\x9fd3749566bfcc295044ee015b2e765ad73a8db672e77fca78623861d326a26940e2caf190376cbff5a294d5666bdf4827824b2fa3f89f9f4f75e44dbcbd5b5e 403 \\x00000001000000012037f458885b59ee97e2f1d739121cd06c25f49bbc3de5a91fbd4c8320307b0f068e3f6938f34f75dff2a2549855d7f86f27cb65119061ff2d1f8ee847e665208e9812f5cc0935b5acc62cc98cd6e6c5442302f15562e9047d2a8f280ca08a5a977a5e46f0d8871dd346ef535cb090637079d3698e0d9f3f5af710aba19a7bbc 1 \\xa6ed7d62a336fdbe09eaa930fa5088df954d0efbbfeca4af820fa7f759bdff0a878e304dc8bff515013689a5c3740cce7b291b171be9ab567ff44fbafbaa960c 1660252001000000 0 11000000
-18 \\x2b681d589277493cbf7e393993083df45aba66b0d24f2f7d30e20cb8e03ada0ab302f212233e39c1f687539d64f9fb97d6d96984aa3ff1129ee1d5e16847f352 403 \\x00000001000000015e6963092c0a5c0b1069014303a8837618af77354997127753888737f0087aebe35bd021055c761196086d65ce2347c3a17a220b6ae4f50ade4cd00c85131eb03fdd443c2887e95fd406f5fa153a7fd7731b7e5161d51ddfd3cd3cfe4bea99cf98544136b8f6f9acd6d816136a78827367aafb931fd4ae61f458a2b948d4ce62 1 \\x84e13c60c92c7c85925d445d065545ea8994ffbc85c1230e11bc34f7e270c936aa38dfb5287a340174362dff78118b641b8f3fc780ef8b3b1e123cb90f1b130d 1660252001000000 0 11000000
-19 \\xf55bfed8d97986b91b9402be92d2e071a744ecd29e0ce67d72b3fd84f7ea3f5e3654ba63bbbe415d8e20bd3894b4beb43aece35da9dff4b1940085d44d4517e1 403 \\x000000010000000123f94bd65cb625b470c5a1a9202e7cbe6c94321e5fe229119f640da40da31f103475adce8187a6ce9f3a39d481ce5b042790439803270cfd85f4214418c08d7c0c0968a471cd5ff3765176aabe7d5be31b402ae15d5158ccb9952f93bcd63c774bb7fd197cd95f178c283fe64f22fa5e53a341d441d42bbece66cb672e3b5fec 1 \\xcab0466b2749d167ba5e45fb891c06f9373b836c7dd965fe432066d382a1d8a705a58f7ac794dadb0f97000abdcd417a95f293c8e970c14e8f63c71ca2278a07 1660252001000000 0 11000000
-20 \\x0f762b8f363d58353b86b136f25591548af6e04f65c0d740e9d09c70139b9df628e60c705e3ab385230721f71782af89edd4a5c61be19f5c848f6d78c416e442 403 \\x00000001000000017ae426d45ede03c0046c9399353e4d420aeca739aad0e1b9d105588cd5b8c21ea873bf3d588a2846a065c7c7a30adc704e03fa90cda72e679c609f9153ae458225b6a99608a9f9d789c8596db4f31370a31e418ebb82d329e81fc4ae3c642e8ac0711685b1a8c30cc3423f11c1e7f218c0e0a1bfac50288acd861d4fb3a4b1f0 1 \\xf8999ead98d399134dddbf19810c997053b8877306062db5bdac38050162c4bea78260e943317cbad886546c47b70342d2f00f6cdf0ac71ab23921ec76be2308 1660252001000000 0 11000000
-21 \\x14fc7a95cf87bf59a19b7dd528bfa3878174168c0e7217e51b6e00186c72c4d01a918d947fd3e812099c76d0827521b8e4cecc059635e20f3190b3bb4b42cee8 403 \\x0000000100000001683128cba071c427bad822ff469361605f62e718f7a919106b06ca6e29de6666d602b9b93f4f2158869520ec1f68a5191e45fe6063bb972c3046cbfc323ba229dbbd2da9c0dfdb0bd2bf0523391ffa4c227ef28edc8c40ef3b16a9d05c6675cea08eaf6352f169c870de0ad1eac4cd30588f142dca5a8a924f589a37a29c7cb1 1 \\x31edae662d2145edc6549d35791842d925eec9b2963469d59ccc238fc8aef45d2c45b4b339795c404e4421bc1798285ea85263f2901e58b85404b0930a438f06 1660252001000000 0 11000000
-22 \\x81a8fd47c3bf204e86f36637f6b5bfd83fee39a3b8ebe8b90843622176180addb5af00edf6777deae33250423c54b4e89c366f726ad8fa0d413227d223abbeb9 403 \\x00000001000000010d6296f5a40971a5c0319ee7d32689fb0e44e825229e2c2d05695b03ac2868c28c4a234fa26f16ee0c1826d8d40a786a3b9b816d1d76b9948a09d76bf535cf10ed4dd7c6060c3b53be30cb39c18d9a9028e8e2b9722fd39709b087a91a219ccbac72344752fd7a952cef44fce3c7a0301efbd04e74743cc88e859216d73addb8 1 \\xc174c5eb78ce843407bdaab8a38a5c370805a6cb44b2ef086e8905e36ee4216694351c92e2da6bb8f356a04d167036d47109b2743268db1cfade358c5bc3230f 1660252002000000 0 11000000
-23 \\xa664465b942b43d139f78067cd948fee40d55a1cadd695902a420703f4025e15d0e0a9a1eea777a02f20ac64cb423fdb002bf4e0991d15ccb64486c351533139 403 \\x00000001000000016f6f9d968e91fd5bc331fbb078e0a6acb921712e9152645cfbdef6d7a56c92624a7f7379dfacb287b7596adf4ee97996ac37aeb5a0a81ebd986ee5fac8c649e5e21f77ae0072ea3ba8fa446e0e806964148d7be9ac1cbc00b7b63da0b95fd303d7ffb087974ffd8066ddb1093a78f28aa6f7f241268c0a9bcb55159d1af61d97 1 \\x571baba1e5720af86342de94e9dbc45c9334c2ed41d8e1e95c98cd6a7516c5581461bb1a38e1e30a9c471097d19afdb57b6ec296a81c11903d65b6b73e8b6602 1660252002000000 0 11000000
-24 \\x2725f5402becb99f9b88c5b70ccbb6cda96a68a505c75e0eee283a4773477d22c07c17baad42363f0e908bbd333dbd46a82773f435fb42c1d27c0d65aa632d1a 336 \\x0000000100000001ba0b91a9d00b1249d02cf0371d0d185968d456474d5e3ac79fd8c6991e5d8dfd0fdc1d2bbf3a792bc34630fc56b26371f2d3e9081e416694d9ddc0a7382c8899986aaedd9210c8e3d6559311b66d8449b0f7484ab0526c87d6f303a81a75415cfc6ed09d786eee784af5e896c6d6f6e902b1174501fc946da8d7cf37899fda2e 1 \\x97096864c0eb8ede8e70ef872398db34415f1da78a78659364c73686753d18f4152c97b0df7b00f0442b8e96b8873089de2bd67e17639abf756c6410f230d306 1660252002000000 0 2000000
-25 \\x0c8ee183c59064303aa6e37faf4891ecfc4bb903bbeae0564dab530432fc8eb0e6396c68fba19ee4fc65bec76ecf3d85330c203696ece3636d7abf3ac503ef71 336 \\x0000000100000001a261b7a74ea47207c5bc7d601396def11c401c1a8becb28869770768ab3b46437785fa27537a066e89179f8a1c4e1460eb600acc3bf55e1f94ce06c59673126615ef9f3eae1339e4617ea6076652838348faed3c3fe4e9a23c5a38af0b5d9a683fc3f21a3f207d7c8212c782a6e03792980381e03fe49501c30e22c3ddc0804e 1 \\xf46bfed34bb241b11653ad4166cdfd5fa80e37af9f749b43198d3ee7becb717b6313c22487365f200d037531d183936a6615dfdc1445d80be1811bb2f1ab8d04 1660252002000000 0 2000000
-26 \\x07c866917cca939069d3ddbda32eb54d3d681fb8d43121fcb9072d340373094fb26438336c4305b639d418547afcebff7c7a067c2fe53fb37f0b9d761b317c8b 336 \\x0000000100000001d5eb11e742638d9d04d20b5a8dacec49d7489a3df045d91e82b6801102a0a7894c5802c6f7d926e37e8a99b198b33cfe0e4da087ca39c8c5c1431279b7464526d4c020494d391143d5432208c34bf1b8e26ff9aa5b5d6dd53bd5ee202d9d9ea34a8a99d0a11021f321d2979593167982fe608f2d1fb1b721cc173c6852b5c8cf 1 \\x3a329b5242ff3d2b272e15dc79a5db1cb94d8d34b47e4047e51c2b2721c0ed0030c650292953b8a6a14a921cb7c86ba92039dcd406a0cc9577393b4020a7d608 1660252002000000 0 2000000
-27 \\x7fe07d483d5c7b877bdffea29da031acc88127bc6ffe3a28ea68733e20a0f46d16e9ca840c1a3de34d60934faa733997bb13cf97c0d88769af946c32750c2336 336 \\x0000000100000001d5d7176977c3e441aaf826f071cdc5a9d210eb19b7fdc088d87081509c097e6f7d792ff0cf9ec602f7986f5bb4f2e4ab7bbcff8ec7474896e105d5244ca1658375b73c2868c7083958036f8f7464a3e6d75d3e78f7e6fe9776a78a7ba3f5b4fcc3185f828fc9acea04f7af8db41dcc81cea05fb8a53eae8c873c61d1e3e1a965 1 \\x785eb5045a74f0de6e784ed333d9801e3caf0ef2756a22d7542a754117742a4b2a6c1959f14ac72df219356abfeb8f8ef03d6bde187944d470ca07044f513107 1660252002000000 0 2000000
-28 \\xef009dcf258587b2b0bd60ae5cb02df02051db387bd4e272e86b70b8785d62ec97aa6ccd9b412bd71a1bc8071e09267c216c98ad6c4e988ff6c1aa7cbb03de55 336 \\x00000001000000019deb70378fc0ec23c50555cd2e678525e32650fca1b911340d3ac5f33093b2705d7336deb2df0466491915ef3ddca0ea09c000525307588b86d105cf6dcb85365d57152a39493502925569acec1d027ae5c5ce9c2164f18a54ca1677809a99aa670679fa4876a491ff745ef0f8d3f8cf2d07951b2080b12ed43a1bfc04cde764 1 \\xf8c4f298832bde3b4bbacce7554aa4c162bc59eae4c2369154f4cb6a337d1b6239457e0e9800116a83c1bc203da880f4fddf515266d281be77a43c6f96de1706 1660252002000000 0 2000000
-\.
-
-
---
--- Data for Name: revolving_work_shards; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.revolving_work_shards (shard_serial_id, last_attempt, start_row, end_row, active, job_name) FROM stdin;
-\.
-
-
---
--- Data for Name: signkey_revocations; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.signkey_revocations (signkey_revocations_serial_id, esk_serial, master_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wad_in_entries_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wad_in_entries_default (wad_in_entry_serial_id, wad_in_serial_id, reserve_pub, purse_pub, h_contract, purse_expiration, merge_timestamp, amount_with_fee_val, amount_with_fee_frac, wad_fee_val, wad_fee_frac, deposit_fees_val, deposit_fees_frac, reserve_sig, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wad_out_entries_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wad_out_entries_default (wad_out_entry_serial_id, wad_out_serial_id, reserve_pub, purse_pub, h_contract, purse_expiration, merge_timestamp, amount_with_fee_val, amount_with_fee_frac, wad_fee_val, wad_fee_frac, deposit_fees_val, deposit_fees_frac, reserve_sig, purse_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: wads_in_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wads_in_default (wad_in_serial_id, wad_id, origin_exchange_url, amount_val, amount_frac, arrival_time) FROM stdin;
-\.
-
-
---
--- Data for Name: wads_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wads_out_default (wad_out_serial_id, wad_id, partner_serial_id, amount_val, amount_frac, execution_time) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_accounts; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_accounts (payto_uri, master_sig, is_active, last_change) FROM stdin;
-payto://iban/SANDBOXX/DE064129?receiver-name=Exchange+Company \\x67129d94d4f028b7e536a2a4d330ac2103cdec329059f9d4f7aa47df502c7539692719d34ac10288b2b8dca765c11d786f5aa12cbc10934864da973fddaaf900 t 1660251981000000
-\.
-
-
---
--- Data for Name: wire_fee; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_fee (wire_fee_serial, wire_method, start_date, end_date, wire_fee_val, wire_fee_frac, closing_fee_val, closing_fee_frac, wad_fee_val, wad_fee_frac, master_sig) FROM stdin;
-1 iban 1640995200000000 1672531200000000 0 1000000 0 1000000 0 1000000 \\x9fda3f2a4bc7c77ab186c3929087712c84a46441d47703351ef6ccfa2cb9d9b5876e5bbc854298fce8480a73a90afd70abc2f590b5503ea4f22ac6bba2cf2901
-\.
-
-
---
--- Data for Name: wire_out_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_out_default (wireout_uuid, execution_date, wtid_raw, wire_target_h_payto, exchange_account_section, amount_val, amount_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: wire_targets_default; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.wire_targets_default (wire_target_serial_id, wire_target_h_payto, payto_uri, kyc_ok, external_id) FROM stdin;
-1 \\x75b009a95c776f463a8a9f5686a05a39a61e4d65458d1dca21f5789940107491 payto://iban/SANDBOXX/DE496362?receiver-name=Name+unknown f \N
-2 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43 f \N
-\.
-
-
---
--- Data for Name: work_shards; Type: TABLE DATA; Schema: exchange; Owner: -
---
-
-COPY exchange.work_shards (shard_serial_id, last_attempt, start_row, end_row, completed, job_name) FROM stdin;
-1 0 0 1024 f wirewatch-exchange-account-1
-\.
-
-
---
--- Data for Name: merchant_accounts; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_accounts (account_serial, merchant_serial, h_wire, salt, payto_uri, active) FROM stdin;
-1 1 \\x0678b2516a6a03a07d769bdcecf7a468774ffd8d9fdc71dd9db51083b16ec263f2c97333baaed167625c522e0b6498f54c4f522a1e78d307b5b99550fdb12e8b \\x79baa0b9272b661741bf49d52101f098 payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43 t
-\.
-
-
---
--- Data for Name: merchant_contract_terms; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_contract_terms (order_serial, merchant_serial, order_id, contract_terms, h_contract_terms, creation_time, pay_deadline, refund_deadline, paid, wired, fulfillment_url, session_id, claim_token) FROM stdin;
-1 1 2022.223-01W2RJ0978BA8 \\x7b22616d6f756e74223a22544553544b55444f533a31222c2273756d6d617279223a22666f6f222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f7468616e6b2b796f75222c22726566756e645f646561646c696e65223a7b22745f73223a313636303235323930337d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303235323930337d2c2270726f6475637473223a5b5d2c22685f77697265223a2230535742344d424144383154305a42504b464545535858344431564d5a5a43444b5a453733514358504d3838374342455239485a354a424b36455841584d42374339453534424742434a4346414b324641384e315759364b305954564b3541475a50524a583252222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232332d30315732524a30393738424138222c2274696d657374616d70223a7b22745f73223a313636303235323030337d2c227061795f646561646c696e65223a7b22745f73223a313636303235353630337d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22514b455139384b524a3752474b425a32465357305330593037473141564a4d424448505a32333039384a43353733314d4e595930227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22573554393059414e315136365a3443394651374347325a30473053534345484d3144304a435643425a5635525333394553424d47222c226e6f6e6365223a22463638324748325031534e32344b564d334a4742383033483437315251514d30535047505a424137515744303351435242534447227d \\x8441fd1913c230ce67352d8eb45d6c172a1b5e5855d8b46b4697557670d81e8dad19fe10cb06f98c00112665d5cf514100ff77d7319c87709f638c1a91092ce8 1660252003000000 1660255603000000 1660252903000000 t f taler://fulfillment-success/thank+you \\xdf55438a8d6cfdb1232c5e672e760d69
-2 1 2022.223-00RBNWXH37EZJ \\x7b22616d6f756e74223a22544553544b55444f533a302e3032222c2273756d6d617279223a22626172222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f7468616e6b2b796f75222c22726566756e645f646561646c696e65223a7b22745f73223a313636303235323933357d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303235323933357d2c2270726f6475637473223a5b5d2c22685f77697265223a2230535742344d424144383154305a42504b464545535858344431564d5a5a43444b5a453733514358504d3838374342455239485a354a424b36455841584d42374339453534424742434a4346414b324641384e315759364b305954564b3541475a50524a583252222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232332d303052424e5758483337455a4a222c2274696d657374616d70223a7b22745f73223a313636303235323033357d2c227061795f646561646c696e65223a7b22745f73223a313636303235353633357d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22514b455139384b524a3752474b425a32465357305330593037473141564a4d424448505a32333039384a43353733314d4e595930227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22573554393059414e315136365a3443394651374347325a30473053534345484d3144304a435643425a5635525333394553424d47222c226e6f6e6365223a2231593841544e5354434630525158334d5a4532395634525339354b5047414d363246385a5951414d593153354b5153354d485047227d \\xd7b5b06be021d66ce41c6560f4717a47aa0b555d40e5791a644bb0586713b09286338aa317eb152d53e5f01914f565c98294bd0e1c75a9844760606674fd4a07 1660252035000000 1660255635000000 1660252935000000 t f taler://fulfillment-success/thank+you \\xb3cb7984e8e89f6d1c16e14460066ca7
-\.
-
-
---
--- Data for Name: merchant_deposit_to_transfer; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_deposit_to_transfer (deposit_serial, coin_contribution_value_val, coin_contribution_value_frac, credit_serial, execution_time, signkey_serial, exchange_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_deposits; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_deposits (deposit_serial, order_serial, deposit_timestamp, coin_pub, exchange_url, amount_with_fee_val, amount_with_fee_frac, deposit_fee_val, deposit_fee_frac, refund_fee_val, refund_fee_frac, wire_fee_val, wire_fee_frac, signkey_serial, exchange_sig, account_serial) FROM stdin;
-1 1 1660252005000000 \\x35290936b3298c531f7663cc352f52328dff8bc55a888c778a6a5f666ec72229 http://localhost:8081/ 1 0 0 2000000 0 1000000 0 1000000 2 \\xd50dc64ca5b7862a12c155e61b64594afc040a31a2be906a362afdbd8aab7b3a5170546d859add936f63fe8355da242984643faf82de20103ab5eff7c78bc606 1
-2 2 1660856839000000 \\x017ffcb450284349856b997a0936f632297b24f9014d29a8e125cafa62343a6a http://localhost:8081/ 0 1000000 0 1000000 0 1000000 0 1000000 2 \\x459f3fcf67a1817ab920c21a7bfc684b70fde3764453b7c168d152dad547ab26948de2b36fee43a133f623b638c4aa1adf16ce57d00b5cbb88c9a7cc3c739500 1
-3 2 1660856839000000 \\x093fb1065ac13f3b0c67e86c7c62fd7a7b70fd2cfa8aff5124f90179d4107648 http://localhost:8081/ 0 1000000 0 1000000 0 1000000 0 1000000 2 \\x2224d9bb7f6af8966c5f4eaf1041a3b8034a5ea9ade16dcae7a330da5d455afd94f9b2436372bc2c2031c1f5a7d8253caabb111ee71d44f2909cae0c0e71ed0d 1
-\.
-
-
---
--- Data for Name: merchant_exchange_signing_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_exchange_signing_keys (signkey_serial, master_pub, exchange_pub, start_date, expire_date, end_date, master_sig) FROM stdin;
-1 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\x61e9b7de014621a1cdd10e78b3c370bc72a9364b5d33ead64773fd2dfdbb8301 1689281174000000 1696538774000000 1698957974000000 \\x4a92c272d749f83bca847f714d0e590c4458b9be6e01e05e0793a5aac9d73d64d1ba72e1d76c3b2a50125c529cf6b95f867ccd6046ca2619137e7ab3cb02dc08
-2 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\x672f96a79906416c79911983f7f421ea7601768c5682b00c0182e6127c394ce5 1660251974000000 1667509574000000 1669928774000000 \\xaef46bdc9c4d567dbd397ec55797c87379aeee60d6756af2c0d32ace59e32f0afcf671521ad58c69e92b2e06c6049f01793c7b539323c438483be063abed8f00
-3 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\x89e5f703eb5057280ec41ac2510840d1d81edeafd57352ce77a78cc6c736d020 1682023874000000 1689281474000000 1691700674000000 \\x88694d8e88dffe78617bdeeca7b61035d2da33266261ed08adc84e6316900e57f0291c0c323c9b6b11daafc85b18b2fb6365d657cc922b14cb558deac5a76d0e
-4 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\xeb5875214f594284c855420dc1f8afd8126b03e06d183ffcd41432f8d9781acf 1667509274000000 1674766874000000 1677186074000000 \\x53ed5d6466a2783f2d1e481995b1bf88eccdfda4bdb72b61afc01c29e7f5ec9994cc11da508b1cbaa8a874b7988519f9fc88f9d089860e4531a0c958d9c19603
-5 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\x5d4aa2e9a1eaec531b2b2d4a927d284f869c4d4bba27935af9a341ca01ecdc76 1674766574000000 1682024174000000 1684443374000000 \\xd66763e65a8b370e300bfdf32df7ca3d026046ad643d28b95aa73d40d90a85e61ae81b2ba34124413f28720f8e64c65208c88a18e6b0ec3eb10ec0b4eee69f00
-\.
-
-
---
--- Data for Name: merchant_exchange_wire_fees; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_exchange_wire_fees (wirefee_serial, master_pub, h_wire_method, start_date, end_date, wire_fee_val, wire_fee_frac, closing_fee_val, closing_fee_frac, wad_fee_val, wad_fee_frac, master_sig) FROM stdin;
-1 \\xbcdd74a27891f109afe27e780c83c03c02adca8b6c6df10c094498538c34afbc \\x21e4a5e9d5d17432fa0b1f7a02f8047c7634c1053d6aa1f6456ac134caa8bbf3da7776a78f85636af980472afd166b4edad654979a89d92c49a4ba992a7e3571 1640995200000000 1672531200000000 0 1000000 0 1000000 0 1000000 \\x9fda3f2a4bc7c77ab186c3929087712c84a46441d47703351ef6ccfa2cb9d9b5876e5bbc854298fce8480a73a90afd70abc2f590b5503ea4f22ac6bba2cf2901
-\.
-
-
---
--- Data for Name: merchant_instances; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_instances (merchant_serial, merchant_pub, auth_hash, auth_salt, merchant_id, merchant_name, address, jurisdiction, default_max_deposit_fee_val, default_max_deposit_fee_frac, default_max_wire_fee_val, default_max_wire_fee_frac, default_wire_fee_amortization, default_wire_transfer_delay, default_pay_delay, website, email, logo) FROM stdin;
-1 \\xe1749079550dcc6f91897dcec80be08033963a340b41266d8bfecb8c8d2ecae9 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x0000000000000000000000000000000000000000000000000000000000000000 default default \\x7b7d \\x7b7d 1 0 1 0 1 3600000000 3600000000 \N \N \N
-\.
-
-
---
--- Data for Name: merchant_inventory; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_inventory (product_serial, merchant_serial, product_id, description, description_i18n, unit, image, taxes, price_val, price_frac, total_stock, total_sold, total_lost, address, next_restock, minimum_age) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_inventory_locks; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_inventory_locks (product_serial, lock_uuid, total_locked, expiration) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_keys (merchant_priv, merchant_serial) FROM stdin;
-\\x6f95cf837c04368bd166ba8b2763becaa7bd36cb0550ee8101ed411a56feafb2 1
-\.
-
-
---
--- Data for Name: merchant_kyc; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_kyc (kyc_serial_id, kyc_timestamp, kyc_ok, exchange_sig, exchange_pub, exchange_kyc_serial, account_serial, exchange_url) FROM stdin;
-1 1660252005000000 f \N \N 0 1 http://localhost:8081/
-\.
-
-
---
--- Data for Name: merchant_order_locks; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_order_locks (product_serial, total_locked, order_serial) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_orders; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_orders (order_serial, merchant_serial, order_id, claim_token, h_post_data, pay_deadline, creation_time, contract_terms) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_refund_proofs; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_refund_proofs (refund_serial, exchange_sig, signkey_serial) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_refunds; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_refunds (refund_serial, order_serial, rtransaction_id, refund_timestamp, coin_pub, reason, refund_amount_val, refund_amount_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_pickup_signatures; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_pickup_signatures (pickup_serial, coin_offset, blind_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_pickups; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_pickups (pickup_serial, tip_serial, pickup_id, amount_val, amount_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_reserve_keys; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_reserve_keys (reserve_serial, reserve_priv, exchange_url, payto_uri) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tip_reserves; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tip_reserves (reserve_serial, reserve_pub, merchant_serial, creation_time, expiration, merchant_initial_balance_val, merchant_initial_balance_frac, exchange_initial_balance_val, exchange_initial_balance_frac, tips_committed_val, tips_committed_frac, tips_picked_up_val, tips_picked_up_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_tips; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_tips (tip_serial, reserve_serial, tip_id, justification, next_url, expiration, amount_val, amount_frac, picked_up_val, picked_up_frac, was_picked_up) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfer_signatures; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfer_signatures (credit_serial, signkey_serial, wire_fee_val, wire_fee_frac, credit_amount_val, credit_amount_frac, execution_time, exchange_sig) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfer_to_coin; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfer_to_coin (deposit_serial, credit_serial, offset_in_exchange_list, exchange_deposit_value_val, exchange_deposit_value_frac, exchange_deposit_fee_val, exchange_deposit_fee_frac) FROM stdin;
-\.
-
-
---
--- Data for Name: merchant_transfers; Type: TABLE DATA; Schema: merchant; Owner: -
---
-
-COPY merchant.merchant_transfers (credit_serial, exchange_url, wtid, credit_amount_val, credit_amount_frac, account_serial, verified, confirmed) FROM stdin;
-\.
-
-
---
--- Name: auditor_reserves_auditor_reserves_rowid_seq; Type: SEQUENCE SET; Schema: auditor; Owner: -
---
-
-SELECT pg_catalog.setval('auditor.auditor_reserves_auditor_reserves_rowid_seq', 1, false);
-
-
---
--- Name: deposit_confirmations_serial_id_seq; Type: SEQUENCE SET; Schema: auditor; Owner: -
---
-
-SELECT pg_catalog.setval('auditor.deposit_confirmations_serial_id_seq', 2, true);
-
-
---
--- Name: account_merges_account_merge_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.account_merges_account_merge_request_serial_id_seq', 1, false);
-
-
---
--- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.aggregation_tracking_aggregation_serial_id_seq', 1, false);
-
-
---
--- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.auditor_denom_sigs_auditor_denom_serial_seq', 1269, true);
-
-
---
--- Name: auditors_auditor_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.auditors_auditor_uuid_seq', 1, true);
-
-
---
--- Name: close_requests_close_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.close_requests_close_request_serial_id_seq', 1, false);
-
-
---
--- Name: contracts_contract_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.contracts_contract_serial_id_seq', 1, false);
-
-
---
--- Name: cs_nonce_locks_cs_nonce_lock_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.cs_nonce_locks_cs_nonce_lock_serial_id_seq', 1, false);
-
-
---
--- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.denomination_revocations_denom_revocations_serial_id_seq', 2, true);
-
-
---
--- Name: denominations_denominations_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.denominations_denominations_serial_seq', 424, true);
-
-
---
--- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.deposits_deposit_serial_id_seq', 3, true);
-
-
---
--- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.exchange_sign_keys_esk_serial_seq', 5, true);
-
-
---
--- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.extension_details_extension_details_serial_id_seq', 1, false);
-
-
---
--- Name: extensions_extension_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.extensions_extension_id_seq', 1, false);
-
-
---
--- Name: global_fee_global_fee_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.global_fee_global_fee_serial_seq', 1, true);
-
-
---
--- Name: history_requests_history_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.history_requests_history_request_serial_id_seq', 1, false);
-
-
---
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.known_coins_known_coin_id_seq', 14, true);
-
-
---
--- Name: legitimizations_legitimization_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.legitimizations_legitimization_serial_id_seq', 1, false);
-
-
---
--- Name: partners_partner_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.partners_partner_serial_id_seq', 1, false);
-
-
---
--- Name: prewire_prewire_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.prewire_prewire_uuid_seq', 1, false);
-
-
---
--- Name: profit_drains_profit_drain_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.profit_drains_profit_drain_serial_id_seq', 1, false);
-
-
---
--- Name: purse_deposits_purse_deposit_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_deposits_purse_deposit_serial_id_seq', 1, false);
-
-
---
--- Name: purse_merges_purse_merge_request_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_merges_purse_merge_request_serial_id_seq', 1, false);
-
-
---
--- Name: purse_refunds_purse_refunds_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_refunds_purse_refunds_serial_id_seq', 1, false);
-
-
---
--- Name: purse_requests_purse_requests_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.purse_requests_purse_requests_serial_id_seq', 1, false);
-
-
---
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.recoup_recoup_uuid_seq', 1, true);
-
-
---
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.recoup_refresh_recoup_refresh_uuid_seq', 8, true);
-
-
---
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_commitments_melt_serial_id_seq', 2, true);
-
-
---
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_revealed_coins_rrc_serial_seq', 50, true);
-
-
---
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refresh_transfer_keys_rtc_serial_seq', 2, true);
-
-
---
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.refunds_refund_serial_id_seq', 1, false);
-
-
---
--- Name: reserves_close_close_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_close_close_uuid_seq', 1, false);
-
-
---
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_in_reserve_in_serial_id_seq', 25, true);
-
-
---
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_out_reserve_out_serial_id_seq', 28, true);
-
-
---
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.reserves_reserve_uuid_seq', 25, true);
-
-
---
--- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.revolving_work_shards_shard_serial_id_seq', 1, false);
-
-
---
--- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.signkey_revocations_signkey_revocations_serial_id_seq', 1, false);
-
-
---
--- Name: wad_in_entries_wad_in_entry_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wad_in_entries_wad_in_entry_serial_id_seq', 1, false);
-
-
---
--- Name: wad_out_entries_wad_out_entry_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wad_out_entries_wad_out_entry_serial_id_seq', 1, false);
-
-
---
--- Name: wads_in_wad_in_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wads_in_wad_in_serial_id_seq', 1, false);
-
-
---
--- Name: wads_out_wad_out_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wads_out_wad_out_serial_id_seq', 1, false);
-
-
---
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_fee_wire_fee_serial_seq', 1, true);
-
-
---
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_out_wireout_uuid_seq', 1, false);
-
-
---
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.wire_targets_wire_target_serial_id_seq', 4, true);
-
-
---
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE SET; Schema: exchange; Owner: -
---
-
-SELECT pg_catalog.setval('exchange.work_shards_shard_serial_id_seq', 1, true);
-
-
---
--- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_accounts_account_serial_seq', 1, true);
-
-
---
--- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_deposits_deposit_serial_seq', 3, true);
-
-
---
--- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_exchange_signing_keys_signkey_serial_seq', 10, true);
-
-
---
--- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_exchange_wire_fees_wirefee_serial_seq', 2, true);
-
-
---
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_instances_merchant_serial_seq', 1, true);
-
-
---
--- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_inventory_product_serial_seq', 1, false);
-
-
---
--- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_kyc_kyc_serial_id_seq', 1, true);
-
-
---
--- Name: merchant_orders_order_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_orders_order_serial_seq', 2, true);
-
-
---
--- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_refunds_refund_serial_seq', 1, false);
-
-
---
--- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tip_pickups_pickup_serial_seq', 1, false);
-
-
---
--- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tip_reserves_reserve_serial_seq', 1, false);
-
-
---
--- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_tips_tip_serial_seq', 1, false);
-
-
---
--- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE SET; Schema: merchant; Owner: -
---
-
-SELECT pg_catalog.setval('merchant.merchant_transfers_credit_serial_seq', 1, false);
-
-
---
--- Name: patches patches_pkey; Type: CONSTRAINT; Schema: _v; Owner: -
---
-
-ALTER TABLE ONLY _v.patches
- ADD CONSTRAINT patches_pkey PRIMARY KEY (patch_name);
-
-
---
--- Name: auditor_denomination_pending auditor_denomination_pending_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_denomination_pending
- ADD CONSTRAINT auditor_denomination_pending_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: auditor_exchanges auditor_exchanges_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_exchanges
- ADD CONSTRAINT auditor_exchanges_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_historic_denomination_revenue auditor_historic_denomination_revenue_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_denomination_revenue
- ADD CONSTRAINT auditor_historic_denomination_revenue_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: auditor_progress_aggregation auditor_progress_aggregation_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_aggregation
- ADD CONSTRAINT auditor_progress_aggregation_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_coin auditor_progress_coin_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_coin
- ADD CONSTRAINT auditor_progress_coin_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_deposit_confirmation auditor_progress_deposit_confirmation_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_deposit_confirmation
- ADD CONSTRAINT auditor_progress_deposit_confirmation_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_progress_reserve auditor_progress_reserve_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_reserve
- ADD CONSTRAINT auditor_progress_reserve_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: auditor_reserves auditor_reserves_auditor_reserves_rowid_key; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves
- ADD CONSTRAINT auditor_reserves_auditor_reserves_rowid_key UNIQUE (auditor_reserves_rowid);
-
-
---
--- Name: deposit_confirmations deposit_confirmations_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT deposit_confirmations_pkey PRIMARY KEY (h_contract_terms, h_wire, coin_pub, merchant_pub, exchange_sig, exchange_pub, master_sig);
-
-
---
--- Name: deposit_confirmations deposit_confirmations_serial_id_key; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT deposit_confirmations_serial_id_key UNIQUE (serial_id);
-
-
---
--- Name: wire_auditor_account_progress wire_auditor_account_progress_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_account_progress
- ADD CONSTRAINT wire_auditor_account_progress_pkey PRIMARY KEY (master_pub, account_name);
-
-
---
--- Name: wire_auditor_progress wire_auditor_progress_pkey; Type: CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_progress
- ADD CONSTRAINT wire_auditor_progress_pkey PRIMARY KEY (master_pub);
-
-
---
--- Name: account_merges_default account_merges_default_account_merge_request_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges_default
- ADD CONSTRAINT account_merges_default_account_merge_request_serial_id_key UNIQUE (account_merge_request_serial_id);
-
-
---
--- Name: account_merges account_merges_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges
- ADD CONSTRAINT account_merges_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: account_merges_default account_merges_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.account_merges_default
- ADD CONSTRAINT account_merges_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: aggregation_tracking_default aggregation_tracking_default_aggregation_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking_default
- ADD CONSTRAINT aggregation_tracking_default_aggregation_serial_id_key UNIQUE (aggregation_serial_id);
-
-
---
--- Name: aggregation_tracking aggregation_tracking_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking
- ADD CONSTRAINT aggregation_tracking_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: aggregation_tracking_default aggregation_tracking_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.aggregation_tracking_default
- ADD CONSTRAINT aggregation_tracking_default_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_auditor_denom_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_auditor_denom_serial_key UNIQUE (auditor_denom_serial);
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_pkey PRIMARY KEY (denominations_serial, auditor_uuid);
-
-
---
--- Name: auditors auditors_auditor_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditors
- ADD CONSTRAINT auditors_auditor_uuid_key UNIQUE (auditor_uuid);
-
-
---
--- Name: auditors auditors_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditors
- ADD CONSTRAINT auditors_pkey PRIMARY KEY (auditor_pub);
-
-
---
--- Name: close_requests close_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.close_requests
- ADD CONSTRAINT close_requests_pkey PRIMARY KEY (reserve_pub, close_timestamp);
-
-
---
--- Name: close_requests_default close_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.close_requests_default
- ADD CONSTRAINT close_requests_default_pkey PRIMARY KEY (reserve_pub, close_timestamp);
-
-
---
--- Name: contracts_default contracts_default_contract_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts_default
- ADD CONSTRAINT contracts_default_contract_serial_id_key UNIQUE (contract_serial_id);
-
-
---
--- Name: contracts contracts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts
- ADD CONSTRAINT contracts_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: contracts_default contracts_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.contracts_default
- ADD CONSTRAINT contracts_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: cs_nonce_locks_default cs_nonce_locks_default_cs_nonce_lock_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks_default
- ADD CONSTRAINT cs_nonce_locks_default_cs_nonce_lock_serial_id_key UNIQUE (cs_nonce_lock_serial_id);
-
-
---
--- Name: cs_nonce_locks cs_nonce_locks_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks
- ADD CONSTRAINT cs_nonce_locks_pkey PRIMARY KEY (nonce);
-
-
---
--- Name: cs_nonce_locks_default cs_nonce_locks_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.cs_nonce_locks_default
- ADD CONSTRAINT cs_nonce_locks_default_pkey PRIMARY KEY (nonce);
-
-
---
--- Name: denomination_revocations denomination_revocations_denom_revocations_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_denom_revocations_serial_id_key UNIQUE (denom_revocations_serial_id);
-
-
---
--- Name: denomination_revocations denomination_revocations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_pkey PRIMARY KEY (denominations_serial);
-
-
---
--- Name: denominations denominations_denominations_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denominations
- ADD CONSTRAINT denominations_denominations_serial_key UNIQUE (denominations_serial);
-
-
---
--- Name: denominations denominations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denominations
- ADD CONSTRAINT denominations_pkey PRIMARY KEY (denom_pub_hash);
-
-
---
--- Name: deposits_default deposits_default_coin_pub_merchant_pub_h_contract_terms_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.deposits_default
- ADD CONSTRAINT deposits_default_coin_pub_merchant_pub_h_contract_terms_key UNIQUE (coin_pub, merchant_pub, h_contract_terms);
-
-
---
--- Name: deposits_default deposits_default_deposit_serial_id_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.deposits_default
- ADD CONSTRAINT deposits_default_deposit_serial_id_pkey PRIMARY KEY (deposit_serial_id);
-
-
---
--- Name: exchange_sign_keys exchange_sign_keys_esk_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.exchange_sign_keys
- ADD CONSTRAINT exchange_sign_keys_esk_serial_key UNIQUE (esk_serial);
-
-
---
--- Name: exchange_sign_keys exchange_sign_keys_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.exchange_sign_keys
- ADD CONSTRAINT exchange_sign_keys_pkey PRIMARY KEY (exchange_pub);
-
-
---
--- Name: extension_details extension_details_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extension_details
- ADD CONSTRAINT extension_details_pkey PRIMARY KEY (extension_details_serial_id);
-
-
---
--- Name: extension_details_default extension_details_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extension_details_default
- ADD CONSTRAINT extension_details_default_pkey PRIMARY KEY (extension_details_serial_id);
-
-
---
--- Name: extensions extensions_extension_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extensions
- ADD CONSTRAINT extensions_extension_id_key UNIQUE (extension_id);
-
-
---
--- Name: extensions extensions_name_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.extensions
- ADD CONSTRAINT extensions_name_key UNIQUE (name);
-
-
---
--- Name: global_fee global_fee_global_fee_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.global_fee
- ADD CONSTRAINT global_fee_global_fee_serial_key UNIQUE (global_fee_serial);
-
-
---
--- Name: global_fee global_fee_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.global_fee
- ADD CONSTRAINT global_fee_pkey PRIMARY KEY (start_date);
-
-
---
--- Name: history_requests history_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.history_requests
- ADD CONSTRAINT history_requests_pkey PRIMARY KEY (reserve_pub, request_timestamp);
-
-
---
--- Name: history_requests_default history_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.history_requests_default
- ADD CONSTRAINT history_requests_default_pkey PRIMARY KEY (reserve_pub, request_timestamp);
-
-
---
--- Name: known_coins_default known_coins_default_known_coin_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins_default
- ADD CONSTRAINT known_coins_default_known_coin_id_key UNIQUE (known_coin_id);
-
-
---
--- Name: known_coins known_coins_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins
- ADD CONSTRAINT known_coins_pkey PRIMARY KEY (coin_pub);
-
-
---
--- Name: known_coins_default known_coins_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.known_coins_default
- ADD CONSTRAINT known_coins_default_pkey PRIMARY KEY (coin_pub);
-
-
---
--- Name: kyc_alerts kyc_alerts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.kyc_alerts
- ADD CONSTRAINT kyc_alerts_pkey PRIMARY KEY (h_payto);
-
-
---
--- Name: kyc_alerts kyc_alerts_trigger_type_h_payto_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.kyc_alerts
- ADD CONSTRAINT kyc_alerts_trigger_type_h_payto_key UNIQUE (trigger_type, h_payto);
-
-
---
--- Name: legitimizations legitimizations_h_payto_provider_section_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations
- ADD CONSTRAINT legitimizations_h_payto_provider_section_key UNIQUE (h_payto, provider_section);
-
-
---
--- Name: legitimizations_default legitimizations_default_h_payto_provider_section_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations_default
- ADD CONSTRAINT legitimizations_default_h_payto_provider_section_key UNIQUE (h_payto, provider_section);
-
-
---
--- Name: legitimizations_default legitimizations_default_legitimization_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.legitimizations_default
- ADD CONSTRAINT legitimizations_default_legitimization_serial_id_key UNIQUE (legitimization_serial_id);
-
-
---
--- Name: partner_accounts partner_accounts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partner_accounts
- ADD CONSTRAINT partner_accounts_pkey PRIMARY KEY (payto_uri);
-
-
---
--- Name: partners partners_partner_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partners
- ADD CONSTRAINT partners_partner_serial_id_key UNIQUE (partner_serial_id);
-
-
---
--- Name: prewire prewire_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.prewire
- ADD CONSTRAINT prewire_pkey PRIMARY KEY (prewire_uuid);
-
-
---
--- Name: prewire_default prewire_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.prewire_default
- ADD CONSTRAINT prewire_default_pkey PRIMARY KEY (prewire_uuid);
-
-
---
--- Name: profit_drains profit_drains_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.profit_drains
- ADD CONSTRAINT profit_drains_pkey PRIMARY KEY (wtid);
-
-
---
--- Name: profit_drains profit_drains_profit_drain_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.profit_drains
- ADD CONSTRAINT profit_drains_profit_drain_serial_id_key UNIQUE (profit_drain_serial_id);
-
-
---
--- Name: purse_actions purse_actions_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_actions
- ADD CONSTRAINT purse_actions_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_deposits purse_deposits_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits
- ADD CONSTRAINT purse_deposits_pkey PRIMARY KEY (purse_pub, coin_pub);
-
-
---
--- Name: purse_deposits_default purse_deposits_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits_default
- ADD CONSTRAINT purse_deposits_default_pkey PRIMARY KEY (purse_pub, coin_pub);
-
-
---
--- Name: purse_deposits_default purse_deposits_default_purse_deposit_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_deposits_default
- ADD CONSTRAINT purse_deposits_default_purse_deposit_serial_id_key UNIQUE (purse_deposit_serial_id);
-
-
---
--- Name: purse_merges purse_merges_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges
- ADD CONSTRAINT purse_merges_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_merges_default purse_merges_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges_default
- ADD CONSTRAINT purse_merges_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_merges_default purse_merges_default_purse_merge_request_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_merges_default
- ADD CONSTRAINT purse_merges_default_purse_merge_request_serial_id_key UNIQUE (purse_merge_request_serial_id);
-
-
---
--- Name: purse_refunds purse_refunds_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds
- ADD CONSTRAINT purse_refunds_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_refunds_default purse_refunds_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds_default
- ADD CONSTRAINT purse_refunds_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_refunds_default purse_refunds_default_purse_refunds_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_refunds_default
- ADD CONSTRAINT purse_refunds_default_purse_refunds_serial_id_key UNIQUE (purse_refunds_serial_id);
-
-
---
--- Name: purse_requests purse_requests_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests
- ADD CONSTRAINT purse_requests_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_requests_default purse_requests_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests_default
- ADD CONSTRAINT purse_requests_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: purse_requests_default purse_requests_default_purse_requests_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.purse_requests_default
- ADD CONSTRAINT purse_requests_default_purse_requests_serial_id_key UNIQUE (purse_requests_serial_id);
-
-
---
--- Name: recoup_default recoup_default_recoup_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.recoup_default
- ADD CONSTRAINT recoup_default_recoup_uuid_key UNIQUE (recoup_uuid);
-
-
---
--- Name: recoup_refresh_default recoup_refresh_default_recoup_refresh_uuid_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.recoup_refresh_default
- ADD CONSTRAINT recoup_refresh_default_recoup_refresh_uuid_key UNIQUE (recoup_refresh_uuid);
-
-
---
--- Name: refresh_commitments_default refresh_commitments_default_melt_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments_default
- ADD CONSTRAINT refresh_commitments_default_melt_serial_id_key UNIQUE (melt_serial_id);
-
-
---
--- Name: refresh_commitments refresh_commitments_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments
- ADD CONSTRAINT refresh_commitments_pkey PRIMARY KEY (rc);
-
-
---
--- Name: refresh_commitments_default refresh_commitments_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_commitments_default
- ADD CONSTRAINT refresh_commitments_default_pkey PRIMARY KEY (rc);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_coin_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_coin_ev_key UNIQUE (coin_ev);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_h_coin_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_h_coin_ev_key UNIQUE (h_coin_ev);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_pkey PRIMARY KEY (melt_serial_id, freshcoin_index);
-
-
---
--- Name: refresh_revealed_coins_default refresh_revealed_coins_default_rrc_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_revealed_coins_default
- ADD CONSTRAINT refresh_revealed_coins_default_rrc_serial_key UNIQUE (rrc_serial);
-
-
---
--- Name: refresh_transfer_keys refresh_transfer_keys_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys
- ADD CONSTRAINT refresh_transfer_keys_pkey PRIMARY KEY (melt_serial_id);
-
-
---
--- Name: refresh_transfer_keys_default refresh_transfer_keys_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys_default
- ADD CONSTRAINT refresh_transfer_keys_default_pkey PRIMARY KEY (melt_serial_id);
-
-
---
--- Name: refresh_transfer_keys_default refresh_transfer_keys_default_rtc_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refresh_transfer_keys_default
- ADD CONSTRAINT refresh_transfer_keys_default_rtc_serial_key UNIQUE (rtc_serial);
-
-
---
--- Name: refunds_default refunds_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refunds_default
- ADD CONSTRAINT refunds_default_pkey PRIMARY KEY (deposit_serial_id, rtransaction_id);
-
-
---
--- Name: refunds_default refunds_default_refund_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.refunds_default
- ADD CONSTRAINT refunds_default_refund_serial_id_key UNIQUE (refund_serial_id);
-
-
---
--- Name: reserves_close_default reserves_close_default_close_uuid_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_close_default
- ADD CONSTRAINT reserves_close_default_close_uuid_pkey PRIMARY KEY (close_uuid);
-
-
---
--- Name: reserves reserves_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves
- ADD CONSTRAINT reserves_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_default reserves_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_default
- ADD CONSTRAINT reserves_default_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in reserves_in_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in
- ADD CONSTRAINT reserves_in_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in_default reserves_in_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in_default
- ADD CONSTRAINT reserves_in_default_pkey PRIMARY KEY (reserve_pub);
-
-
---
--- Name: reserves_in_default reserves_in_default_reserve_in_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_in_default
- ADD CONSTRAINT reserves_in_default_reserve_in_serial_id_key UNIQUE (reserve_in_serial_id);
-
-
---
--- Name: reserves_out reserves_out_h_blind_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out
- ADD CONSTRAINT reserves_out_h_blind_ev_key UNIQUE (h_blind_ev);
-
-
---
--- Name: reserves_out_default reserves_out_default_h_blind_ev_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out_default
- ADD CONSTRAINT reserves_out_default_h_blind_ev_key UNIQUE (h_blind_ev);
-
-
---
--- Name: reserves_out_default reserves_out_default_reserve_out_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.reserves_out_default
- ADD CONSTRAINT reserves_out_default_reserve_out_serial_id_key UNIQUE (reserve_out_serial_id);
-
-
---
--- Name: revolving_work_shards revolving_work_shards_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.revolving_work_shards
- ADD CONSTRAINT revolving_work_shards_pkey PRIMARY KEY (job_name, start_row);
-
-
---
--- Name: revolving_work_shards revolving_work_shards_shard_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.revolving_work_shards
- ADD CONSTRAINT revolving_work_shards_shard_serial_id_key UNIQUE (shard_serial_id);
-
-
---
--- Name: signkey_revocations signkey_revocations_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_pkey PRIMARY KEY (esk_serial);
-
-
---
--- Name: signkey_revocations signkey_revocations_signkey_revocations_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_signkey_revocations_serial_id_key UNIQUE (signkey_revocations_serial_id);
-
-
---
--- Name: wad_in_entries wad_in_entries_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries
- ADD CONSTRAINT wad_in_entries_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_in_entries_default wad_in_entries_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries_default
- ADD CONSTRAINT wad_in_entries_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_in_entries_default wad_in_entries_default_wad_in_entry_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_in_entries_default
- ADD CONSTRAINT wad_in_entries_default_wad_in_entry_serial_id_key UNIQUE (wad_in_entry_serial_id);
-
-
---
--- Name: wad_out_entries wad_out_entries_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries
- ADD CONSTRAINT wad_out_entries_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_out_entries_default wad_out_entries_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries_default
- ADD CONSTRAINT wad_out_entries_default_pkey PRIMARY KEY (purse_pub);
-
-
---
--- Name: wad_out_entries_default wad_out_entries_default_wad_out_entry_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wad_out_entries_default
- ADD CONSTRAINT wad_out_entries_default_wad_out_entry_serial_id_key UNIQUE (wad_out_entry_serial_id);
-
-
---
--- Name: wads_in wads_in_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in
- ADD CONSTRAINT wads_in_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_in_default wads_in_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_in wads_in_wad_id_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in
- ADD CONSTRAINT wads_in_wad_id_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_in_default wads_in_default_wad_id_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_id_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_in_default wads_in_default_wad_in_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_in_serial_id_key UNIQUE (wad_in_serial_id);
-
-
---
--- Name: wads_in_default wads_in_default_wad_is_origin_exchange_url_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_in_default
- ADD CONSTRAINT wads_in_default_wad_is_origin_exchange_url_key UNIQUE (wad_id, origin_exchange_url);
-
-
---
--- Name: wads_out wads_out_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out
- ADD CONSTRAINT wads_out_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_out_default wads_out_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out_default
- ADD CONSTRAINT wads_out_default_pkey PRIMARY KEY (wad_id);
-
-
---
--- Name: wads_out_default wads_out_default_wad_out_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wads_out_default
- ADD CONSTRAINT wads_out_default_wad_out_serial_id_key UNIQUE (wad_out_serial_id);
-
-
---
--- Name: wire_accounts wire_accounts_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_accounts
- ADD CONSTRAINT wire_accounts_pkey PRIMARY KEY (payto_uri);
-
-
---
--- Name: wire_fee wire_fee_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_fee
- ADD CONSTRAINT wire_fee_pkey PRIMARY KEY (wire_method, start_date);
-
-
---
--- Name: wire_fee wire_fee_wire_fee_serial_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_fee
- ADD CONSTRAINT wire_fee_wire_fee_serial_key UNIQUE (wire_fee_serial);
-
-
---
--- Name: wire_out_default wire_out_default_wireout_uuid_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out_default
- ADD CONSTRAINT wire_out_default_wireout_uuid_pkey PRIMARY KEY (wireout_uuid);
-
-
---
--- Name: wire_out wire_out_wtid_raw_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out
- ADD CONSTRAINT wire_out_wtid_raw_key UNIQUE (wtid_raw);
-
-
---
--- Name: wire_out_default wire_out_default_wtid_raw_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_out_default
- ADD CONSTRAINT wire_out_default_wtid_raw_key UNIQUE (wtid_raw);
-
-
---
--- Name: wire_targets wire_targets_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets
- ADD CONSTRAINT wire_targets_pkey PRIMARY KEY (wire_target_h_payto);
-
-
---
--- Name: wire_targets_default wire_targets_default_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets_default
- ADD CONSTRAINT wire_targets_default_pkey PRIMARY KEY (wire_target_h_payto);
-
-
---
--- Name: wire_targets_default wire_targets_default_wire_target_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.wire_targets_default
- ADD CONSTRAINT wire_targets_default_wire_target_serial_id_key UNIQUE (wire_target_serial_id);
-
-
---
--- Name: work_shards work_shards_pkey; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.work_shards
- ADD CONSTRAINT work_shards_pkey PRIMARY KEY (job_name, start_row);
-
-
---
--- Name: work_shards work_shards_shard_serial_id_key; Type: CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.work_shards
- ADD CONSTRAINT work_shards_shard_serial_id_key UNIQUE (shard_serial_id);
-
-
---
--- Name: merchant_accounts merchant_accounts_h_wire_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_h_wire_key UNIQUE (h_wire);
-
-
---
--- Name: merchant_accounts merchant_accounts_merchant_serial_payto_uri_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_merchant_serial_payto_uri_key UNIQUE (merchant_serial, payto_uri);
-
-
---
--- Name: merchant_accounts merchant_accounts_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_pkey PRIMARY KEY (account_serial);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_h_contract_terms_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_h_contract_terms_key UNIQUE (merchant_serial, h_contract_terms);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_order_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_order_id_key UNIQUE (merchant_serial, order_id);
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_pkey PRIMARY KEY (order_serial);
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_deposit_serial_credit_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_deposit_serial_credit_serial_key UNIQUE (deposit_serial, credit_serial);
-
-
---
--- Name: merchant_deposits merchant_deposits_order_serial_coin_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_order_serial_coin_pub_key UNIQUE (order_serial, coin_pub);
-
-
---
--- Name: merchant_deposits merchant_deposits_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_pkey PRIMARY KEY (deposit_serial);
-
-
---
--- Name: merchant_exchange_signing_keys merchant_exchange_signing_key_exchange_pub_start_date_maste_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_signing_keys
- ADD CONSTRAINT merchant_exchange_signing_key_exchange_pub_start_date_maste_key UNIQUE (exchange_pub, start_date, master_pub);
-
-
---
--- Name: merchant_exchange_signing_keys merchant_exchange_signing_keys_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_signing_keys
- ADD CONSTRAINT merchant_exchange_signing_keys_pkey PRIMARY KEY (signkey_serial);
-
-
---
--- Name: merchant_exchange_wire_fees merchant_exchange_wire_fees_master_pub_h_wire_method_start__key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_wire_fees
- ADD CONSTRAINT merchant_exchange_wire_fees_master_pub_h_wire_method_start__key UNIQUE (master_pub, h_wire_method, start_date);
-
-
---
--- Name: merchant_exchange_wire_fees merchant_exchange_wire_fees_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_exchange_wire_fees
- ADD CONSTRAINT merchant_exchange_wire_fees_pkey PRIMARY KEY (wirefee_serial);
-
-
---
--- Name: merchant_instances merchant_instances_merchant_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_merchant_id_key UNIQUE (merchant_id);
-
-
---
--- Name: merchant_instances merchant_instances_merchant_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_merchant_pub_key UNIQUE (merchant_pub);
-
-
---
--- Name: merchant_instances merchant_instances_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_instances
- ADD CONSTRAINT merchant_instances_pkey PRIMARY KEY (merchant_serial);
-
-
---
--- Name: merchant_inventory merchant_inventory_merchant_serial_product_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_merchant_serial_product_id_key UNIQUE (merchant_serial, product_id);
-
-
---
--- Name: merchant_inventory merchant_inventory_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_pkey PRIMARY KEY (product_serial);
-
-
---
--- Name: merchant_keys merchant_keys_merchant_priv_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_merchant_priv_key UNIQUE (merchant_priv);
-
-
---
--- Name: merchant_keys merchant_keys_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_pkey PRIMARY KEY (merchant_serial);
-
-
---
--- Name: merchant_kyc merchant_kyc_kyc_serial_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_kyc_serial_id_key UNIQUE (kyc_serial_id);
-
-
---
--- Name: merchant_kyc merchant_kyc_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_pkey PRIMARY KEY (account_serial, exchange_url);
-
-
---
--- Name: merchant_orders merchant_orders_merchant_serial_order_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_merchant_serial_order_id_key UNIQUE (merchant_serial, order_id);
-
-
---
--- Name: merchant_orders merchant_orders_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_pkey PRIMARY KEY (order_serial);
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_pkey PRIMARY KEY (refund_serial);
-
-
---
--- Name: merchant_refunds merchant_refunds_order_serial_coin_pub_rtransaction_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_order_serial_coin_pub_rtransaction_id_key UNIQUE (order_serial, coin_pub, rtransaction_id);
-
-
---
--- Name: merchant_refunds merchant_refunds_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_pkey PRIMARY KEY (refund_serial);
-
-
---
--- Name: merchant_tip_pickup_signatures merchant_tip_pickup_signatures_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickup_signatures
- ADD CONSTRAINT merchant_tip_pickup_signatures_pkey PRIMARY KEY (pickup_serial, coin_offset);
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_pickup_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_pickup_id_key UNIQUE (pickup_id);
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_pkey PRIMARY KEY (pickup_serial);
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_priv_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_priv_key UNIQUE (reserve_priv);
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_serial_key UNIQUE (reserve_serial);
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_pkey PRIMARY KEY (reserve_serial);
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_reserve_pub_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_reserve_pub_key UNIQUE (reserve_pub);
-
-
---
--- Name: merchant_tips merchant_tips_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_pkey PRIMARY KEY (tip_serial);
-
-
---
--- Name: merchant_tips merchant_tips_tip_id_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_tip_id_key UNIQUE (tip_id);
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_pkey PRIMARY KEY (credit_serial);
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_deposit_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_deposit_serial_key UNIQUE (deposit_serial);
-
-
---
--- Name: merchant_transfers merchant_transfers_pkey; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_pkey PRIMARY KEY (credit_serial);
-
-
---
--- Name: merchant_transfers merchant_transfers_wtid_exchange_url_account_serial_key; Type: CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_wtid_exchange_url_account_serial_key UNIQUE (wtid, exchange_url, account_serial);
-
-
---
--- Name: auditor_historic_reserve_summary_by_master_pub_start_date; Type: INDEX; Schema: auditor; Owner: -
---
-
-CREATE INDEX auditor_historic_reserve_summary_by_master_pub_start_date ON auditor.auditor_historic_reserve_summary USING btree (master_pub, start_date);
-
-
---
--- Name: auditor_reserves_by_reserve_pub; Type: INDEX; Schema: auditor; Owner: -
---
-
-CREATE INDEX auditor_reserves_by_reserve_pub ON auditor.auditor_reserves USING btree (reserve_pub);
-
-
---
--- Name: account_merges_by_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX account_merges_by_reserve_pub ON ONLY exchange.account_merges USING btree (reserve_pub);
-
-
---
--- Name: account_merges_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX account_merges_default_reserve_pub_idx ON exchange.account_merges_default USING btree (reserve_pub);
-
-
---
--- Name: aggregation_tracking_by_wtid_raw_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX aggregation_tracking_by_wtid_raw_index ON ONLY exchange.aggregation_tracking USING btree (wtid_raw);
-
-
---
--- Name: INDEX aggregation_tracking_by_wtid_raw_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.aggregation_tracking_by_wtid_raw_index IS 'for lookup_transactions';
-
-
---
--- Name: aggregation_tracking_default_wtid_raw_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX aggregation_tracking_default_wtid_raw_idx ON exchange.aggregation_tracking_default USING btree (wtid_raw);
-
-
---
--- Name: denominations_by_expire_legal_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX denominations_by_expire_legal_index ON exchange.denominations USING btree (expire_legal);
-
-
---
--- Name: deposits_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_coin_pub_index ON ONLY exchange.deposits USING btree (coin_pub);
-
-
---
--- Name: deposits_by_ready_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_ready_main_index ON ONLY exchange.deposits_by_ready USING btree (wire_deadline, shard, coin_pub);
-
-
---
--- Name: deposits_by_ready_default_wire_deadline_shard_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_by_ready_default_wire_deadline_shard_coin_pub_idx ON exchange.deposits_by_ready_default USING btree (wire_deadline, shard, coin_pub);
-
-
---
--- Name: deposits_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_default_coin_pub_idx ON exchange.deposits_default USING btree (coin_pub);
-
-
---
--- Name: deposits_for_matching_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_for_matching_main_index ON ONLY exchange.deposits_for_matching USING btree (refund_deadline, merchant_pub, coin_pub);
-
-
---
--- Name: deposits_for_matching_default_refund_deadline_merchant_pub__idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX deposits_for_matching_default_refund_deadline_merchant_pub__idx ON exchange.deposits_for_matching_default USING btree (refund_deadline, merchant_pub, coin_pub);
-
-
---
--- Name: global_fee_by_end_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX global_fee_by_end_date_index ON exchange.global_fee USING btree (end_date);
-
-
---
--- Name: legitimizations_default_by_provider_and_legi_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX legitimizations_default_by_provider_and_legi_index ON exchange.legitimizations_default USING btree (provider_section, provider_legitimization_id);
-
-
---
--- Name: INDEX legitimizations_default_by_provider_and_legi_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.legitimizations_default_by_provider_and_legi_index IS 'used (rarely) in kyc_provider_account_lookup';
-
-
---
--- Name: partner_accounts_index_by_partner_and_time; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX partner_accounts_index_by_partner_and_time ON exchange.partner_accounts USING btree (partner_serial_id, last_seen);
-
-
---
--- Name: partner_by_wad_time; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX partner_by_wad_time ON exchange.partners USING btree (next_wad);
-
-
---
--- Name: prewire_by_failed_finished_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_by_failed_finished_index ON ONLY exchange.prewire USING btree (failed, finished);
-
-
---
--- Name: INDEX prewire_by_failed_finished_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.prewire_by_failed_finished_index IS 'for wire_prepare_data_get';
-
-
---
--- Name: prewire_by_finished_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_by_finished_index ON ONLY exchange.prewire USING btree (finished);
-
-
---
--- Name: INDEX prewire_by_finished_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.prewire_by_finished_index IS 'for gc_prewire';
-
-
---
--- Name: prewire_default_failed_finished_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_default_failed_finished_idx ON exchange.prewire_default USING btree (failed, finished);
-
-
---
--- Name: prewire_default_finished_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX prewire_default_finished_idx ON exchange.prewire_default USING btree (finished);
-
-
---
--- Name: purse_action_by_target; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_action_by_target ON exchange.purse_actions USING btree (partner_serial_id, action_date);
-
-
---
--- Name: purse_deposits_by_coin_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_deposits_by_coin_pub ON ONLY exchange.purse_deposits USING btree (coin_pub);
-
-
---
--- Name: purse_deposits_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_deposits_default_coin_pub_idx ON exchange.purse_deposits_default USING btree (coin_pub);
-
-
---
--- Name: purse_merges_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_merges_reserve_pub ON ONLY exchange.purse_merges USING btree (reserve_pub);
-
-
---
--- Name: INDEX purse_merges_reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.purse_merges_reserve_pub IS 'needed in reserve history computation';
-
-
---
--- Name: purse_merges_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_merges_default_reserve_pub_idx ON exchange.purse_merges_default USING btree (reserve_pub);
-
-
---
--- Name: purse_requests_merge_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_merge_pub ON ONLY exchange.purse_requests USING btree (merge_pub);
-
-
---
--- Name: purse_requests_default_merge_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_default_merge_pub_idx ON exchange.purse_requests_default USING btree (merge_pub);
-
-
---
--- Name: purse_requests_purse_expiration; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_purse_expiration ON ONLY exchange.purse_requests USING btree (purse_expiration);
-
-
---
--- Name: purse_requests_default_purse_expiration_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX purse_requests_default_purse_expiration_idx ON exchange.purse_requests_default USING btree (purse_expiration);
-
-
---
--- Name: recoup_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_coin_pub_index ON ONLY exchange.recoup USING btree (coin_pub);
-
-
---
--- Name: recoup_by_reserve_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_reserve_main_index ON ONLY exchange.recoup_by_reserve USING btree (reserve_out_serial_id);
-
-
---
--- Name: recoup_by_reserve_default_reserve_out_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_by_reserve_default_reserve_out_serial_id_idx ON exchange.recoup_by_reserve_default USING btree (reserve_out_serial_id);
-
-
---
--- Name: recoup_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_default_coin_pub_idx ON exchange.recoup_default USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_by_coin_pub_index ON ONLY exchange.recoup_refresh USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_by_rrc_serial_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_by_rrc_serial_index ON ONLY exchange.recoup_refresh USING btree (rrc_serial);
-
-
---
--- Name: recoup_refresh_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_default_coin_pub_idx ON exchange.recoup_refresh_default USING btree (coin_pub);
-
-
---
--- Name: recoup_refresh_default_rrc_serial_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX recoup_refresh_default_rrc_serial_idx ON exchange.recoup_refresh_default USING btree (rrc_serial);
-
-
---
--- Name: refresh_commitments_by_old_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_commitments_by_old_coin_pub_index ON ONLY exchange.refresh_commitments USING btree (old_coin_pub);
-
-
---
--- Name: refresh_commitments_default_old_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_commitments_default_old_coin_pub_idx ON exchange.refresh_commitments_default USING btree (old_coin_pub);
-
-
---
--- Name: refresh_revealed_coins_coins_by_melt_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_revealed_coins_coins_by_melt_serial_id_index ON ONLY exchange.refresh_revealed_coins USING btree (melt_serial_id);
-
-
---
--- Name: refresh_revealed_coins_default_melt_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refresh_revealed_coins_default_melt_serial_id_idx ON exchange.refresh_revealed_coins_default USING btree (melt_serial_id);
-
-
---
--- Name: refunds_by_coin_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refunds_by_coin_pub_index ON ONLY exchange.refunds USING btree (coin_pub);
-
-
---
--- Name: refunds_default_coin_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX refunds_default_coin_pub_idx ON exchange.refunds_default USING btree (coin_pub);
-
-
---
--- Name: reserves_by_expiration_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_expiration_index ON ONLY exchange.reserves USING btree (expiration_date, current_balance_val, current_balance_frac);
-
-
---
--- Name: INDEX reserves_by_expiration_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_by_expiration_index IS 'used in get_expired_reserves';
-
-
---
--- Name: reserves_by_gc_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_gc_date_index ON ONLY exchange.reserves USING btree (gc_date);
-
-
---
--- Name: INDEX reserves_by_gc_date_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_by_gc_date_index IS 'for reserve garbage collection';
-
-
---
--- Name: reserves_by_reserve_uuid_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_by_reserve_uuid_index ON ONLY exchange.reserves USING btree (reserve_uuid);
-
-
---
--- Name: reserves_close_by_close_uuid_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_by_close_uuid_index ON ONLY exchange.reserves_close USING btree (close_uuid);
-
-
---
--- Name: reserves_close_by_reserve_pub_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_by_reserve_pub_index ON ONLY exchange.reserves_close USING btree (reserve_pub);
-
-
---
--- Name: reserves_close_default_close_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_default_close_uuid_idx ON exchange.reserves_close_default USING btree (close_uuid);
-
-
---
--- Name: reserves_close_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_close_default_reserve_pub_idx ON exchange.reserves_close_default USING btree (reserve_pub);
-
-
---
--- Name: reserves_default_expiration_date_current_balance_val_curren_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_expiration_date_current_balance_val_curren_idx ON exchange.reserves_default USING btree (expiration_date, current_balance_val, current_balance_frac);
-
-
---
--- Name: reserves_default_gc_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_gc_date_idx ON exchange.reserves_default USING btree (gc_date);
-
-
---
--- Name: reserves_default_reserve_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_default_reserve_uuid_idx ON exchange.reserves_default USING btree (reserve_uuid);
-
-
---
--- Name: reserves_in_by_exch_accnt_reserve_in_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_exch_accnt_reserve_in_serial_id_idx ON ONLY exchange.reserves_in USING btree (exchange_account_section, reserve_in_serial_id DESC);
-
-
---
--- Name: reserves_in_by_exch_accnt_section_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_exch_accnt_section_execution_date_idx ON ONLY exchange.reserves_in USING btree (exchange_account_section, execution_date);
-
-
---
--- Name: reserves_in_by_reserve_in_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_by_reserve_in_serial_id_index ON ONLY exchange.reserves_in USING btree (reserve_in_serial_id);
-
-
---
--- Name: reserves_in_default_exchange_account_section_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_exchange_account_section_execution_date_idx ON exchange.reserves_in_default USING btree (exchange_account_section, execution_date);
-
-
---
--- Name: reserves_in_default_exchange_account_section_reserve_in_ser_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_exchange_account_section_reserve_in_ser_idx ON exchange.reserves_in_default USING btree (exchange_account_section, reserve_in_serial_id DESC);
-
-
---
--- Name: reserves_in_default_reserve_in_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_in_default_reserve_in_serial_id_idx ON exchange.reserves_in_default USING btree (reserve_in_serial_id);
-
-
---
--- Name: reserves_out_by_reserve_main_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_main_index ON ONLY exchange.reserves_out_by_reserve USING btree (reserve_uuid);
-
-
---
--- Name: reserves_out_by_reserve_default_reserve_uuid_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_default_reserve_uuid_idx ON exchange.reserves_out_by_reserve_default USING btree (reserve_uuid);
-
-
---
--- Name: reserves_out_by_reserve_out_serial_id_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_out_serial_id_index ON ONLY exchange.reserves_out USING btree (reserve_out_serial_id);
-
-
---
--- Name: reserves_out_by_reserve_uuid_and_execution_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_by_reserve_uuid_and_execution_date_index ON ONLY exchange.reserves_out USING btree (reserve_uuid, execution_date);
-
-
---
--- Name: INDEX reserves_out_by_reserve_uuid_and_execution_date_index; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.reserves_out_by_reserve_uuid_and_execution_date_index IS 'for get_reserves_out and exchange_do_withdraw_limit_check';
-
-
---
--- Name: reserves_out_default_reserve_out_serial_id_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_default_reserve_out_serial_id_idx ON exchange.reserves_out_default USING btree (reserve_out_serial_id);
-
-
---
--- Name: reserves_out_default_reserve_uuid_execution_date_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX reserves_out_default_reserve_uuid_execution_date_idx ON exchange.reserves_out_default USING btree (reserve_uuid, execution_date);
-
-
---
--- Name: revolving_work_shards_by_job_name_active_last_attempt_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX revolving_work_shards_by_job_name_active_last_attempt_index ON exchange.revolving_work_shards USING btree (job_name, active, last_attempt);
-
-
---
--- Name: wad_in_entries_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_in_entries_reserve_pub ON ONLY exchange.wad_in_entries USING btree (reserve_pub);
-
-
---
--- Name: INDEX wad_in_entries_reserve_pub; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON INDEX exchange.wad_in_entries_reserve_pub IS 'needed in reserve history computation';
-
-
---
--- Name: wad_in_entries_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_in_entries_default_reserve_pub_idx ON exchange.wad_in_entries_default USING btree (reserve_pub);
-
-
---
--- Name: wad_out_entries_by_reserve_pub; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_out_entries_by_reserve_pub ON ONLY exchange.wad_out_entries USING btree (reserve_pub);
-
-
---
--- Name: wad_out_entries_default_reserve_pub_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wad_out_entries_default_reserve_pub_idx ON exchange.wad_out_entries_default USING btree (reserve_pub);
-
-
---
--- Name: wire_fee_by_end_date_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_fee_by_end_date_index ON exchange.wire_fee USING btree (end_date);
-
-
---
--- Name: wire_out_by_wire_target_h_payto_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_out_by_wire_target_h_payto_index ON ONLY exchange.wire_out USING btree (wire_target_h_payto);
-
-
---
--- Name: wire_out_default_wire_target_h_payto_idx; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX wire_out_default_wire_target_h_payto_idx ON exchange.wire_out_default USING btree (wire_target_h_payto);
-
-
---
--- Name: work_shards_by_job_name_completed_last_attempt_index; Type: INDEX; Schema: exchange; Owner: -
---
-
-CREATE INDEX work_shards_by_job_name_completed_last_attempt_index ON exchange.work_shards USING btree (job_name, completed, last_attempt);
-
-
---
--- Name: merchant_contract_terms_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_expiration ON merchant.merchant_contract_terms USING btree (paid, pay_deadline);
-
-
---
--- Name: INDEX merchant_contract_terms_by_expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON INDEX merchant.merchant_contract_terms_by_expiration IS 'for unlock_contracts';
-
-
---
--- Name: merchant_contract_terms_by_merchant_and_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_and_expiration ON merchant.merchant_contract_terms USING btree (merchant_serial, pay_deadline);
-
-
---
--- Name: INDEX merchant_contract_terms_by_merchant_and_expiration; Type: COMMENT; Schema: merchant; Owner: -
---
-
-COMMENT ON INDEX merchant.merchant_contract_terms_by_merchant_and_expiration IS 'for delete_contract_terms';
-
-
---
--- Name: merchant_contract_terms_by_merchant_and_payment; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_and_payment ON merchant.merchant_contract_terms USING btree (merchant_serial, paid);
-
-
---
--- Name: merchant_contract_terms_by_merchant_session_and_fulfillment; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_contract_terms_by_merchant_session_and_fulfillment ON merchant.merchant_contract_terms USING btree (merchant_serial, fulfillment_url, session_id);
-
-
---
--- Name: merchant_inventory_locks_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_inventory_locks_by_expiration ON merchant.merchant_inventory_locks USING btree (expiration);
-
-
---
--- Name: merchant_inventory_locks_by_uuid; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_inventory_locks_by_uuid ON merchant.merchant_inventory_locks USING btree (lock_uuid);
-
-
---
--- Name: merchant_orders_by_creation_time; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_by_creation_time ON merchant.merchant_orders USING btree (creation_time);
-
-
---
--- Name: merchant_orders_by_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_by_expiration ON merchant.merchant_orders USING btree (pay_deadline);
-
-
---
--- Name: merchant_orders_locks_by_order_and_product; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_orders_locks_by_order_and_product ON merchant.merchant_order_locks USING btree (order_serial, product_serial);
-
-
---
--- Name: merchant_refunds_by_coin_and_order; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_refunds_by_coin_and_order ON merchant.merchant_refunds USING btree (coin_pub, order_serial);
-
-
---
--- Name: merchant_tip_reserves_by_exchange_balance; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_exchange_balance ON merchant.merchant_tip_reserves USING btree (exchange_initial_balance_val, exchange_initial_balance_frac);
-
-
---
--- Name: merchant_tip_reserves_by_merchant_serial_and_creation_time; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_merchant_serial_and_creation_time ON merchant.merchant_tip_reserves USING btree (merchant_serial, creation_time);
-
-
---
--- Name: merchant_tip_reserves_by_reserve_pub_and_merchant_serial; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tip_reserves_by_reserve_pub_and_merchant_serial ON merchant.merchant_tip_reserves USING btree (reserve_pub, merchant_serial, creation_time);
-
-
---
--- Name: merchant_tips_by_pickup_and_expiration; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_tips_by_pickup_and_expiration ON merchant.merchant_tips USING btree (was_picked_up, expiration);
-
-
---
--- Name: merchant_transfers_by_credit; Type: INDEX; Schema: merchant; Owner: -
---
-
-CREATE INDEX merchant_transfers_by_credit ON merchant.merchant_transfer_to_coin USING btree (credit_serial);
-
-
---
--- Name: account_merges_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.account_merges_pkey ATTACH PARTITION exchange.account_merges_default_pkey;
-
-
---
--- Name: account_merges_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.account_merges_by_reserve_pub ATTACH PARTITION exchange.account_merges_default_reserve_pub_idx;
-
-
---
--- Name: aggregation_tracking_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.aggregation_tracking_pkey ATTACH PARTITION exchange.aggregation_tracking_default_pkey;
-
-
---
--- Name: aggregation_tracking_default_wtid_raw_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.aggregation_tracking_by_wtid_raw_index ATTACH PARTITION exchange.aggregation_tracking_default_wtid_raw_idx;
-
-
---
--- Name: close_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.close_requests_pkey ATTACH PARTITION exchange.close_requests_default_pkey;
-
-
---
--- Name: contracts_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.contracts_pkey ATTACH PARTITION exchange.contracts_default_pkey;
-
-
---
--- Name: cs_nonce_locks_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.cs_nonce_locks_pkey ATTACH PARTITION exchange.cs_nonce_locks_default_pkey;
-
-
---
--- Name: deposits_by_ready_default_wire_deadline_shard_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_by_ready_main_index ATTACH PARTITION exchange.deposits_by_ready_default_wire_deadline_shard_coin_pub_idx;
-
-
---
--- Name: deposits_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_by_coin_pub_index ATTACH PARTITION exchange.deposits_default_coin_pub_idx;
-
-
---
--- Name: deposits_for_matching_default_refund_deadline_merchant_pub__idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.deposits_for_matching_main_index ATTACH PARTITION exchange.deposits_for_matching_default_refund_deadline_merchant_pub__idx;
-
-
---
--- Name: extension_details_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.extension_details_pkey ATTACH PARTITION exchange.extension_details_default_pkey;
-
-
---
--- Name: history_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.history_requests_pkey ATTACH PARTITION exchange.history_requests_default_pkey;
-
-
---
--- Name: known_coins_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.known_coins_pkey ATTACH PARTITION exchange.known_coins_default_pkey;
-
-
---
--- Name: legitimizations_default_h_payto_provider_section_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.legitimizations_h_payto_provider_section_key ATTACH PARTITION exchange.legitimizations_default_h_payto_provider_section_key;
-
-
---
--- Name: prewire_default_failed_finished_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_by_failed_finished_index ATTACH PARTITION exchange.prewire_default_failed_finished_idx;
-
-
---
--- Name: prewire_default_finished_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_by_finished_index ATTACH PARTITION exchange.prewire_default_finished_idx;
-
-
---
--- Name: prewire_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.prewire_pkey ATTACH PARTITION exchange.prewire_default_pkey;
-
-
---
--- Name: purse_deposits_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_deposits_by_coin_pub ATTACH PARTITION exchange.purse_deposits_default_coin_pub_idx;
-
-
---
--- Name: purse_deposits_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_deposits_pkey ATTACH PARTITION exchange.purse_deposits_default_pkey;
-
-
---
--- Name: purse_merges_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_merges_pkey ATTACH PARTITION exchange.purse_merges_default_pkey;
-
-
---
--- Name: purse_merges_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_merges_reserve_pub ATTACH PARTITION exchange.purse_merges_default_reserve_pub_idx;
-
-
---
--- Name: purse_refunds_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_refunds_pkey ATTACH PARTITION exchange.purse_refunds_default_pkey;
-
-
---
--- Name: purse_requests_default_merge_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_merge_pub ATTACH PARTITION exchange.purse_requests_default_merge_pub_idx;
-
-
---
--- Name: purse_requests_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_pkey ATTACH PARTITION exchange.purse_requests_default_pkey;
-
-
---
--- Name: purse_requests_default_purse_expiration_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.purse_requests_purse_expiration ATTACH PARTITION exchange.purse_requests_default_purse_expiration_idx;
-
-
---
--- Name: recoup_by_reserve_default_reserve_out_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_by_reserve_main_index ATTACH PARTITION exchange.recoup_by_reserve_default_reserve_out_serial_id_idx;
-
-
---
--- Name: recoup_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_by_coin_pub_index ATTACH PARTITION exchange.recoup_default_coin_pub_idx;
-
-
---
--- Name: recoup_refresh_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_refresh_by_coin_pub_index ATTACH PARTITION exchange.recoup_refresh_default_coin_pub_idx;
-
-
---
--- Name: recoup_refresh_default_rrc_serial_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.recoup_refresh_by_rrc_serial_index ATTACH PARTITION exchange.recoup_refresh_default_rrc_serial_idx;
-
-
---
--- Name: refresh_commitments_default_old_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_commitments_by_old_coin_pub_index ATTACH PARTITION exchange.refresh_commitments_default_old_coin_pub_idx;
-
-
---
--- Name: refresh_commitments_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_commitments_pkey ATTACH PARTITION exchange.refresh_commitments_default_pkey;
-
-
---
--- Name: refresh_revealed_coins_default_melt_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_revealed_coins_coins_by_melt_serial_id_index ATTACH PARTITION exchange.refresh_revealed_coins_default_melt_serial_id_idx;
-
-
---
--- Name: refresh_transfer_keys_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refresh_transfer_keys_pkey ATTACH PARTITION exchange.refresh_transfer_keys_default_pkey;
-
-
---
--- Name: refunds_default_coin_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.refunds_by_coin_pub_index ATTACH PARTITION exchange.refunds_default_coin_pub_idx;
-
-
---
--- Name: reserves_close_default_close_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_close_by_close_uuid_index ATTACH PARTITION exchange.reserves_close_default_close_uuid_idx;
-
-
---
--- Name: reserves_close_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_close_by_reserve_pub_index ATTACH PARTITION exchange.reserves_close_default_reserve_pub_idx;
-
-
---
--- Name: reserves_default_expiration_date_current_balance_val_curren_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_expiration_index ATTACH PARTITION exchange.reserves_default_expiration_date_current_balance_val_curren_idx;
-
-
---
--- Name: reserves_default_gc_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_gc_date_index ATTACH PARTITION exchange.reserves_default_gc_date_idx;
-
-
---
--- Name: reserves_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_pkey ATTACH PARTITION exchange.reserves_default_pkey;
-
-
---
--- Name: reserves_default_reserve_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_by_reserve_uuid_index ATTACH PARTITION exchange.reserves_default_reserve_uuid_idx;
-
-
---
--- Name: reserves_in_default_exchange_account_section_execution_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_exch_accnt_section_execution_date_idx ATTACH PARTITION exchange.reserves_in_default_exchange_account_section_execution_date_idx;
-
-
---
--- Name: reserves_in_default_exchange_account_section_reserve_in_ser_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_exch_accnt_reserve_in_serial_id_idx ATTACH PARTITION exchange.reserves_in_default_exchange_account_section_reserve_in_ser_idx;
-
-
---
--- Name: reserves_in_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_pkey ATTACH PARTITION exchange.reserves_in_default_pkey;
-
-
---
--- Name: reserves_in_default_reserve_in_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_in_by_reserve_in_serial_id_index ATTACH PARTITION exchange.reserves_in_default_reserve_in_serial_id_idx;
-
-
---
--- Name: reserves_out_by_reserve_default_reserve_uuid_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_main_index ATTACH PARTITION exchange.reserves_out_by_reserve_default_reserve_uuid_idx;
-
-
---
--- Name: reserves_out_default_h_blind_ev_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_h_blind_ev_key ATTACH PARTITION exchange.reserves_out_default_h_blind_ev_key;
-
-
---
--- Name: reserves_out_default_reserve_out_serial_id_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_out_serial_id_index ATTACH PARTITION exchange.reserves_out_default_reserve_out_serial_id_idx;
-
-
---
--- Name: reserves_out_default_reserve_uuid_execution_date_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.reserves_out_by_reserve_uuid_and_execution_date_index ATTACH PARTITION exchange.reserves_out_default_reserve_uuid_execution_date_idx;
-
-
---
--- Name: wad_in_entries_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_in_entries_pkey ATTACH PARTITION exchange.wad_in_entries_default_pkey;
-
-
---
--- Name: wad_in_entries_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_in_entries_reserve_pub ATTACH PARTITION exchange.wad_in_entries_default_reserve_pub_idx;
-
-
---
--- Name: wad_out_entries_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_out_entries_pkey ATTACH PARTITION exchange.wad_out_entries_default_pkey;
-
-
---
--- Name: wad_out_entries_default_reserve_pub_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wad_out_entries_by_reserve_pub ATTACH PARTITION exchange.wad_out_entries_default_reserve_pub_idx;
-
-
---
--- Name: wads_in_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_in_pkey ATTACH PARTITION exchange.wads_in_default_pkey;
-
-
---
--- Name: wads_in_default_wad_id_origin_exchange_url_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_in_wad_id_origin_exchange_url_key ATTACH PARTITION exchange.wads_in_default_wad_id_origin_exchange_url_key;
-
-
---
--- Name: wads_out_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wads_out_pkey ATTACH PARTITION exchange.wads_out_default_pkey;
-
-
---
--- Name: wire_out_default_wire_target_h_payto_idx; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_out_by_wire_target_h_payto_index ATTACH PARTITION exchange.wire_out_default_wire_target_h_payto_idx;
-
-
---
--- Name: wire_out_default_wtid_raw_key; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_out_wtid_raw_key ATTACH PARTITION exchange.wire_out_default_wtid_raw_key;
-
-
---
--- Name: wire_targets_default_pkey; Type: INDEX ATTACH; Schema: exchange; Owner: -
---
-
-ALTER INDEX exchange.wire_targets_pkey ATTACH PARTITION exchange.wire_targets_default_pkey;
-
-
---
--- Name: deposits deposits_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_delete AFTER DELETE ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_delete_trigger();
-
-
---
--- Name: deposits deposits_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_insert AFTER INSERT ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_insert_trigger();
-
-
---
--- Name: deposits deposits_on_update; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER deposits_on_update AFTER UPDATE ON exchange.deposits FOR EACH ROW EXECUTE FUNCTION exchange.deposits_update_trigger();
-
-
---
--- Name: purse_requests purse_requests_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER purse_requests_on_insert AFTER INSERT ON exchange.purse_requests FOR EACH ROW EXECUTE FUNCTION exchange.purse_requests_insert_trigger();
-
-
---
--- Name: TRIGGER purse_requests_on_insert ON purse_requests; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TRIGGER purse_requests_on_insert ON exchange.purse_requests IS 'Here we install an entry for the purse expiration.';
-
-
---
--- Name: purse_requests purse_requests_on_update; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER purse_requests_on_update BEFORE UPDATE ON exchange.purse_requests FOR EACH ROW EXECUTE FUNCTION exchange.purse_requests_on_update_trigger();
-
-
---
--- Name: TRIGGER purse_requests_on_update ON purse_requests; Type: COMMENT; Schema: exchange; Owner: -
---
-
-COMMENT ON TRIGGER purse_requests_on_update ON exchange.purse_requests IS 'This covers the case where a deposit is made into a purse, which inherently then changes the purse balance via an UPDATE. If the merge is already present and the balance matches the total, we trigger the router. Once the router sets the purse to finished, the trigger will remove the purse from the watchlist of the router.';
-
-
---
--- Name: recoup recoup_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER recoup_on_delete AFTER DELETE ON exchange.recoup FOR EACH ROW EXECUTE FUNCTION exchange.recoup_delete_trigger();
-
-
---
--- Name: recoup recoup_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER recoup_on_insert AFTER INSERT ON exchange.recoup FOR EACH ROW EXECUTE FUNCTION exchange.recoup_insert_trigger();
-
-
---
--- Name: reserves_out reserves_out_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER reserves_out_on_delete AFTER DELETE ON exchange.reserves_out FOR EACH ROW EXECUTE FUNCTION exchange.reserves_out_by_reserve_delete_trigger();
-
-
---
--- Name: reserves_out reserves_out_on_insert; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER reserves_out_on_insert AFTER INSERT ON exchange.reserves_out FOR EACH ROW EXECUTE FUNCTION exchange.reserves_out_by_reserve_insert_trigger();
-
-
---
--- Name: wire_out wire_out_on_delete; Type: TRIGGER; Schema: exchange; Owner: -
---
-
-CREATE TRIGGER wire_out_on_delete AFTER DELETE ON exchange.wire_out FOR EACH ROW EXECUTE FUNCTION exchange.wire_out_delete_trigger();
-
-
---
--- Name: auditor_exchange_signkeys master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_exchange_signkeys
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_reserve master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_reserve
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_aggregation master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_aggregation
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_deposit_confirmation master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_deposit_confirmation
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_progress_coin master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_progress_coin
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: wire_auditor_account_progress master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_account_progress
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: wire_auditor_progress master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.wire_auditor_progress
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_reserves master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserves
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_reserve_balance master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_reserve_balance
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_wire_fee_balance master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_wire_fee_balance
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_balance_summary master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_balance_summary
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_historic_denomination_revenue master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_denomination_revenue
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_historic_reserve_summary master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_historic_reserve_summary
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: deposit_confirmations master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.deposit_confirmations
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_predicted_result master_pub_ref; Type: FK CONSTRAINT; Schema: auditor; Owner: -
---
-
-ALTER TABLE ONLY auditor.auditor_predicted_result
- ADD CONSTRAINT master_pub_ref FOREIGN KEY (master_pub) REFERENCES auditor.auditor_exchanges(master_pub) ON DELETE CASCADE;
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_auditor_uuid_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_auditor_uuid_fkey FOREIGN KEY (auditor_uuid) REFERENCES exchange.auditors(auditor_uuid) ON DELETE CASCADE;
-
-
---
--- Name: auditor_denom_sigs auditor_denom_sigs_denominations_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.auditor_denom_sigs
- ADD CONSTRAINT auditor_denom_sigs_denominations_serial_fkey FOREIGN KEY (denominations_serial) REFERENCES exchange.denominations(denominations_serial) ON DELETE CASCADE;
-
-
---
--- Name: denomination_revocations denomination_revocations_denominations_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.denomination_revocations
- ADD CONSTRAINT denomination_revocations_denominations_serial_fkey FOREIGN KEY (denominations_serial) REFERENCES exchange.denominations(denominations_serial) ON DELETE CASCADE;
-
-
---
--- Name: partner_accounts partner_accounts_partner_serial_id_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.partner_accounts
- ADD CONSTRAINT partner_accounts_partner_serial_id_fkey FOREIGN KEY (partner_serial_id) REFERENCES exchange.partners(partner_serial_id) ON DELETE CASCADE;
-
-
---
--- Name: signkey_revocations signkey_revocations_esk_serial_fkey; Type: FK CONSTRAINT; Schema: exchange; Owner: -
---
-
-ALTER TABLE ONLY exchange.signkey_revocations
- ADD CONSTRAINT signkey_revocations_esk_serial_fkey FOREIGN KEY (esk_serial) REFERENCES exchange.exchange_sign_keys(esk_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_accounts merchant_accounts_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_accounts
- ADD CONSTRAINT merchant_accounts_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_contract_terms merchant_contract_terms_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_contract_terms
- ADD CONSTRAINT merchant_contract_terms_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial);
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_deposit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_deposit_serial_fkey FOREIGN KEY (deposit_serial) REFERENCES merchant.merchant_deposits(deposit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposit_to_transfer merchant_deposit_to_transfer_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposit_to_transfer
- ADD CONSTRAINT merchant_deposit_to_transfer_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_contract_terms(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_deposits merchant_deposits_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_deposits
- ADD CONSTRAINT merchant_deposits_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_inventory_locks merchant_inventory_locks_product_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory_locks
- ADD CONSTRAINT merchant_inventory_locks_product_serial_fkey FOREIGN KEY (product_serial) REFERENCES merchant.merchant_inventory(product_serial);
-
-
---
--- Name: merchant_inventory merchant_inventory_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_inventory
- ADD CONSTRAINT merchant_inventory_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_keys merchant_keys_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_keys
- ADD CONSTRAINT merchant_keys_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_kyc merchant_kyc_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_kyc
- ADD CONSTRAINT merchant_kyc_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_order_locks merchant_order_locks_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_order_locks
- ADD CONSTRAINT merchant_order_locks_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_orders(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_order_locks merchant_order_locks_product_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_order_locks
- ADD CONSTRAINT merchant_order_locks_product_serial_fkey FOREIGN KEY (product_serial) REFERENCES merchant.merchant_inventory(product_serial);
-
-
---
--- Name: merchant_orders merchant_orders_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_orders
- ADD CONSTRAINT merchant_orders_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_refund_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_refund_serial_fkey FOREIGN KEY (refund_serial) REFERENCES merchant.merchant_refunds(refund_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refund_proofs merchant_refund_proofs_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refund_proofs
- ADD CONSTRAINT merchant_refund_proofs_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_refunds merchant_refunds_order_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_refunds
- ADD CONSTRAINT merchant_refunds_order_serial_fkey FOREIGN KEY (order_serial) REFERENCES merchant.merchant_contract_terms(order_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_pickup_signatures merchant_tip_pickup_signatures_pickup_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickup_signatures
- ADD CONSTRAINT merchant_tip_pickup_signatures_pickup_serial_fkey FOREIGN KEY (pickup_serial) REFERENCES merchant.merchant_tip_pickups(pickup_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_pickups merchant_tip_pickups_tip_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_pickups
- ADD CONSTRAINT merchant_tip_pickups_tip_serial_fkey FOREIGN KEY (tip_serial) REFERENCES merchant.merchant_tips(tip_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_reserve_keys merchant_tip_reserve_keys_reserve_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserve_keys
- ADD CONSTRAINT merchant_tip_reserve_keys_reserve_serial_fkey FOREIGN KEY (reserve_serial) REFERENCES merchant.merchant_tip_reserves(reserve_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tip_reserves merchant_tip_reserves_merchant_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tip_reserves
- ADD CONSTRAINT merchant_tip_reserves_merchant_serial_fkey FOREIGN KEY (merchant_serial) REFERENCES merchant.merchant_instances(merchant_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_tips merchant_tips_reserve_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_tips
- ADD CONSTRAINT merchant_tips_reserve_serial_fkey FOREIGN KEY (reserve_serial) REFERENCES merchant.merchant_tip_reserves(reserve_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_signatures merchant_transfer_signatures_signkey_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_signatures
- ADD CONSTRAINT merchant_transfer_signatures_signkey_serial_fkey FOREIGN KEY (signkey_serial) REFERENCES merchant.merchant_exchange_signing_keys(signkey_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_credit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_credit_serial_fkey FOREIGN KEY (credit_serial) REFERENCES merchant.merchant_transfers(credit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfer_to_coin merchant_transfer_to_coin_deposit_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfer_to_coin
- ADD CONSTRAINT merchant_transfer_to_coin_deposit_serial_fkey FOREIGN KEY (deposit_serial) REFERENCES merchant.merchant_deposits(deposit_serial) ON DELETE CASCADE;
-
-
---
--- Name: merchant_transfers merchant_transfers_account_serial_fkey; Type: FK CONSTRAINT; Schema: merchant; Owner: -
---
-
-ALTER TABLE ONLY merchant.merchant_transfers
- ADD CONSTRAINT merchant_transfers_account_serial_fkey FOREIGN KEY (account_serial) REFERENCES merchant.merchant_accounts(account_serial) ON DELETE CASCADE;
-
-
---
--- PostgreSQL database dump complete
---
-
diff --git a/src/auditor/setup.sh b/src/auditor/setup.sh
new file mode 100755
index 000000000..bb17e92ae
--- /dev/null
+++ b/src/auditor/setup.sh
@@ -0,0 +1,93 @@
+#!/bin/bash
+# This file is in the public domain
+
+# Script to be inlined into the main test scripts. Defines function 'setup()'
+# which wraps around 'taler-unified-setup.sh' to launch GNU Taler services.
+# Call setup() with the arguments to pass to 'taler-unified-setup'. setup()
+# will then launch GNU Taler, wait for the process to be complete before
+# returning. The script will also install an exit handler to ensure the GNU
+# Taler processes are stopped when the shell exits.
+
+set -eu
+
+# Cleanup to run whenever we exit
+function exit_cleanup()
+{
+ if [ ! -z ${SETUP_PID+x} ]
+ then
+ echo "Killing taler-unified-setup ($SETUP_PID)" >&2
+ kill -TERM "$SETUP_PID" 2> /dev/null || true
+ wait "$SETUP_PID" 2> /dev/null || true
+ fi
+}
+
+# Install cleanup handler (except for kill -9)
+trap exit_cleanup EXIT
+
+function setup()
+{
+ echo "Starting test system ..." >&2
+ # Create a named pipe in a temp directory we own.
+ FIFO_DIR=$(mktemp -d fifo-XXXXXX)
+ FIFO_OUT=$(echo "$FIFO_DIR/out")
+ mkfifo "$FIFO_OUT"
+ # Open pipe as FD 3 (RW) and FD 4 (RO)
+ exec 3<> "$FIFO_OUT" 4< "$FIFO_OUT"
+ rm -rf "$FIFO_DIR"
+ # We require '-W' for our termination logic to work.
+ taler-unified-setup.sh -W "$@" \
+ > >(tee taler-unified-setup.log >&3) &
+ SETUP_PID=$!
+ # Close FD3
+ exec 3>&-
+ sed -u '/<<READY>>/ q' <&4
+ # Close FD4
+ exec 4>&-
+ echo "Test system ready" >&2
+}
+
+# Exit, with status code "skip" (no 'real' failure)
+function exit_fail() {
+ echo "$@" >&2
+ exit 1
+}
+
+# Exit, with status code "skip" (no 'real' failure)
+function exit_skip() {
+ echo "SKIPPING: $1"
+ exit 77
+}
+
+function get_payto_uri() {
+ export LIBEUFIN_SANDBOX_USERNAME="$1"
+ export LIBEUFIN_SANDBOX_PASSWORD="$2"
+ export LIBEUFIN_SANDBOX_URL="http://localhost:18082"
+ echo "get_payto_uri currently not implemented"
+ exit 1
+# libeufin-cli sandbox demobank info --bank-account "$1" | jq --raw-output '.paytoUri'
+}
+
+# Stop libeufin-bank (if running)
+function stop_libeufin()
+{
+ echo -n "Stopping libeufin... "
+ if [ -f "${MY_TMP_DIR:-/}/libeufin-bank.pid" ]
+ then
+ PID=$(cat "${MY_TMP_DIR}/libeufin-bank.pid" 2> /dev/null)
+ echo "Killing libeufin-bank $PID"
+ rm "${MY_TMP_DIR}/libeufin-bank.pid"
+ kill "$PID" 2> /dev/null || true
+ wait "$PID" || true
+ fi
+ echo "DONE"
+}
+
+
+function launch_libeufin () {
+ libeufin-bank serve \
+ -c "$CONF" \
+ -L "INFO" \
+ > "${MY_TMP_DIR}/libeufin-bank-stdout.log" \
+ 2> "${MY_TMP_DIR}/libeufin-bank-stderr.log" &
+ echo $! > "${MY_TMP_DIR}/libeufin-bank.pid"
+}
diff --git a/src/auditor/taler-auditor-dbinit.c b/src/auditor/taler-auditor-dbinit.c
index 54f8152a5..4cb46f470 100644
--- a/src/auditor/taler-auditor-dbinit.c
+++ b/src/auditor/taler-auditor-dbinit.c
@@ -90,7 +90,9 @@ run (void *cls,
"Failed to restart audits\n");
}
if (GNUNET_OK !=
- plugin->create_tables (plugin->cls))
+ plugin->create_tables (plugin->cls,
+ false,
+ 0))
{
fprintf (stderr,
"Failed to initialize database.\n");
diff --git a/src/auditor/taler-auditor-exchange.c b/src/auditor/taler-auditor-exchange.c
deleted file mode 100644
index 04181ce3f..000000000
--- a/src/auditor/taler-auditor-exchange.c
+++ /dev/null
@@ -1,224 +0,0 @@
-/*
- This file is part of TALER
- Copyright (C) 2014-2021 Taler Systems SA
-
- TALER is free software; you can redistribute it and/or modify it under the
- terms of the GNU General Public License as published by the Free Software
- Foundation; either version 3, or (at your option) any later version.
-
- TALER is distributed in the hope that it will be useful, but WITHOUT ANY
- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- A PARTICULAR PURPOSE. See the GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License along with
- TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
-*/
-/**
- * @file taler-auditor-exchange.c
- * @brief Tool used by the auditor to add or remove the exchange's master key
- * to its database.
- * @author Christian Grothoff
- */
-#include <platform.h>
-#include "taler_exchangedb_lib.h"
-#include "taler_auditordb_lib.h"
-
-
-/**
- * URL of the exchange.
- */
-static char *exchange_url;
-
-/**
- * Master public key of the exchange.
- */
-static struct TALER_MasterPublicKeyP master_public_key;
-
-/**
- * Our configuration.
- */
-static struct GNUNET_CONFIGURATION_Handle *cfg;
-
-/**
- * Handle to access the auditor's database.
- */
-static struct TALER_AUDITORDB_Plugin *adb;
-
-/**
- * -r option given.
- */
-static int remove_flag;
-
-
-/**
- * The main function of the taler-auditor-exchange tool. This tool is used
- * to add (or remove) an exchange's master key and base URL to the auditor's
- * database.
- *
- * @param argc number of arguments from the command line
- * @param argv command line arguments
- * @return 0 ok, non-zero on error
- */
-int
-main (int argc,
- char *const *argv)
-{
- char *cfgfile = NULL;
- const struct GNUNET_GETOPT_CommandLineOption options[] = {
- GNUNET_GETOPT_option_cfgfile (&cfgfile),
- GNUNET_GETOPT_option_help (
- "Add or remove exchange to list of audited exchanges"),
- GNUNET_GETOPT_option_mandatory
- (GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &master_public_key)),
- GNUNET_GETOPT_option_string ('u',
- "exchange-url",
- "URL",
- "base URL of the exchange",
- &exchange_url),
- GNUNET_GETOPT_option_flag ('r',
- "remove",
- "remove the exchange's key (default is to add)",
- &remove_flag),
- GNUNET_GETOPT_option_version (VERSION "-" VCS_VERSION),
- GNUNET_GETOPT_OPTION_END
- };
-
- TALER_gcrypt_init (); /* must trigger initialization manually at this point! */
- GNUNET_assert (GNUNET_OK ==
- GNUNET_log_setup ("taler-auditor-exchange",
- "WARNING",
- NULL));
- {
- int ret;
-
- ret = GNUNET_GETOPT_run ("taler-auditor-exchange",
- options,
- argc, argv);
- if (GNUNET_NO == ret)
- return EXIT_SUCCESS;
- if (GNUNET_SYSERR == ret)
- return EXIT_INVALIDARGUMENT;
- }
- if (NULL == cfgfile)
- cfgfile = GNUNET_CONFIGURATION_default_filename ();
- if (NULL == cfgfile)
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Can't find default configuration file.\n");
- return EXIT_NOTCONFIGURED;
- }
- cfg = GNUNET_CONFIGURATION_create ();
-
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Loading config file: %s\n",
- cfgfile);
-
- if (GNUNET_SYSERR ==
- GNUNET_CONFIGURATION_load (cfg,
- cfgfile))
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Malformed configuration file `%s', exit ...\n",
- cfgfile);
- GNUNET_free (cfgfile);
- return EXIT_NOTCONFIGURED;
- }
- GNUNET_free (cfgfile);
-
- if (! remove_flag)
- {
- if (NULL == exchange_url)
- {
- fprintf (stderr,
- _ ("Missing either `%s' or `%s'.\n"),
- "-u URL",
- "--remove");
- return EXIT_INVALIDARGUMENT;
- }
- if ( (0 == strlen (exchange_url)) ||
- ( (0 != strncasecmp ("http://",
- exchange_url,
- strlen ("http://"))) &&
- (0 != strncasecmp ("https://",
- exchange_url,
- strlen ("https://"))) ) ||
- ('/' != exchange_url[strlen (exchange_url) - 1]) )
- {
- fprintf (stderr,
- "Exchange URL must begin with `http://` or `https://` and end with `/'\n");
- return EXIT_INVALIDARGUMENT;
- }
- }
-
-
- if (NULL ==
- (adb = TALER_AUDITORDB_plugin_load (cfg)))
- {
- fprintf (stderr,
- "Failed to initialize auditor database plugin.\n");
- return EXIT_NOTINSTALLED;
- }
-
- /* Create required tables */
- if (GNUNET_OK !=
- adb->create_tables (adb->cls))
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Failed to create tables in auditor's database\n");
- TALER_AUDITORDB_plugin_unload (adb);
- return EXIT_NOPERMISSION;
- }
-
- /* Update DB */
- {
- enum GNUNET_DB_QueryStatus qs;
-
- if (GNUNET_SYSERR ==
- adb->preflight (adb->cls))
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Failed to initialize database connection\n");
- TALER_AUDITORDB_plugin_unload (adb);
- return EXIT_FAILURE;
- }
-
- if (remove_flag)
- {
- qs = adb->delete_exchange (adb->cls,
- &master_public_key);
- }
- else
- {
- qs = adb->insert_exchange (adb->cls,
- &master_public_key,
- exchange_url);
- }
- if (0 > qs)
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Failed to update auditor database (status code: %d)\n",
- qs);
- TALER_AUDITORDB_plugin_unload (adb);
- return EXIT_FAILURE;
- }
- if (0 == qs)
- {
- GNUNET_log (
- GNUNET_ERROR_TYPE_WARNING,
- (remove_flag)
- ? "Could not remove exchange from database: entry already absent\n"
- : "Could not add exchange to database: entry already exists\n");
- TALER_AUDITORDB_plugin_unload (adb);
- return EXIT_FAILURE;
- }
- }
- TALER_AUDITORDB_plugin_unload (adb);
- return EXIT_SUCCESS;
-}
-
-
-/* end of taler-auditor-exchange.c */
diff --git a/src/auditor/taler-auditor-httpd.c b/src/auditor/taler-auditor-httpd.c
index a212eddca..59bd849bc 100644
--- a/src/auditor/taler-auditor-httpd.c
+++ b/src/auditor/taler-auditor-httpd.c
@@ -31,7 +31,7 @@
#include "taler_auditordb_lib.h"
#include "taler_exchangedb_lib.h"
#include "taler-auditor-httpd_deposit-confirmation.h"
-#include "taler-auditor-httpd_exchanges.h"
+#include "taler-auditor-httpd_deposit-confirmation-get.h"
#include "taler-auditor-httpd_mhd.h"
#include "taler-auditor-httpd.h"
@@ -48,7 +48,8 @@
* release version, and the format is NOT the same that semantic
* versioning uses either.
*/
-#define AUDITOR_PROTOCOL_VERSION "0:0:0"
+#define AUDITOR_PROTOCOL_VERSION "1:0:1"
+
/**
* Backlog for listen operation on unix domain sockets.
@@ -81,6 +82,12 @@ struct TALER_EXCHANGEDB_Plugin *TAH_eplugin;
static struct TALER_AuditorPublicKeyP auditor_pub;
/**
+ * Exchange master public key (according to the
+ * configuration). (global)
+ */
+struct TALER_MasterPublicKeyP TAH_master_public_key;
+
+/**
* Default timeout in seconds for HTTP requests.
*/
static unsigned int connection_timeout = 30;
@@ -132,7 +139,7 @@ handle_mhd_completion_callback (void *cls,
/**
- * Handle a "/version" request.
+ * Handle a "/config" request.
*
* @param rh context of the handler
* @param connection the MHD connection to handle
@@ -142,11 +149,11 @@ handle_mhd_completion_callback (void *cls,
* @return MHD result code
*/
static MHD_RESULT
-handle_version (struct TAH_RequestHandler *rh,
- struct MHD_Connection *connection,
- void **connection_cls,
- const char *upload_data,
- size_t *upload_data_size)
+handle_config (struct TAH_RequestHandler *rh,
+ struct MHD_Connection *connection,
+ void **connection_cls,
+ const char *upload_data,
+ size_t *upload_data_size)
{
static json_t *ver; /* we build the response only once, keep around for next query! */
@@ -157,12 +164,18 @@ handle_version (struct TAH_RequestHandler *rh,
if (NULL == ver)
{
ver = GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("name",
+ "taler-auditor"),
GNUNET_JSON_pack_string ("version",
AUDITOR_PROTOCOL_VERSION),
+ GNUNET_JSON_pack_string ("implementation",
+ "urn:net:taler:specs:taler-auditor:c-reference"),
GNUNET_JSON_pack_string ("currency",
TAH_currency),
GNUNET_JSON_pack_data_auto ("auditor_public_key",
- &auditor_pub));
+ &auditor_pub),
+ GNUNET_JSON_pack_data_auto ("exchange_master_public_key",
+ &TAH_master_public_key));
}
if (NULL == ver)
{
@@ -204,12 +217,15 @@ handle_mhd_request (void *cls,
{ "/deposit-confirmation", MHD_HTTP_METHOD_PUT, "application/json",
NULL, 0,
&TAH_DEPOSIT_CONFIRMATION_handler, MHD_HTTP_OK },
- { "/exchanges", MHD_HTTP_METHOD_GET, "application/json",
+ { "/deposit-confirmation", MHD_HTTP_METHOD_GET, "application/json",
NULL, 0,
- &TAH_EXCHANGES_handler, MHD_HTTP_OK },
- { "/version", MHD_HTTP_METHOD_GET, "application/json",
+ &TAH_DEPOSIT_CONFIRMATION_handler_get, MHD_HTTP_OK },
+// { "/deposit-confirmation", MHD_HTTP_METHOD_DELETE, "application/json",
+// NULL, 0,
+// &TAH_DEPOSIT_CONFIRMATION_delete, MHD_HTTP_OK },
+ { "/config", MHD_HTTP_METHOD_GET, "application/json",
NULL, 0,
- &handle_version, MHD_HTTP_OK },
+ &handle_config, MHD_HTTP_OK },
/* Landing page, for now tells humans to go away
* (NOTE: ideally, the reverse proxy will respond with a nicer page) */
{ "/", MHD_HTTP_METHOD_GET, "text/plain",
@@ -298,6 +314,40 @@ auditor_serve_process_config (void)
{
return GNUNET_SYSERR;
}
+
+ {
+ char *master_public_key_str;
+
+ if (GNUNET_OK !=
+ GNUNET_CONFIGURATION_get_value_string (cfg,
+ "exchange",
+ "MASTER_PUBLIC_KEY",
+ &master_public_key_str))
+ {
+ GNUNET_log_config_missing (GNUNET_ERROR_TYPE_ERROR,
+ "exchange",
+ "MASTER_PUBLIC_KEY");
+ return GNUNET_SYSERR;
+ }
+ if (GNUNET_OK !=
+ GNUNET_CRYPTO_eddsa_public_key_from_string (
+ master_public_key_str,
+ strlen (master_public_key_str),
+ &TAH_master_public_key.eddsa_pub))
+ {
+ GNUNET_log_config_invalid (GNUNET_ERROR_TYPE_ERROR,
+ "exchange",
+ "MASTER_PUBLIC_KEY",
+ "invalid base32 encoding for a master public key");
+ GNUNET_free (master_public_key_str);
+ return GNUNET_SYSERR;
+ }
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Launching auditor for exchange `%s'...\n",
+ master_public_key_str);
+ GNUNET_free (master_public_key_str);
+ }
+
{
char *pub;
diff --git a/src/auditor/taler-auditor-httpd.h b/src/auditor/taler-auditor-httpd.h
index 79e56ff55..853722f09 100644
--- a/src/auditor/taler-auditor-httpd.h
+++ b/src/auditor/taler-auditor-httpd.h
@@ -39,6 +39,12 @@ extern struct TALER_AUDITORDB_Plugin *TAH_plugin;
extern struct TALER_EXCHANGEDB_Plugin *TAH_eplugin;
/**
+ * Exchange master public key (according to the
+ * configuration). (global)
+ */
+extern struct TALER_MasterPublicKeyP TAH_master_public_key;
+
+/**
* Our currency.
*/
extern char *TAH_currency;
diff --git a/src/auditor/taler-auditor-httpd_deposit-confirmation-get.c b/src/auditor/taler-auditor-httpd_deposit-confirmation-get.c
new file mode 100644
index 000000000..265d625c4
--- /dev/null
+++ b/src/auditor/taler-auditor-httpd_deposit-confirmation-get.c
@@ -0,0 +1,166 @@
+/*
+ This file is part of TALER
+ Copyright (C) 2014-2024 Taler Systems SA
+
+ TALER is free software; you can redistribute it and/or modify it under the
+ terms of the GNU Affero General Public License as published by the Free Software
+ Foundation; either version 3, or (at your option) any later version.
+
+ TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+ A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License along with
+ TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
+*/
+
+/**
+ * @file taler-auditor-httpd_deposit-confirmation-get.c
+ * @brief Handle /deposit-confirmation requests; return list of deposit confirmations from merchant
+ * that were not received from the exchange, by auditor.
+ * @author Nic Eigel
+ */
+
+#include "platform.h"
+#include <gnunet/gnunet_util_lib.h>
+#include <gnunet/gnunet_json_lib.h>
+#include <jansson.h>
+#include <microhttpd.h>
+#include <pthread.h>
+#include "taler_json_lib.h"
+#include "taler_mhd_lib.h"
+#include "taler-auditor-httpd.h"
+#include "taler-auditor-httpd_deposit-confirmation-get.h"
+
+GNUNET_NETWORK_STRUCT_BEGIN
+
+/**
+ * @brief Information about a signing key of the exchange. Signing keys are used
+ * to sign exchange messages other than coins, i.e. to confirm that a
+ * deposit was successful or that a refresh was accepted.
+ */
+struct ExchangeSigningKeyDataP
+{
+
+ /**
+ * When does this signing key begin to be valid?
+ */
+ struct GNUNET_TIME_TimestampNBO start;
+
+ /**
+ * When does this signing key expire? Note: This is currently when
+ * the Exchange will definitively stop using it. Signatures made with
+ * the key remain valid until @e end. When checking validity periods,
+ * clients should allow for some overlap between keys and tolerate
+ * the use of either key during the overlap time (due to the
+ * possibility of clock skew).
+ */
+ struct GNUNET_TIME_TimestampNBO expire;
+
+ /**
+ * When do signatures with this signing key become invalid? After
+ * this point, these signatures cannot be used in (legal) disputes
+ * anymore, as the Exchange is then allowed to destroy its side of the
+ * evidence. @e end is expected to be significantly larger than @e
+ * expire (by a year or more).
+ */
+ struct GNUNET_TIME_TimestampNBO end;
+
+ /**
+ * The public online signing key that the exchange will use
+ * between @e start and @e expire.
+ */
+ struct TALER_ExchangePublicKeyP signkey_pub;
+};
+
+GNUNET_NETWORK_STRUCT_END
+
+
+/**
+ * Add deposit confirmation to the list.
+ *
+ * @param[in,out] cls a `json_t *` array to extend
+ * @param serial_id location of the @a dc in the database
+ * @param dc struct of deposit confirmation
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop iterating
+ */
+static enum GNUNET_GenericReturnValue
+add_deposit_confirmation (void *cls,
+ uint64_t serial_id,
+ const struct TALER_AUDITORDB_DepositConfirmation *dc)
+{
+ json_t *list = cls;
+ json_t *obj;
+
+ obj = GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_data_auto ("dc",
+ dc));
+ GNUNET_break (0 ==
+ json_array_append_new (list,
+ obj));
+ return GNUNET_OK;
+}
+
+
+/**
+ *
+ * @param rh context of the handler
+ * @param connection the MHD connection to handle
+ * @param[in,out] connection_cls the connection's closure (can be updated)
+ * @param upload_data upload data
+ * @param[in,out] upload_data_size number of bytes (left) in @a upload_data
+ * @return MHD result code
+ */
+MHD_RESULT
+TAH_DEPOSIT_CONFIRMATION_handler_get (struct TAH_RequestHandler *rh,
+ struct MHD_Connection *connection,
+ void **connection_cls,
+ const char *upload_data,
+ size_t *upload_data_size)
+{
+ json_t *ja;
+ enum GNUNET_DB_QueryStatus qs;
+
+ (void) rh;
+ (void) connection_cls;
+ (void) upload_data;
+ (void) upload_data_size;
+ if (GNUNET_SYSERR ==
+ TAH_plugin->preflight (TAH_plugin->cls))
+ {
+ GNUNET_break (0);
+ return TALER_MHD_reply_with_error (connection,
+ MHD_HTTP_INTERNAL_SERVER_ERROR,
+ TALER_EC_GENERIC_DB_SETUP_FAILED,
+ NULL);
+ }
+ ja = json_array ();
+ GNUNET_break (NULL != ja);
+ // TODO correct below
+ qs = TAH_plugin->get_deposit_confirmations (
+ TAH_plugin->cls,
+ 0, /* FIXME: get from query parameters! */
+ false, /* FIXME: get from query parameters! */
+ &add_deposit_confirmation,
+ ja);
+
+ if (0 > qs)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs);
+ json_decref (ja);
+ TALER_LOG_WARNING (
+ "Failed to handle GET /deposit-confirmation in database\n");
+ return TALER_MHD_reply_with_error (connection,
+ MHD_HTTP_INTERNAL_SERVER_ERROR,
+ TALER_EC_GENERIC_DB_FETCH_FAILED,
+ "deposit-confirmation");
+ }
+ return TALER_MHD_REPLY_JSON_PACK (
+ connection,
+ MHD_HTTP_OK,
+ GNUNET_JSON_pack_array_steal ("deposit-confirmation",
+ ja));
+}
+
+
+/* end of taler-auditor-httpd_deposit-confirmation-get.c */
diff --git a/src/auditor/taler-auditor-httpd_deposit-confirmation-get.h b/src/auditor/taler-auditor-httpd_deposit-confirmation-get.h
new file mode 100644
index 000000000..f1f522787
--- /dev/null
+++ b/src/auditor/taler-auditor-httpd_deposit-confirmation-get.h
@@ -0,0 +1,70 @@
+/*
+ This file is part of TALER
+ Copyright (C) 2024 Taler Systems SA
+
+ TALER is free software; you can redistribute it and/or modify it under the
+ terms of the GNU Affero General Public License as published by the Free Software
+ Foundation; either version 3, or (at your option) any later version.
+
+ TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+ A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License along with
+ TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
+*/
+/**
+ * @file taler-auditor-httpd_deposit-confirmation-get.h
+ * @brief Handle GET /deposit-confirmation requests
+ * @author Nic Eigel
+ */
+#ifndef TALER_AUDITOR_HTTPD_DEPOSIT_CONFIRMATION_GET_H
+#define TALER_AUDITOR_HTTPD_DEPOSIT_CONFIRMATION_GET_H
+
+#include <gnunet/gnunet_util_lib.h>
+#include <microhttpd.h>
+#include "taler-auditor-httpd.h"
+
+/**
+ * Initialize subsystem.
+ */
+void
+TEAH_DEPOSIT_CONFIRMATION_GET_init (void);
+
+/**
+ * Shut down subsystem.
+ */
+void
+TEAH_DEPOSIT_CONFIRMATION_GET_done (void);
+
+/**
+ * Handle a "/deposit-confirmation" request.
+ *
+ * @param rh context of the handler
+ * @param connection the MHD connection to handle
+ * @param[in,out] connection_cls the connection's closure (can be updated)
+ * @param upload_data upload data
+ * @param[in,out] upload_data_size number of bytes (left) in @a upload_data
+ * @return MHD result code
+ */
+MHD_RESULT
+TAH_DEPOSIT_CONFIRMATION_handler_get (struct TAH_RequestHandler *rh,
+ struct MHD_Connection *connection,
+ void **connection_cls,
+ const char *upload_data,
+ size_t *upload_data_size);
+
+/**
+ * Handle a DELETE "/deposit-confirmation/$dc" request.
+ *
+ * @param rc request details about the request to handle
+ * @param args argument with the dc primary key
+ * @return MHD result code
+ */
+/*MHD_RESULT
+TAH_DEPOSIT_CONFIRMATION_delete (
+ struct TEH_RequestContext *rc,
+ const char *const args[1]);*/
+
+
+#endif
diff --git a/src/auditor/taler-auditor-httpd_deposit-confirmation.c b/src/auditor/taler-auditor-httpd_deposit-confirmation.c
index f4d89b7ca..8b449bf47 100644
--- a/src/auditor/taler-auditor-httpd_deposit-confirmation.c
+++ b/src/auditor/taler-auditor-httpd_deposit-confirmation.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2014-2020 Taler Systems SA
+ Copyright (C) 2014-2023 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero General Public License as published by the Free Software
@@ -31,7 +31,6 @@
#include "taler-auditor-httpd.h"
#include "taler-auditor-httpd_deposit-confirmation.h"
-
GNUNET_NETWORK_STRUCT_BEGIN
/**
@@ -115,9 +114,14 @@ verify_and_execute_deposit_confirmation (
.end = GNUNET_TIME_timestamp_hton (es->ep_end),
.signkey_pub = es->exchange_pub
};
+ const struct TALER_CoinSpendSignatureP *coin_sigps[
+ GNUNET_NZL (dc->num_coins)];
+
+ for (unsigned int i = 0; i < dc->num_coins; i++)
+ coin_sigps[i] = &dc->coin_sigs[i];
if (GNUNET_TIME_absolute_is_future (es->ep_start.abs_time) ||
- GNUNET_TIME_absolute_is_past (es->ep_expire.abs_time) )
+ GNUNET_TIME_absolute_is_past (es->ep_expire.abs_time))
{
/* Signing key expired */
TALER_LOG_WARNING ("Expired exchange signing key\n");
@@ -129,7 +133,7 @@ verify_and_execute_deposit_confirmation (
/* check our cache */
GNUNET_CRYPTO_hash (&skv,
- sizeof (skv),
+ sizeof(skv),
&h);
GNUNET_assert (0 == pthread_mutex_lock (&lock));
cached = GNUNET_CONTAINER_multihashmap_get (cache,
@@ -153,7 +157,7 @@ verify_and_execute_deposit_confirmation (
es->ep_start,
es->ep_expire,
es->ep_end,
- &es->master_public_key,
+ &TAH_master_public_key,
&es->master_sig))
{
TALER_LOG_WARNING ("Invalid signature on exchange signing key\n");
@@ -227,12 +231,13 @@ verify_and_execute_deposit_confirmation (
TALER_exchange_online_deposit_confirmation_verify (
&dc->h_contract_terms,
&dc->h_wire,
- NULL /* h_extensions! */,
+ &dc->h_policy,
dc->exchange_timestamp,
dc->wire_deadline,
dc->refund_deadline,
- &dc->amount_without_fee,
- &dc->coin_pub,
+ &dc->total_without_fee,
+ dc->num_coins,
+ coin_sigps,
&dc->merchant,
&dc->exchange_pub,
&dc->exchange_sig))
@@ -265,40 +270,47 @@ verify_and_execute_deposit_confirmation (
MHD_RESULT
-TAH_DEPOSIT_CONFIRMATION_handler (struct TAH_RequestHandler *rh,
- struct MHD_Connection *connection,
- void **connection_cls,
- const char *upload_data,
- size_t *upload_data_size)
+TAH_DEPOSIT_CONFIRMATION_handler (
+ struct TAH_RequestHandler *rh,
+ struct MHD_Connection *connection,
+ void **connection_cls,
+ const char *upload_data,
+ size_t *upload_data_size)
{
- struct TALER_AUDITORDB_DepositConfirmation dc;
+ struct TALER_AUDITORDB_DepositConfirmation dc = {
+ .refund_deadline = GNUNET_TIME_UNIT_ZERO_TS
+ };
struct TALER_AUDITORDB_ExchangeSigningKey es;
+ const json_t *jcoin_sigs;
+ const json_t *jcoin_pubs;
struct GNUNET_JSON_Specification spec[] = {
GNUNET_JSON_spec_fixed_auto ("h_contract_terms",
&dc.h_contract_terms),
- GNUNET_JSON_spec_fixed_auto ("h_extensions",
- &dc.h_extensions),
+ GNUNET_JSON_spec_fixed_auto ("h_policy",
+ &dc.h_policy),
GNUNET_JSON_spec_fixed_auto ("h_wire",
&dc.h_wire),
GNUNET_JSON_spec_timestamp ("exchange_timestamp",
&dc.exchange_timestamp),
- GNUNET_JSON_spec_timestamp ("refund_deadline",
- &dc.refund_deadline),
+ GNUNET_JSON_spec_mark_optional (
+ GNUNET_JSON_spec_timestamp ("refund_deadline",
+ &dc.refund_deadline),
+ NULL),
GNUNET_JSON_spec_timestamp ("wire_deadline",
&dc.wire_deadline),
- TALER_JSON_spec_amount ("amount_without_fee",
+ TALER_JSON_spec_amount ("total_without_fee",
TAH_currency,
- &dc.amount_without_fee),
- GNUNET_JSON_spec_fixed_auto ("coin_pub",
- &dc.coin_pub),
+ &dc.total_without_fee),
+ GNUNET_JSON_spec_array_const ("coin_pubs",
+ &jcoin_pubs),
+ GNUNET_JSON_spec_array_const ("coin_sigs",
+ &jcoin_sigs),
GNUNET_JSON_spec_fixed_auto ("merchant_pub",
&dc.merchant),
GNUNET_JSON_spec_fixed_auto ("exchange_sig",
&dc.exchange_sig),
GNUNET_JSON_spec_fixed_auto ("exchange_pub",
&dc.exchange_pub),
- GNUNET_JSON_spec_fixed_auto ("master_pub",
- &es.master_public_key),
GNUNET_JSON_spec_timestamp ("ep_start",
&es.ep_start),
GNUNET_JSON_spec_timestamp ("ep_expire",
@@ -309,13 +321,14 @@ TAH_DEPOSIT_CONFIRMATION_handler (struct TAH_RequestHandler *rh,
&es.master_sig),
GNUNET_JSON_spec_end ()
};
+ unsigned int num_coins;
+ json_t *json;
(void) rh;
(void) connection_cls;
(void) upload_data;
(void) upload_data_size;
{
- json_t *json;
enum GNUNET_GenericReturnValue res;
res = TALER_MHD_parse_post_json (connection,
@@ -325,28 +338,94 @@ TAH_DEPOSIT_CONFIRMATION_handler (struct TAH_RequestHandler *rh,
&json);
if (GNUNET_SYSERR == res)
return MHD_NO;
- if ( (GNUNET_NO == res) ||
- (NULL == json) )
+ if ((GNUNET_NO == res) ||
+ (NULL == json))
return MHD_YES;
res = TALER_MHD_parse_json_data (connection,
json,
spec);
- json_decref (json);
if (GNUNET_SYSERR == res)
- return MHD_NO; /* hard failure */
+ {
+ json_decref (json);
+ return MHD_NO; /* hard failure */
+ }
if (GNUNET_NO == res)
- return MHD_YES; /* failure */
+ {
+ json_decref (json);
+ return MHD_YES; /* failure */
+ }
}
-
- es.exchange_pub = dc.exchange_pub; /* used twice! */
- dc.master_public_key = es.master_public_key;
+ num_coins = json_array_size (jcoin_sigs);
+ if (num_coins != json_array_size (jcoin_pubs))
{
+ GNUNET_break_op (0);
+ json_decref (json);
+ return TALER_MHD_reply_with_ec (
+ connection,
+ TALER_EC_GENERIC_PARAMETER_MALFORMED,
+ "coin_pubs.length != coin_sigs.length");
+ }
+ if (0 == num_coins)
+ {
+ GNUNET_break_op (0);
+ json_decref (json);
+ return TALER_MHD_reply_with_ec (
+ connection,
+ TALER_EC_GENERIC_PARAMETER_MALFORMED,
+ "coin_pubs array is empty");
+ }
+ {
+ struct TALER_CoinSpendPublicKeyP coin_pubs[num_coins];
+ struct TALER_CoinSpendSignatureP coin_sigs[num_coins];
MHD_RESULT res;
+ for (unsigned int i = 0; i < num_coins; i++)
+ {
+ json_t *jpub = json_array_get (jcoin_pubs,
+ i);
+ json_t *jsig = json_array_get (jcoin_sigs,
+ i);
+ const char *ps = json_string_value (jpub);
+ const char *ss = json_string_value (jsig);
+
+ if ((NULL == ps) ||
+ (GNUNET_OK !=
+ GNUNET_STRINGS_string_to_data (ps,
+ strlen (ps),
+ &coin_pubs[i],
+ sizeof(coin_pubs[i]))))
+ {
+ GNUNET_break_op (0);
+ json_decref (json);
+ return TALER_MHD_reply_with_ec (
+ connection,
+ TALER_EC_GENERIC_PARAMETER_MALFORMED,
+ "coin_pub[] malformed");
+ }
+ if ((NULL == ss) ||
+ (GNUNET_OK !=
+ GNUNET_STRINGS_string_to_data (ss,
+ strlen (ss),
+ &coin_sigs[i],
+ sizeof(coin_sigs[i]))))
+ {
+ GNUNET_break_op (0);
+ json_decref (json);
+ return TALER_MHD_reply_with_ec (
+ connection,
+ TALER_EC_GENERIC_PARAMETER_MALFORMED,
+ "coin_sig[] malformed");
+ }
+ }
+ dc.num_coins = num_coins;
+ dc.coin_pubs = coin_pubs;
+ dc.coin_sigs = coin_sigs;
+ es.exchange_pub = dc.exchange_pub; /* used twice! */
res = verify_and_execute_deposit_confirmation (connection,
&dc,
&es);
GNUNET_JSON_parse_free (spec);
+ json_decref (json);
return res;
}
}
@@ -371,6 +450,3 @@ TEAH_DEPOSIT_CONFIRMATION_done (void)
GNUNET_assert (0 == pthread_mutex_destroy (&lock));
}
}
-
-
-/* end of taler-auditor-httpd_deposit-confirmation.c */
diff --git a/src/auditor/taler-auditor-httpd_deposit-confirmation.h b/src/auditor/taler-auditor-httpd_deposit-confirmation.h
index a7c331916..1226dda69 100644
--- a/src/auditor/taler-auditor-httpd_deposit-confirmation.h
+++ b/src/auditor/taler-auditor-httpd_deposit-confirmation.h
@@ -56,4 +56,5 @@ TAH_DEPOSIT_CONFIRMATION_handler (struct TAH_RequestHandler *rh,
const char *upload_data,
size_t *upload_data_size);
+
#endif
diff --git a/src/auditor/taler-auditor-httpd_exchanges.c b/src/auditor/taler-auditor-httpd_exchanges.c
deleted file mode 100644
index f9a9e9e60..000000000
--- a/src/auditor/taler-auditor-httpd_exchanges.c
+++ /dev/null
@@ -1,116 +0,0 @@
-/*
- This file is part of TALER
- Copyright (C) 2014-2021 Taler Systems SA
-
- TALER is free software; you can redistribute it and/or modify it under the
- terms of the GNU Affero General Public License as published by the Free Software
- Foundation; either version 3, or (at your option) any later version.
-
- TALER is distributed in the hope that it will be useful, but WITHOUT ANY
- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License along with
- TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
-*/
-/**
- * @file taler-auditor-httpd_exchanges.c
- * @brief Handle /exchanges requests; returns list of exchanges we audit
- * @author Christian Grothoff
- */
-#include "platform.h"
-#include <gnunet/gnunet_util_lib.h>
-#include <gnunet/gnunet_json_lib.h>
-#include <jansson.h>
-#include <microhttpd.h>
-#include <pthread.h>
-#include "taler_json_lib.h"
-#include "taler_mhd_lib.h"
-#include "taler-auditor-httpd.h"
-#include "taler-auditor-httpd_exchanges.h"
-
-
-/**
- * Add exchange information to the list.
- *
- * @param[in,out] cls a `json_t *` array to extend
- * @param master_pub master public key of an exchange
- * @param exchange_url base URL of an exchange
- */
-static void
-add_exchange (void *cls,
- const struct TALER_MasterPublicKeyP *master_pub,
- const char *exchange_url)
-{
- json_t *list = cls;
- json_t *obj;
-
- obj = GNUNET_JSON_PACK (
- GNUNET_JSON_pack_data_auto ("master_pub",
- master_pub),
- GNUNET_JSON_pack_string ("exchange_url",
- exchange_url));
- GNUNET_break (0 ==
- json_array_append_new (list,
- obj));
-
-}
-
-
-/**
- * Handle a "/exchanges" request.
- *
- * @param rh context of the handler
- * @param connection the MHD connection to handle
- * @param[in,out] connection_cls the connection's closure (can be updated)
- * @param upload_data upload data
- * @param[in,out] upload_data_size number of bytes (left) in @a upload_data
- * @return MHD result code
- */
-MHD_RESULT
-TAH_EXCHANGES_handler (struct TAH_RequestHandler *rh,
- struct MHD_Connection *connection,
- void **connection_cls,
- const char *upload_data,
- size_t *upload_data_size)
-{
- json_t *ja;
- enum GNUNET_DB_QueryStatus qs;
-
- (void) rh;
- (void) connection_cls;
- (void) upload_data;
- (void) upload_data_size;
- if (GNUNET_SYSERR ==
- TAH_plugin->preflight (TAH_plugin->cls))
- {
- GNUNET_break (0);
- return TALER_MHD_reply_with_error (connection,
- MHD_HTTP_INTERNAL_SERVER_ERROR,
- TALER_EC_GENERIC_DB_SETUP_FAILED,
- NULL);
- }
- ja = json_array ();
- GNUNET_break (NULL != ja);
- qs = TAH_plugin->list_exchanges (TAH_plugin->cls,
- &add_exchange,
- ja);
- if (0 > qs)
- {
- GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs);
- json_decref (ja);
- TALER_LOG_WARNING ("Failed to handle /exchanges in database\n");
- return TALER_MHD_reply_with_error (connection,
- MHD_HTTP_INTERNAL_SERVER_ERROR,
- TALER_EC_GENERIC_DB_FETCH_FAILED,
- "exchanges");
- }
- return TALER_MHD_REPLY_JSON_PACK (
- connection,
- MHD_HTTP_OK,
- GNUNET_JSON_pack_array_steal ("exchanges",
- ja));
-}
-
-
-/* end of taler-auditor-httpd_exchanges.c */
diff --git a/src/auditor/taler-auditor-httpd_exchanges.h b/src/auditor/taler-auditor-httpd_exchanges.h
deleted file mode 100644
index c7d8dd5fd..000000000
--- a/src/auditor/taler-auditor-httpd_exchanges.h
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- This file is part of TALER
- Copyright (C) 2018 Taler Systems SA
-
- TALER is free software; you can redistribute it and/or modify it under the
- terms of the GNU Affero General Public License as published by the Free Software
- Foundation; either version 3, or (at your option) any later version.
-
- TALER is distributed in the hope that it will be useful, but WITHOUT ANY
- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License along with
- TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
-*/
-/**
- * @file taler-auditor-httpd_exchanges.h
- * @brief Handle /exchanges requests
- * @author Christian Grothoff
- */
-#ifndef TALER_AUDITOR_HTTPD_EXCHANGES_H
-#define TALER_AUDITOR_HTTPD_EXCHANGES_H
-
-#include <gnunet/gnunet_util_lib.h>
-#include <microhttpd.h>
-#include "taler-auditor-httpd.h"
-
-
-/**
- * Handle a "/exchanges" request.
- *
- * @param rh context of the handler
- * @param connection the MHD connection to handle
- * @param[in,out] connection_cls the connection's closure (can be updated)
- * @param upload_data upload data
- * @param[in,out] upload_data_size number of bytes (left) in @a upload_data
- * @return MHD result code
- */
-MHD_RESULT
-TAH_EXCHANGES_handler (struct TAH_RequestHandler *rh,
- struct MHD_Connection *connection,
- void **connection_cls,
- const char *upload_data,
- size_t *upload_data_size);
-
-#endif
diff --git a/src/auditor/taler-auditor-sync.c b/src/auditor/taler-auditor-sync.c
index 9bc596136..e4022d325 100644
--- a/src/auditor/taler-auditor-sync.c
+++ b/src/auditor/taler-auditor-sync.c
@@ -92,9 +92,13 @@ static struct Table tables[] = {
{ .rt = TALER_EXCHANGEDB_RT_DENOMINATIONS},
{ .rt = TALER_EXCHANGEDB_RT_DENOMINATION_REVOCATIONS},
{ .rt = TALER_EXCHANGEDB_RT_WIRE_TARGETS},
+ { .rt = TALER_EXCHANGEDB_RT_LEGITIMIZATION_PROCESSES},
+ { .rt = TALER_EXCHANGEDB_RT_LEGITIMIZATION_REQUIREMENTS},
{ .rt = TALER_EXCHANGEDB_RT_RESERVES},
{ .rt = TALER_EXCHANGEDB_RT_RESERVES_IN},
{ .rt = TALER_EXCHANGEDB_RT_RESERVES_CLOSE},
+ { .rt = TALER_EXCHANGEDB_RT_RESERVES_OPEN_REQUESTS},
+ { .rt = TALER_EXCHANGEDB_RT_RESERVES_OPEN_DEPOSITS},
{ .rt = TALER_EXCHANGEDB_RT_RESERVES_OUT},
{ .rt = TALER_EXCHANGEDB_RT_AUDITORS},
{ .rt = TALER_EXCHANGEDB_RT_AUDITOR_DENOM_SIGS},
@@ -104,7 +108,8 @@ static struct Table tables[] = {
{ .rt = TALER_EXCHANGEDB_RT_REFRESH_COMMITMENTS},
{ .rt = TALER_EXCHANGEDB_RT_REFRESH_REVEALED_COINS},
{ .rt = TALER_EXCHANGEDB_RT_REFRESH_TRANSFER_KEYS},
- { .rt = TALER_EXCHANGEDB_RT_DEPOSITS},
+ { .rt = TALER_EXCHANGEDB_RT_BATCH_DEPOSITS},
+ { .rt = TALER_EXCHANGEDB_RT_COIN_DEPOSITS},
{ .rt = TALER_EXCHANGEDB_RT_REFUNDS},
{ .rt = TALER_EXCHANGEDB_RT_WIRE_OUT},
{ .rt = TALER_EXCHANGEDB_RT_AGGREGATION_TRACKING},
@@ -113,9 +118,10 @@ static struct Table tables[] = {
{ .rt = TALER_EXCHANGEDB_RT_RECOUP},
{ .rt = TALER_EXCHANGEDB_RT_RECOUP_REFRESH },
{ .rt = TALER_EXCHANGEDB_RT_EXTENSIONS},
- { .rt = TALER_EXCHANGEDB_RT_EXTENSION_DETAILS },
+ { .rt = TALER_EXCHANGEDB_RT_POLICY_DETAILS },
+ { .rt = TALER_EXCHANGEDB_RT_POLICY_FULFILLMENTS },
{ .rt = TALER_EXCHANGEDB_RT_PURSE_REQUESTS},
- { .rt = TALER_EXCHANGEDB_RT_PURSE_REFUNDS},
+ { .rt = TALER_EXCHANGEDB_RT_PURSE_DECISION},
{ .rt = TALER_EXCHANGEDB_RT_PURSE_MERGES},
{ .rt = TALER_EXCHANGEDB_RT_PURSE_DEPOSITS},
{ .rt = TALER_EXCHANGEDB_RT_ACCOUNT_MERGES},
@@ -155,7 +161,7 @@ struct InsertContext
* @return #GNUNET_OK to continue to iterate,
* #GNUNET_SYSERR to fail with an error
*/
-static int
+static enum GNUNET_GenericReturnValue
do_insert (void *cls,
const struct TALER_EXCHANGEDB_TableData *td)
{
@@ -388,7 +394,7 @@ do_sync (void *cls)
* @param value actual value of the option (a string)
* @return #GNUNET_OK
*/
-static int
+static enum GNUNET_GenericReturnValue
set_filename (struct GNUNET_GETOPT_CommandLineProcessorContext *ctx,
void *scls,
const char *option,
@@ -600,6 +606,9 @@ main (int argc,
level,
NULL));
GNUNET_free (level);
+ /* suppress compiler warnings... */
+ GNUNET_assert (NULL != src_cfgfile);
+ GNUNET_assert (NULL != dst_cfgfile);
if (0 == strcmp (src_cfgfile,
dst_cfgfile))
{
diff --git a/src/auditor/taler-auditor.in b/src/auditor/taler-auditor.in
index 6a8e88daa..ab3d8d202 100644
--- a/src/auditor/taler-auditor.in
+++ b/src/auditor/taler-auditor.in
@@ -83,14 +83,17 @@ optcheck "$@"
ARGS=("$@")
ARGS=(${ARGS[@]/$INF})
-DIR=`mktemp -d reportXXXXXX`
-for n in aggregation coins deposits reserves
+DATE=`date +%F_%H:%M:%S`
+DIR="report_$DATE"
+mkdir $DIR
+for n in aggregation coins deposits purses reserves
do
taler-helper-auditor-$n ${ARGS[*]} > ${DIR}/$n.json
done
taler-helper-auditor-wire $INF ${ARGS[*]} > ${DIR}/wire.json
+echo "Generating auditor report in ${DIR}."
taler-helper-auditor-render.py \
${DIR}/aggregation.json \
${DIR}/coins.json \
diff --git a/src/auditor/taler-helper-auditor-aggregation.c b/src/auditor/taler-helper-auditor-aggregation.c
index c03dffe35..a0f2a190f 100644
--- a/src/auditor/taler-helper-auditor-aggregation.c
+++ b/src/auditor/taler-helper-auditor-aggregation.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2016-2022 Taler Systems SA
+ Copyright (C) 2016-2024 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero Public License as published by the Free Software
@@ -34,17 +34,26 @@
static int global_ret;
/**
- * Checkpointing our progress for aggregations.
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
*/
-static struct TALER_AUDITORDB_ProgressPointAggregation ppa;
+static int test_mode;
/**
* Checkpointing our progress for aggregations.
*/
-static struct TALER_AUDITORDB_ProgressPointAggregation ppa_start;
+static TALER_ARL_DEF_PP (aggregation_last_wire_out_serial_id);
+
+/**
+ * Total aggregation fees (wire fees) earned.
+ */
+static TALER_ARL_DEF_AB (aggregation_total_wire_fee_revenue);
+
/**
- * Array of reports about row inconsitencies.
+ * Array of reports about row inconsistencies.
*/
static json_t *report_row_inconsistencies;
@@ -102,11 +111,6 @@ static struct TALER_Amount total_arithmetic_delta_plus;
static struct TALER_Amount total_arithmetic_delta_minus;
/**
- * Total aggregation fees (wire fees) earned.
- */
-static struct TALER_Amount total_aggregation_fee_income;
-
-/**
* Array of reports about coin operations with bad signatures.
*/
static json_t *report_bad_sig_losses;
@@ -593,7 +597,45 @@ check_transaction_history_for_deposit (
amount_with_fee);
break;
}
- }
+
+ case TALER_EXCHANGEDB_TT_PURSE_REFUND:
+ {
+ const struct TALER_Amount *amount_with_fee;
+
+ amount_with_fee = &tl->details.purse_refund->refund_amount;
+ fee_claimed = &tl->details.purse_refund->refund_fee;
+ TALER_ARL_amount_add (&refunds,
+ &refunds,
+ amount_with_fee);
+ TALER_ARL_amount_add (&expenditures,
+ &expenditures,
+ fee_claimed);
+ /* Check that the fees given in the transaction list and in dki match */
+ if (0 !=
+ TALER_amount_cmp (&issue->fees.refund,
+ fee_claimed))
+ {
+ /* Disagreement in fee structure between exchange and auditor! */
+ report_amount_arithmetic_inconsistency ("refund fee",
+ 0,
+ fee_claimed,
+ &issue->fees.refund,
+ 1);
+ }
+ break;
+ }
+
+ case TALER_EXCHANGEDB_TT_RESERVE_OPEN:
+ {
+ const struct TALER_Amount *amount_with_fee;
+
+ amount_with_fee = &tl->details.reserve_open->coin_contribution;
+ TALER_ARL_amount_add (&expenditures,
+ &expenditures,
+ amount_with_fee);
+ break;
+ }
+ } /* switch (tl->type) */
} /* for 'tl' */
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -729,10 +771,7 @@ wire_transfer_information_cb (
struct TALER_CoinPublicInfo coin;
enum GNUNET_DB_QueryStatus qs;
struct TALER_PaytoHashP hpt;
-
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "DEPFEE: %s\n",
- TALER_amount2s (deposit_fee));
+ uint64_t etag_out;
TALER_payto_hash (account_pay_uri,
&hpt);
@@ -745,9 +784,23 @@ wire_transfer_information_cb (
"h-payto does not match payto URI");
}
/* Obtain coin's transaction history */
- qs = TALER_ARL_edb->get_coin_transactions (TALER_ARL_edb->cls,
- coin_pub,
- &tl);
+ /* TODO: could use 'start' mechanism to only fetch transactions
+ we did not yet process, instead of going over them
+ again and again.*/
+
+ {
+ struct TALER_Amount balance;
+ struct TALER_DenominationHashP h_denom_pub;
+
+ qs = TALER_ARL_edb->get_coin_transactions (TALER_ARL_edb->cls,
+ coin_pub,
+ 0,
+ 0,
+ &etag_out,
+ &balance,
+ &h_denom_pub,
+ &tl);
+ }
if ( (qs < 0) ||
(NULL == tl) )
{
@@ -1046,8 +1099,9 @@ check_wire_out_cb (void *cls,
char *method;
/* should be monotonically increasing */
- GNUNET_assert (rowid >= ppa.last_wire_out_serial_id);
- ppa.last_wire_out_serial_id = rowid + 1;
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (aggregation_last_wire_out_serial_id));
+ TALER_ARL_USE_PP (aggregation_last_wire_out_serial_id) = rowid + 1;
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Checking wire transfer %s over %s performed on %s\n",
@@ -1134,8 +1188,8 @@ check_wire_out_cb (void *cls,
&wcc.total_deposits,
&final_amount);
/* Sum up aggregation fees (we simply include the rounding gains) */
- TALER_ARL_amount_add (&total_aggregation_fee_income,
- &total_aggregation_fee_income,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (aggregation_total_wire_fee_revenue),
+ &TALER_ARL_USE_AB (aggregation_total_wire_fee_revenue),
&exchange_gain);
/* Check that calculated amount matches actual amount */
@@ -1207,9 +1261,10 @@ analyze_aggregations (void *cls)
(void) cls;
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Analyzing aggregations\n");
- qsp = TALER_ARL_adb->get_auditor_progress_aggregation (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppa);
+ qsp = TALER_ARL_adb->get_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_PP (aggregation_last_wire_out_serial_id),
+ NULL);
if (0 > qsp)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsp);
@@ -1222,18 +1277,19 @@ analyze_aggregations (void *cls)
}
else
{
- ppa_start = ppa;
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Resuming aggregation audit at %llu\n",
- (unsigned long long) ppa.last_wire_out_serial_id);
+ (unsigned long long) TALER_ARL_USE_PP (
+ aggregation_last_wire_out_serial_id));
}
memset (&ac,
0,
sizeof (ac));
- qsx = TALER_ARL_adb->get_wire_fee_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_aggregation_fee_income);
+ qsx = TALER_ARL_adb->get_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_AB (aggregation_total_wire_fee_revenue),
+ NULL);
if (0 > qsx)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsx);
@@ -1242,7 +1298,7 @@ analyze_aggregations (void *cls)
ac.qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
qs = TALER_ARL_edb->select_wire_out_above_serial_id (
TALER_ARL_edb->cls,
- ppa.last_wire_out_serial_id,
+ TALER_ARL_USE_PP (aggregation_last_wire_out_serial_id),
&check_wire_out_cb,
&ac);
if (0 > qs)
@@ -1268,30 +1324,30 @@ analyze_aggregations (void *cls)
return ac.qs;
}
if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qsx)
- ac.qs = TALER_ARL_adb->insert_wire_fee_summary (
+ ac.qs = TALER_ARL_adb->insert_balance (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_aggregation_fee_income);
+ TALER_ARL_SET_AB (aggregation_total_wire_fee_revenue),
+ NULL);
else
- ac.qs = TALER_ARL_adb->update_wire_fee_summary (
+ ac.qs = TALER_ARL_adb->update_balance (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_aggregation_fee_income);
+ TALER_ARL_SET_AB (aggregation_total_wire_fee_revenue),
+ NULL);
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != ac.qs)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == ac.qs);
return ac.qs;
}
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsp)
- qs = TALER_ARL_adb->update_auditor_progress_aggregation (
+ qs = TALER_ARL_adb->update_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppa);
+ TALER_ARL_SET_PP (aggregation_last_wire_out_serial_id),
+ NULL);
else
- qs = TALER_ARL_adb->insert_auditor_progress_aggregation (
+ qs = TALER_ARL_adb->insert_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppa);
+ TALER_ARL_SET_PP (aggregation_last_wire_out_serial_id),
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -1301,7 +1357,8 @@ analyze_aggregations (void *cls)
}
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Concluded aggregation audit step at %llu\n",
- (unsigned long long) ppa.last_wire_out_serial_id);
+ (unsigned long long) TALER_ARL_USE_PP (
+ aggregation_last_wire_out_serial_id));
return GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
}
@@ -1336,7 +1393,8 @@ run (void *cls,
"Starting audit\n");
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_aggregation_fee_income));
+ &TALER_ARL_USE_AB (
+ aggregation_total_wire_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_wire_out_delta_plus));
@@ -1430,14 +1488,14 @@ run (void *cls,
"total_arithmetic_delta_minus",
&total_arithmetic_delta_minus),
TALER_JSON_pack_amount (
- "total_aggregation_fee_income",
- &total_aggregation_fee_income),
+ "aggregation_total_wire_fee_revenue",
+ &TALER_ARL_USE_AB (aggregation_total_wire_fee_revenue)),
GNUNET_JSON_pack_uint64 (
"start_ppa_wire_out_serial_id",
- ppa_start.last_wire_out_serial_id),
+ 0 /* defunct */),
GNUNET_JSON_pack_uint64 (
"end_ppa_wire_out_serial_id",
- ppa.last_wire_out_serial_id),
+ TALER_ARL_USE_PP (aggregation_last_wire_out_serial_id)),
/* block #4 */
TALER_JSON_pack_time_abs_human (
"auditor_start_time",
@@ -1467,11 +1525,10 @@ main (int argc,
"internal",
"perform checks only applicable for exchange-internal audits",
&internal_checks),
- GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &TALER_ARL_master_pub),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
GNUNET_GETOPT_option_timetravel ('T',
"timetravel"),
GNUNET_GETOPT_OPTION_END
diff --git a/src/auditor/taler-helper-auditor-coins.c b/src/auditor/taler-helper-auditor-coins.c
index a3c8afb54..f88f39eaf 100644
--- a/src/auditor/taler-helper-auditor-coins.c
+++ b/src/auditor/taler-helper-auditor-coins.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2016-2022 Taler Systems SA
+ Copyright (C) 2016-2024 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero Public License as published by the Free Software
@@ -45,14 +45,37 @@
static int global_ret;
/**
- * Checkpointing our progress for coins.
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
*/
-static struct TALER_AUDITORDB_ProgressPointCoin ppc;
+static int test_mode;
/**
* Checkpointing our progress for coins.
*/
-static struct TALER_AUDITORDB_ProgressPointCoin ppc_start;
+static TALER_ARL_DEF_PP (coins_withdraw_serial_id);
+static TALER_ARL_DEF_PP (coins_deposit_serial_id);
+static TALER_ARL_DEF_PP (coins_melt_serial_id);
+static TALER_ARL_DEF_PP (coins_refund_serial_id);
+static TALER_ARL_DEF_PP (coins_recoup_serial_id);
+static TALER_ARL_DEF_PP (coins_recoup_refresh_serial_id);
+static TALER_ARL_DEF_PP (coins_purse_deposits_serial_id);
+static TALER_ARL_DEF_PP (coins_purse_refunds_serial_id);
+
+
+/**
+ * Global coin balance sheet (for coins).
+ */
+static TALER_ARL_DEF_AB (coin_balance_risk);
+static TALER_ARL_DEF_AB (total_escrowed);
+static TALER_ARL_DEF_AB (coin_irregular_loss);
+static TALER_ARL_DEF_AB (coin_melt_fee_revenue);
+static TALER_ARL_DEF_AB (coin_deposit_fee_revenue);
+static TALER_ARL_DEF_AB (coin_refund_fee_revenue);
+static TALER_ARL_DEF_AB (total_recoup_loss);
+
/**
* Array of reports about denomination keys with an
@@ -67,7 +90,7 @@ static json_t *report_emergencies;
static json_t *report_emergencies_by_count;
/**
- * Array of reports about row inconsitencies.
+ * Array of reports about row inconsistencies.
*/
static json_t *report_row_inconsistencies;
@@ -112,40 +135,6 @@ static struct TALER_Amount reported_emergency_loss;
*/
static struct TALER_Amount reported_emergency_loss_by_count;
-/**
- * Expected balance in the escrow account.
- */
-static struct TALER_Amount total_escrow_balance;
-
-/**
- * Active risk exposure.
- */
-static struct TALER_Amount total_risk;
-
-/**
- * Actualized risk (= loss) from recoups.
- */
-static struct TALER_Amount total_recoup_loss;
-
-/**
- * Recoups we made on denominations that were not revoked (!?).
- */
-static struct TALER_Amount total_irregular_recoups;
-
-/**
- * Total deposit fees earned.
- */
-static struct TALER_Amount total_deposit_fee_income;
-
-/**
- * Total melt fees earned.
- */
-static struct TALER_Amount total_melt_fee_income;
-
-/**
- * Total refund fees earned.
- */
-static struct TALER_Amount total_refund_fee_income;
/**
* Array of reports about coin operations with bad signatures.
@@ -153,15 +142,10 @@ static struct TALER_Amount total_refund_fee_income;
static json_t *report_bad_sig_losses;
/**
- * Total amount lost by operations for which signatures were invalid.
- */
-static struct TALER_Amount total_bad_sig_loss;
-
-/**
* Array of refresh transactions where the /refresh/reveal has not yet
* happened (and may of course never happen).
*/
-static json_t *report_refreshs_hanging;
+static json_t *report_refreshes_hanging;
/**
* Total amount lost by operations for which signatures were invalid.
@@ -207,9 +191,9 @@ coin_history_index (const struct TALER_CoinSpendPublicKeyP *coin_pub)
{
uint32_t i;
- memcpy (&i,
- coin_pub,
- sizeof (i));
+ GNUNET_memcpy (&i,
+ coin_pub,
+ sizeof (i));
return i % MAX_COIN_HISTORIES;
}
@@ -470,10 +454,24 @@ check_coin_history (const struct TALER_CoinSpendPublicKeyP *coin_pub,
struct TALER_Amount refunded;
struct TALER_Amount deposit_fee;
bool have_refund;
+ uint64_t etag_out;
- qs = TALER_ARL_edb->get_coin_transactions (TALER_ARL_edb->cls,
- coin_pub,
- &tl);
+ /* TODO: could use 'etag' mechanism to only fetch transactions
+ we did not yet process, instead of going over them
+ again and again. */
+ {
+ struct TALER_Amount balance;
+ struct TALER_DenominationHashP h_denom_pub;
+
+ qs = TALER_ARL_edb->get_coin_transactions (TALER_ARL_edb->cls,
+ coin_pub,
+ 0,
+ 0,
+ &etag_out,
+ &balance,
+ &h_denom_pub,
+ &tl);
+ }
if (0 >= qs)
return qs;
GNUNET_assert (GNUNET_OK ==
@@ -539,8 +537,22 @@ check_coin_history (const struct TALER_CoinSpendPublicKeyP *coin_pub,
&spent,
&pos->details.purse_deposit->amount);
break;
- }
- }
+ case TALER_EXCHANGEDB_TT_PURSE_REFUND:
+ TALER_ARL_amount_add (&refunded,
+ &refunded,
+ &tl->details.purse_refund->refund_amount);
+ TALER_ARL_amount_add (&spent,
+ &spent,
+ &pos->details.purse_refund->refund_fee);
+ have_refund = true;
+ break;
+ case TALER_EXCHANGEDB_TT_RESERVE_OPEN:
+ TALER_ARL_amount_add (&spent,
+ &spent,
+ &tl->details.reserve_open->coin_contribution);
+ break;
+ } /* switch (pos->type) */
+ } /* for (...) */
if (have_refund)
{
@@ -591,33 +603,9 @@ check_coin_history (const struct TALER_CoinSpendPublicKeyP *coin_pub,
struct DenominationSummary
{
/**
- * Total value of outstanding (not deposited) coins issued with this
- * denomination key.
- */
- struct TALER_Amount denom_balance;
-
- /**
- * Total losses made (once coins deposited exceed
- * coins withdrawn and thus the @e denom_balance is
- * effectively negative).
+ * Information about the circulation.
*/
- struct TALER_Amount denom_loss;
-
- /**
- * Total value of coins issued with this denomination key.
- */
- struct TALER_Amount denom_risk;
-
- /**
- * Total value of coins subjected to recoup with this denomination key.
- */
- struct TALER_Amount denom_recoup;
-
- /**
- * How many coins (not their amount!) of this denomination
- * did the exchange issue overall?
- */
- uint64_t num_issued;
+ struct TALER_AUDITORDB_DenominationCirculationData dcd;
/**
* Denomination key information for this denomination.
@@ -680,11 +668,7 @@ init_denomination (const struct TALER_DenominationHashP *denom_hash,
qs = TALER_ARL_adb->get_denomination_balance (TALER_ARL_adb->cls,
denom_hash,
- &ds->denom_balance,
- &ds->denom_loss,
- &ds->denom_risk,
- &ds->denom_recoup,
- &ds->num_issued);
+ &ds->dcd);
if (0 > qs)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
@@ -698,22 +682,22 @@ init_denomination (const struct TALER_DenominationHashP *denom_hash,
{
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &ds->denom_balance));
+ &ds->dcd.denom_balance));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &ds->denom_loss));
+ &ds->dcd.denom_loss));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &ds->denom_risk));
+ &ds->dcd.denom_risk));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &ds->denom_recoup));
+ &ds->dcd.recoup_loss));
}
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Starting balance for denomination `%s' is %s (%llu)\n",
GNUNET_h2s (&denom_hash->hash),
- TALER_amount2s (&ds->denom_balance),
- (unsigned long long) ds->num_issued);
+ TALER_amount2s (&ds->dcd.denom_balance),
+ (unsigned long long) ds->dcd.num_issued);
qs = TALER_ARL_edb->get_denomination_revocation (TALER_ARL_edb->cls,
denom_hash,
&msig,
@@ -828,15 +812,14 @@ sync_denomination (void *cls,
else
qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
if ( (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qs) &&
- ( (0 != ds->denom_risk.value) ||
- (0 != ds->denom_risk.fraction) ) )
+ (! TALER_amount_is_zero (&ds->dcd.denom_risk)) )
{
/* The denomination expired and carried a balance; we can now
book the remaining balance as profit, and reduce our risk
exposure by the accumulated risk of the denomination. */
- TALER_ARL_amount_subtract (&total_risk,
- &total_risk,
- &ds->denom_risk);
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (coin_balance_risk),
+ &TALER_ARL_USE_AB (coin_balance_risk),
+ &ds->dcd.denom_risk);
/* If the above fails, our risk assessment is inconsistent!
This is really, really bad (auditor-internal invariant
would be violated). Hence we can "safely" assert. If
@@ -844,22 +827,20 @@ sync_denomination (void *cls,
in the auditor _or_ the auditor's database is corrupt. */
}
if ( (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qs) &&
- ( (0 != ds->denom_balance.value) ||
- (0 != ds->denom_balance.fraction) ) )
+ (! TALER_amount_is_zero (&ds->dcd.denom_balance)) )
{
/* book denom_balance coin expiration profits! */
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Denomination `%s' expired, booking %s in expiration profits\n",
GNUNET_h2s (denom_hash),
- TALER_amount2s (&ds->denom_balance));
+ TALER_amount2s (&ds->dcd.denom_balance));
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT !=
(qs = TALER_ARL_adb->insert_historic_denom_revenue (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
&denom_h,
expire_deposit,
- &ds->denom_balance,
- &ds->denom_recoup)))
+ &ds->dcd.denom_balance,
+ &ds->dcd.recoup_loss)))
{
/* Failed to store profits? Bad database */
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
@@ -876,8 +857,8 @@ sync_denomination (void *cls,
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Final balance for denomination `%s' is %s (%llu)\n",
GNUNET_h2s (denom_hash),
- TALER_amount2s (&ds->denom_balance),
- (unsigned long long) ds->num_issued);
+ TALER_amount2s (&ds->dcd.denom_balance),
+ (unsigned long long) ds->dcd.num_issued);
cnt = TALER_ARL_edb->count_known_coins (TALER_ARL_edb->cls,
&denom_h);
if (0 > cnt)
@@ -889,39 +870,31 @@ sync_denomination (void *cls,
}
else
{
- if (ds->num_issued < (uint64_t) cnt)
+ if (ds->dcd.num_issued < (uint64_t) cnt)
{
/* more coins deposited than issued! very bad */
report_emergency_by_count (issue,
- ds->num_issued,
+ ds->dcd.num_issued,
cnt,
- &ds->denom_risk);
+ &ds->dcd.denom_risk);
}
if (ds->report_emergency)
{
/* Value of coins deposited exceed value of coins
issued! Also very bad! */
report_emergency_by_amount (issue,
- &ds->denom_risk,
- &ds->denom_loss);
+ &ds->dcd.denom_risk,
+ &ds->dcd.denom_loss);
}
if (ds->in_db)
qs = TALER_ARL_adb->update_denomination_balance (TALER_ARL_adb->cls,
&denom_h,
- &ds->denom_balance,
- &ds->denom_loss,
- &ds->denom_risk,
- &ds->denom_recoup,
- ds->num_issued);
+ &ds->dcd);
else
qs = TALER_ARL_adb->insert_denomination_balance (TALER_ARL_adb->cls,
&denom_h,
- &ds->denom_balance,
- &ds->denom_loss,
- &ds->denom_risk,
- &ds->denom_recoup,
- ds->num_issued);
+ &ds->dcd);
}
}
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != qs)
@@ -983,8 +956,9 @@ withdraw_cb (void *cls,
(void) execution_date;
(void) amount_with_fee;
- GNUNET_assert (rowid >= ppc.last_withdraw_serial_id); /* should be monotonically increasing */
- ppc.last_withdraw_serial_id = rowid + 1;
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (coins_withdraw_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_withdraw_serial_id) = rowid + 1;
qs = TALER_ARL_get_denomination_info (denom_pub,
&issue,
@@ -1018,22 +992,22 @@ withdraw_cb (void *cls,
"Issued coin in denomination `%s' of total value %s\n",
GNUNET_h2s (&dh.hash),
TALER_amount2s (&issue->value));
- ds->num_issued++;
- TALER_ARL_amount_add (&ds->denom_balance,
- &ds->denom_balance,
- &issue->value);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' is %s\n",
GNUNET_h2s (&dh.hash),
- TALER_amount2s (&ds->denom_balance));
- TALER_ARL_amount_add (&total_escrow_balance,
- &total_escrow_balance,
+ TALER_amount2s (&ds->dcd.denom_balance));
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_escrowed),
+ &TALER_ARL_USE_AB (total_escrowed),
&issue->value);
- TALER_ARL_amount_add (&total_risk,
- &total_risk,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_balance_risk),
+ &TALER_ARL_USE_AB (coin_balance_risk),
&issue->value);
- TALER_ARL_amount_add (&ds->denom_risk,
- &ds->denom_risk,
+ ds->dcd.num_issued++;
+ TALER_ARL_amount_add (&ds->dcd.denom_balance,
+ &ds->dcd.denom_balance,
+ &issue->value);
+ TALER_ARL_amount_add (&ds->dcd.denom_risk,
+ &ds->dcd.denom_risk,
&issue->value);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -1187,8 +1161,8 @@ check_known_coin (
loss_potential),
GNUNET_JSON_pack_data_auto ("coin_pub",
coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
loss_potential);
}
TALER_denom_sig_free (&ci.denom_sig);
@@ -1199,7 +1173,7 @@ check_known_coin (
/**
* Update the denom balance in @a dso reducing it by
* @a amount_with_fee. If this is not possible, report
- * an emergency. Also updates the #total_escrow_balance.
+ * an emergency. Also updates the balance.
*
* @param dso denomination summary to update
* @param rowid responsible row (for logging)
@@ -1214,19 +1188,19 @@ reduce_denom_balance (struct DenominationSummary *dso,
if (TALER_ARL_SR_INVALID_NEGATIVE ==
TALER_ARL_amount_subtract_neg (&tmp,
- &dso->denom_balance,
+ &dso->dcd.denom_balance,
amount_with_fee))
{
- TALER_ARL_amount_add (&dso->denom_loss,
- &dso->denom_loss,
+ TALER_ARL_amount_add (&dso->dcd.denom_loss,
+ &dso->dcd.denom_loss,
amount_with_fee);
dso->report_emergency = true;
}
else
{
- dso->denom_balance = tmp;
+ dso->dcd.denom_balance = tmp;
}
- if (-1 == TALER_amount_cmp (&total_escrow_balance,
+ if (-1 == TALER_amount_cmp (&TALER_ARL_USE_AB (total_escrowed),
amount_with_fee))
{
/* This can theoretically happen if for example the exchange
@@ -1238,20 +1212,20 @@ reduce_denom_balance (struct DenominationSummary *dso,
report_amount_arithmetic_inconsistency (
"subtracting amount from escrow balance",
rowid,
- &total_escrow_balance,
+ &TALER_ARL_USE_AB (total_escrowed),
amount_with_fee,
0);
}
else
{
- TALER_ARL_amount_subtract (&total_escrow_balance,
- &total_escrow_balance,
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (total_escrowed),
+ &TALER_ARL_USE_AB (total_escrowed),
amount_with_fee);
}
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' is %s\n",
GNUNET_h2s (&dso->issue->denom_hash.hash),
- TALER_amount2s (&dso->denom_balance));
+ TALER_amount2s (&dso->dcd.denom_balance));
}
@@ -1291,8 +1265,9 @@ refresh_session_cb (void *cls,
enum GNUNET_DB_QueryStatus qs;
(void) noreveal_index;
- GNUNET_assert (rowid >= ppc.last_melt_serial_id); /* should be monotonically increasing */
- ppc.last_melt_serial_id = rowid + 1;
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (coins_melt_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_melt_serial_id) = rowid + 1;
qs = TALER_ARL_get_denomination_info (denom_pub,
&issue,
@@ -1351,8 +1326,8 @@ refresh_session_cb (void *cls,
amount_with_fee),
GNUNET_JSON_pack_data_auto ("coin_pub",
coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount_with_fee);
}
}
@@ -1385,7 +1360,7 @@ refresh_session_cb (void *cls,
/* This can legitimately happen if reveal was not yet called or only
with invalid data, even if the exchange is correctly operating. We
still report it. */
- TALER_ARL_report (report_refreshs_hanging,
+ TALER_ARL_report (report_refreshes_hanging,
GNUNET_JSON_PACK (
GNUNET_JSON_pack_uint64 ("row",
rowid),
@@ -1487,22 +1462,22 @@ refresh_session_cb (void *cls,
"Created fresh coin in denomination `%s' of value %s\n",
GNUNET_h2s (&ni->denom_hash.hash),
TALER_amount2s (&ni->value));
- dsi->num_issued++;
- TALER_ARL_amount_add (&dsi->denom_balance,
- &dsi->denom_balance,
+ dsi->dcd.num_issued++;
+ TALER_ARL_amount_add (&dsi->dcd.denom_balance,
+ &dsi->dcd.denom_balance,
&ni->value);
- TALER_ARL_amount_add (&dsi->denom_risk,
- &dsi->denom_risk,
+ TALER_ARL_amount_add (&dsi->dcd.denom_risk,
+ &dsi->dcd.denom_risk,
&ni->value);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' is %s\n",
GNUNET_h2s (&ni->denom_hash.hash),
- TALER_amount2s (&dsi->denom_balance));
- TALER_ARL_amount_add (&total_escrow_balance,
- &total_escrow_balance,
+ TALER_amount2s (&dsi->dcd.denom_balance));
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_escrowed),
+ &TALER_ARL_USE_AB (total_escrowed),
&ni->value);
- TALER_ARL_amount_add (&total_risk,
- &total_risk,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_balance_risk),
+ &TALER_ARL_USE_AB (coin_balance_risk),
&ni->value);
}
}
@@ -1527,8 +1502,8 @@ refresh_session_cb (void *cls,
}
/* update global melt fees */
- TALER_ARL_amount_add (&total_melt_fee_income,
- &total_melt_fee_income,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_melt_fee_revenue),
+ &TALER_ARL_USE_AB (coin_melt_fee_revenue),
&issue->fees.refresh);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -1563,8 +1538,9 @@ deposit_cb (void *cls,
(void) done;
(void) exchange_timestamp;
- GNUNET_assert (rowid >= ppc.last_deposit_serial_id); /* should be monotonically increasing */
- ppc.last_deposit_serial_id = rowid + 1;
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (coins_deposit_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_deposit_serial_id) = rowid + 1;
qs = TALER_ARL_get_denomination_info (denom_pub,
&issue,
@@ -1624,8 +1600,11 @@ deposit_cb (void *cls,
&issue->fees.deposit,
&h_wire,
&deposit->h_contract_terms,
+ deposit->no_wallet_data_hash
+ ? NULL
+ : &deposit->wallet_data_hash,
&deposit->coin.h_age_commitment,
- NULL /* FIXME-Oec: #7270: h_extensions! */,
+ &deposit->h_policy,
&h_denom_pub,
deposit->timestamp,
&deposit->merchant_pub,
@@ -1643,8 +1622,8 @@ deposit_cb (void *cls,
&deposit->amount_with_fee),
GNUNET_JSON_pack_data_auto ("coin_pub",
&deposit->coin.coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
&deposit->amount_with_fee);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -1675,8 +1654,8 @@ deposit_cb (void *cls,
}
/* update global deposit fees */
- TALER_ARL_amount_add (&total_deposit_fee_income,
- &total_deposit_fee_income,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_deposit_fee_revenue),
+ &TALER_ARL_USE_AB (coin_deposit_fee_revenue),
&issue->fees.deposit);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -1720,8 +1699,8 @@ refund_cb (void *cls,
struct TALER_Amount amount_without_fee;
enum GNUNET_DB_QueryStatus qs;
- GNUNET_assert (rowid >= ppc.last_refund_serial_id); /* should be monotonically increasing */
- ppc.last_refund_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (coins_refund_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_refund_serial_id) = rowid + 1;
qs = TALER_ARL_get_denomination_info (denom_pub,
&issue,
@@ -1760,8 +1739,8 @@ refund_cb (void *cls,
amount_with_fee),
GNUNET_JSON_pack_data_auto ("coin_pub",
coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount_with_fee);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -1801,31 +1780,31 @@ refund_cb (void *cls,
}
else
{
- TALER_ARL_amount_add (&ds->denom_balance,
- &ds->denom_balance,
+ TALER_ARL_amount_add (&ds->dcd.denom_balance,
+ &ds->dcd.denom_balance,
&amount_without_fee);
- TALER_ARL_amount_add (&ds->denom_risk,
- &ds->denom_risk,
+ TALER_ARL_amount_add (&ds->dcd.denom_risk,
+ &ds->dcd.denom_risk,
&amount_without_fee);
- TALER_ARL_amount_add (&total_escrow_balance,
- &total_escrow_balance,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_escrowed),
+ &TALER_ARL_USE_AB (total_escrowed),
&amount_without_fee);
- TALER_ARL_amount_add (&total_risk,
- &total_risk,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_balance_risk),
+ &TALER_ARL_USE_AB (coin_balance_risk),
&amount_without_fee);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' after refund is %s\n",
GNUNET_h2s (&issue->denom_hash.hash),
- TALER_amount2s (&ds->denom_balance));
+ TALER_amount2s (&ds->dcd.denom_balance));
}
/* update total refund fee balance */
- TALER_ARL_amount_add (&total_refund_fee_income,
- &total_refund_fee_income,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_refund_fee_revenue),
+ &TALER_ARL_USE_AB (coin_refund_fee_revenue),
&issue->fees.refund);
if (full_refund)
{
- TALER_ARL_amount_subtract (&total_deposit_fee_income,
- &total_deposit_fee_income,
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (coin_deposit_fee_revenue),
+ &TALER_ARL_USE_AB (coin_deposit_fee_revenue),
&issue->fees.deposit);
}
if (TALER_ARL_do_abort ())
@@ -1893,26 +1872,26 @@ purse_refund_coin_cb (
}
else
{
- TALER_ARL_amount_add (&ds->denom_balance,
- &ds->denom_balance,
+ TALER_ARL_amount_add (&ds->dcd.denom_balance,
+ &ds->dcd.denom_balance,
amount_with_fee);
- TALER_ARL_amount_add (&ds->denom_risk,
- &ds->denom_risk,
+ TALER_ARL_amount_add (&ds->dcd.denom_risk,
+ &ds->dcd.denom_risk,
amount_with_fee);
- TALER_ARL_amount_add (&total_escrow_balance,
- &total_escrow_balance,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_escrowed),
+ &TALER_ARL_USE_AB (total_escrowed),
amount_with_fee);
- TALER_ARL_amount_add (&total_risk,
- &total_risk,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_balance_risk),
+ &TALER_ARL_USE_AB (coin_balance_risk),
amount_with_fee);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' after purse-refund is %s\n",
GNUNET_h2s (&issue->denom_hash.hash),
- TALER_amount2s (&ds->denom_balance));
+ TALER_amount2s (&ds->dcd.denom_balance));
}
/* update total deposit fee balance */
- TALER_ARL_amount_subtract (&total_deposit_fee_income,
- &total_deposit_fee_income,
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (coin_deposit_fee_revenue),
+ &TALER_ARL_USE_AB (coin_deposit_fee_revenue),
&issue->fees.deposit);
return GNUNET_OK;
@@ -1927,18 +1906,25 @@ purse_refund_coin_cb (
* @param cls closure
* @param rowid unique serial ID for the refund in our DB
* @param purse_pub public key of the purse
+ * @param reserve_pub public key of the targeted reserve (ignored)
+ * @param val targeted amount to be in the reserve (ignored)
* @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
*/
static enum GNUNET_GenericReturnValue
purse_refund_cb (void *cls,
uint64_t rowid,
- const struct TALER_PurseContractPublicKeyP *purse_pub)
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_Amount *val)
{
struct CoinContext *cc = cls;
enum GNUNET_DB_QueryStatus qs;
- GNUNET_assert (rowid >= ppc.last_purse_refunds_serial_id); /* should be monotonically increasing */
- ppc.last_purse_refunds_serial_id = rowid + 1;
+ (void) val; /* irrelevant on refund */
+ (void) reserve_pub; /* irrelevant, may even be NULL */
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (coins_purse_refunds_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_purse_refunds_serial_id) = rowid + 1;
qs = TALER_ARL_edb->select_purse_deposits_by_purse (TALER_ARL_edb->cls,
purse_pub,
&purse_refund_coin_cb,
@@ -1976,13 +1962,23 @@ check_recoup (struct CoinContext *cc,
const struct TALER_CoinPublicInfo *coin,
const struct TALER_DenominationPublicKey *denom_pub,
const struct TALER_CoinSpendSignatureP *coin_sig,
- const union TALER_DenominationBlindingKeyP *coin_blind)
+ const union GNUNET_CRYPTO_BlindingSecretP *coin_blind)
{
struct DenominationSummary *ds;
enum GNUNET_DB_QueryStatus qs;
const struct TALER_EXCHANGEDB_DenominationKeyInformation *issue;
if (GNUNET_OK !=
+ TALER_wallet_recoup_verify (&coin->denom_pub_hash,
+ coin_blind,
+ &coin->coin_pub,
+ coin_sig))
+ {
+ report_row_inconsistency (operation,
+ rowid,
+ "recoup signature invalid");
+ }
+ if (GNUNET_OK !=
TALER_test_coin_valid (coin,
denom_pub))
{
@@ -1996,8 +1992,8 @@ check_recoup (struct CoinContext *cc,
amount),
GNUNET_JSON_pack_data_auto ("coin_pub",
&coin->denom_pub_hash)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount);
}
qs = TALER_ARL_get_denomination_info_by_hash (&coin->denom_pub_hash,
@@ -2057,15 +2053,15 @@ check_recoup (struct CoinContext *cc,
amount),
GNUNET_JSON_pack_data_auto ("coin_pub",
&coin->coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount);
}
- TALER_ARL_amount_add (&ds->denom_recoup,
- &ds->denom_recoup,
+ TALER_ARL_amount_add (&ds->dcd.recoup_loss,
+ &ds->dcd.recoup_loss,
amount);
- TALER_ARL_amount_add (&total_recoup_loss,
- &total_recoup_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_recoup_loss),
+ &TALER_ARL_USE_AB (total_recoup_loss),
amount);
}
if (TALER_ARL_do_abort ())
@@ -2097,12 +2093,12 @@ recoup_cb (void *cls,
const struct TALER_CoinPublicInfo *coin,
const struct TALER_DenominationPublicKey *denom_pub,
const struct TALER_CoinSpendSignatureP *coin_sig,
- const union TALER_DenominationBlindingKeyP *coin_blind)
+ const union GNUNET_CRYPTO_BlindingSecretP *coin_blind)
{
struct CoinContext *cc = cls;
- GNUNET_assert (rowid >= ppc.last_recoup_serial_id); /* should be monotonically increasing */
- ppc.last_recoup_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (coins_recoup_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_recoup_serial_id) = rowid + 1;
(void) timestamp;
(void) reserve_pub;
if (GNUNET_OK !=
@@ -2121,8 +2117,8 @@ recoup_cb (void *cls,
amount),
GNUNET_JSON_pack_data_auto ("coin_pub",
&coin->coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -2165,7 +2161,7 @@ recoup_refresh_cb (void *cls,
const struct TALER_CoinPublicInfo *coin,
const struct TALER_DenominationPublicKey *denom_pub,
const struct TALER_CoinSpendSignatureP *coin_sig,
- const union TALER_DenominationBlindingKeyP *coin_blind)
+ const union GNUNET_CRYPTO_BlindingSecretP *coin_blind)
{
struct CoinContext *cc = cls;
const struct TALER_EXCHANGEDB_DenominationKeyInformation *issue;
@@ -2173,8 +2169,8 @@ recoup_refresh_cb (void *cls,
(void) timestamp;
(void) old_coin_pub;
- GNUNET_assert (rowid >= ppc.last_recoup_refresh_serial_id); /* should be monotonically increasing */
- ppc.last_recoup_refresh_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (coins_recoup_refresh_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (coins_recoup_refresh_serial_id) = rowid + 1;
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Recoup-refresh amount is %s\n",
TALER_amount2s (amount));
@@ -2209,13 +2205,13 @@ recoup_refresh_cb (void *cls,
}
else
{
- TALER_ARL_amount_add (&dso->denom_balance,
- &dso->denom_balance,
+ TALER_ARL_amount_add (&dso->dcd.denom_balance,
+ &dso->dcd.denom_balance,
amount);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"New balance of denomination `%s' after refresh-recoup is %s\n",
GNUNET_h2s (&issue->denom_hash.hash),
- TALER_amount2s (&dso->denom_balance));
+ TALER_amount2s (&dso->dcd.denom_balance));
}
}
@@ -2235,8 +2231,8 @@ recoup_refresh_cb (void *cls,
amount),
GNUNET_JSON_pack_data_auto ("coin_pub",
&coin->coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
amount);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -2359,8 +2355,9 @@ purse_deposit_cb (
(void) auditor_balance;
(void) purse_total;
(void) reserve_pub;
- GNUNET_assert (rowid >= ppc.last_purse_deposits_serial_id);
- ppc.last_purse_deposits_serial_id = rowid + 1;
+ GNUNET_assert (rowid >=
+ TALER_ARL_USE_PP (coins_purse_deposits_serial_id));
+ TALER_ARL_USE_PP (coins_purse_deposits_serial_id) = rowid + 1;
qs = TALER_ARL_get_denomination_info (denom_pub,
&issue,
&dh);
@@ -2408,8 +2405,8 @@ purse_deposit_cb (
&deposit->amount),
GNUNET_JSON_pack_data_auto ("coin_pub",
&deposit->coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_irregular_loss),
+ &TALER_ARL_USE_AB (coin_irregular_loss),
&deposit->amount);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -2434,8 +2431,8 @@ purse_deposit_cb (
}
/* update global deposit fees */
- TALER_ARL_amount_add (&total_deposit_fee_income,
- &total_deposit_fee_income,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (coin_deposit_fee_revenue),
+ &TALER_ARL_USE_AB (coin_deposit_fee_revenue),
&issue->fees.deposit);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
@@ -2470,9 +2467,17 @@ analyze_coins (void *cls)
}
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Analyzing coins\n");
- qsp = TALER_ARL_adb->get_auditor_progress_coin (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppc);
+ qsp = TALER_ARL_adb->get_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_PP (coins_withdraw_serial_id),
+ TALER_ARL_GET_PP (coins_deposit_serial_id),
+ TALER_ARL_GET_PP (coins_melt_serial_id),
+ TALER_ARL_GET_PP (coins_refund_serial_id),
+ TALER_ARL_GET_PP (coins_recoup_serial_id),
+ TALER_ARL_GET_PP (coins_recoup_refresh_serial_id),
+ TALER_ARL_GET_PP (coins_purse_deposits_serial_id),
+ TALER_ARL_GET_PP (coins_purse_refunds_serial_id),
+ NULL);
if (0 > qsp)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsp);
@@ -2485,30 +2490,39 @@ analyze_coins (void *cls)
}
else
{
- ppc_start = ppc;
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Resuming coin audit at %llu/%llu/%llu/%llu/%llu/%llu\n",
- (unsigned long long) ppc.last_deposit_serial_id,
- (unsigned long long) ppc.last_melt_serial_id,
- (unsigned long long) ppc.last_refund_serial_id,
- (unsigned long long) ppc.last_withdraw_serial_id,
- (unsigned long long) ppc.last_recoup_refresh_serial_id,
- (unsigned long long) ppc.last_purse_deposits_serial_id);
+ GNUNET_log (
+ GNUNET_ERROR_TYPE_INFO,
+ "Resuming coin audit at %llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_deposit_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_melt_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_refund_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_withdraw_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_recoup_refresh_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_purse_deposits_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_purse_refunds_serial_id));
}
/* setup 'cc' */
cc.qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
cc.denom_summaries = GNUNET_CONTAINER_multihashmap_create (256,
GNUNET_NO);
- qsx = TALER_ARL_adb->get_balance_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_deposit_fee_income,
- &total_melt_fee_income,
- &total_refund_fee_income,
- &total_risk,
- &total_recoup_loss,
- &total_irregular_recoups);
+ qsx = TALER_ARL_adb->get_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_AB (coin_balance_risk),
+ TALER_ARL_GET_AB (total_escrowed),
+ TALER_ARL_GET_AB (coin_irregular_loss),
+ TALER_ARL_GET_AB (coin_melt_fee_revenue),
+ TALER_ARL_GET_AB (coin_deposit_fee_revenue),
+ TALER_ARL_GET_AB (coin_refund_fee_revenue),
+ TALER_ARL_GET_AB (total_recoup_loss),
+ NULL);
if (0 > qsx)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsx);
@@ -2519,7 +2533,7 @@ analyze_coins (void *cls)
if (0 >
(qs = TALER_ARL_edb->select_withdrawals_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_withdraw_serial_id,
+ TALER_ARL_USE_PP (coins_withdraw_serial_id),
&withdraw_cb,
&cc)) )
{
@@ -2533,7 +2547,7 @@ analyze_coins (void *cls)
if (0 >
(qs = TALER_ARL_edb->select_refunds_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_refund_serial_id,
+ TALER_ARL_USE_PP (coins_refund_serial_id),
&refund_cb,
&cc)))
{
@@ -2545,9 +2559,10 @@ analyze_coins (void *cls)
/* process purse_refunds */
if (0 >
- (qs = TALER_ARL_edb->select_purse_refunds_above_serial_id (
+ (qs = TALER_ARL_edb->select_purse_decisions_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_purse_refunds_serial_id,
+ TALER_ARL_USE_PP (coins_purse_refunds_serial_id),
+ true, /* only go for refunds! */
&purse_refund_cb,
&cc)))
{
@@ -2561,7 +2576,7 @@ analyze_coins (void *cls)
if (0 >
(qs = TALER_ARL_edb->select_recoup_refresh_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_recoup_refresh_serial_id,
+ TALER_ARL_USE_PP (coins_recoup_refresh_serial_id),
&recoup_refresh_cb,
&cc)))
{
@@ -2573,7 +2588,7 @@ analyze_coins (void *cls)
if (0 >
(qs = TALER_ARL_edb->select_recoup_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_recoup_serial_id,
+ TALER_ARL_USE_PP (coins_recoup_serial_id),
&recoup_cb,
&cc)))
{
@@ -2583,11 +2598,11 @@ analyze_coins (void *cls)
if (0 > cc.qs)
return cc.qs;
- /* process refreshs */
+ /* process refreshes */
if (0 >
(qs = TALER_ARL_edb->select_refreshes_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_melt_serial_id,
+ TALER_ARL_USE_PP (coins_melt_serial_id),
&refresh_session_cb,
&cc)))
{
@@ -2599,9 +2614,9 @@ analyze_coins (void *cls)
/* process deposits */
if (0 >
- (qs = TALER_ARL_edb->select_deposits_above_serial_id (
+ (qs = TALER_ARL_edb->select_coin_deposits_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_deposit_serial_id,
+ TALER_ARL_USE_PP (coins_deposit_serial_id),
&deposit_cb,
&cc)))
{
@@ -2615,7 +2630,7 @@ analyze_coins (void *cls)
if (0 >
(qs = TALER_ARL_edb->select_purse_deposits_above_serial_id (
TALER_ARL_edb->cls,
- ppc.last_purse_deposits_serial_id,
+ TALER_ARL_USE_PP (coins_purse_deposits_serial_id),
&purse_deposit_cb,
&cc)))
{
@@ -2637,25 +2652,27 @@ analyze_coins (void *cls)
return cc.qs;
}
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsx)
- qs = TALER_ARL_adb->update_balance_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_deposit_fee_income,
- &total_melt_fee_income,
- &total_refund_fee_income,
- &total_risk,
- &total_recoup_loss,
- &total_irregular_recoups);
+ qs = TALER_ARL_adb->update_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (coin_balance_risk),
+ TALER_ARL_SET_AB (total_escrowed),
+ TALER_ARL_SET_AB (coin_irregular_loss),
+ TALER_ARL_SET_AB (coin_melt_fee_revenue),
+ TALER_ARL_SET_AB (coin_deposit_fee_revenue),
+ TALER_ARL_SET_AB (coin_refund_fee_revenue),
+ TALER_ARL_SET_AB (total_recoup_loss),
+ NULL);
else
- qs = TALER_ARL_adb->insert_balance_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_deposit_fee_income,
- &total_melt_fee_income,
- &total_refund_fee_income,
- &total_risk,
- &total_recoup_loss,
- &total_irregular_recoups);
+ qs = TALER_ARL_adb->insert_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (coin_balance_risk),
+ TALER_ARL_SET_AB (total_escrowed),
+ TALER_ARL_SET_AB (coin_irregular_loss),
+ TALER_ARL_SET_AB (coin_melt_fee_revenue),
+ TALER_ARL_SET_AB (coin_deposit_fee_revenue),
+ TALER_ARL_SET_AB (coin_refund_fee_revenue),
+ TALER_ARL_SET_AB (total_recoup_loss),
+ NULL);
if (0 >= qs)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
@@ -2663,13 +2680,29 @@ analyze_coins (void *cls)
}
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsp)
- qs = TALER_ARL_adb->update_auditor_progress_coin (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppc);
+ qs = TALER_ARL_adb->update_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (coins_withdraw_serial_id),
+ TALER_ARL_SET_PP (coins_deposit_serial_id),
+ TALER_ARL_SET_PP (coins_melt_serial_id),
+ TALER_ARL_SET_PP (coins_refund_serial_id),
+ TALER_ARL_SET_PP (coins_recoup_serial_id),
+ TALER_ARL_SET_PP (coins_recoup_refresh_serial_id),
+ TALER_ARL_SET_PP (coins_purse_deposits_serial_id),
+ TALER_ARL_SET_PP (coins_purse_refunds_serial_id),
+ NULL);
else
- qs = TALER_ARL_adb->insert_auditor_progress_coin (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppc);
+ qs = TALER_ARL_adb->insert_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (coins_withdraw_serial_id),
+ TALER_ARL_SET_PP (coins_deposit_serial_id),
+ TALER_ARL_SET_PP (coins_melt_serial_id),
+ TALER_ARL_SET_PP (coins_refund_serial_id),
+ TALER_ARL_SET_PP (coins_recoup_serial_id),
+ TALER_ARL_SET_PP (coins_recoup_refresh_serial_id),
+ TALER_ARL_SET_PP (coins_purse_deposits_serial_id),
+ TALER_ARL_SET_PP (coins_purse_refunds_serial_id),
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -2678,13 +2711,17 @@ analyze_coins (void *cls)
return qs;
}
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Concluded coin audit step at %llu/%llu/%llu/%llu/%llu/%llu\n",
- (unsigned long long) ppc.last_deposit_serial_id,
- (unsigned long long) ppc.last_melt_serial_id,
- (unsigned long long) ppc.last_refund_serial_id,
- (unsigned long long) ppc.last_withdraw_serial_id,
- (unsigned long long) ppc.last_recoup_refresh_serial_id,
- (unsigned long long) ppc.last_purse_deposits_serial_id);
+ "Concluded coin audit step at %llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (coins_deposit_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (coins_melt_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (coins_refund_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (coins_withdraw_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_recoup_refresh_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_purse_deposits_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ coins_purse_refunds_serial_id));
return qs;
}
@@ -2730,25 +2767,29 @@ run (void *cls,
&reported_emergency_loss_by_count));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_escrow_balance));
+ &TALER_ARL_USE_AB (total_escrowed)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_risk));
+ &TALER_ARL_USE_AB (
+ coin_deposit_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_recoup_loss));
+ &TALER_ARL_USE_AB (
+ coin_melt_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_irregular_recoups));
+ &TALER_ARL_USE_AB (
+ coin_refund_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_deposit_fee_income));
+ &TALER_ARL_USE_AB (coin_balance_risk)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_melt_fee_income));
+ &TALER_ARL_USE_AB (total_recoup_loss)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_refund_fee_income));
+ &TALER_ARL_USE_AB (
+ coin_irregular_loss)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_arithmetic_delta_plus));
@@ -2757,9 +2798,6 @@ run (void *cls,
&total_arithmetic_delta_minus));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_bad_sig_loss));
- GNUNET_assert (GNUNET_OK ==
- TALER_amount_set_zero (TALER_ARL_currency,
&total_refresh_hanging));
GNUNET_assert (NULL !=
(report_emergencies = json_array ()));
@@ -2775,7 +2813,7 @@ run (void *cls,
GNUNET_assert (NULL !=
(report_bad_sig_losses = json_array ()));
GNUNET_assert (NULL !=
- (report_refreshs_hanging = json_array ()));
+ (report_refreshes_hanging = json_array ()));
if (GNUNET_OK !=
TALER_ARL_setup_sessions_and_run (&analyze_coins,
NULL))
@@ -2788,27 +2826,26 @@ run (void *cls,
TALER_ARL_done (
GNUNET_JSON_PACK (
TALER_JSON_pack_amount ("total_escrow_balance",
- &total_escrow_balance),
- TALER_JSON_pack_amount ("total_active_risk",
- &total_risk),
+ &TALER_ARL_USE_AB (total_escrowed)),
TALER_JSON_pack_amount ("total_deposit_fee_income",
- &total_deposit_fee_income),
+ &TALER_ARL_USE_AB (coin_deposit_fee_revenue)),
TALER_JSON_pack_amount ("total_melt_fee_income",
- &total_melt_fee_income),
+ &TALER_ARL_USE_AB (coin_melt_fee_revenue)),
TALER_JSON_pack_amount ("total_refund_fee_income",
- &total_refund_fee_income),
+ &TALER_ARL_USE_AB (coin_refund_fee_revenue)),
+ TALER_JSON_pack_amount ("total_active_risk",
+ &TALER_ARL_USE_AB (coin_balance_risk)),
+ TALER_JSON_pack_amount ("total_recoup_loss",
+ &TALER_ARL_USE_AB (total_recoup_loss)),
+ /* Tested in test-auditor.sh #4/#5/#6/#13/#26 */
+ TALER_JSON_pack_amount ("irregular_loss",
+ &TALER_ARL_USE_AB (coin_irregular_loss)),
/* Tested in test-auditor.sh #18 */
GNUNET_JSON_pack_array_steal ("emergencies",
report_emergencies),
/* Tested in test-auditor.sh #18 */
TALER_JSON_pack_amount ("emergencies_risk_by_amount",
&reported_emergency_risk_by_amount),
- /* Tested in test-auditor.sh #4/#5/#6/#13/#26 */
- GNUNET_JSON_pack_array_steal ("bad_sig_losses",
- report_bad_sig_losses),
- /* Tested in test-auditor.sh #4/#5/#6/#13/#26 */
- TALER_JSON_pack_amount ("total_bad_sig_loss",
- &total_bad_sig_loss),
/* Tested in test-auditor.sh #31 */
GNUNET_JSON_pack_array_steal ("row_inconsistencies",
report_row_inconsistencies),
@@ -2821,11 +2858,11 @@ run (void *cls,
&total_arithmetic_delta_minus),
TALER_JSON_pack_amount ("total_refresh_hanging",
&total_refresh_hanging),
+ GNUNET_JSON_pack_array_steal ("bad_sig_losses",
+ report_bad_sig_losses),
/* Tested in test-auditor.sh #12 */
GNUNET_JSON_pack_array_steal ("refresh_hanging",
- report_refreshs_hanging),
- TALER_JSON_pack_amount ("total_recoup_loss",
- &total_recoup_loss),
+ report_refreshes_hanging),
/* Tested in test-auditor.sh #18 */
GNUNET_JSON_pack_array_steal ("emergencies_by_count",
report_emergencies_by_count),
@@ -2839,45 +2876,48 @@ run (void *cls,
TALER_JSON_pack_amount ("emergencies_loss_by_count",
&reported_emergency_loss_by_count),
GNUNET_JSON_pack_uint64 ("start_ppc_withdraw_serial_id",
- ppc_start.last_withdraw_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_deposit_serial_id",
- ppc_start.last_deposit_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_melt_serial_id",
- ppc_start.last_melt_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_refund_serial_id",
- ppc_start.last_refund_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_recoup_serial_id",
- ppc_start.last_recoup_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_recoup_refresh_serial_id",
- ppc_start.last_recoup_refresh_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_purse_deposits_serial_id",
- ppc_start.last_purse_deposits_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("start_ppc_purse_refunds_serial_id",
- ppc_start.last_purse_refunds_serial_id),
+ 0 /* not implemented */),
GNUNET_JSON_pack_uint64 ("end_ppc_withdraw_serial_id",
- ppc.last_withdraw_serial_id),
+ TALER_ARL_USE_PP (coins_withdraw_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_deposit_serial_id",
- ppc.last_deposit_serial_id),
+ TALER_ARL_USE_PP (coins_deposit_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_melt_serial_id",
- ppc.last_melt_serial_id),
+ TALER_ARL_USE_PP (coins_melt_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_refund_serial_id",
- ppc.last_refund_serial_id),
+ TALER_ARL_USE_PP (coins_refund_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_recoup_serial_id",
- ppc.last_recoup_serial_id),
+ TALER_ARL_USE_PP (coins_recoup_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_recoup_refresh_serial_id",
- ppc.last_recoup_refresh_serial_id),
+ TALER_ARL_USE_PP (
+ coins_recoup_refresh_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_purse_deposits_serial_id",
- ppc.last_purse_deposits_serial_id),
+ TALER_ARL_USE_PP (
+ coins_purse_deposits_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppc_purse_refunds_serial_id",
- ppc.last_purse_refunds_serial_id),
- TALER_JSON_pack_time_abs_human ("auditor_start_time",
- start_time),
+ TALER_ARL_USE_PP (
+ coins_purse_refunds_serial_id)),
+ TALER_JSON_pack_time_abs_human (
+ "auditor_start_time",
+ start_time),
TALER_JSON_pack_time_abs_human ("auditor_end_time",
GNUNET_TIME_absolute_get ()),
- TALER_JSON_pack_amount ("total_irregular_recoups",
- &total_irregular_recoups),
- GNUNET_JSON_pack_array_steal ("unsigned_denominations",
- report_denominations_without_sigs)));
+ GNUNET_JSON_pack_array_steal (
+ "unsigned_denominations",
+ report_denominations_without_sigs)));
}
@@ -2897,11 +2937,10 @@ main (int argc,
"internal",
"perform checks only applicable for exchange-internal audits",
&internal_checks),
- GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &TALER_ARL_master_pub),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
GNUNET_GETOPT_option_timetravel ('T',
"timetravel"),
GNUNET_GETOPT_OPTION_END
diff --git a/src/auditor/taler-helper-auditor-deposits.c b/src/auditor/taler-helper-auditor-deposits.c
index c08727d37..3dbce0183 100644
--- a/src/auditor/taler-helper-auditor-deposits.c
+++ b/src/auditor/taler-helper-auditor-deposits.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2016-2021 Taler Systems SA
+ Copyright (C) 2016-2023 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero Public License as published by the Free Software
@@ -17,6 +17,7 @@
* @file auditor/taler-helper-auditor-deposits.c
* @brief audits an exchange database for deposit confirmation consistency
* @author Christian Grothoff
+ * @author Nic Eigel
*
* We simply check that all of the deposit confirmations reported to us
* by merchants were also reported to us by the exchange.
@@ -29,7 +30,29 @@
#include "taler_bank_service.h"
#include "taler_signatures.h"
#include "report-lib.h"
+#include "taler_dbevents.h"
+#include <jansson.h>
+/*
+--
+-- SELECT serial_id,h_contract_terms,h_wire,merchant_pub ...
+-- FROM auditor.auditor_deposit_confirmations
+-- WHERE NOT ancient
+-- ORDER BY exchange_timestamp ASC;
+-- SELECT 1
+- FROM exchange.deposits dep
+ WHERE ($RESULT.contract_terms = dep.h_contract_terms) AND ($RESULT.h_wire = dep.h_wire) AND ...);
+-- IF FOUND
+-- DELETE FROM auditor.auditor_deposit_confirmations
+-- WHERE serial_id = $RESULT.serial_id;
+-- SELECT exchange_timestamp AS latest
+-- FROM exchange.deposits ORDER BY exchange_timestamp DESC;
+-- latest -= 1 hour; // time is not exactly monotonic...
+-- UPDATE auditor.deposit_confirmations
+-- SET ancient=TRUE
+-- WHERE exchange_timestamp < latest
+-- AND NOT ancient;
+*/
/**
* Return value from main().
@@ -37,6 +60,14 @@
static int global_ret;
/**
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
+ */
+static int test_mode;
+
+/**
* Array of reports about missing deposit confirmations.
*/
static json_t *report_deposit_confirmation_inconsistencies;
@@ -56,6 +87,18 @@ static struct TALER_Amount total_missed_deposit_confirmations;
*/
static int internal_checks;
+static struct GNUNET_DB_EventHandler *eh;
+
+/**
+ * Our database plugin.
+ */
+static struct TALER_AUDITORDB_Plugin *db_plugin;
+
+/**
+ * The auditors's configuration.
+ */
+static const struct GNUNET_CONFIGURATION_Handle *cfg;
+
/**
* Closure for #test_dc.
*/
@@ -92,7 +135,6 @@ struct DepositConfirmationContext
};
-
/**
* Given a deposit confirmation from #TALER_ARL_adb, check that it is also
* in #TALER_ARL_edb. Update the deposit confirmation context accordingly.
@@ -108,8 +150,10 @@ test_dc (void *cls,
const struct TALER_AUDITORDB_DepositConfirmation *dc)
{
struct DepositConfirmationContext *dcc = cls;
+ bool missing = false;
dcc->last_seen_coin_serial = serial_id;
+ for (unsigned int i = 0; i < dc->num_coins; i++)
{
enum GNUNET_DB_QueryStatus qs;
struct GNUNET_TIME_Timestamp exchange_timestamp;
@@ -118,20 +162,12 @@ test_dc (void *cls,
qs = TALER_ARL_edb->have_deposit2 (TALER_ARL_edb->cls,
&dc->h_contract_terms,
&dc->h_wire,
- &dc->coin_pub,
+ &dc->coin_pubs[i],
&dc->merchant,
dc->refund_deadline,
&deposit_fee,
&exchange_timestamp);
- if (qs > 0)
- {
- GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
- "Found deposit %s in exchange database\n",
- GNUNET_h2s (&dc->h_contract_terms.hash));
- if (TALER_ARL_do_abort ())
- return GNUNET_SYSERR;
- return GNUNET_OK; /* found, all good */
- }
+ missing |= (0 == qs);
if (qs < 0)
{
GNUNET_break (0); /* DB error, complain */
@@ -139,6 +175,15 @@ test_dc (void *cls,
return GNUNET_SYSERR;
}
}
+ if (! missing)
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Found deposit %s in exchange database\n",
+ GNUNET_h2s (&dc->h_contract_terms.hash));
+ if (TALER_ARL_do_abort ())
+ return GNUNET_SYSERR;
+ return GNUNET_OK; /* all coins found, all good */
+ }
/* deposit confirmation missing! report! */
TALER_ARL_report (
report_deposit_confirmation_inconsistencies,
@@ -146,7 +191,7 @@ test_dc (void *cls,
TALER_JSON_pack_time_abs_human ("timestamp",
dc->exchange_timestamp.abs_time),
TALER_JSON_pack_amount ("amount",
- &dc->amount_without_fee),
+ &dc->total_without_fee),
GNUNET_JSON_pack_uint64 ("rowid",
serial_id),
GNUNET_JSON_pack_data_auto ("account",
@@ -156,7 +201,7 @@ test_dc (void *cls,
dcc->missed_count++;
TALER_ARL_amount_add (&dcc->missed_amount,
&dcc->missed_amount,
- &dc->amount_without_fee);
+ &dc->total_without_fee);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
return GNUNET_OK;
@@ -173,20 +218,18 @@ test_dc (void *cls,
static enum GNUNET_DB_QueryStatus
analyze_deposit_confirmations (void *cls)
{
- struct TALER_AUDITORDB_ProgressPointDepositConfirmation ppdc;
+ TALER_ARL_DEF_PP (deposit_confirmation_serial_id);
struct DepositConfirmationContext dcc;
enum GNUNET_DB_QueryStatus qs;
enum GNUNET_DB_QueryStatus qsx;
enum GNUNET_DB_QueryStatus qsp;
-
(void) cls;
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Analyzing deposit confirmations\n");
- ppdc.last_deposit_confirmation_serial_id = 0;
- qsp = TALER_ARL_adb->get_auditor_progress_deposit_confirmation (
+
+ qsp = TALER_ARL_adb->get_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppdc);
+ TALER_ARL_GET_PP (deposit_confirmation_serial_id),
+ NULL);
+
if (0 > qsp)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsp);
@@ -201,7 +244,8 @@ analyze_deposit_confirmations (void *cls)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Resuming deposit confirmation audit at %llu\n",
- (unsigned long long) ppdc.last_deposit_confirmation_serial_id);
+ (unsigned long long) TALER_ARL_USE_PP (
+ deposit_confirmation_serial_id));
}
/* setup 'cc' */
@@ -211,10 +255,13 @@ analyze_deposit_confirmations (void *cls)
dcc.qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
dcc.missed_count = 0LLU;
dcc.first_missed_coin_serial = UINT64_MAX;
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "lastdepconfserialid %lu\n",
+ TALER_ARL_USE_PP (deposit_confirmation_serial_id));
qsx = TALER_ARL_adb->get_deposit_confirmations (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- ppdc.last_deposit_confirmation_serial_id,
+ TALER_ARL_USE_PP (deposit_confirmation_serial_id),
+ true, /* return suppressed */
&test_dc,
&dcc);
if (0 > qsx)
@@ -225,28 +272,30 @@ analyze_deposit_confirmations (void *cls)
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Analyzed %d deposit confirmations (above serial ID %llu)\n",
(int) qsx,
- (unsigned long long) ppdc.last_deposit_confirmation_serial_id);
+ (unsigned long long) TALER_ARL_USE_PP (
+ deposit_confirmation_serial_id));
if (0 > dcc.qs)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == dcc.qs);
return dcc.qs;
}
- if (UINT64_MAX == dcc.first_missed_coin_serial)
- ppdc.last_deposit_confirmation_serial_id = dcc.last_seen_coin_serial;
- else
- ppdc.last_deposit_confirmation_serial_id = dcc.first_missed_coin_serial - 1;
+ /* if (UINT64_MAX == dcc.first_missed_coin_serial)
+ ppdc.last_deposit_confirmation_serial_id = dcc.last_seen_coin_serial;
+ else
+ ppdc.last_deposit_confirmation_serial_id = dcc.first_missed_coin_serial - 1;
+ */
/* sync 'cc' back to disk */
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsp)
- qs = TALER_ARL_adb->update_auditor_progress_deposit_confirmation (
+ qs = TALER_ARL_adb->update_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppdc);
+ TALER_ARL_SET_PP (deposit_confirmation_serial_id),
+ NULL);
else
- qs = TALER_ARL_adb->insert_auditor_progress_deposit_confirmation (
+ qs = TALER_ARL_adb->insert_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppdc);
+ TALER_ARL_SET_PP (deposit_confirmation_serial_id),
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -254,17 +303,90 @@ analyze_deposit_confirmations (void *cls)
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
+
number_missed_deposit_confirmations = (json_int_t) dcc.missed_count;
total_missed_deposit_confirmations = dcc.missed_amount;
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Concluded deposit confirmation audit step at %llu\n",
- (unsigned long long) ppdc.last_deposit_confirmation_serial_id);
+ (unsigned long long) TALER_ARL_USE_PP (
+ deposit_confirmation_serial_id));
return qs;
}
/**
+ * Function called on events received from Postgres.
+ *
+ * @param cls closure, NULL
+ * @param extra additional event data provided
+ * @param extra_size number of bytes in @a extra
+ */
+static void
+db_notify (void *cls,
+ const void *extra,
+ size_t extra_size)
+{
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Received notification for new deposit_confirmation\n");
+
+ (void) cls;
+ (void) extra;
+ (void) extra_size;
+
+ if (NULL ==
+ (db_plugin = TALER_AUDITORDB_plugin_load (cfg)))
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Failed to initialize DB subsystem\n");
+ GNUNET_SCHEDULER_shutdown ();
+ return;
+ }
+ GNUNET_assert (NULL !=
+ (report_deposit_confirmation_inconsistencies = json_array ()));
+
+ if (GNUNET_OK !=
+ TALER_ARL_setup_sessions_and_run (&analyze_deposit_confirmations,
+ NULL))
+ {
+ global_ret = EXIT_FAILURE;
+ return;
+ }
+
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Deposit audit complete\n");
+ TALER_ARL_done (
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_array_steal ("deposit_confirmation_inconsistencies",
+ report_deposit_confirmation_inconsistencies),
+ GNUNET_JSON_pack_uint64 ("missing_deposit_confirmation_count",
+ number_missed_deposit_confirmations),
+ TALER_JSON_pack_amount ("missing_deposit_confirmation_total",
+ &total_missed_deposit_confirmations),
+ TALER_JSON_pack_time_abs_human ("auditor_start_time",
+ start_time),
+ TALER_JSON_pack_time_abs_human ("auditor_end_time",
+ GNUNET_TIME_absolute_get ())));
+}
+
+
+/**
+ * Function called on shutdown.
+ */
+static void
+do_shutdown (void *cls)
+{
+ (void) cls;
+
+ db_plugin->event_listen_cancel (eh);
+ eh = NULL;
+ TALER_AUDITORDB_plugin_unload (db_plugin);
+ db_plugin = NULL;
+ TALER_ARL_done (NULL);
+}
+
+
+/**
* Main function that will be run.
*
* @param cls closure
@@ -281,6 +403,10 @@ run (void *cls,
(void) cls;
(void) args;
(void) cfgfile;
+ cfg = c;
+
+ GNUNET_SCHEDULER_add_shutdown (&do_shutdown,
+ NULL);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Launching deposit auditor\n");
if (GNUNET_OK !=
@@ -289,6 +415,34 @@ run (void *cls,
global_ret = EXIT_FAILURE;
return;
}
+
+ if (NULL ==
+ (db_plugin = TALER_AUDITORDB_plugin_load (cfg)))
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Failed to initialize DB subsystem\n");
+ GNUNET_SCHEDULER_shutdown ();
+ return;
+ }
+ if (GNUNET_OK !=
+ db_plugin->preflight (db_plugin->cls))
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Failed to connect to database\n");
+ GNUNET_SCHEDULER_shutdown ();
+ return;
+ }
+
+ struct GNUNET_DB_EventHeaderP es = {
+ .size = htons (sizeof (es)),
+ .type = htons (TALER_DBEVENT_EXCHANGE_AUDITOR_NEW_DEPOSIT_CONFIRMATION)
+ };
+ eh = db_plugin->event_listen (db_plugin->cls,
+ &es,
+ GNUNET_TIME_UNIT_FOREVER_REL,
+ &db_notify,
+ NULL);
+
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Starting deposit audit\n");
GNUNET_assert (NULL !=
@@ -333,11 +487,10 @@ main (int argc,
"internal",
"perform checks only applicable for exchange-internal audits",
&internal_checks),
- GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &TALER_ARL_master_pub),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
GNUNET_GETOPT_option_timetravel ('T',
"timetravel"),
GNUNET_GETOPT_OPTION_END
diff --git a/src/auditor/taler-helper-auditor-purses.c b/src/auditor/taler-helper-auditor-purses.c
new file mode 100644
index 000000000..967ac13a7
--- /dev/null
+++ b/src/auditor/taler-helper-auditor-purses.c
@@ -0,0 +1,1451 @@
+/*
+ This file is part of TALER
+ Copyright (C) 2016-2024 Taler Systems SA
+
+ TALER is free software; you can redistribute it and/or modify it under the
+ terms of the GNU Affero Public License as published by the Free Software
+ Foundation; either version 3, or (at your option) any later version.
+
+ TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+ A PARTICULAR PURPOSE. See the GNU Affero Public License for more details.
+
+ You should have received a copy of the GNU Affero Public License along with
+ TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
+*/
+/**
+ * @file auditor/taler-helper-auditor-purses.c
+ * @brief audits the purses of an exchange database
+ * @author Christian Grothoff
+ */
+#include "platform.h"
+#include <gnunet/gnunet_util_lib.h>
+#include "taler_auditordb_plugin.h"
+#include "taler_exchangedb_lib.h"
+#include "taler_json_lib.h"
+#include "taler_bank_service.h"
+#include "taler_signatures.h"
+#include "report-lib.h"
+
+
+/**
+ * Use a 1 day grace period to deal with clocks not being perfectly synchronized.
+ */
+#define EXPIRATION_GRACE_PERIOD GNUNET_TIME_UNIT_DAYS
+
+/**
+ * Return value from main().
+ */
+static int global_ret;
+
+/**
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
+ */
+static int test_mode;
+
+/**
+ * Checkpointing our progress for purses.
+ */
+static TALER_ARL_DEF_PP (purse_account_merge_serial_id);
+static TALER_ARL_DEF_PP (purse_decision_serial_id);
+static TALER_ARL_DEF_PP (purse_deposits_serial_id);
+static TALER_ARL_DEF_PP (purse_merges_serial_id);
+static TALER_ARL_DEF_PP (purse_request_serial_id);
+static TALER_ARL_DEF_PP (purse_open_counter);
+static TALER_ARL_DEF_AB (purse_global_balance);
+
+/**
+ * Array of reports about row inconsistencies.
+ */
+static json_t *report_row_inconsistencies;
+
+/**
+ * Array of reports about purse balance insufficient inconsistencies.
+ */
+static json_t *report_purse_balance_insufficient_inconsistencies;
+
+/**
+ * Total amount purses were merged with insufficient balance.
+ */
+static struct TALER_Amount total_balance_insufficient_loss;
+
+/**
+ * Total amount purse decisions are delayed past deadline.
+ */
+static struct TALER_Amount total_delayed_decisions;
+
+/**
+ * Array of reports about purses's not being closed inconsistencies.
+ */
+static json_t *report_purse_not_closed_inconsistencies;
+
+/**
+ * Total amount affected by purses not having been closed on time.
+ */
+static struct TALER_Amount total_balance_purse_not_closed;
+
+/**
+ * Report about amount calculation differences (causing profit
+ * or loss at the exchange).
+ */
+static json_t *report_amount_arithmetic_inconsistencies;
+
+/**
+ * Profits the exchange made by bad amount calculations.
+ */
+static struct TALER_Amount total_arithmetic_delta_plus;
+
+/**
+ * Losses the exchange made by bad amount calculations.
+ */
+static struct TALER_Amount total_arithmetic_delta_minus;
+
+/**
+ * Array of reports about coin operations with bad signatures.
+ */
+static json_t *report_bad_sig_losses;
+
+/**
+ * Total amount lost by operations for which signatures were invalid.
+ */
+static struct TALER_Amount total_bad_sig_loss;
+
+/**
+ * Should we run checks that only work for exchange-internal audits?
+ */
+static int internal_checks;
+
+/* ***************************** Report logic **************************** */
+
+
+/**
+ * Report a (serious) inconsistency in the exchange's database with
+ * respect to calculations involving amounts.
+ *
+ * @param operation what operation had the inconsistency
+ * @param rowid affected row, 0 if row is missing
+ * @param exchange amount calculated by exchange
+ * @param auditor amount calculated by auditor
+ * @param profitable 1 if @a exchange being larger than @a auditor is
+ * profitable for the exchange for this operation,
+ * -1 if @a exchange being smaller than @a auditor is
+ * profitable for the exchange, and 0 if it is unclear
+ */
+static void
+report_amount_arithmetic_inconsistency (
+ const char *operation,
+ uint64_t rowid,
+ const struct TALER_Amount *exchange,
+ const struct TALER_Amount *auditor,
+ int profitable)
+{
+ struct TALER_Amount delta;
+ struct TALER_Amount *target;
+
+ if (0 < TALER_amount_cmp (exchange,
+ auditor))
+ {
+ /* exchange > auditor */
+ TALER_ARL_amount_subtract (&delta,
+ exchange,
+ auditor);
+ }
+ else
+ {
+ /* auditor < exchange */
+ profitable = -profitable;
+ TALER_ARL_amount_subtract (&delta,
+ auditor,
+ exchange);
+ }
+ TALER_ARL_report (report_amount_arithmetic_inconsistencies,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ operation),
+ GNUNET_JSON_pack_uint64 ("rowid",
+ rowid),
+ TALER_JSON_pack_amount ("exchange",
+ exchange),
+ TALER_JSON_pack_amount ("auditor",
+ auditor),
+ GNUNET_JSON_pack_int64 ("profitable",
+ profitable)));
+ if (0 != profitable)
+ {
+ target = (1 == profitable)
+ ? &total_arithmetic_delta_plus
+ : &total_arithmetic_delta_minus;
+ TALER_ARL_amount_add (target,
+ target,
+ &delta);
+ }
+}
+
+
+/**
+ * Report a (serious) inconsistency in the exchange's database.
+ *
+ * @param table affected table
+ * @param rowid affected row, 0 if row is missing
+ * @param diagnostic message explaining the problem
+ */
+static void
+report_row_inconsistency (const char *table,
+ uint64_t rowid,
+ const char *diagnostic)
+{
+ TALER_ARL_report (report_row_inconsistencies,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("table",
+ table),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ GNUNET_JSON_pack_string ("diagnostic",
+ diagnostic)));
+}
+
+
+/**
+ * Obtain the purse fee for a purse created at @a time.
+ *
+ * @param atime when was the purse created
+ * @param[out] fee set to the purse fee
+ * @return #GNUNET_OK on success
+ */
+static enum GNUNET_GenericReturnValue
+get_purse_fee (struct GNUNET_TIME_Timestamp atime,
+ struct TALER_Amount *fee)
+{
+ struct TALER_MasterSignatureP master_sig;
+ struct GNUNET_TIME_Timestamp start_date;
+ struct GNUNET_TIME_Timestamp end_date;
+ struct TALER_GlobalFeeSet fees;
+ struct GNUNET_TIME_Relative ptimeout;
+ struct GNUNET_TIME_Relative hexp;
+ uint32_t pacl;
+
+ if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT !=
+ TALER_ARL_edb->get_global_fee (TALER_ARL_edb->cls,
+ atime,
+ &start_date,
+ &end_date,
+ &fees,
+ &ptimeout,
+ &hexp,
+ &pacl,
+ &master_sig))
+ {
+ char *diag;
+
+ GNUNET_asprintf (&diag,
+ "purse fee unavailable at %s\n",
+ GNUNET_TIME_timestamp2s (atime));
+ report_row_inconsistency ("purse-fee",
+ atime.abs_time.abs_value_us,
+ diag);
+ GNUNET_free (diag);
+ return GNUNET_SYSERR;
+ }
+ *fee = fees.purse;
+ return GNUNET_OK;
+}
+
+
+/* ***************************** Analyze purses ************************ */
+/* This logic checks the purses_requests, purse_deposits,
+ purse_refunds, purse_merges and account_merges */
+
+/**
+ * Summary data we keep per purse.
+ */
+struct PurseSummary
+{
+ /**
+ * Public key of the purse.
+ * Always set when the struct is first initialized.
+ */
+ struct TALER_PurseContractPublicKeyP purse_pub;
+
+ /**
+ * Balance of the purse from deposits (includes purse fee, excludes deposit
+ * fees), as calculated by auditor.
+ */
+ struct TALER_Amount balance;
+
+ /**
+ * Expected value of the purse, excludes purse fee.
+ */
+ struct TALER_Amount total_value;
+
+ /**
+ * Purse balance according to exchange DB.
+ */
+ struct TALER_Amount exchange_balance;
+
+ /**
+ * Contract terms of the purse.
+ */
+ struct TALER_PrivateContractHashP h_contract_terms;
+
+ /**
+ * Merge timestamp (as per exchange DB).
+ */
+ struct GNUNET_TIME_Timestamp merge_timestamp;
+
+ /**
+ * Purse creation date. This is when the merge
+ * fee is applied.
+ */
+ struct GNUNET_TIME_Timestamp creation_date;
+
+ /**
+ * Purse expiration date.
+ */
+ struct GNUNET_TIME_Timestamp expiration_date;
+
+ /**
+ * Did we have a previous purse info? Used to decide between UPDATE and
+ * INSERT later. Initialized in #load_auditor_purse_summary().
+ */
+ bool had_pi;
+
+ /**
+ * Was the purse deleted? FIXME: Not yet handled (do we need to? purse
+ * might just appear as expired eventually; but in the meantime, exchange
+ * may seem to have refunded the coins for no good reason...), also we do
+ * not yet check the deletion signature.
+ */
+ bool purse_deleted;
+
+ /**
+ * Was the purse refunded? FIXME: Not yet handled (do we need to?)
+ */
+ bool purse_refunded;
+
+};
+
+
+/**
+ * Load the auditor's remembered state about the purse into @a ps.
+ *
+ * @param[in,out] ps purse summary to (fully) initialize
+ * @return transaction status code
+ */
+static enum GNUNET_DB_QueryStatus
+load_auditor_purse_summary (struct PurseSummary *ps)
+{
+ enum GNUNET_DB_QueryStatus qs;
+ uint64_t rowid;
+
+ qs = TALER_ARL_adb->get_purse_info (TALER_ARL_adb->cls,
+ &ps->purse_pub,
+ &rowid,
+ &ps->balance,
+ &ps->expiration_date);
+ if (0 > qs)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qs)
+ {
+ ps->had_pi = false;
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &ps->balance));
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Creating fresh purse `%s'\n",
+ TALER_B2S (&ps->purse_pub));
+ return GNUNET_DB_STATUS_SUCCESS_NO_RESULTS;
+ }
+ ps->had_pi = true;
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Auditor remembers purse `%s' has balance %s\n",
+ TALER_B2S (&ps->purse_pub),
+ TALER_amount2s (&ps->balance));
+ return GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
+}
+
+
+/**
+ * Closure to the various callbacks we make while checking a purse.
+ */
+struct PurseContext
+{
+ /**
+ * Map from hash of purse's public key to a `struct PurseSummary`.
+ */
+ struct GNUNET_CONTAINER_MultiHashMap *purses;
+
+ /**
+ * Transaction status code, set to error codes if applicable.
+ */
+ enum GNUNET_DB_QueryStatus qs;
+
+};
+
+
+/**
+ * Create a new reserve for @a reserve_pub in @a rc.
+ *
+ * @param[in,out] pc context to update
+ * @param purse_pub key for which to create a purse
+ * @return NULL on error
+ */
+static struct PurseSummary *
+setup_purse (struct PurseContext *pc,
+ const struct TALER_PurseContractPublicKeyP *purse_pub)
+{
+ struct PurseSummary *ps;
+ struct GNUNET_HashCode key;
+ enum GNUNET_DB_QueryStatus qs;
+
+ GNUNET_CRYPTO_hash (purse_pub,
+ sizeof (*purse_pub),
+ &key);
+ ps = GNUNET_CONTAINER_multihashmap_get (pc->purses,
+ &key);
+ if (NULL != ps)
+ return ps;
+ ps = GNUNET_new (struct PurseSummary);
+ ps->purse_pub = *purse_pub;
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &ps->balance));
+ /* get purse meta-data from exchange DB */
+ qs = TALER_ARL_edb->select_purse (TALER_ARL_edb->cls,
+ purse_pub,
+ &ps->creation_date,
+ &ps->expiration_date,
+ &ps->total_value,
+ &ps->exchange_balance,
+ &ps->h_contract_terms,
+ &ps->merge_timestamp,
+ &ps->purse_deleted,
+ &ps->purse_refunded);
+ if (0 >= qs)
+ {
+ GNUNET_free (ps);
+ pc->qs = qs;
+ return NULL;
+ }
+ if (0 > (qs = load_auditor_purse_summary (ps)))
+ {
+ GNUNET_free (ps);
+ pc->qs = qs;
+ return NULL;
+ }
+ GNUNET_assert (GNUNET_OK ==
+ GNUNET_CONTAINER_multihashmap_put (pc->purses,
+ &key,
+ ps,
+ GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY));
+ return ps;
+}
+
+
+/**
+ * Function called on purse requests.
+ *
+ * @param cls closure
+ * @param rowid which row in the database was the request stored in
+ * @param purse_pub public key of the purse
+ * @param merge_pub public key representing the merge capability
+ * @param purse_creation when was the purse created
+ * @param purse_expiration when would an unmerged purse expire
+ * @param h_contract_terms contract associated with the purse
+ * @param age_limit the age limit for deposits into the purse
+ * @param target_amount amount to be put into the purse
+ * @param purse_sig signature of the purse over the initialization data
+ * @return #GNUNET_OK to continue to iterate
+ */
+static enum GNUNET_GenericReturnValue
+handle_purse_requested (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_PurseMergePublicKeyP *merge_pub,
+ struct GNUNET_TIME_Timestamp purse_creation,
+ struct GNUNET_TIME_Timestamp purse_expiration,
+ const struct TALER_PrivateContractHashP *h_contract_terms,
+ uint32_t age_limit,
+ const struct TALER_Amount *target_amount,
+ const struct TALER_PurseContractSignatureP *purse_sig)
+{
+ struct PurseContext *pc = cls;
+ struct PurseSummary *ps;
+ struct GNUNET_HashCode key;
+
+ TALER_ARL_USE_PP (purse_request_serial_id) = rowid;
+ if (GNUNET_OK !=
+ TALER_wallet_purse_create_verify (purse_expiration,
+ h_contract_terms,
+ merge_pub,
+ age_limit,
+ target_amount,
+ purse_pub,
+ purse_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "purse-reqeust"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ target_amount),
+ GNUNET_JSON_pack_data_auto ("key_pub",
+ purse_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ target_amount);
+ }
+ GNUNET_CRYPTO_hash (purse_pub,
+ sizeof (*purse_pub),
+ &key);
+ ps = GNUNET_new (struct PurseSummary);
+ ps->purse_pub = *purse_pub;
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &ps->balance));
+ ps->creation_date = purse_creation;
+ ps->expiration_date = purse_expiration;
+ ps->total_value = *target_amount;
+ ps->h_contract_terms = *h_contract_terms;
+ GNUNET_assert (GNUNET_OK ==
+ GNUNET_CONTAINER_multihashmap_put (pc->purses,
+ &key,
+ ps,
+ GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY));
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called with details about purse deposits that have been made, with
+ * the goal of auditing the deposit's execution.
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the deposit in our DB
+ * @param deposit deposit details
+ * @param reserve_pub which reserve is the purse merged into, NULL if unknown
+ * @param flags purse flags
+ * @param auditor_balance purse balance (according to the
+ * auditor during auditing)
+ * @param purse_total target amount the purse should reach
+ * @param denom_pub denomination public key of @a coin_pub
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_purse_deposits (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_EXCHANGEDB_PurseDeposit *deposit,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ enum TALER_WalletAccountMergeFlags flags,
+ const struct TALER_Amount *auditor_balance,
+ const struct TALER_Amount *purse_total,
+ const struct TALER_DenominationPublicKey *denom_pub)
+{
+ struct PurseContext *pc = cls;
+ struct TALER_Amount amount_minus_fee;
+ struct PurseSummary *ps;
+ const char *base_url
+ = (NULL == deposit->exchange_base_url)
+ ? TALER_ARL_exchange_url
+ : deposit->exchange_base_url;
+ struct TALER_DenominationHashP h_denom_pub;
+
+ /* should be monotonically increasing */
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (purse_deposits_serial_id));
+ TALER_ARL_USE_PP (purse_deposits_serial_id) = rowid + 1;
+
+ {
+ const struct TALER_EXCHANGEDB_DenominationKeyInformation *issue;
+ enum GNUNET_DB_QueryStatus qs;
+
+ qs = TALER_ARL_get_denomination_info (denom_pub,
+ &issue,
+ &h_denom_pub);
+ if (0 > qs)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ if (GNUNET_DB_STATUS_HARD_ERROR == qs)
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Hard database error trying to get denomination %s from database!\n",
+ TALER_B2S (denom_pub));
+ pc->qs = qs;
+ return GNUNET_SYSERR;
+ }
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qs)
+ {
+ report_row_inconsistency ("purse-deposit",
+ rowid,
+ "denomination key not found");
+ if (TALER_ARL_do_abort ())
+ return GNUNET_SYSERR;
+ return GNUNET_OK;
+ }
+ TALER_ARL_amount_subtract (&amount_minus_fee,
+ &deposit->amount,
+ &issue->fees.deposit);
+ }
+
+ if (GNUNET_OK !=
+ TALER_wallet_purse_deposit_verify (base_url,
+ &deposit->purse_pub,
+ &deposit->amount,
+ &h_denom_pub,
+ &deposit->h_age_commitment,
+ &deposit->coin_pub,
+ &deposit->coin_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "purse-deposit"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ &deposit->amount),
+ GNUNET_JSON_pack_data_auto ("key_pub",
+ &deposit->coin_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ &deposit->amount);
+ return GNUNET_OK;
+ }
+
+ ps = setup_purse (pc,
+ &deposit->purse_pub);
+ if (NULL == ps)
+ {
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == pc->qs)
+ {
+ report_row_inconsistency ("purse-deposit",
+ rowid,
+ "purse not found");
+ }
+ else
+ {
+ /* Database trouble!? */
+ GNUNET_break (0);
+ }
+ return GNUNET_SYSERR;
+ }
+ TALER_ARL_amount_add (&ps->balance,
+ &ps->balance,
+ &amount_minus_fee);
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (purse_global_balance),
+ &TALER_ARL_USE_AB (purse_global_balance),
+ &amount_minus_fee);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called with details about purse merges that have been made, with
+ * the goal of auditing the purse merge execution.
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the deposit in our DB
+ * @param partner_base_url where is the reserve, NULL for this exchange
+ * @param amount total amount expected in the purse
+ * @param balance current balance in the purse
+ * @param flags purse flags
+ * @param merge_pub merge capability key
+ * @param reserve_pub reserve the merge affects
+ * @param merge_sig signature affirming the merge
+ * @param purse_pub purse key
+ * @param merge_timestamp when did the merge happen
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_purse_merged (
+ void *cls,
+ uint64_t rowid,
+ const char *partner_base_url,
+ const struct TALER_Amount *amount,
+ const struct TALER_Amount *balance,
+ enum TALER_WalletAccountMergeFlags flags,
+ const struct TALER_PurseMergePublicKeyP *merge_pub,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_PurseMergeSignatureP *merge_sig,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ struct GNUNET_TIME_Timestamp merge_timestamp)
+{
+ struct PurseContext *pc = cls;
+ struct PurseSummary *ps;
+
+ /* should be monotonically increasing */
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (purse_merges_serial_id));
+ TALER_ARL_USE_PP (purse_merges_serial_id) = rowid + 1;
+
+ {
+ char *reserve_url;
+
+ reserve_url
+ = TALER_reserve_make_payto (NULL == partner_base_url
+ ? TALER_ARL_exchange_url
+ : partner_base_url,
+ reserve_pub);
+ if (GNUNET_OK !=
+ TALER_wallet_purse_merge_verify (reserve_url,
+ merge_timestamp,
+ purse_pub,
+ merge_pub,
+ merge_sig))
+ {
+ GNUNET_free (reserve_url);
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "merge-purse"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ amount),
+ GNUNET_JSON_pack_data_auto ("key_pub",
+ merge_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ amount);
+ return GNUNET_OK;
+ }
+ GNUNET_free (reserve_url);
+ }
+
+ ps = setup_purse (pc,
+ purse_pub);
+ if (NULL == ps)
+ {
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == pc->qs)
+ {
+ report_row_inconsistency ("purse-merge",
+ rowid,
+ "purse not found");
+ }
+ else
+ {
+ /* Database trouble!? */
+ GNUNET_break (0);
+ }
+ return GNUNET_SYSERR;
+ }
+ GNUNET_break (0 ==
+ GNUNET_TIME_timestamp_cmp (merge_timestamp,
+ ==,
+ ps->merge_timestamp));
+ TALER_ARL_amount_add (&ps->balance,
+ &ps->balance,
+ amount);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called with details about account merge requests that have been
+ * made, with the goal of auditing the account merge execution.
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the deposit in our DB
+ * @param reserve_pub reserve affected by the merge
+ * @param purse_pub purse being merged
+ * @param h_contract_terms hash over contract of the purse
+ * @param purse_expiration when would the purse expire
+ * @param amount total amount in the purse
+ * @param min_age minimum age of all coins deposited into the purse
+ * @param flags how was the purse created
+ * @param purse_fee if a purse fee was paid, how high is it
+ * @param merge_timestamp when was the merge approved
+ * @param reserve_sig signature by reserve approving the merge
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_account_merged (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_PrivateContractHashP *h_contract_terms,
+ struct GNUNET_TIME_Timestamp purse_expiration,
+ const struct TALER_Amount *amount,
+ uint32_t min_age,
+ enum TALER_WalletAccountMergeFlags flags,
+ const struct TALER_Amount *purse_fee,
+ struct GNUNET_TIME_Timestamp merge_timestamp,
+ const struct TALER_ReserveSignatureP *reserve_sig)
+{
+ struct PurseContext *pc = cls;
+ struct PurseSummary *ps;
+
+ /* should be monotonically increasing */
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (purse_account_merge_serial_id));
+ TALER_ARL_USE_PP (purse_account_merge_serial_id) = rowid + 1;
+ if (GNUNET_OK !=
+ TALER_wallet_account_merge_verify (merge_timestamp,
+ purse_pub,
+ purse_expiration,
+ h_contract_terms,
+ amount,
+ purse_fee,
+ min_age,
+ flags,
+ reserve_pub,
+ reserve_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "account-merge"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ purse_fee),
+ GNUNET_JSON_pack_data_auto ("key_pub",
+ reserve_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ purse_fee);
+ return GNUNET_OK;
+ }
+ ps = setup_purse (pc,
+ purse_pub);
+ if (NULL == ps)
+ {
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == pc->qs)
+ {
+ report_row_inconsistency ("account-merge",
+ rowid,
+ "purse not found");
+ }
+ else
+ {
+ /* Database trouble!? */
+ GNUNET_break (0);
+ }
+ return GNUNET_SYSERR;
+ }
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (purse_global_balance),
+ &TALER_ARL_USE_AB (purse_global_balance),
+ purse_fee);
+ TALER_ARL_amount_add (&ps->balance,
+ &ps->balance,
+ purse_fee);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called with details about purse decisions that have been made.
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the deposit in our DB
+ * @param purse_pub which purse was the decision made on
+ * @param refunded true if decision was to refund
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_purse_decision (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ bool refunded)
+{
+ struct PurseContext *pc = cls;
+ struct PurseSummary *ps;
+ struct GNUNET_HashCode key;
+ enum GNUNET_DB_QueryStatus qs;
+ struct TALER_Amount purse_fee;
+ struct TALER_Amount balance_without_purse_fee;
+
+ TALER_ARL_USE_PP (purse_decision_serial_id) = rowid;
+ ps = setup_purse (pc,
+ purse_pub);
+ if (NULL == ps)
+ {
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == pc->qs)
+ {
+ report_row_inconsistency ("purse-decision",
+ rowid,
+ "purse not found");
+ }
+ else
+ {
+ /* Database trouble!? */
+ GNUNET_break (0);
+ }
+ return GNUNET_SYSERR;
+ }
+ if (GNUNET_OK !=
+ get_purse_fee (ps->creation_date,
+ &purse_fee))
+ {
+ report_row_inconsistency ("purse-request",
+ rowid,
+ "purse fee unavailable");
+ }
+ if (0 >
+ TALER_amount_subtract (&balance_without_purse_fee,
+ &ps->balance,
+ &purse_fee))
+ {
+ report_row_inconsistency ("purse-request",
+ rowid,
+ "purse fee higher than balance");
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &balance_without_purse_fee));
+ }
+
+ if (refunded)
+ {
+ if (-1 != TALER_amount_cmp (&balance_without_purse_fee,
+ &ps->total_value))
+ {
+ report_amount_arithmetic_inconsistency ("purse-decision: refund",
+ rowid,
+ &balance_without_purse_fee,
+ &ps->total_value,
+ 0);
+ }
+ }
+ else
+ {
+ if (-1 == TALER_amount_cmp (&balance_without_purse_fee,
+ &ps->total_value))
+ {
+ report_amount_arithmetic_inconsistency ("purse-decision: merge",
+ rowid,
+ &ps->total_value,
+ &balance_without_purse_fee,
+ 0);
+ TALER_ARL_amount_add (&total_balance_insufficient_loss,
+ &total_balance_insufficient_loss,
+ &ps->total_value);
+ }
+ }
+
+ qs = TALER_ARL_adb->delete_purse_info (TALER_ARL_adb->cls,
+ purse_pub);
+ GNUNET_assert (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS != qs);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs);
+ pc->qs = qs;
+ return GNUNET_SYSERR;
+ }
+ GNUNET_CRYPTO_hash (purse_pub,
+ sizeof (*purse_pub),
+ &key);
+ GNUNET_assert (GNUNET_YES ==
+ GNUNET_CONTAINER_multihashmap_remove (pc->purses,
+ &key,
+ ps));
+ GNUNET_free (ps);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called on expired purses.
+ *
+ * @param cls closure
+ * @param purse_pub public key of the purse
+ * @param balance amount of money in the purse
+ * @param expiration_date when did the purse expire?
+ * @return #GNUNET_OK to continue to iterate
+ */
+static enum GNUNET_GenericReturnValue
+handle_purse_expired (
+ void *cls,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_Amount *balance,
+ struct GNUNET_TIME_Timestamp expiration_date)
+{
+ struct PurseContext *pc = cls;
+
+ (void) pc;
+ TALER_ARL_report (report_purse_not_closed_inconsistencies,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_data_auto ("purse_pub",
+ purse_pub),
+ TALER_JSON_pack_amount ("balance",
+ balance),
+ TALER_JSON_pack_time_abs_human ("expired",
+ expiration_date.abs_time)));
+ TALER_ARL_amount_add (&total_delayed_decisions,
+ &total_delayed_decisions,
+ balance);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Check that the purse summary matches what the exchange database
+ * thinks about the purse, and update our own state of the purse.
+ *
+ * Remove all purses that we are happy with from the DB.
+ *
+ * @param cls our `struct PurseContext`
+ * @param key hash of the purse public key
+ * @param value a `struct PurseSummary`
+ * @return #GNUNET_OK to process more entries
+ */
+static enum GNUNET_GenericReturnValue
+verify_purse_balance (void *cls,
+ const struct GNUNET_HashCode *key,
+ void *value)
+{
+ struct PurseContext *pc = cls;
+ struct PurseSummary *ps = value;
+ enum GNUNET_GenericReturnValue ret;
+ enum GNUNET_DB_QueryStatus qs;
+
+ ret = GNUNET_OK;
+ if (internal_checks)
+ {
+ struct TALER_Amount pf;
+ struct TALER_Amount balance_without_purse_fee;
+
+ /* subtract purse fee from ps->balance to get actual balance we expect, as
+ we track the balance including purse fee, while the exchange subtracts
+ the purse fee early on. */
+ if (GNUNET_OK !=
+ get_purse_fee (ps->creation_date,
+ &pf))
+ {
+ GNUNET_break (0);
+ report_row_inconsistency ("purse",
+ 0,
+ "purse fee unavailable");
+ }
+ if (0 >
+ TALER_amount_subtract (&balance_without_purse_fee,
+ &ps->balance,
+ &pf))
+ {
+ report_row_inconsistency ("purse",
+ 0,
+ "purse fee higher than balance");
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &balance_without_purse_fee));
+ }
+
+ if (0 != TALER_amount_cmp (&ps->exchange_balance,
+ &balance_without_purse_fee))
+ {
+ report_amount_arithmetic_inconsistency ("purse-balance",
+ 0,
+ &ps->exchange_balance,
+ &balance_without_purse_fee,
+ 0);
+ }
+ }
+
+ if (ps->had_pi)
+ qs = TALER_ARL_adb->update_purse_info (TALER_ARL_adb->cls,
+ &ps->purse_pub,
+ &ps->balance);
+ else
+ qs = TALER_ARL_adb->insert_purse_info (TALER_ARL_adb->cls,
+ &ps->purse_pub,
+ &ps->balance,
+ ps->expiration_date);
+ GNUNET_assert (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS != qs);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs);
+ pc->qs = qs;
+ return GNUNET_SYSERR;
+ }
+
+ GNUNET_assert (GNUNET_YES ==
+ GNUNET_CONTAINER_multihashmap_remove (pc->purses,
+ key,
+ ps));
+ GNUNET_free (ps);
+ return ret;
+}
+
+
+/**
+ * Analyze purses for being well-formed.
+ *
+ * @param cls NULL
+ * @return transaction status code
+ */
+static enum GNUNET_DB_QueryStatus
+analyze_purses (void *cls)
+{
+ struct PurseContext pc;
+ enum GNUNET_DB_QueryStatus qsx;
+ enum GNUNET_DB_QueryStatus qs;
+ enum GNUNET_DB_QueryStatus qsp;
+
+ (void) cls;
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Analyzing purses\n");
+ qsp = TALER_ARL_adb->get_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_PP (purse_account_merge_serial_id),
+ TALER_ARL_GET_PP (purse_decision_serial_id),
+ TALER_ARL_GET_PP (purse_deposits_serial_id),
+ TALER_ARL_GET_PP (purse_merges_serial_id),
+ TALER_ARL_GET_PP (purse_request_serial_id),
+ TALER_ARL_GET_PP (purse_open_counter),
+ NULL);
+ if (0 > qsp)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsp);
+ return qsp;
+ }
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qsp)
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_MESSAGE,
+ "First analysis using this auditor, starting audit from scratch\n");
+ }
+ else
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Resuming purse audit at %llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_request_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_decision_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_merges_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_deposits_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_account_merge_serial_id));
+ }
+ pc.qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
+ qsx = TALER_ARL_adb->get_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_AB (purse_global_balance),
+ NULL);
+ if (qsx < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsx);
+ return qsx;
+ }
+ pc.purses = GNUNET_CONTAINER_multihashmap_create (512,
+ GNUNET_NO);
+
+ qs = TALER_ARL_edb->select_purse_requests_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (purse_request_serial_id),
+ &handle_purse_requested,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+
+ qs = TALER_ARL_edb->select_purse_merges_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (purse_merges_serial_id),
+ &handle_purse_merged,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+ qs = TALER_ARL_edb->select_purse_deposits_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (purse_deposits_serial_id),
+ &handle_purse_deposits,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+ /* Charge purse fee! */
+ qs = TALER_ARL_edb->select_account_merges_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (purse_account_merge_serial_id),
+ &handle_account_merged,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+
+ qs = TALER_ARL_edb->select_all_purse_decisions_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (purse_decision_serial_id),
+ &handle_purse_decision,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+
+ qs = TALER_ARL_adb->select_purse_expired (
+ TALER_ARL_adb->cls,
+ &handle_purse_expired,
+ &pc);
+ if (qs < 0)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+
+ GNUNET_CONTAINER_multihashmap_iterate (pc.purses,
+ &verify_purse_balance,
+ &pc);
+ GNUNET_break (0 ==
+ GNUNET_CONTAINER_multihashmap_size (pc.purses));
+ GNUNET_CONTAINER_multihashmap_destroy (pc.purses);
+ if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != pc.qs)
+ return qs;
+ if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qsx)
+ {
+ qs = TALER_ARL_adb->insert_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (purse_global_balance),
+ NULL);
+ }
+ else
+ {
+ qs = TALER_ARL_adb->update_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (purse_global_balance),
+ NULL);
+ }
+ if (0 >= qs)
+ {
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+ if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsp)
+ qs = TALER_ARL_adb->update_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (purse_account_merge_serial_id),
+ TALER_ARL_SET_PP (purse_decision_serial_id),
+ TALER_ARL_SET_PP (purse_deposits_serial_id),
+ TALER_ARL_SET_PP (purse_merges_serial_id),
+ TALER_ARL_SET_PP (purse_request_serial_id),
+ TALER_ARL_SET_PP (purse_open_counter),
+ NULL);
+ else
+ qs = TALER_ARL_adb->insert_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (purse_account_merge_serial_id),
+ TALER_ARL_SET_PP (purse_decision_serial_id),
+ TALER_ARL_SET_PP (purse_deposits_serial_id),
+ TALER_ARL_SET_PP (purse_merges_serial_id),
+ TALER_ARL_SET_PP (purse_request_serial_id),
+ TALER_ARL_SET_PP (purse_open_counter),
+ NULL);
+ if (0 >= qs)
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Failed to update auditor DB, not recording progress\n");
+ GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ return qs;
+ }
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Concluded purse audit step at %llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_request_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_decision_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_merges_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_deposits_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ purse_account_merge_serial_id));
+ return GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
+}
+
+
+/**
+ * Main function that will be run.
+ *
+ * @param cls closure
+ * @param args remaining command-line arguments
+ * @param cfgfile name of the configuration file used (for saving, can be NULL!)
+ * @param c configuration
+ */
+static void
+run (void *cls,
+ char *const *args,
+ const char *cfgfile,
+ const struct GNUNET_CONFIGURATION_Handle *c)
+{
+ (void) cls;
+ (void) args;
+ (void) cfgfile;
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Launching auditor\n");
+ if (GNUNET_OK !=
+ TALER_ARL_init (c))
+ {
+ global_ret = EXIT_FAILURE;
+ return;
+ }
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &TALER_ARL_USE_AB (
+ purse_global_balance)));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_balance_insufficient_loss));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_delayed_decisions));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_arithmetic_delta_plus));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_arithmetic_delta_minus));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_balance_purse_not_closed));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &total_bad_sig_loss));
+
+ GNUNET_assert (NULL !=
+ (report_row_inconsistencies = json_array ()));
+ GNUNET_assert (NULL !=
+ (report_purse_balance_insufficient_inconsistencies
+ = json_array ()));
+ GNUNET_assert (NULL !=
+ (report_purse_not_closed_inconsistencies
+ = json_array ()));
+ GNUNET_assert (NULL !=
+ (report_amount_arithmetic_inconsistencies
+ = json_array ()));
+ GNUNET_assert (NULL !=
+ (report_bad_sig_losses = json_array ()));
+ if (GNUNET_OK !=
+ TALER_ARL_setup_sessions_and_run (&analyze_purses,
+ NULL))
+ {
+ global_ret = EXIT_FAILURE;
+ return;
+ }
+ TALER_ARL_done (
+ GNUNET_JSON_PACK (
+ /* Globals (REVIEW!) */
+ TALER_JSON_pack_amount ("total_balance_insufficient",
+ &total_balance_insufficient_loss),
+ TALER_JSON_pack_amount ("total_delayed_purse_decisions",
+ &total_delayed_decisions),
+ GNUNET_JSON_pack_array_steal (
+ "purse_balance_insufficient_inconsistencies",
+ report_purse_balance_insufficient_inconsistencies),
+ TALER_JSON_pack_amount ("total_balance_purse_not_closed",
+ &total_balance_purse_not_closed),
+ TALER_JSON_pack_amount ("total_bad_sig_loss",
+ &total_bad_sig_loss),
+ TALER_JSON_pack_amount ("total_arithmetic_delta_plus",
+ &total_arithmetic_delta_plus),
+ TALER_JSON_pack_amount ("total_arithmetic_delta_minus",
+ &total_arithmetic_delta_minus),
+
+ /* Global 'balances' */
+ TALER_JSON_pack_amount ("total_purse_balance",
+ &TALER_ARL_USE_AB (purse_global_balance)),
+ GNUNET_JSON_pack_uint64 ("total_purse_count",
+ TALER_ARL_USE_PP (purse_open_counter)),
+
+ GNUNET_JSON_pack_array_steal ("purse_not_closed_inconsistencies",
+ report_purse_not_closed_inconsistencies),
+ GNUNET_JSON_pack_array_steal ("bad_sig_losses",
+ report_bad_sig_losses),
+ GNUNET_JSON_pack_array_steal ("row_inconsistencies",
+ report_row_inconsistencies),
+ GNUNET_JSON_pack_array_steal ("amount_arithmetic_inconsistencies",
+ report_amount_arithmetic_inconsistencies),
+ /* Information about audited range ... */
+ TALER_JSON_pack_time_abs_human ("auditor_start_time",
+ start_time),
+ TALER_JSON_pack_time_abs_human ("auditor_end_time",
+ GNUNET_TIME_absolute_get ()),
+ GNUNET_JSON_pack_uint64 ("start_ppp_purse_merges_serial_id",
+ 0 /* not supported anymore */),
+ GNUNET_JSON_pack_uint64 ("start_ppp_purse_deposits_serial_id",
+ 0 /* not supported anymore */),
+ GNUNET_JSON_pack_uint64 ("start_ppp_account_merge_serial_id",
+ 0 /* not supported anymore */),
+ GNUNET_JSON_pack_uint64 ("end_ppp_purse_merges_serial_id",
+ TALER_ARL_USE_PP (
+ purse_merges_serial_id)),
+ GNUNET_JSON_pack_uint64 ("end_ppp_purse_deposits_serial_id",
+ TALER_ARL_USE_PP (
+ purse_deposits_serial_id)),
+ GNUNET_JSON_pack_uint64 ("end_ppp_account_merge_serial_id",
+ TALER_ARL_USE_PP (
+ purse_account_merge_serial_id))));
+}
+
+
+/**
+ * The main function to check the database's handling of purses.
+ *
+ * @param argc number of arguments from the command line
+ * @param argv command line arguments
+ * @return 0 ok, 1 on error
+ */
+int
+main (int argc,
+ char *const *argv)
+{
+ const struct GNUNET_GETOPT_CommandLineOption options[] = {
+ GNUNET_GETOPT_option_flag ('i',
+ "internal",
+ "perform checks only applicable for exchange-internal audits",
+ &internal_checks),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
+ GNUNET_GETOPT_option_timetravel ('T',
+ "timetravel"),
+ GNUNET_GETOPT_OPTION_END
+ };
+ enum GNUNET_GenericReturnValue ret;
+
+ /* force linker to link against libtalerutil; if we do
+ not do this, the linker may "optimize" libtalerutil
+ away and skip #TALER_OS_init(), which we do need */
+ (void) TALER_project_data_default ();
+ if (GNUNET_OK !=
+ GNUNET_STRINGS_get_utf8_args (argc, argv,
+ &argc, &argv))
+ return EXIT_INVALIDARGUMENT;
+ ret = GNUNET_PROGRAM_run (
+ argc,
+ argv,
+ "taler-helper-auditor-purses",
+ gettext_noop ("Audit Taler exchange purse handling"),
+ options,
+ &run,
+ NULL);
+ GNUNET_free_nz ((void *) argv);
+ if (GNUNET_SYSERR == ret)
+ return EXIT_INVALIDARGUMENT;
+ if (GNUNET_NO == ret)
+ return EXIT_SUCCESS;
+ return global_ret;
+}
+
+
+/* end of taler-helper-auditor-purses.c */
diff --git a/src/auditor/taler-helper-auditor-render.py b/src/auditor/taler-helper-auditor-render.py
index 4b086cb62..b9c92b29c 100644
--- a/src/auditor/taler-helper-auditor-render.py
+++ b/src/auditor/taler-helper-auditor-render.py
@@ -53,4 +53,14 @@ jinjaEnv = jinja2.Environment(loader=StdinLoader(),
autoescape=False)
tmpl = jinjaEnv.get_template('stdin');
-print(tmpl.render(aggregation = jsonData1, coins = jsonData2, deposits = jsonData3, reserves = jsonData4, wire = jsonData5))
+try:
+ print(tmpl.render(aggregation = jsonData1, coins = jsonData2, deposits = jsonData3, reserves = jsonData4, wire = jsonData5))
+except jinja2.TemplateSyntaxError as error:
+ print("Template syntax error: {error.message} on line {error.lineno}.".format(error=error))
+ exit(1)
+except jinja2.UndefinedError as error:
+ print("Template undefined error: {error.message}.".format(error=error))
+ exit(1)
+except TypeError as error:
+ print("Template type error: {0}.".format(error.args[0]))
+ exit(1)
diff --git a/src/auditor/taler-helper-auditor-reserves.c b/src/auditor/taler-helper-auditor-reserves.c
index 547a45871..aa35c6a75 100644
--- a/src/auditor/taler-helper-auditor-reserves.c
+++ b/src/auditor/taler-helper-auditor-reserves.c
@@ -39,6 +39,14 @@
static int global_ret;
/**
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
+ */
+static int test_mode;
+
+/**
* After how long should idle reserves be closed?
*/
static struct GNUNET_TIME_Relative idle_reserve_expiration_time;
@@ -46,15 +54,29 @@ static struct GNUNET_TIME_Relative idle_reserve_expiration_time;
/**
* Checkpointing our progress for reserves.
*/
-static struct TALER_AUDITORDB_ProgressPointReserve ppr;
+static TALER_ARL_DEF_PP (reserves_reserve_in_serial_id);
+static TALER_ARL_DEF_PP (reserves_reserve_out_serial_id);
+static TALER_ARL_DEF_PP (reserves_reserve_recoup_serial_id);
+static TALER_ARL_DEF_PP (reserves_reserve_open_serial_id);
+static TALER_ARL_DEF_PP (reserves_reserve_close_serial_id);
+static TALER_ARL_DEF_PP (reserves_purse_decisions_serial_id);
+static TALER_ARL_DEF_PP (reserves_account_merges_serial_id);
+static TALER_ARL_DEF_PP (reserves_history_requests_serial_id);
/**
- * Checkpointing our progress for reserves.
+ * Tracked global reserve balances.
*/
-static struct TALER_AUDITORDB_ProgressPointReserve ppr_start;
+static TALER_ARL_DEF_AB (reserves_reserve_total_balance);
+static TALER_ARL_DEF_AB (reserves_reserve_loss);
+static TALER_ARL_DEF_AB (reserves_withdraw_fee_revenue);
+static TALER_ARL_DEF_AB (reserves_close_fee_revenue);
+static TALER_ARL_DEF_AB (reserves_purse_fee_revenue);
+static TALER_ARL_DEF_AB (reserves_open_fee_revenue);
+static TALER_ARL_DEF_AB (reserves_history_fee_revenue);
+
/**
- * Array of reports about row inconsitencies.
+ * Array of reports about row inconsistencies.
*/
static json_t *report_row_inconsistencies;
@@ -65,39 +87,36 @@ static json_t *report_row_inconsistencies;
static json_t *denomination_key_validity_withdraw_inconsistencies;
/**
- * Array of reports about reserve balance insufficient inconsitencies.
+ * Array of reports about reserve balance insufficient inconsistencies.
*/
static json_t *report_reserve_balance_insufficient_inconsistencies;
/**
- * Array of reports about purse balance insufficient inconsitencies.
+ * Array of reports about purse balance insufficient inconsistencies.
*/
static json_t *report_purse_balance_insufficient_inconsistencies;
/**
- * Total amount reserves were charged beyond their balance.
- */
-static struct TALER_Amount total_balance_insufficient_loss;
-
-/**
* Array of reports about reserve balance summary wrong in database.
*/
static json_t *report_reserve_balance_summary_wrong_inconsistencies;
/**
* Total delta between expected and stored reserve balance summaries,
- * for positive deltas.
+ * for positive deltas. Used only when internal checks are
+ * enabled.
*/
static struct TALER_Amount total_balance_summary_delta_plus;
/**
* Total delta between expected and stored reserve balance summaries,
- * for negative deltas.
+ * for negative deltas. Used only when internal checks are
+ * enabled.
*/
static struct TALER_Amount total_balance_summary_delta_minus;
/**
- * Array of reports about reserve's not being closed inconsitencies.
+ * Array of reports about reserve's not being closed inconsistencies.
*/
static json_t *report_reserve_not_closed_inconsistencies;
@@ -123,31 +142,6 @@ static struct TALER_Amount total_arithmetic_delta_plus;
static struct TALER_Amount total_arithmetic_delta_minus;
/**
- * Expected balance in the escrow account.
- */
-static struct TALER_Amount total_escrow_balance;
-
-/**
- * Recoups we made on denominations that were not revoked (!?).
- */
-static struct TALER_Amount total_irregular_recoups;
-
-/**
- * Total withdraw fees earned.
- */
-static struct TALER_Amount total_withdraw_fee_income;
-
-/**
- * Total purse fees earned.
- */
-static struct TALER_Amount total_purse_fee_income;
-
-/**
- * Total history fees earned.
- */
-static struct TALER_Amount total_history_fee_income;
-
-/**
* Array of reports about coin operations with bad signatures.
*/
static json_t *report_bad_sig_losses;
@@ -220,8 +214,8 @@ report_amount_arithmetic_inconsistency (
if (0 != profitable)
{
target = (1 == profitable)
- ? &total_arithmetic_delta_plus
- : &total_arithmetic_delta_minus;
+ ? &total_arithmetic_delta_plus
+ : &total_arithmetic_delta_minus;
TALER_ARL_amount_add (target,
target,
&delta);
@@ -279,21 +273,15 @@ struct ReserveSummary
struct TALER_Amount total_out;
/**
- * Sum of withdraw fees encountered during this transaction.
+ * Sum of balance and fees encountered during this transaction.
*/
- struct TALER_Amount total_fee;
+ struct TALER_AUDITORDB_ReserveFeeBalance curr_balance;
/**
- * Previous balance of the reserve as remembered by the auditor.
+ * Previous balances of the reserve as remembered by the auditor.
* (updated based on @e total_in and @e total_out at the end).
*/
- struct TALER_Amount balance_at_previous_audit;
-
- /**
- * Previous withdraw fee balance of the reserve, as remembered by the auditor.
- * (updated based on @e total_fee at the end).
- */
- struct TALER_Amount a_withdraw_fee_balance;
+ struct TALER_AUDITORDB_ReserveFeeBalance prev_balance;
/**
* Previous reserve expiration data, as remembered by the auditor.
@@ -333,10 +321,8 @@ load_auditor_reserve_summary (struct ReserveSummary *rs)
qs = TALER_ARL_adb->get_reserve_info (TALER_ARL_adb->cls,
&rs->reserve_pub,
- &TALER_ARL_master_pub,
&rowid,
- &rs->balance_at_previous_audit,
- &rs->a_withdraw_fee_balance,
+ &rs->prev_balance,
&rs->a_expiration_date,
&rs->sender_account);
if (0 > qs)
@@ -349,31 +335,35 @@ load_auditor_reserve_summary (struct ReserveSummary *rs)
rs->had_ri = false;
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (rs->total_in.currency,
- &rs->balance_at_previous_audit));
+ &rs->prev_balance.reserve_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (rs->total_in.currency,
+ &rs->prev_balance.reserve_loss));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (rs->total_in.currency,
- &rs->a_withdraw_fee_balance));
+ &rs->prev_balance.withdraw_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (rs->total_in.currency,
+ &rs->prev_balance.close_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (rs->total_in.currency,
+ &rs->prev_balance.purse_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (rs->total_in.currency,
+ &rs->prev_balance.open_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (rs->total_in.currency,
+ &rs->prev_balance.history_fee_balance));
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
- "Creating fresh reserve `%s' with starting balance %s\n",
- TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&rs->balance_at_previous_audit));
+ "Creating fresh reserve `%s'\n",
+ TALER_B2S (&rs->reserve_pub));
return GNUNET_DB_STATUS_SUCCESS_NO_RESULTS;
}
rs->had_ri = true;
- if ( (GNUNET_YES !=
- TALER_amount_cmp_currency (&rs->balance_at_previous_audit,
- &rs->a_withdraw_fee_balance)) ||
- (GNUNET_YES !=
- TALER_amount_cmp_currency (&rs->total_in,
- &rs->balance_at_previous_audit)) )
- {
- GNUNET_break (0);
- return GNUNET_DB_STATUS_HARD_ERROR;
- }
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Auditor remembers reserve `%s' has balance %s\n",
TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&rs->balance_at_previous_audit));
+ TALER_amount2s (&rs->prev_balance.reserve_balance));
return GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
}
@@ -436,7 +426,25 @@ setup_reserve (struct ReserveContext *rc,
&rs->total_out));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &rs->total_fee));
+ &rs->curr_balance.reserve_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.reserve_loss));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.withdraw_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.close_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.purse_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.open_fee_balance));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.history_fee_balance));
if (0 > (qs = load_auditor_reserve_summary (rs)))
{
GNUNET_free (rs);
@@ -479,9 +487,8 @@ handle_reserve_in (void *cls,
(void) wire_reference;
/* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_reserve_in_serial_id);
- ppr.last_reserve_in_serial_id = rowid + 1;
-
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_reserve_in_serial_id));
+ TALER_ARL_USE_PP (reserves_reserve_in_serial_id) = rowid + 1;
rs = setup_reserve (rc,
reserve_pub);
if (NULL == rs)
@@ -489,9 +496,6 @@ handle_reserve_in (void *cls,
GNUNET_break (0);
return GNUNET_SYSERR;
}
- TALER_ARL_amount_add (&rs->total_in,
- &rs->total_in,
- credit);
if (NULL == rs->sender_account)
rs->sender_account = GNUNET_strdup (sender_account_details);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
@@ -503,6 +507,9 @@ handle_reserve_in (void *cls,
idle_reserve_expiration_time));
rs->a_expiration_date = GNUNET_TIME_timestamp_max (rs->a_expiration_date,
expiry);
+ TALER_ARL_amount_add (&rs->total_in,
+ &rs->total_in,
+ credit);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
return GNUNET_OK;
@@ -541,8 +548,8 @@ handle_reserve_out (void *cls,
struct TALER_DenominationHashP h_denom_pub;
/* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_reserve_out_serial_id);
- ppr.last_reserve_out_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_reserve_out_serial_id));
+ TALER_ARL_USE_PP (reserves_reserve_out_serial_id) = rowid + 1;
/* lookup denomination pub data (make sure denom_pub is valid, establish fees);
initializes wsrd.h_denomination_pub! */
@@ -618,7 +625,7 @@ handle_reserve_out (void *cls,
amount_with_fee);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
- return GNUNET_OK; /* exit function here, we cannot add this to the legitimate withdrawals */
+ return GNUNET_OK; /* exit function here, we cannot add this to the legitimate withdrawals */
}
TALER_ARL_amount_add (&auditor_amount_with_fee,
@@ -639,9 +646,6 @@ handle_reserve_out (void *cls,
GNUNET_break (0);
return GNUNET_SYSERR;
}
- TALER_ARL_amount_add (&rs->total_out,
- &rs->total_out,
- &auditor_amount_with_fee);
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Reserve `%s' reduced by %s from withdraw\n",
TALER_B2S (reserve_pub),
@@ -649,9 +653,15 @@ handle_reserve_out (void *cls,
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Increasing withdraw profits by fee %s\n",
TALER_amount2s (&issue->fees.withdraw));
- TALER_ARL_amount_add (&rs->total_fee,
- &rs->total_fee,
+ TALER_ARL_amount_add (&rs->curr_balance.withdraw_fee_balance,
+ &rs->curr_balance.withdraw_fee_balance,
+ &issue->fees.withdraw);
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_withdraw_fee_revenue),
+ &TALER_ARL_USE_AB (reserves_withdraw_fee_revenue),
&issue->fees.withdraw);
+ TALER_ARL_amount_add (&rs->total_out,
+ &rs->total_out,
+ &auditor_amount_with_fee);
if (TALER_ARL_do_abort ())
return GNUNET_SYSERR;
return GNUNET_OK;
@@ -684,7 +694,7 @@ handle_recoup_by_reserve (
const struct TALER_CoinPublicInfo *coin,
const struct TALER_DenominationPublicKey *denom_pub,
const struct TALER_CoinSpendSignatureP *coin_sig,
- const union TALER_DenominationBlindingKeyP *coin_blind)
+ const union GNUNET_CRYPTO_BlindingSecretP *coin_blind)
{
struct ReserveContext *rc = cls;
struct ReserveSummary *rs;
@@ -696,8 +706,8 @@ handle_recoup_by_reserve (
(void) denom_pub;
/* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_reserve_recoup_serial_id);
- ppr.last_reserve_recoup_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_reserve_recoup_serial_id));
+ TALER_ARL_USE_PP (reserves_reserve_recoup_serial_id) = rowid + 1;
/* We know that denom_pub matches denom_pub_hash because this
is how the SQL statement joined the tables. */
if (GNUNET_OK !=
@@ -741,8 +751,8 @@ handle_recoup_by_reserve (
report_row_inconsistency ("recoup",
rowid,
"denomination key not in revocation set");
- TALER_ARL_amount_add (&total_irregular_recoups,
- &total_irregular_recoups,
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_reserve_loss),
+ &TALER_ARL_USE_AB (reserves_reserve_loss),
amount);
}
else
@@ -770,10 +780,11 @@ handle_recoup_by_reserve (
}
else
{
- rev_rowid = 0; /* reported elsewhere */
+ rev_rowid = 0; /* reported elsewhere */
}
if ( (NULL != rev) &&
- (0 == strcmp (rev, "master signature invalid")) )
+ (0 == strcmp (rev,
+ "master signature invalid")) )
{
TALER_ARL_report (report_bad_sig_losses,
GNUNET_JSON_PACK (
@@ -868,6 +879,88 @@ get_closing_fee (const char *receiver_account,
/**
+ * Function called about reserve opening operations.
+ *
+ * @param cls closure
+ * @param rowid row identifier used to uniquely identify the reserve closing operation
+ * @param reserve_payment how much to pay from the
+ * reserve's own balance for opening the reserve
+ * @param request_timestamp when was the request created
+ * @param reserve_expiration desired expiration time for the reserve
+ * @param purse_limit minimum number of purses the client
+ * wants to have concurrently open for this reserve
+ * @param reserve_pub public key of the reserve
+ * @param reserve_sig signature affirming the operation
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_reserve_open (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_Amount *reserve_payment,
+ struct GNUNET_TIME_Timestamp request_timestamp,
+ struct GNUNET_TIME_Timestamp reserve_expiration,
+ uint32_t purse_limit,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_ReserveSignatureP *reserve_sig)
+{
+ struct ReserveContext *rc = cls;
+ struct ReserveSummary *rs;
+
+ /* should be monotonically increasing */
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_reserve_open_serial_id));
+ TALER_ARL_USE_PP (reserves_reserve_open_serial_id) = rowid + 1;
+
+ rs = setup_reserve (rc,
+ reserve_pub);
+ if (NULL == rs)
+ {
+ GNUNET_break (0);
+ return GNUNET_SYSERR;
+ }
+ if (GNUNET_OK !=
+ TALER_wallet_reserve_open_verify (reserve_payment,
+ request_timestamp,
+ reserve_expiration,
+ purse_limit,
+ reserve_pub,
+ reserve_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "reserve-open"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ reserve_payment),
+ GNUNET_JSON_pack_data_auto ("reserve_pub",
+ reserve_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ reserve_payment);
+ return GNUNET_OK;
+ }
+ TALER_ARL_amount_add (&rs->curr_balance.open_fee_balance,
+ &rs->curr_balance.open_fee_balance,
+ reserve_payment);
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_open_fee_revenue),
+ &TALER_ARL_USE_AB (reserves_open_fee_revenue),
+ reserve_payment);
+ TALER_ARL_amount_add (&rs->total_out,
+ &rs->total_out,
+ reserve_payment);
+ GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
+ "Additional open operation for reserve `%s' of %s\n",
+ TALER_B2S (reserve_pub),
+ TALER_amount2s (reserve_payment));
+ if (TALER_ARL_do_abort ())
+ return GNUNET_SYSERR;
+ return GNUNET_OK;
+}
+
+
+/**
* Function called about reserve closing operations
* the aggregator triggered.
*
@@ -879,6 +972,8 @@ get_closing_fee (const char *receiver_account,
* @param reserve_pub public key of the reserve
* @param receiver_account where did we send the funds
* @param transfer_details details about the wire transfer
+ * @param close_request_row which close request triggered the operation?
+ * 0 if it was a timeout
* @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
*/
static enum GNUNET_GenericReturnValue
@@ -890,15 +985,16 @@ handle_reserve_closed (
const struct TALER_Amount *closing_fee,
const struct TALER_ReservePublicKeyP *reserve_pub,
const char *receiver_account,
- const struct TALER_WireTransferIdentifierRawP *transfer_details)
+ const struct TALER_WireTransferIdentifierRawP *transfer_details,
+ uint64_t close_request_row)
{
struct ReserveContext *rc = cls;
struct ReserveSummary *rs;
(void) transfer_details;
/* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_reserve_close_serial_id);
- ppr.last_reserve_close_serial_id = rowid + 1;
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_reserve_close_serial_id));
+ TALER_ARL_USE_PP (reserves_reserve_close_serial_id) = rowid + 1;
rs = setup_reserve (rc,
reserve_pub);
@@ -910,12 +1006,6 @@ handle_reserve_closed (
{
struct TALER_Amount expected_fee;
- TALER_ARL_amount_add (&rs->total_out,
- &rs->total_out,
- amount_with_fee);
- TALER_ARL_amount_add (&rs->total_fee,
- &rs->total_fee,
- closing_fee);
/* verify closing_fee is correct! */
if (GNUNET_OK !=
get_closing_fee (receiver_account,
@@ -935,20 +1025,117 @@ handle_reserve_closed (
1);
}
}
- if (NULL == rs->sender_account)
- {
- GNUNET_break (! rs->had_ri);
- report_row_inconsistency ("reserves_close",
- rowid,
- "target account not verified, auditor does not know reserve");
+
+ TALER_ARL_amount_add (&rs->curr_balance.close_fee_balance,
+ &rs->curr_balance.close_fee_balance,
+ closing_fee);
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_close_fee_revenue),
+ &TALER_ARL_USE_AB (reserves_close_fee_revenue),
+ closing_fee);
+ TALER_ARL_amount_add (&rs->total_out,
+ &rs->total_out,
+ amount_with_fee);
+ if (0 != close_request_row)
+ {
+ struct TALER_ReserveSignatureP reserve_sig;
+ struct GNUNET_TIME_Timestamp request_timestamp;
+ struct TALER_Amount close_balance;
+ struct TALER_Amount close_fee;
+ char *payto_uri;
+ enum GNUNET_DB_QueryStatus qs;
+
+ qs = TALER_ARL_edb->select_reserve_close_request_info (
+ TALER_ARL_edb->cls,
+ reserve_pub,
+ close_request_row,
+ &reserve_sig,
+ &request_timestamp,
+ &close_balance,
+ &close_fee,
+ &payto_uri);
+ if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != qs)
+ {
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "reserve close request unknown");
+ }
+ else
+ {
+ struct TALER_PaytoHashP h_payto;
+
+ TALER_payto_hash (payto_uri,
+ &h_payto);
+ if (GNUNET_OK !=
+ TALER_wallet_reserve_close_verify (
+ request_timestamp,
+ &h_payto,
+ reserve_pub,
+ &reserve_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "close-request"),
+ GNUNET_JSON_pack_uint64 ("row",
+ close_request_row),
+ TALER_JSON_pack_amount ("loss",
+ amount_with_fee),
+ GNUNET_JSON_pack_data_auto ("reserve_pub",
+ reserve_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ amount_with_fee);
+ }
+ }
+ if ( (NULL == payto_uri) &&
+ (NULL == rs->sender_account) )
+ {
+ GNUNET_break (! rs->had_ri);
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "target account not verified, auditor does not know reserve");
+ }
+ if (NULL == payto_uri)
+ {
+ if ( (NULL == rs->sender_account) ||
+ (0 != strcmp (rs->sender_account,
+ receiver_account)) )
+ {
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "target account does not match origin account");
+ }
+ }
+ else
+ {
+ if (0 != strcmp (payto_uri,
+ receiver_account))
+ {
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "target account does not match origin account");
+ }
+ }
+ GNUNET_free (payto_uri);
}
- else if (0 != strcmp (rs->sender_account,
- receiver_account))
+ else
{
- report_row_inconsistency ("reserves_close",
- rowid,
- "target account does not match origin account");
+ if (NULL == rs->sender_account)
+ {
+ GNUNET_break (! rs->had_ri);
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "target account not verified, auditor does not know reserve");
+ }
+ else if (0 != strcmp (rs->sender_account,
+ receiver_account))
+ {
+ report_row_inconsistency ("reserves_close",
+ rowid,
+ "target account does not match origin account");
+ }
}
+
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Additional closing operation for reserve `%s' of %s\n",
TALER_B2S (reserve_pub),
@@ -960,6 +1147,137 @@ handle_reserve_closed (
/**
+ * Function called with details about account merge requests that have been
+ * made, with the goal of accounting for the merge fee paid by the reserve (if
+ * applicable).
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the deposit in our DB
+ * @param reserve_pub reserve affected by the merge
+ * @param purse_pub purse being merged
+ * @param h_contract_terms hash over contract of the purse
+ * @param purse_expiration when would the purse expire
+ * @param amount total amount in the purse
+ * @param min_age minimum age of all coins deposited into the purse
+ * @param flags how was the purse created
+ * @param purse_fee if a purse fee was paid, how high is it
+ * @param merge_timestamp when was the merge approved
+ * @param reserve_sig signature by reserve approving the merge
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+handle_account_merged (
+ void *cls,
+ uint64_t rowid,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_PrivateContractHashP *h_contract_terms,
+ struct GNUNET_TIME_Timestamp purse_expiration,
+ const struct TALER_Amount *amount,
+ uint32_t min_age,
+ enum TALER_WalletAccountMergeFlags flags,
+ const struct TALER_Amount *purse_fee,
+ struct GNUNET_TIME_Timestamp merge_timestamp,
+ const struct TALER_ReserveSignatureP *reserve_sig)
+{
+ struct ReserveContext *rc = cls;
+ struct ReserveSummary *rs;
+
+ /* should be monotonically increasing */
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (reserves_account_merges_serial_id));
+ TALER_ARL_USE_PP (reserves_account_merges_serial_id) = rowid + 1;
+ if (GNUNET_OK !=
+ TALER_wallet_account_merge_verify (merge_timestamp,
+ purse_pub,
+ purse_expiration,
+ h_contract_terms,
+ amount,
+ purse_fee,
+ min_age,
+ flags,
+ reserve_pub,
+ reserve_sig))
+ {
+ TALER_ARL_report (report_bad_sig_losses,
+ GNUNET_JSON_PACK (
+ GNUNET_JSON_pack_string ("operation",
+ "account-merge"),
+ GNUNET_JSON_pack_uint64 ("row",
+ rowid),
+ TALER_JSON_pack_amount ("loss",
+ purse_fee),
+ GNUNET_JSON_pack_data_auto ("key_pub",
+ reserve_pub)));
+ TALER_ARL_amount_add (&total_bad_sig_loss,
+ &total_bad_sig_loss,
+ purse_fee);
+ return GNUNET_OK;
+ }
+ if ( (flags & TALER_WAMF_MERGE_MODE_MASK) !=
+ TALER_WAMF_MODE_CREATE_WITH_PURSE_FEE)
+ return GNUNET_OK; /* no impact on reserve balance */
+ rs = setup_reserve (rc,
+ reserve_pub);
+ if (NULL == rs)
+ {
+ GNUNET_break (0);
+ return GNUNET_SYSERR;
+ }
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_purse_fee_revenue),
+ &TALER_ARL_USE_AB (reserves_purse_fee_revenue),
+ purse_fee);
+ TALER_ARL_amount_add (&rs->curr_balance.purse_fee_balance,
+ &rs->curr_balance.purse_fee_balance,
+ purse_fee);
+ TALER_ARL_amount_add (&rs->total_out,
+ &rs->total_out,
+ purse_fee);
+ return GNUNET_OK;
+}
+
+
+/**
+ * Function called with details about a purse that was merged into an account.
+ * Only updates the reserve balance, the actual verifications are done in the
+ * purse helper.
+ *
+ * @param cls closure
+ * @param rowid unique serial ID for the refund in our DB
+ * @param purse_pub public key of the purse
+ * @param reserve_pub which reserve is the purse credited to
+ * @param purse_value what is the target value of the purse
+ * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
+ */
+static enum GNUNET_GenericReturnValue
+purse_decision_cb (void *cls,
+ uint64_t rowid,
+ const struct TALER_PurseContractPublicKeyP *purse_pub,
+ const struct TALER_ReservePublicKeyP *reserve_pub,
+ const struct TALER_Amount *purse_value)
+{
+ struct ReserveContext *rc = cls;
+ struct ReserveSummary *rs;
+
+ GNUNET_assert (rowid >= TALER_ARL_USE_PP (
+ reserves_purse_decisions_serial_id)); /* should be monotonically increasing */
+ TALER_ARL_USE_PP (reserves_purse_decisions_serial_id) = rowid + 1;
+ rs = setup_reserve (rc,
+ reserve_pub);
+ if (NULL == rs)
+ {
+ GNUNET_break (0);
+ return GNUNET_SYSERR;
+ }
+ TALER_ARL_amount_add (&rs->total_in,
+ &rs->total_in,
+ purse_value);
+ if (TALER_ARL_do_abort ())
+ return GNUNET_SYSERR;
+ return GNUNET_OK;
+}
+
+
+/**
* Check that the reserve summary matches what the exchange database
* thinks about the reserve, and update our own state of the reserve.
*
@@ -977,29 +1295,32 @@ verify_reserve_balance (void *cls,
{
struct ReserveContext *rc = cls;
struct ReserveSummary *rs = value;
- struct TALER_Amount balance;
+ struct TALER_Amount mbalance;
struct TALER_Amount nbalance;
enum GNUNET_DB_QueryStatus qs;
- int ret;
+ enum GNUNET_GenericReturnValue ret;
ret = GNUNET_OK;
/* Check our reserve summary balance calculation shows that
the reserve balance is acceptable (i.e. non-negative) */
- TALER_ARL_amount_add (&balance,
+ TALER_ARL_amount_add (&mbalance,
&rs->total_in,
- &rs->balance_at_previous_audit);
+ &rs->prev_balance.reserve_balance);
if (TALER_ARL_SR_INVALID_NEGATIVE ==
TALER_ARL_amount_subtract_neg (&nbalance,
- &balance,
+ &mbalance,
&rs->total_out))
{
struct TALER_Amount loss;
TALER_ARL_amount_subtract (&loss,
&rs->total_out,
- &balance);
- TALER_ARL_amount_add (&total_balance_insufficient_loss,
- &total_balance_insufficient_loss,
+ &mbalance);
+ TALER_ARL_amount_add (&rs->curr_balance.reserve_loss,
+ &rs->prev_balance.reserve_loss,
+ &loss);
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_reserve_loss),
+ &TALER_ARL_USE_AB (reserves_reserve_loss),
&loss);
TALER_ARL_report (report_reserve_balance_insufficient_inconsistencies,
GNUNET_JSON_PACK (
@@ -1009,8 +1330,13 @@ verify_reserve_balance (void *cls,
&loss)));
/* Continue with a reserve balance of zero */
GNUNET_assert (GNUNET_OK ==
- TALER_amount_set_zero (balance.currency,
- &nbalance));
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &rs->curr_balance.reserve_balance));
+ }
+ else
+ {
+ /* Update remaining reserve balance! */
+ rs->curr_balance.reserve_balance = nbalance;
}
if (internal_checks)
@@ -1020,13 +1346,10 @@ verify_reserve_balance (void *cls,
internal audit, as otherwise the balance of the 'reserves' table
is not replicated at the auditor. */
struct TALER_EXCHANGEDB_Reserve reserve;
- struct TALER_EXCHANGEDB_KycStatus kyc;
reserve.pub = rs->reserve_pub;
qs = TALER_ARL_edb->reserves_get (TALER_ARL_edb->cls,
- &reserve,
- &kyc);
- // FIXME: figure out what to do with KYC status!
+ &reserve);
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != qs)
{
/* If the exchange doesn't have this reserve in the summary, it
@@ -1051,17 +1374,17 @@ verify_reserve_balance (void *cls,
else
{
/* Check that exchange's balance matches our expected balance for the reserve */
- if (0 != TALER_amount_cmp (&nbalance,
+ if (0 != TALER_amount_cmp (&rs->curr_balance.reserve_balance,
&reserve.balance))
{
struct TALER_Amount delta;
- if (0 < TALER_amount_cmp (&nbalance,
+ if (0 < TALER_amount_cmp (&rs->curr_balance.reserve_balance,
&reserve.balance))
{
/* balance > reserve.balance */
TALER_ARL_amount_subtract (&delta,
- &nbalance,
+ &rs->curr_balance.reserve_balance,
&reserve.balance);
TALER_ARL_amount_add (&total_balance_summary_delta_plus,
&total_balance_summary_delta_plus,
@@ -1072,7 +1395,7 @@ verify_reserve_balance (void *cls,
/* balance < reserve.balance */
TALER_ARL_amount_subtract (&delta,
&reserve.balance,
- &nbalance);
+ &rs->curr_balance.reserve_balance);
TALER_ARL_amount_add (&total_balance_summary_delta_minus,
&total_balance_summary_delta_minus,
&delta);
@@ -1084,10 +1407,11 @@ verify_reserve_balance (void *cls,
TALER_JSON_pack_amount ("exchange",
&reserve.balance),
TALER_JSON_pack_amount ("auditor",
- &nbalance)));
+ &rs->curr_balance.
+ reserve_balance)));
}
}
- } /* end of 'if (internal_checks)' */
+ } /* end of 'if (internal_checks)' */
/* Check that reserve is being closed if it is past its expiration date
(and the closing fee would not exceed the remaining balance) */
@@ -1144,26 +1468,43 @@ verify_reserve_balance (void *cls,
}
}
- /* Add withdraw fees we encountered to totals */
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Reserve reserve `%s' made %s in withdraw fees\n",
- TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&rs->total_fee));
- TALER_ARL_amount_add (&rs->a_withdraw_fee_balance,
- &rs->a_withdraw_fee_balance,
- &rs->total_fee);
- TALER_ARL_amount_add (&total_escrow_balance,
- &total_escrow_balance,
+ /* We already computed the 'new' balance in 'curr_balance'
+ to include the previous balance, so this one is just
+ an assignment, not adding up! */
+ rs->prev_balance.reserve_balance = rs->curr_balance.reserve_balance;
+
+ /* Add up new totals to previous totals */
+ TALER_ARL_amount_add (&rs->prev_balance.reserve_loss,
+ &rs->prev_balance.reserve_loss,
+ &rs->curr_balance.reserve_loss);
+ TALER_ARL_amount_add (&rs->prev_balance.withdraw_fee_balance,
+ &rs->prev_balance.withdraw_fee_balance,
+ &rs->curr_balance.withdraw_fee_balance);
+ TALER_ARL_amount_add (&rs->prev_balance.close_fee_balance,
+ &rs->prev_balance.close_fee_balance,
+ &rs->curr_balance.close_fee_balance);
+ TALER_ARL_amount_add (&rs->prev_balance.purse_fee_balance,
+ &rs->prev_balance.purse_fee_balance,
+ &rs->curr_balance.purse_fee_balance);
+ TALER_ARL_amount_add (&rs->prev_balance.open_fee_balance,
+ &rs->prev_balance.open_fee_balance,
+ &rs->curr_balance.open_fee_balance);
+ TALER_ARL_amount_add (&rs->prev_balance.history_fee_balance,
+ &rs->prev_balance.history_fee_balance,
+ &rs->curr_balance.history_fee_balance);
+
+ /* Update global balance: add incoming first, then try
+ to subtract outgoing... */
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (reserves_reserve_total_balance),
+ &TALER_ARL_USE_AB (reserves_reserve_total_balance),
&rs->total_in);
- TALER_ARL_amount_add (&total_withdraw_fee_income,
- &total_withdraw_fee_income,
- &rs->total_fee);
{
struct TALER_Amount r;
if (TALER_ARL_SR_INVALID_NEGATIVE ==
TALER_ARL_amount_subtract_neg (&r,
- &total_escrow_balance,
+ &TALER_ARL_USE_AB (
+ reserves_reserve_total_balance),
&rs->total_out))
{
/* We could not reduce our total balance, i.e. exchange allowed IN TOTAL (!)
@@ -1171,34 +1512,33 @@ verify_reserve_balance (void *cls,
went negative!). Woopsie. Calculate how badly it went and log. */
report_amount_arithmetic_inconsistency ("global escrow balance",
0,
- &total_escrow_balance, /* what we had */
- &rs->total_out, /* what we needed */
+ &TALER_ARL_USE_AB (
+ reserves_reserve_total_balance), /* what we had */
+ &rs->total_out, /* what we needed */
0 /* specific profit/loss does not apply to the total summary */);
/* We unexpectedly went negative, so a sane value to continue from
would be zero. */
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_escrow_balance));
+ &TALER_ARL_USE_AB (
+ reserves_reserve_total_balance)));
}
else
{
- total_escrow_balance = r;
+ TALER_ARL_USE_AB (reserves_reserve_total_balance) = r;
}
}
- if ( (0ULL == balance.value) &&
- (0U == balance.fraction) )
+ if (TALER_amount_is_zero (&rs->prev_balance.reserve_balance))
{
/* balance is zero, drop reserve details (and then do not update/insert) */
if (rs->had_ri)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Final balance of reserve `%s' is %s, dropping it\n",
- TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&nbalance));
+ "Final balance of reserve `%s' is zero, dropping it\n",
+ TALER_B2S (&rs->reserve_pub));
qs = TALER_ARL_adb->del_reserve_info (TALER_ARL_adb->cls,
- &rs->reserve_pub,
- &TALER_ARL_master_pub);
+ &rs->reserve_pub);
if (0 >= qs)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
@@ -1209,9 +1549,8 @@ verify_reserve_balance (void *cls,
else
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Final balance of reserve `%s' is %s, no need to remember it\n",
- TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&nbalance));
+ "Final balance of reserve `%s' is zero, no need to remember it\n",
+ TALER_B2S (&rs->reserve_pub));
}
}
else
@@ -1220,20 +1559,16 @@ verify_reserve_balance (void *cls,
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Remembering final balance of reserve `%s' as %s\n",
TALER_B2S (&rs->reserve_pub),
- TALER_amount2s (&nbalance));
+ TALER_amount2s (&rs->prev_balance.reserve_balance));
if (rs->had_ri)
qs = TALER_ARL_adb->update_reserve_info (TALER_ARL_adb->cls,
&rs->reserve_pub,
- &TALER_ARL_master_pub,
- &nbalance,
- &rs->a_withdraw_fee_balance,
+ &rs->prev_balance,
rs->a_expiration_date);
else
qs = TALER_ARL_adb->insert_reserve_info (TALER_ARL_adb->cls,
&rs->reserve_pub,
- &TALER_ARL_master_pub,
- &nbalance,
- &rs->a_withdraw_fee_balance,
+ &rs->prev_balance,
rs->a_expiration_date,
rs->sender_account);
if (0 >= qs)
@@ -1243,7 +1578,7 @@ verify_reserve_balance (void *cls,
rc->qs = qs;
}
}
-
+ /* now we can discard the cached entry */
GNUNET_assert (GNUNET_YES ==
GNUNET_CONTAINER_multihashmap_remove (rc->reserves,
key,
@@ -1255,426 +1590,6 @@ verify_reserve_balance (void *cls,
/**
- * Function called with details about purse deposits that have been made, with
- * the goal of auditing the deposit's execution.
- *
- * @param cls closure
- * @param rowid unique serial ID for the deposit in our DB
- * @param deposit deposit details
- * @param reserve_pub which reserve is the purse merged into, NULL if unknown
- * @param flags purse flags
- * @param auditor_balance purse balance (according to the
- * auditor during auditing)
- * @param purse_total target amount the purse should reach
- * @param denom_pub denomination public key of @a coin_pub
- * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
- */
-static enum GNUNET_GenericReturnValue
-handle_purse_deposits (
- void *cls,
- uint64_t rowid,
- const struct TALER_EXCHANGEDB_PurseDeposit *deposit,
- const struct TALER_ReservePublicKeyP *reserve_pub,
- enum TALER_WalletAccountMergeFlags flags,
- const struct TALER_Amount *auditor_balance,
- const struct TALER_Amount *purse_total,
- const struct TALER_DenominationPublicKey *denom_pub)
-{
- struct ReserveContext *rc = cls;
- const char *base_url
- = (NULL == deposit->exchange_base_url)
- ? TALER_ARL_exchange_url
- : deposit->exchange_base_url;
- enum GNUNET_DB_QueryStatus qs;
- struct TALER_Amount amount_minus_fee;
- struct TALER_Amount new_balance;
- struct ReserveSummary *rs;
- struct TALER_DenominationHashP h_denom_pub;
-
- /* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_purse_deposits_serial_id);
- ppr.last_purse_deposits_serial_id = rowid + 1;
-
- {
- const struct TALER_EXCHANGEDB_DenominationKeyInformation *issue;
- enum GNUNET_DB_QueryStatus qs;
-
- qs = TALER_ARL_get_denomination_info (denom_pub,
- &issue,
- &h_denom_pub);
- if (0 > qs)
- {
- GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
- if (GNUNET_DB_STATUS_HARD_ERROR == qs)
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Hard database error trying to get denomination %s from database!\n",
- TALER_B2S (denom_pub));
- rc->qs = qs;
- return GNUNET_SYSERR;
- }
- if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qs)
- {
- report_row_inconsistency ("purse-deposit",
- rowid,
- "denomination key not found");
- if (TALER_ARL_do_abort ())
- return GNUNET_SYSERR;
- return GNUNET_OK;
- }
- TALER_ARL_amount_subtract (&amount_minus_fee,
- &deposit->amount,
- &issue->fees.deposit);
- }
-
- if (GNUNET_OK !=
- TALER_wallet_purse_deposit_verify (base_url,
- &deposit->purse_pub,
- &deposit->amount,
- &h_denom_pub,
- &deposit->h_age_commitment,
- &deposit->coin_pub,
- &deposit->coin_sig))
- {
- TALER_ARL_report (report_bad_sig_losses,
- GNUNET_JSON_PACK (
- GNUNET_JSON_pack_string ("operation",
- "purse-deposit"),
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("loss",
- &deposit->amount),
- GNUNET_JSON_pack_data_auto ("key_pub",
- &deposit->coin_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
- &deposit->amount);
- return GNUNET_OK;
- }
-
- TALER_ARL_amount_add (&new_balance,
- auditor_balance,
- &amount_minus_fee);
- qs = TALER_ARL_edb->set_purse_balance (TALER_ARL_edb->cls,
- &deposit->purse_pub,
- &new_balance);
- GNUNET_assert (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS != qs);
- if (qs < 0)
- {
- GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
- GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs);
- rc->qs = qs;
- return GNUNET_SYSERR;
- }
- if (TALER_WAMF_MODE_CREATE_WITH_PURSE_FEE !=
- (flags & TALER_WAMF_MERGE_MODE_MASK))
- {
- /* This just created the purse, actual credit to
- the reserve will be done in handle_account_merged() */
- return GNUNET_OK;
- }
- if ( (NULL != deposit->exchange_base_url) &&
- (0 != strcmp (deposit->exchange_base_url,
- TALER_ARL_exchange_url)) )
- {
- /* credited reserve is at another exchange, do NOT credit here! */
- return GNUNET_OK;
- }
-
- rs = setup_reserve (rc,
- reserve_pub);
- if (NULL == rs)
- {
- GNUNET_break (0);
- return GNUNET_SYSERR;
- }
- if ( (-1 != TALER_amount_cmp (&new_balance,
- purse_total)) &&
- (-1 == TALER_amount_cmp (auditor_balance,
- purse_total)) )
- {
- /* new balance at or above purse_total
- (and previous balance was below); thus
- credit reserve with purse value! */
- TALER_ARL_amount_add (&rs->total_in,
- &rs->total_in,
- purse_total);
- }
- return GNUNET_OK;
-}
-
-
-/**
- * Function called with details about purse
- * merges that have been made, with
- * the goal of auditing the purse merge execution.
- *
- * @param cls closure
- * @param rowid unique serial ID for the deposit in our DB
- * @param partner_base_url where is the reserve, NULL for this exchange
- * @param amount total amount expected in the purse
- * @param balance current balance in the purse (according to the auditor)
- * @param flags purse flags
- * @param merge_pub merge capability key
- * @param reserve_pub reserve the merge affects
- * @param merge_sig signature affirming the merge
- * @param purse_pub purse key
- * @param merge_timestamp when did the merge happen
- * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
- */
-static enum GNUNET_GenericReturnValue
-handle_purse_merged (
- void *cls,
- uint64_t rowid,
- const char *partner_base_url,
- const struct TALER_Amount *amount,
- const struct TALER_Amount *balance,
- enum TALER_WalletAccountMergeFlags flags,
- const struct TALER_PurseMergePublicKeyP *merge_pub,
- const struct TALER_ReservePublicKeyP *reserve_pub,
- const struct TALER_PurseMergeSignatureP *merge_sig,
- const struct TALER_PurseContractPublicKeyP *purse_pub,
- struct GNUNET_TIME_Timestamp merge_timestamp)
-{
- struct ReserveContext *rc = cls;
- struct ReserveSummary *rs;
- char *reserve_url;
-
- /* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_purse_merges_serial_id);
- ppr.last_purse_merges_serial_id = rowid + 1;
- reserve_url
- = TALER_reserve_make_payto (NULL == partner_base_url
- ? TALER_ARL_exchange_url
- : partner_base_url,
- reserve_pub);
- if (GNUNET_OK !=
- TALER_wallet_purse_merge_verify (reserve_url,
- merge_timestamp,
- purse_pub,
- merge_pub,
- merge_sig))
- {
- GNUNET_free (reserve_url);
- TALER_ARL_report (report_bad_sig_losses,
- GNUNET_JSON_PACK (
- GNUNET_JSON_pack_string ("operation",
- "merge-purse"),
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("loss",
- amount),
- GNUNET_JSON_pack_data_auto ("key_pub",
- merge_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
- amount);
- return GNUNET_OK;
- }
- GNUNET_free (reserve_url);
- if (TALER_WAMF_MODE_CREATE_WITH_PURSE_FEE ==
- (flags & TALER_WAMF_MERGE_MODE_MASK))
- {
- /* This just created the purse, actual credit to
- the reserve will be done in handle_purse_deposits() */
- return GNUNET_OK;
- }
- if ( (NULL != partner_base_url) &&
- (0 != strcmp (partner_base_url,
- TALER_ARL_exchange_url)) )
- {
- /* credited reserve is at another exchange, do NOT credit here! */
- return GNUNET_OK;
- }
- rs = setup_reserve (rc,
- reserve_pub);
- if (NULL == rs)
- {
- GNUNET_break (0);
- return GNUNET_SYSERR;
- }
- if (-1 == TALER_amount_cmp (balance,
- amount))
- {
- struct TALER_Amount loss;
-
- TALER_ARL_amount_subtract (&loss,
- amount,
- balance);
- /* illegal merge, balance is still below total purse value */
- TALER_ARL_report (report_purse_balance_insufficient_inconsistencies,
- GNUNET_JSON_PACK (
- GNUNET_JSON_pack_string ("operation",
- "merge-purse"),
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("loss",
- &loss),
- GNUNET_JSON_pack_data_auto ("purse_pub",
- purse_pub)));
- TALER_ARL_amount_add (&total_balance_insufficient_loss,
- &total_balance_insufficient_loss,
- &loss);
- return GNUNET_OK;
- }
- TALER_ARL_amount_add (&rs->total_in,
- &rs->total_in,
- amount);
- // rs->a_expiration_date = FIXME: do we care? If so, set to what (so that the auditor no longer complains about the reserve not being closed)
- return GNUNET_OK;
-}
-
-
-/**
- * Function called with details about
- * account merge requests that have been made, with
- * the goal of auditing the account merge execution.
- *
- * @param cls closure
- * @param rowid unique serial ID for the deposit in our DB
- * @param reserve_pub reserve affected by the merge
- * @param purse_pub purse being merged
- * @param h_contract_terms hash over contract of the purse
- * @param purse_expiration when would the purse expire
- * @param amount total amount in the purse
- * @param min_age minimum age of all coins deposited into the purse
- * @param flags how was the purse created
- * @param purse_fee if a purse fee was paid, how high is it
- * @param merge_timestamp when was the merge approved
- * @param reserve_sig signature by reserve approving the merge
- * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
- */
-static enum GNUNET_GenericReturnValue
-handle_account_merged (
- void *cls,
- uint64_t rowid,
- const struct TALER_ReservePublicKeyP *reserve_pub,
- const struct TALER_PurseContractPublicKeyP *purse_pub,
- const struct TALER_PrivateContractHashP *h_contract_terms,
- struct GNUNET_TIME_Timestamp purse_expiration,
- const struct TALER_Amount *amount,
- uint32_t min_age,
- enum TALER_WalletAccountMergeFlags flags,
- const struct TALER_Amount *purse_fee,
- struct GNUNET_TIME_Timestamp merge_timestamp,
- const struct TALER_ReserveSignatureP *reserve_sig)
-{
- struct ReserveContext *rc = cls;
- struct ReserveSummary *rs;
-
- /* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_account_merges_serial_id);
- ppr.last_account_merges_serial_id = rowid + 1;
- if (GNUNET_OK !=
- TALER_wallet_account_merge_verify (merge_timestamp,
- purse_pub,
- purse_expiration,
- h_contract_terms,
- amount,
- purse_fee,
- min_age,
- flags,
- reserve_pub,
- reserve_sig))
- {
- TALER_ARL_report (report_bad_sig_losses,
- GNUNET_JSON_PACK (
- GNUNET_JSON_pack_string ("operation",
- "account-merge"),
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("loss",
- purse_fee),
- GNUNET_JSON_pack_data_auto ("key_pub",
- reserve_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
- purse_fee);
- return GNUNET_OK;
- }
- rs = setup_reserve (rc,
- reserve_pub);
- if (NULL == rs)
- {
- GNUNET_break (0);
- return GNUNET_SYSERR;
- }
- TALER_ARL_amount_add (&total_purse_fee_income,
- &total_purse_fee_income,
- purse_fee);
- TALER_ARL_amount_add (&rs->total_out,
- &rs->total_out,
- purse_fee);
- return GNUNET_OK;
-}
-
-
-/**
- * Function called with details about
- * history requests that have been made, with
- * the goal of auditing the history request execution.
- *
- * @param cls closure
- * @param rowid unique serial ID for the deposit in our DB
- * @param history_fee fee paid for the request
- * @param ts timestamp of the request
- * @param reserve_pub reserve history was requested for
- * @param reserve_sig signature approving the @a history_fee
- * @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
- */
-static enum GNUNET_GenericReturnValue
-handle_history_request (
- void *cls,
- uint64_t rowid,
- const struct TALER_Amount *history_fee,
- const struct GNUNET_TIME_Timestamp ts,
- const struct TALER_ReservePublicKeyP *reserve_pub,
- const struct TALER_ReserveSignatureP *reserve_sig)
-{
- struct ReserveContext *rc = cls;
- struct ReserveSummary *rs;
-
- /* should be monotonically increasing */
- GNUNET_assert (rowid >= ppr.last_history_requests_serial_id);
- ppr.last_history_requests_serial_id = rowid + 1;
- if (GNUNET_OK !=
- TALER_wallet_reserve_history_verify (ts,
- history_fee,
- reserve_pub,
- reserve_sig))
- {
- TALER_ARL_report (report_bad_sig_losses,
- GNUNET_JSON_PACK (
- GNUNET_JSON_pack_string ("operation",
- "account-history"),
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("loss",
- history_fee),
- GNUNET_JSON_pack_data_auto ("key_pub",
- reserve_pub)));
- TALER_ARL_amount_add (&total_bad_sig_loss,
- &total_bad_sig_loss,
- history_fee);
- return GNUNET_OK;
- }
- rs = setup_reserve (rc,
- reserve_pub);
- if (NULL == rs)
- {
- GNUNET_break (0);
- return GNUNET_SYSERR;
- }
- TALER_ARL_amount_add (&total_history_fee_income,
- &total_history_fee_income,
- history_fee);
- TALER_ARL_amount_add (&rs->total_out,
- &rs->total_out,
- history_fee);
- return GNUNET_OK;
-}
-
-
-/**
* Analyze reserves for being well-formed.
*
* @param cls NULL
@@ -1691,9 +1606,17 @@ analyze_reserves (void *cls)
(void) cls;
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
"Analyzing reserves\n");
- qsp = TALER_ARL_adb->get_auditor_progress_reserve (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppr);
+ qsp = TALER_ARL_adb->get_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_PP (reserves_reserve_in_serial_id),
+ TALER_ARL_GET_PP (reserves_reserve_out_serial_id),
+ TALER_ARL_GET_PP (reserves_reserve_recoup_serial_id),
+ TALER_ARL_GET_PP (reserves_reserve_open_serial_id),
+ TALER_ARL_GET_PP (reserves_reserve_close_serial_id),
+ TALER_ARL_GET_PP (reserves_purse_decisions_serial_id),
+ TALER_ARL_GET_PP (reserves_account_merges_serial_id),
+ TALER_ARL_GET_PP (reserves_history_requests_serial_id),
+ NULL);
if (0 > qsp)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsp);
@@ -1706,26 +1629,36 @@ analyze_reserves (void *cls)
}
else
{
- ppr_start = ppr;
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Resuming reserve audit at %llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
- (unsigned long long) ppr.last_reserve_in_serial_id,
- (unsigned long long) ppr.last_reserve_out_serial_id,
- (unsigned long long) ppr.last_reserve_recoup_serial_id,
- (unsigned long long) ppr.last_reserve_close_serial_id,
- (unsigned long long) ppr.last_purse_merges_serial_id,
- (unsigned long long) ppr.last_purse_deposits_serial_id,
- (unsigned long long) ppr.last_account_merges_serial_id,
- (unsigned long long) ppr.last_history_requests_serial_id,
- (unsigned long long) ppr.last_close_requests_serial_id);
+ "Resuming reserve audit at %llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_in_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_out_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_recoup_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_open_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_close_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_purse_decisions_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_account_merges_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_history_requests_serial_id));
}
rc.qs = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
- qsx = TALER_ARL_adb->get_reserve_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_withdraw_fee_income,
- &total_purse_fee_income,
- &total_history_fee_income);
+ qsx = TALER_ARL_adb->get_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_AB (reserves_reserve_total_balance),
+ TALER_ARL_GET_AB (reserves_reserve_loss),
+ TALER_ARL_GET_AB (reserves_withdraw_fee_revenue),
+ TALER_ARL_GET_AB (reserves_close_fee_revenue),
+ TALER_ARL_GET_AB (reserves_purse_fee_revenue),
+ TALER_ARL_GET_AB (reserves_open_fee_revenue),
+ TALER_ARL_GET_AB (reserves_history_fee_revenue),
+ NULL);
if (qsx < 0)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsx);
@@ -1735,10 +1668,9 @@ analyze_reserves (void *cls)
GNUNET_NO);
rc.revoked = GNUNET_CONTAINER_multihashmap_create (4,
GNUNET_NO);
-
qs = TALER_ARL_edb->select_reserves_in_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_reserve_in_serial_id,
+ TALER_ARL_USE_PP (reserves_reserve_in_serial_id),
&handle_reserve_in,
&rc);
if (qs < 0)
@@ -1748,7 +1680,7 @@ analyze_reserves (void *cls)
}
qs = TALER_ARL_edb->select_withdrawals_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_reserve_out_serial_id,
+ TALER_ARL_USE_PP (reserves_reserve_out_serial_id),
&handle_reserve_out,
&rc);
if (qs < 0)
@@ -1758,7 +1690,7 @@ analyze_reserves (void *cls)
}
qs = TALER_ARL_edb->select_recoup_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_reserve_recoup_serial_id,
+ TALER_ARL_USE_PP (reserves_reserve_recoup_serial_id),
&handle_recoup_by_reserve,
&rc);
if (qs < 0)
@@ -1766,72 +1698,51 @@ analyze_reserves (void *cls)
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
- qs = TALER_ARL_edb->select_reserve_closed_above_serial_id (
- TALER_ARL_edb->cls,
- ppr.last_reserve_close_serial_id,
- &handle_reserve_closed,
- &rc);
- if (qs < 0)
- {
- GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
- return qs;
- }
- qs = TALER_ARL_edb->select_purse_deposits_above_serial_id (
- TALER_ARL_edb->cls,
- ppr.last_purse_deposits_serial_id,
- &handle_purse_deposits,
- &rc);
- if (qs < 0)
- {
- GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
- return qs;
- }
- /* Charge purse fee! */
- qs = TALER_ARL_edb->select_account_merges_above_serial_id (
+ qs = TALER_ARL_edb->select_reserve_open_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_account_merges_serial_id,
- &handle_account_merged,
+ TALER_ARL_USE_PP (reserves_reserve_open_serial_id),
+ &handle_reserve_open,
&rc);
if (qs < 0)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
- /* Credit purse value (if last op)! */
- qs = TALER_ARL_edb->select_purse_merges_above_serial_id (
+ qs = TALER_ARL_edb->select_reserve_closed_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_purse_merges_serial_id,
- &handle_purse_merged,
+ TALER_ARL_USE_PP (reserves_reserve_close_serial_id),
+ &handle_reserve_closed,
&rc);
if (qs < 0)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
- /* Charge history fee! */
- qs = TALER_ARL_edb->select_history_requests_above_serial_id (
- TALER_ARL_edb->cls,
- ppr.last_history_requests_serial_id,
- &handle_history_request,
- &rc);
- if (qs < 0)
+ /* process purse_decisions (to credit reserve) */
+ if (0 >
+ (qs = TALER_ARL_edb->select_purse_decisions_above_serial_id (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (reserves_purse_decisions_serial_id),
+ false, /* only go for merged purses! */
+ &purse_decision_cb,
+ &rc)))
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
-#if 0
- /* FIXME #7269 (support for explicit reserve closure request) */
- qs = TALER_ARL_edb->select_close_requests_above_serial_id (
+ if (0 > rc.qs)
+ return rc.qs;
+ /* Charge purse fee! */
+ qs = TALER_ARL_edb->select_account_merges_above_serial_id (
TALER_ARL_edb->cls,
- ppr.last_close_requests_serial_id,
- &handle_close_request,
+ TALER_ARL_USE_PP (reserves_account_merges_serial_id),
+ &handle_account_merged,
&rc);
if (qs < 0)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
return qs;
}
-#endif
GNUNET_CONTAINER_multihashmap_iterate (rc.reserves,
&verify_reserve_balance,
&rc);
@@ -1839,27 +1750,33 @@ analyze_reserves (void *cls)
GNUNET_CONTAINER_multihashmap_size (rc.reserves));
GNUNET_CONTAINER_multihashmap_destroy (rc.reserves);
GNUNET_CONTAINER_multihashmap_destroy (rc.revoked);
-
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != rc.qs)
return qs;
-
if (GNUNET_DB_STATUS_SUCCESS_NO_RESULTS == qsx)
{
- qs = TALER_ARL_adb->insert_reserve_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_withdraw_fee_income,
- &total_purse_fee_income,
- &total_history_fee_income);
+ qs = TALER_ARL_adb->insert_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (reserves_reserve_total_balance),
+ TALER_ARL_SET_AB (reserves_reserve_loss),
+ TALER_ARL_SET_AB (reserves_withdraw_fee_revenue),
+ TALER_ARL_SET_AB (reserves_close_fee_revenue),
+ TALER_ARL_SET_AB (reserves_purse_fee_revenue),
+ TALER_ARL_SET_AB (reserves_open_fee_revenue),
+ TALER_ARL_SET_AB (reserves_history_fee_revenue),
+ NULL);
}
else
{
- qs = TALER_ARL_adb->update_reserve_summary (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &total_escrow_balance,
- &total_withdraw_fee_income,
- &total_purse_fee_income,
- &total_history_fee_income);
+ qs = TALER_ARL_adb->update_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (reserves_reserve_total_balance),
+ TALER_ARL_SET_AB (reserves_reserve_loss),
+ TALER_ARL_SET_AB (reserves_withdraw_fee_revenue),
+ TALER_ARL_SET_AB (reserves_close_fee_revenue),
+ TALER_ARL_SET_AB (reserves_purse_fee_revenue),
+ TALER_ARL_SET_AB (reserves_open_fee_revenue),
+ TALER_ARL_SET_AB (reserves_history_fee_revenue),
+ NULL);
}
if (0 >= qs)
{
@@ -1867,13 +1784,29 @@ analyze_reserves (void *cls)
return qs;
}
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsp)
- qs = TALER_ARL_adb->update_auditor_progress_reserve (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppr);
+ qs = TALER_ARL_adb->update_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (reserves_reserve_in_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_out_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_recoup_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_open_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_close_serial_id),
+ TALER_ARL_SET_PP (reserves_purse_decisions_serial_id),
+ TALER_ARL_SET_PP (reserves_account_merges_serial_id),
+ TALER_ARL_SET_PP (reserves_history_requests_serial_id),
+ NULL);
else
- qs = TALER_ARL_adb->insert_auditor_progress_reserve (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &ppr);
+ qs = TALER_ARL_adb->insert_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (reserves_reserve_in_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_out_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_recoup_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_open_serial_id),
+ TALER_ARL_SET_PP (reserves_reserve_close_serial_id),
+ TALER_ARL_SET_PP (reserves_purse_decisions_serial_id),
+ TALER_ARL_SET_PP (reserves_account_merges_serial_id),
+ TALER_ARL_SET_PP (reserves_history_requests_serial_id),
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -1882,16 +1815,23 @@ analyze_reserves (void *cls)
return qs;
}
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Concluded reserve audit step at %llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
- (unsigned long long) ppr.last_reserve_in_serial_id,
- (unsigned long long) ppr.last_reserve_out_serial_id,
- (unsigned long long) ppr.last_reserve_recoup_serial_id,
- (unsigned long long) ppr.last_reserve_close_serial_id,
- (unsigned long long) ppr.last_purse_merges_serial_id,
- (unsigned long long) ppr.last_purse_deposits_serial_id,
- (unsigned long long) ppr.last_account_merges_serial_id,
- (unsigned long long) ppr.last_history_requests_serial_id,
- (unsigned long long) ppr.last_close_requests_serial_id);
+ "Concluded reserve audit step at %llu/%llu/%llu/%llu/%llu/%llu/%llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_in_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_out_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_recoup_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_open_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_reserve_close_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_purse_decisions_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_account_merges_serial_id),
+ (unsigned long long) TALER_ARL_USE_PP (
+ reserves_history_requests_serial_id));
return GNUNET_DB_STATUS_SUCCESS_ONE_RESULT;
}
@@ -1937,22 +1877,33 @@ run (void *cls,
"Starting audit\n");
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_escrow_balance));
+ &TALER_ARL_USE_AB (
+ reserves_reserve_total_balance)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_irregular_recoups));
+ &TALER_ARL_USE_AB (
+ reserves_reserve_loss)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_withdraw_fee_income));
+ &TALER_ARL_USE_AB (
+ reserves_withdraw_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_history_fee_income));
+ &TALER_ARL_USE_AB (
+ reserves_close_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_purse_fee_income));
+ &TALER_ARL_USE_AB (
+ reserves_purse_fee_revenue)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_balance_insufficient_loss));
+ &TALER_ARL_USE_AB (
+ reserves_open_fee_revenue)));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &TALER_ARL_USE_AB (
+ reserves_history_fee_revenue)));
+ // REVIEW:
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_balance_summary_delta_plus));
@@ -1971,6 +1922,7 @@ run (void *cls,
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_bad_sig_loss));
+
GNUNET_assert (NULL !=
(report_row_inconsistencies = json_array ()));
GNUNET_assert (NULL !=
@@ -2002,15 +1954,6 @@ run (void *cls,
}
TALER_ARL_done (
GNUNET_JSON_PACK (
- GNUNET_JSON_pack_array_steal (
- "reserve_balance_insufficient_inconsistencies",
- report_reserve_balance_insufficient_inconsistencies),
- GNUNET_JSON_pack_array_steal (
- "purse_balance_insufficient_inconsistencies",
- report_purse_balance_insufficient_inconsistencies),
- /* Tested in test-auditor.sh #3 */
- TALER_JSON_pack_amount ("total_loss_balance_insufficient",
- &total_balance_insufficient_loss),
/* Tested in test-auditor.sh #3 */
GNUNET_JSON_pack_array_steal (
"reserve_balance_summary_wrong_inconsistencies",
@@ -2019,26 +1962,49 @@ run (void *cls,
&total_balance_summary_delta_plus),
TALER_JSON_pack_amount ("total_balance_summary_delta_minus",
&total_balance_summary_delta_minus),
+ /* Tested in test-auditor.sh #21 */
+ TALER_JSON_pack_amount ("total_balance_reserve_not_closed",
+ &total_balance_reserve_not_closed),
+ /* Tested in test-auditor.sh #7 */
+ TALER_JSON_pack_amount ("total_bad_sig_loss",
+ &total_bad_sig_loss),
+ TALER_JSON_pack_amount ("total_arithmetic_delta_plus",
+ &total_arithmetic_delta_plus),
+ TALER_JSON_pack_amount ("total_arithmetic_delta_minus",
+ &total_arithmetic_delta_minus),
+
+ /* Global 'balances' */
TALER_JSON_pack_amount ("total_escrow_balance",
- &total_escrow_balance),
+ &TALER_ARL_USE_AB (
+ reserves_reserve_total_balance)),
+ /* Tested in test-auditor.sh #3 */
+ TALER_JSON_pack_amount ("total_irregular_loss",
+ &TALER_ARL_USE_AB (reserves_reserve_loss)),
TALER_JSON_pack_amount ("total_withdraw_fee_income",
- &total_withdraw_fee_income),
- TALER_JSON_pack_amount ("total_history_fee_income",
- &total_history_fee_income),
+ &TALER_ARL_USE_AB (
+ reserves_withdraw_fee_revenue)),
+ TALER_JSON_pack_amount ("total_close_fee_income",
+ &TALER_ARL_USE_AB (reserves_close_fee_revenue)),
TALER_JSON_pack_amount ("total_purse_fee_income",
- &total_purse_fee_income),
+ &TALER_ARL_USE_AB (reserves_purse_fee_revenue)),
+ TALER_JSON_pack_amount ("total_open_fee_income",
+ &TALER_ARL_USE_AB (reserves_open_fee_revenue)),
+ TALER_JSON_pack_amount ("total_history_fee_income",
+ &TALER_ARL_USE_AB (reserves_history_fee_revenue)),
+
+ /* Detailed report tables */
+ GNUNET_JSON_pack_array_steal (
+ "reserve_balance_insufficient_inconsistencies",
+ report_reserve_balance_insufficient_inconsistencies),
+ GNUNET_JSON_pack_array_steal (
+ "purse_balance_insufficient_inconsistencies",
+ report_purse_balance_insufficient_inconsistencies),
/* Tested in test-auditor.sh #21 */
GNUNET_JSON_pack_array_steal ("reserve_not_closed_inconsistencies",
report_reserve_not_closed_inconsistencies),
- /* Tested in test-auditor.sh #21 */
- TALER_JSON_pack_amount ("total_balance_reserve_not_closed",
- &total_balance_reserve_not_closed),
/* Tested in test-auditor.sh #7 */
GNUNET_JSON_pack_array_steal ("bad_sig_losses",
report_bad_sig_losses),
- /* Tested in test-auditor.sh #7 */
- TALER_JSON_pack_amount ("total_bad_sig_loss",
- &total_bad_sig_loss),
/* Tested in test-revocation.sh #4 */
GNUNET_JSON_pack_array_steal ("row_inconsistencies",
report_row_inconsistencies),
@@ -2048,42 +2014,52 @@ run (void *cls,
denomination_key_validity_withdraw_inconsistencies),
GNUNET_JSON_pack_array_steal ("amount_arithmetic_inconsistencies",
report_amount_arithmetic_inconsistencies),
- TALER_JSON_pack_amount ("total_arithmetic_delta_plus",
- &total_arithmetic_delta_plus),
- TALER_JSON_pack_amount ("total_arithmetic_delta_minus",
- &total_arithmetic_delta_minus),
+
+ /* Information about audited range ... */
TALER_JSON_pack_time_abs_human ("auditor_start_time",
start_time),
TALER_JSON_pack_time_abs_human ("auditor_end_time",
GNUNET_TIME_absolute_get ()),
- TALER_JSON_pack_amount ("total_irregular_recoups",
- &total_irregular_recoups),
GNUNET_JSON_pack_uint64 ("start_ppr_reserve_in_serial_id",
- ppr_start.last_reserve_in_serial_id),
+ 0 /* no longer supported */),
GNUNET_JSON_pack_uint64 ("start_ppr_reserve_out_serial_id",
- ppr_start.last_reserve_out_serial_id),
+ 0 /* no longer supported */),
GNUNET_JSON_pack_uint64 ("start_ppr_reserve_recoup_serial_id",
- ppr_start.last_reserve_recoup_serial_id),
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("start_ppr_reserve_open_serial_id",
+ 0 /* no longer supported */),
GNUNET_JSON_pack_uint64 ("start_ppr_reserve_close_serial_id",
- ppr_start.last_reserve_close_serial_id),
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("start_ppr_purse_decisions_serial_id",
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("start_ppr_account_merges_serial_id",
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("start_ppr_history_requests_serial_id",
+ 0 /* no longer supported */),
GNUNET_JSON_pack_uint64 ("end_ppr_reserve_in_serial_id",
- ppr.last_reserve_in_serial_id),
+ TALER_ARL_USE_PP (
+ reserves_reserve_in_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppr_reserve_out_serial_id",
- ppr.last_reserve_out_serial_id),
+ TALER_ARL_USE_PP (
+ reserves_reserve_out_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppr_reserve_recoup_serial_id",
- ppr.last_reserve_recoup_serial_id),
+ TALER_ARL_USE_PP (
+ reserves_reserve_recoup_serial_id)),
+ GNUNET_JSON_pack_uint64 ("end_ppr_reserve_open_serial_id",
+ TALER_ARL_USE_PP (
+ reserves_reserve_open_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppr_reserve_close_serial_id",
- ppr.last_reserve_close_serial_id),
- GNUNET_JSON_pack_uint64 ("end_ppr_purse_merges_serial_id",
- ppr.last_purse_merges_serial_id),
- GNUNET_JSON_pack_uint64 ("end_ppr_purse_deposits_serial_id",
- ppr.last_purse_deposits_serial_id),
+ TALER_ARL_USE_PP (
+ reserves_reserve_close_serial_id)),
+ GNUNET_JSON_pack_uint64 ("end_ppr_purse_decisions_serial_id",
+ TALER_ARL_USE_PP (
+ reserves_purse_decisions_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppr_account_merges_serial_id",
- ppr.last_account_merges_serial_id),
+ TALER_ARL_USE_PP (
+ reserves_account_merges_serial_id)),
GNUNET_JSON_pack_uint64 ("end_ppr_history_requests_serial_id",
- ppr.last_history_requests_serial_id),
- GNUNET_JSON_pack_uint64 ("end_ppr_close_requests_serial_id",
- ppr.last_close_requests_serial_id)));
+ TALER_ARL_USE_PP (
+ reserves_history_requests_serial_id))));
}
@@ -2103,11 +2079,10 @@ main (int argc,
"internal",
"perform checks only applicable for exchange-internal audits",
&internal_checks),
- GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &TALER_ARL_master_pub),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
GNUNET_GETOPT_option_timetravel ('T',
"timetravel"),
GNUNET_GETOPT_OPTION_END
diff --git a/src/auditor/taler-helper-auditor-wire.c b/src/auditor/taler-helper-auditor-wire.c
index f9c87b6f0..d48ac1f18 100644
--- a/src/auditor/taler-helper-auditor-wire.c
+++ b/src/auditor/taler-helper-auditor-wire.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2017-2022 Taler Systems SA
+ Copyright (C) 2017-2023 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
@@ -53,6 +53,20 @@
/**
+ * Run in test mode. Exit when idle instead of
+ * going to sleep and waiting for more work.
+ *
+ * FIXME: not yet implemented!
+ */
+static int test_mode;
+
+struct TALER_AUDITORDB_WireAccountProgressPoint
+{
+ uint64_t last_reserve_in_serial_id;
+ uint64_t last_wire_out_serial_id;
+};
+
+/**
* Information we keep for each supported account.
*/
struct WireAccount
@@ -93,14 +107,34 @@ struct WireAccount
struct TALER_AUDITORDB_WireAccountProgressPoint start_pp;
/**
- * Where we are in the inbound (CREDIT) transaction history.
+ * Where we are in the inbound transaction history.
+ */
+ uint64_t wire_off_in;
+
+ /**
+ * Where we are in the outbound transaction history.
*/
- uint64_t in_wire_off;
+ uint64_t wire_off_out;
/**
- * Where we are in the inbound (DEBIT) transaction history.
+ * Label under which we store our pp's reserve_in_serial_id.
*/
- uint64_t out_wire_off;
+ char *label_reserve_in_serial_id;
+
+ /**
+ * Label under which we store our pp's reserve_in_serial_id.
+ */
+ char *label_wire_out_serial_id;
+
+ /**
+ * Label under which we store our wire_off_in.
+ */
+ char *label_wire_off_in;
+
+ /**
+ * Label under which we store our wire_off_out.
+ */
+ char *label_wire_off_out;
/**
* Return value when we got this account's progress point.
@@ -183,20 +217,17 @@ static enum GNUNET_DB_QueryStatus qsx_gwap;
/**
* Last reserve_in / wire_out serial IDs seen.
*/
-static struct TALER_AUDITORDB_WireProgressPoint pp;
+static TALER_ARL_DEF_PP (wire_reserve_close_id);
+static TALER_ARL_DEF_PP (wire_batch_deposit_id);
+static TALER_ARL_DEF_PP (wire_aggregation_id);
/**
- * Last reserve_in / wire_out serial IDs seen.
- */
-static struct TALER_AUDITORDB_WireProgressPoint start_pp;
-
-/**
- * Array of reports about row inconsitencies in wire_out table.
+ * Array of reports about row inconsistencies in wire_out table.
*/
static json_t *report_wire_out_inconsistencies;
/**
- * Array of reports about row inconsitencies in reserves_in table.
+ * Array of reports about row inconsistencies in reserves_in table.
*/
static json_t *report_reserve_in_inconsistencies;
@@ -204,7 +235,7 @@ static json_t *report_reserve_in_inconsistencies;
* Array of reports about wrong bank account being recorded for
* incoming wire transfers.
*/
-static json_t *report_missattribution_in_inconsistencies;
+static json_t *report_misattribution_in_inconsistencies;
/**
* Array of reports about row inconsistencies.
@@ -228,6 +259,16 @@ static json_t *report_row_minor_inconsistencies;
static json_t *report_lags;
/**
+ * Array of reports about lagging transactions from deposits due to missing KYC.
+ */
+static json_t *report_kyc_lags;
+
+/**
+ * Array of reports about lagging transactions from deposits due to pending or frozen AML decisions.
+ */
+static json_t *report_aml_lags;
+
+/**
* Array of reports about lagging transactions from reserve closures.
*/
static json_t *report_closure_lags;
@@ -267,7 +308,7 @@ static struct TALER_Amount total_bad_amount_in_minus;
* for incoming funds and may thus wire funds to the wrong
* destination when closing the reserve.
*/
-static struct TALER_Amount total_missattribution_in;
+static struct TALER_Amount total_misattribution_in;
/**
* Total amount which the exchange did not transfer in time.
@@ -297,17 +338,17 @@ static struct TALER_Amount total_wire_out;
/**
* Total amount of profits drained.
*/
-static struct TALER_Amount total_drained;
+static TALER_ARL_DEF_AB (total_drained);
/**
- * Starting balance at the beginning of this iteration.
+ * Final balance at the end of this iteration.
*/
-static struct TALER_Amount start_balance;
+static TALER_ARL_DEF_AB (final_balance);
/**
- * Final balance at the end of this iteration.
+ * Starting balance at the beginning of this iteration.
*/
-static struct TALER_Amount final_balance;
+static struct TALER_Amount start_balance;
/**
* True if #start_balance was initialized.
@@ -499,11 +540,11 @@ do_shutdown (void *cls)
TALER_JSON_pack_amount ("total_wire_in_delta_minus",
&total_bad_amount_in_minus),
/* Tested in test-auditor.sh #9 */
- GNUNET_JSON_pack_array_steal ("missattribution_in_inconsistencies",
- report_missattribution_in_inconsistencies),
+ GNUNET_JSON_pack_array_steal ("misattribution_in_inconsistencies",
+ report_misattribution_in_inconsistencies),
/* Tested in test-auditor.sh #9 */
- TALER_JSON_pack_amount ("total_missattribution_in",
- &total_missattribution_in),
+ TALER_JSON_pack_amount ("total_misattribution_in",
+ &total_misattribution_in),
GNUNET_JSON_pack_array_steal ("row_inconsistencies",
report_row_inconsistencies),
/* Tested in test-auditor.sh #10/#17 */
@@ -520,15 +561,19 @@ do_shutdown (void *cls)
TALER_JSON_pack_amount ("total_wire_out",
&total_wire_out),
TALER_JSON_pack_amount ("total_drained",
- &total_drained),
+ &TALER_ARL_USE_AB (total_drained)),
TALER_JSON_pack_amount ("final_balance",
- &final_balance),
+ &TALER_ARL_USE_AB (final_balance)),
/* Tested in test-auditor.sh #1 */
TALER_JSON_pack_amount ("total_amount_lag",
&total_amount_lag),
/* Tested in test-auditor.sh #1 */
GNUNET_JSON_pack_array_steal ("lag_details",
report_lags),
+ GNUNET_JSON_pack_array_steal ("lag_aml_details",
+ report_aml_lags),
+ GNUNET_JSON_pack_array_steal ("lag_kyc_details",
+ report_kyc_lags),
/* Tested in test-auditor.sh #22 */
TALER_JSON_pack_amount ("total_closure_amount_lag",
&total_closure_amount_lag),
@@ -539,22 +584,28 @@ do_shutdown (void *cls)
start_time),
TALER_JSON_pack_time_abs_human ("wire_auditor_end_time",
GNUNET_TIME_absolute_get ()),
- GNUNET_JSON_pack_uint64 ("start_pp_reserve_close_uuid",
- start_pp.last_reserve_close_uuid),
- GNUNET_JSON_pack_uint64 ("end_pp_reserve_close_uuid",
- pp.last_reserve_close_uuid),
- TALER_JSON_pack_time_abs_human ("start_pp_last_timestamp",
- start_pp.last_timestamp.abs_time),
- TALER_JSON_pack_time_abs_human ("end_pp_last_timestamp",
- pp.last_timestamp.abs_time),
+ GNUNET_JSON_pack_uint64 ("start_pp_reserve_close_id",
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("end_pp_reserve_close_id",
+ TALER_ARL_USE_PP (wire_reserve_close_id)),
+ GNUNET_JSON_pack_uint64 ("start_pp_last_batch_deposit_id",
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("end_pp_last_batch_deposit_id",
+ TALER_ARL_USE_PP (wire_batch_deposit_id)),
+ GNUNET_JSON_pack_uint64 ("start_pp_last_aggregation_serial_id",
+ 0 /* no longer supported */),
+ GNUNET_JSON_pack_uint64 ("end_pp_last_aggregation_serial_id",
+ TALER_ARL_USE_PP (wire_aggregation_id)),
GNUNET_JSON_pack_array_steal ("account_progress",
report_account_progress)));
report_wire_out_inconsistencies = NULL;
report_reserve_in_inconsistencies = NULL;
report_row_inconsistencies = NULL;
report_row_minor_inconsistencies = NULL;
- report_missattribution_in_inconsistencies = NULL;
+ report_misattribution_in_inconsistencies = NULL;
report_lags = NULL;
+ report_kyc_lags = NULL;
+ report_aml_lags = NULL;
report_closure_lags = NULL;
report_account_progress = NULL;
report_wire_format_inconsistencies = NULL;
@@ -602,6 +653,10 @@ do_shutdown (void *cls)
GNUNET_CONTAINER_DLL_remove (wa_head,
wa_tail,
wa);
+ GNUNET_free (wa->label_reserve_in_serial_id);
+ GNUNET_free (wa->label_wire_out_serial_id);
+ GNUNET_free (wa->label_wire_off_in);
+ GNUNET_free (wa->label_wire_off_out);
GNUNET_free (wa);
}
if (NULL != ctx)
@@ -656,8 +711,8 @@ check_pending_rc (void *cls,
&rc->wtid),
GNUNET_JSON_pack_string ("account",
rc->receiver_account)));
- pp.last_reserve_close_uuid
- = GNUNET_MIN (pp.last_reserve_close_uuid,
+ TALER_ARL_USE_PP (wire_reserve_close_id)
+ = GNUNET_MIN (TALER_ARL_USE_PP (wire_reserve_close_id),
rc->rowid);
return GNUNET_OK;
}
@@ -679,12 +734,12 @@ hash_rc (const char *receiver_account,
size_t slen = strlen (receiver_account);
char buf[sizeof (struct TALER_WireTransferIdentifierRawP) + slen];
- memcpy (buf,
- wtid,
- sizeof (*wtid));
- memcpy (&buf[sizeof (*wtid)],
- receiver_account,
- slen);
+ GNUNET_memcpy (buf,
+ wtid,
+ sizeof (*wtid));
+ GNUNET_memcpy (&buf[sizeof (*wtid)],
+ receiver_account,
+ slen);
GNUNET_CRYPTO_hash (buf,
sizeof (buf),
key);
@@ -709,25 +764,33 @@ commit (enum GNUNET_DB_QueryStatus qs)
TALER_ARL_amount_add (&sum,
&total_wire_in,
&start_balance);
- TALER_ARL_amount_subtract (&final_balance,
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (final_balance),
&sum,
&total_wire_out);
- qs = TALER_ARL_adb->update_predicted_result (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &final_balance,
- &total_drained);
+ qs = TALER_ARL_adb->update_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (total_drained),
+ TALER_ARL_SET_AB (final_balance),
+ NULL);
}
else
{
- TALER_ARL_amount_subtract (&final_balance,
+ TALER_ARL_amount_subtract (&TALER_ARL_USE_AB (final_balance),
&total_wire_in,
&total_wire_out);
- qs = TALER_ARL_adb->insert_predicted_result (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &final_balance,
- &total_drained);
+ qs = TALER_ARL_adb->insert_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_AB (total_drained),
+ TALER_ARL_SET_AB (final_balance),
+ NULL);
}
}
+ else
+ {
+ GNUNET_assert (GNUNET_OK ==
+ TALER_amount_set_zero (TALER_ARL_currency,
+ &TALER_ARL_USE_AB (final_balance)));
+ }
if (0 > qs)
{
if (GNUNET_DB_STATUS_SOFT_ERROR == qs)
@@ -756,26 +819,33 @@ commit (enum GNUNET_DB_QueryStatus qs)
GNUNET_JSON_pack_uint64 ("end_reserve_in",
wa->pp.last_reserve_in_serial_id),
GNUNET_JSON_pack_uint64 ("start_wire_out",
- wa->start_pp.
- last_wire_out_serial_id),
+ wa->start_pp.last_wire_out_serial_id),
GNUNET_JSON_pack_uint64 ("end_wire_out",
wa->pp.last_wire_out_serial_id))));
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == wa->qsx)
- qs = TALER_ARL_adb->update_wire_auditor_account_progress (
+ qs = TALER_ARL_adb->update_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- wa->ai->section_name,
- &wa->pp,
- wa->in_wire_off,
- wa->out_wire_off);
+ wa->label_reserve_in_serial_id,
+ wa->pp.last_reserve_in_serial_id,
+ wa->label_wire_out_serial_id,
+ wa->pp.last_wire_out_serial_id,
+ wa->label_wire_off_in,
+ wa->wire_off_in,
+ wa->label_wire_off_out,
+ wa->wire_off_out,
+ NULL);
else
- qs = TALER_ARL_adb->insert_wire_auditor_account_progress (
+ qs = TALER_ARL_adb->insert_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- wa->ai->section_name,
- &wa->pp,
- wa->in_wire_off,
- wa->out_wire_off);
+ wa->label_reserve_in_serial_id,
+ wa->pp.last_reserve_in_serial_id,
+ wa->label_wire_out_serial_id,
+ wa->pp.last_wire_out_serial_id,
+ wa->label_wire_off_in,
+ wa->wire_off_in,
+ wa->label_wire_off_out,
+ wa->wire_off_out,
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -788,13 +858,19 @@ commit (enum GNUNET_DB_QueryStatus qs)
&check_pending_rc,
NULL);
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qsx_gwap)
- qs = TALER_ARL_adb->update_wire_auditor_progress (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &pp);
+ qs = TALER_ARL_adb->update_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (wire_reserve_close_id),
+ TALER_ARL_SET_PP (wire_batch_deposit_id),
+ TALER_ARL_SET_PP (wire_aggregation_id),
+ NULL);
else
- qs = TALER_ARL_adb->insert_wire_auditor_progress (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &pp);
+ qs = TALER_ARL_adb->insert_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_SET_PP (wire_reserve_close_id),
+ TALER_ARL_SET_PP (wire_batch_deposit_id),
+ TALER_ARL_SET_PP (wire_aggregation_id),
+ NULL);
if (0 >= qs)
{
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
@@ -803,8 +879,9 @@ commit (enum GNUNET_DB_QueryStatus qs)
return qs;
}
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Concluded audit step at %s\n",
- GNUNET_TIME_timestamp2s (pp.last_timestamp));
+ "Concluded audit step at %llu/%llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (wire_aggregation_id),
+ (unsigned long long) TALER_ARL_USE_PP (wire_batch_deposit_id));
if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT == qs)
{
@@ -841,59 +918,341 @@ commit (enum GNUNET_DB_QueryStatus qs)
/* ***************************** Analyze required transfers ************************ */
/**
- * Function called on deposits that are past their due date
- * and have not yet seen a wire transfer.
+ * Closure for import_wire_missing_cb().
+ */
+struct ImportMissingWireContext
+{
+ /**
+ * Set to maximum row ID encountered.
+ */
+ uint64_t max_batch_deposit_uuid;
+
+ /**
+ * Set to database errors in callback.
+ */
+ enum GNUNET_DB_QueryStatus err;
+};
+
+
+/**
+ * Function called on deposits that need to be checked for their
+ * wire transfer.
*
- * @param cls closure
- * @param rowid deposit table row of the coin's deposit
- * @param coin_pub public key of the coin
- * @param amount value of the deposit, including fee
- * @param payto_uri where should the funds be wired
- * @param deadline what was the requested wire transfer deadline
- * @param done did the exchange claim that it made a transfer?
- * NOTE: only valid in internal audit mode!
+ * @param cls closure, points to a `struct ImportMissingWireContext`
+ * @param batch_deposit_serial_id serial of the entry in the batch deposits table
+ * @param total_amount value of the missing deposits, including fee
+ * @param wire_target_h_payto where should the funds be wired
+ * @param deadline what was the earliest requested wire transfer deadline
*/
static void
-wire_missing_cb (void *cls,
- uint64_t rowid,
- const struct TALER_CoinSpendPublicKeyP *coin_pub,
- const struct TALER_Amount *amount,
- const char *payto_uri,
- struct GNUNET_TIME_Timestamp deadline,
- bool done)
+import_wire_missing_cb (void *cls,
+ uint64_t batch_deposit_serial_id,
+ const struct TALER_Amount *total_amount,
+ const struct TALER_PaytoHashP *wire_target_h_payto,
+ struct GNUNET_TIME_Timestamp deadline)
{
- json_t *rep;
+ struct ImportMissingWireContext *wc = cls;
+ enum GNUNET_DB_QueryStatus qs;
+
+ if (wc->err < 0)
+ return; /* already failed */
+ GNUNET_assert (batch_deposit_serial_id > wc->max_batch_deposit_uuid);
+ wc->max_batch_deposit_uuid = batch_deposit_serial_id;
+ qs = TALER_ARL_adb->insert_pending_deposit (
+ TALER_ARL_adb->cls,
+ batch_deposit_serial_id,
+ wire_target_h_payto,
+ total_amount,
+ deadline);
+ if (qs < 0)
+ wc->err = qs;
+}
+
+
+/**
+ * Information about a delayed wire transfer and the possible
+ * reasons for the delay.
+ */
+struct ReasonDetail
+{
+ /**
+ * Total amount that should have been transferred.
+ */
+ struct TALER_Amount total_amount;
+
+ /**
+ * Earliest deadline for an expected transfer to the account.
+ */
+ struct GNUNET_TIME_Timestamp deadline;
+
+ /**
+ * Target account, NULL if even that is not known (due to
+ * exchange lacking required entry in wire_targets table).
+ */
+ char *payto_uri;
+
+ /**
+ * Reasons due to pending KYC requests.
+ */
+ char *kyc_pending;
+
+ /**
+ * AML decision state for the target account.
+ */
+ enum TALER_AmlDecisionState status;
+
+ /**
+ * Current AML threshold for the account, may be an invalid account if the
+ * default threshold applies.
+ */
+ struct TALER_Amount aml_limit;
+};
+
+/**
+ * Closure for report_wire_missing_cb().
+ */
+struct ReportMissingWireContext
+{
+ /**
+ * Map from wire_target_h_payto to `struct ReasonDetail`.
+ */
+ struct GNUNET_CONTAINER_MultiShortmap *map;
+
+ /**
+ * Set to database errors in callback.
+ */
+ enum GNUNET_DB_QueryStatus err;
+};
+
+
+/**
+ * Closure for #clear_finished_transfer_cb().
+ */
+struct AggregationContext
+{
+ /**
+ * Set to maximum row ID encountered.
+ */
+ uint64_t max_aggregation_serial;
+
+ /**
+ * Set to database errors in callback.
+ */
+ enum GNUNET_DB_QueryStatus err;
+};
+
+
+/**
+ * Free memory allocated in @a value.
+ *
+ * @param cls unused
+ * @param key unused
+ * @param value must be a `struct ReasonDetail`
+ * @return #GNUNET_YES if we should continue to
+ * iterate,
+ * #GNUNET_NO if not.
+ */
+static enum GNUNET_GenericReturnValue
+free_report_entry (void *cls,
+ const struct GNUNET_ShortHashCode *key,
+ void *value)
+{
+ struct ReasonDetail *rd = value;
+
+ GNUNET_free (rd->kyc_pending);
+ GNUNET_free (rd->payto_uri);
+ GNUNET_free (rd);
+ return GNUNET_YES;
+}
+
+
+/**
+ * We had an entry in our map of wire transfers that
+ * should have been performed. Generate report.
+ *
+ * @param cls unused
+ * @param key unused
+ * @param value must be a `struct ReasonDetail`
+ * @return #GNUNET_YES if we should continue to
+ * iterate,
+ * #GNUNET_NO if not.
+ */
+static enum GNUNET_GenericReturnValue
+generate_report (void *cls,
+ const struct GNUNET_ShortHashCode *key,
+ void *value)
+{
+ struct ReasonDetail *rd = value;
- (void) cls;
- TALER_ARL_amount_add (&total_amount_lag,
- &total_amount_lag,
- amount);
/* For now, we simplify and only check that the
amount was tiny */
- if (0 > TALER_amount_cmp (amount,
+ if (0 > TALER_amount_cmp (&rd->total_amount,
&tiny_amount))
- return; /* acceptable, amount was tiny */
- rep = GNUNET_JSON_PACK (
- GNUNET_JSON_pack_uint64 ("row",
- rowid),
- TALER_JSON_pack_amount ("amount",
- amount),
- TALER_JSON_pack_time_abs_human ("deadline",
- deadline.abs_time),
- GNUNET_JSON_pack_data_auto ("coin_pub",
- coin_pub),
- GNUNET_JSON_pack_string ("account",
- payto_uri));
- if (internal_checks)
+ return free_report_entry (cls,
+ key,
+ value); /* acceptable, amount was tiny */
+ // TODO: maybe split total_amount_lag up by category below?
+ TALER_ARL_amount_add (&total_amount_lag,
+ &total_amount_lag,
+ &rd->total_amount);
+ if (NULL != rd->kyc_pending)
+ {
+ json_t *rep;
+
+ rep = GNUNET_JSON_PACK (
+ TALER_JSON_pack_amount ("total_amount",
+ &rd->total_amount),
+ TALER_JSON_pack_time_abs_human ("deadline",
+ rd->deadline.abs_time),
+ GNUNET_JSON_pack_string ("kyc_pending",
+ rd->kyc_pending),
+ GNUNET_JSON_pack_allow_null (
+ GNUNET_JSON_pack_string ("account",
+ rd->payto_uri)));
+ TALER_ARL_report (report_kyc_lags,
+ rep);
+ }
+ else if (TALER_AML_NORMAL != rd->status)
+ {
+ const char *sstatus = "<undefined>";
+ json_t *rep;
+
+ switch (rd->status)
+ {
+ case TALER_AML_NORMAL:
+ GNUNET_assert (0);
+ break;
+ case TALER_AML_PENDING:
+ sstatus = "pending";
+ break;
+ case TALER_AML_FROZEN:
+ sstatus = "frozen";
+ break;
+ }
+ rep = GNUNET_JSON_PACK (
+ TALER_JSON_pack_amount ("total_amount",
+ &rd->total_amount),
+ GNUNET_JSON_pack_allow_null (
+ TALER_JSON_pack_amount ("aml_limit",
+ TALER_amount_is_valid (&rd->aml_limit)
+ ? &rd->aml_limit
+ : NULL)),
+ TALER_JSON_pack_time_abs_human ("deadline",
+ rd->deadline.abs_time),
+ GNUNET_JSON_pack_string ("aml_status",
+ sstatus),
+ GNUNET_JSON_pack_allow_null (
+ GNUNET_JSON_pack_string ("account",
+ rd->payto_uri)));
+ TALER_ARL_report (report_aml_lags,
+ rep);
+ }
+ else
{
- /* the 'done' bit is only useful in 'internal' mode */
- GNUNET_assert (0 ==
- json_object_set (rep,
- "claimed_done",
- json_string ((done) ? "yes" : "no")));
+ json_t *rep;
+
+ rep = GNUNET_JSON_PACK (
+ TALER_JSON_pack_amount ("total_amount",
+ &rd->total_amount),
+ TALER_JSON_pack_time_abs_human ("deadline",
+ rd->deadline.abs_time),
+ GNUNET_JSON_pack_allow_null (
+ GNUNET_JSON_pack_string ("account",
+ rd->payto_uri)));
+ TALER_ARL_report (report_lags,
+ rep);
}
- TALER_ARL_report (report_lags,
- rep);
+
+ return free_report_entry (cls,
+ key,
+ value);
+}
+
+
+/**
+ * Function called on deposits that are past their due date
+ * and have not yet seen a wire transfer.
+ *
+ * @param cls closure, points to a `struct ReportMissingWireContext`
+ * @param batch_deposit_serial_id row in the database for which the wire transfer is missing
+ * @param total_amount value of the missing deposits, including fee
+ * @param wire_target_h_payto hash of payto-URI where the funds should have been wired
+ * @param deadline what was the earliest requested wire transfer deadline
+ */
+static void
+report_wire_missing_cb (void *cls,
+ uint64_t batch_deposit_serial_id,
+ const struct TALER_Amount *total_amount,
+ const struct TALER_PaytoHashP *wire_target_h_payto,
+ struct GNUNET_TIME_Timestamp deadline)
+{
+ struct ReportMissingWireContext *rc = cls;
+ struct ReasonDetail *rd;
+
+ rd = GNUNET_CONTAINER_multishortmap_get (rc->map,
+ &wire_target_h_payto->hash);
+ if (NULL == rd)
+ {
+ rd = GNUNET_new (struct ReasonDetail);
+ GNUNET_assert (GNUNET_YES ==
+ GNUNET_CONTAINER_multishortmap_put (
+ rc->map,
+ &wire_target_h_payto->hash,
+ rd,
+ GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY));
+ rc->err = TALER_ARL_edb->select_justification_for_missing_wire (
+ TALER_ARL_edb->cls,
+ wire_target_h_payto,
+ &rd->payto_uri,
+ &rd->kyc_pending,
+ &rd->status,
+ &rd->aml_limit);
+ rd->total_amount = *total_amount;
+ rd->deadline = deadline;
+ }
+ else
+ {
+ TALER_ARL_amount_add (&rd->total_amount,
+ &rd->total_amount,
+ total_amount);
+ rd->deadline = GNUNET_TIME_timestamp_min (rd->deadline,
+ deadline);
+ }
+}
+
+
+/**
+ * Function called on aggregations that were done for
+ * a (batch) deposit.
+ *
+ * @param cls closure
+ * @param tracking_serial_id where in the table are we
+ * @param batch_deposit_serial_id which batch deposit was aggregated
+ */
+static void
+clear_finished_transfer_cb (
+ void *cls,
+ uint64_t tracking_serial_id,
+ uint64_t batch_deposit_serial_id)
+{
+ struct AggregationContext *ac = cls;
+ enum GNUNET_DB_QueryStatus qs;
+
+ if (0 > ac->err)
+ return; /* already failed */
+ GNUNET_assert (ac->max_aggregation_serial < tracking_serial_id);
+ ac->max_aggregation_serial = tracking_serial_id;
+ qs = TALER_ARL_adb->delete_pending_deposit (
+ TALER_ARL_adb->cls,
+ batch_deposit_serial_id);
+ if (0 == qs)
+ {
+ /* Aggregated something twice or other error, report! */
+ GNUNET_break (0);
+ // FIXME: report more nicely!
+ }
+ if (0 > qs)
+ ac->err = qs;
}
@@ -904,30 +1263,78 @@ wire_missing_cb (void *cls,
static void
check_for_required_transfers (void)
{
- struct GNUNET_TIME_Timestamp next_timestamp;
+ struct ImportMissingWireContext wc = {
+ .max_batch_deposit_uuid = TALER_ARL_USE_PP (wire_batch_deposit_id),
+ .err = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT
+ };
+ struct GNUNET_TIME_Absolute deadline;
enum GNUNET_DB_QueryStatus qs;
+ struct ReportMissingWireContext rc = {
+ .err = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT
+ };
+ struct AggregationContext ac = {
+ .max_aggregation_serial = TALER_ARL_USE_PP (wire_aggregation_id),
+ .err = GNUNET_DB_STATUS_SUCCESS_ONE_RESULT
+ };
+ qs = TALER_ARL_edb->select_batch_deposits_missing_wire (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (wire_batch_deposit_id),
+ &import_wire_missing_cb,
+ &wc);
+ if ( (0 > qs) || (0 > wc.err) )
+ {
+ GNUNET_break (0);
+ GNUNET_break ( (GNUNET_DB_STATUS_SOFT_ERROR == qs) ||
+ (GNUNET_DB_STATUS_SOFT_ERROR == wc.err) );
+ global_ret = EXIT_FAILURE;
+ GNUNET_SCHEDULER_shutdown ();
+ return;
+ }
+ TALER_ARL_USE_PP (wire_batch_deposit_id) = wc.max_batch_deposit_uuid;
+ qs = TALER_ARL_edb->select_aggregations_above_serial (
+ TALER_ARL_edb->cls,
+ TALER_ARL_USE_PP (wire_aggregation_id),
+ &clear_finished_transfer_cb,
+ &ac);
+ if ( (0 > qs) || (0 > ac.err) )
+ {
+ GNUNET_break (0);
+ GNUNET_break ( (GNUNET_DB_STATUS_SOFT_ERROR == qs) ||
+ (GNUNET_DB_STATUS_SOFT_ERROR == ac.err) );
+ global_ret = EXIT_FAILURE;
+ GNUNET_SCHEDULER_shutdown ();
+ return;
+ }
+ TALER_ARL_USE_PP (wire_aggregation_id) = ac.max_aggregation_serial;
/* Subtract #GRACE_PERIOD, so we can be a bit behind in processing
without immediately raising undue concern */
- next_timestamp = GNUNET_TIME_absolute_to_timestamp (
- GNUNET_TIME_absolute_subtract (GNUNET_TIME_absolute_get (),
- GRACE_PERIOD));
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Analyzing exchange's unfinished deposits (deadline: %s)\n",
- GNUNET_TIME_timestamp2s (next_timestamp));
- qs = TALER_ARL_edb->select_deposits_missing_wire (TALER_ARL_edb->cls,
- pp.last_timestamp,
- next_timestamp,
- &wire_missing_cb,
- &next_timestamp);
- if (0 > qs)
+ deadline = GNUNET_TIME_absolute_subtract (GNUNET_TIME_absolute_get (),
+ GRACE_PERIOD);
+ rc.map = GNUNET_CONTAINER_multishortmap_create (1024,
+ GNUNET_NO);
+ qs = TALER_ARL_adb->select_pending_deposits (
+ TALER_ARL_adb->cls,
+ deadline,
+ &report_wire_missing_cb,
+ &rc);
+ if ( (0 > qs) || (0 > rc.err) )
{
- GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qs);
+ GNUNET_break (0);
+ GNUNET_break ( (GNUNET_DB_STATUS_SOFT_ERROR == qs) ||
+ (GNUNET_DB_STATUS_SOFT_ERROR == rc.err) );
+ GNUNET_CONTAINER_multishortmap_iterate (rc.map,
+ &free_report_entry,
+ NULL);
+ GNUNET_CONTAINER_multishortmap_destroy (rc.map);
global_ret = EXIT_FAILURE;
GNUNET_SCHEDULER_shutdown ();
return;
}
- pp.last_timestamp = next_timestamp;
+ GNUNET_CONTAINER_multishortmap_iterate (rc.map,
+ &generate_report,
+ NULL);
+ GNUNET_CONTAINER_multishortmap_destroy (rc.map);
/* conclude with success */
commit (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT);
GNUNET_SCHEDULER_shutdown ();
@@ -1034,7 +1441,7 @@ wire_out_cb (void *cls,
{
/* Wire transfer was not made (yet) at all (but would have been
justified), so the entire amount is missing / still to be done.
- This is moderately harmless, it might just be that the aggreator
+ This is moderately harmless, it might just be that the aggregator
has not yet fully caught up with the transfers it should do. */
TALER_ARL_report (
report_wire_out_inconsistencies,
@@ -1286,6 +1693,7 @@ complain_out_not_found (void *cls,
switch (qs)
{
case GNUNET_DB_STATUS_HARD_ERROR:
+ GNUNET_break (0);
global_ret = EXIT_FAILURE;
GNUNET_SCHEDULER_shutdown ();
return GNUNET_SYSERR;
@@ -1297,6 +1705,10 @@ complain_out_not_found (void *cls,
/* not a profit drain */
break;
case GNUNET_DB_STATUS_SUCCESS_ONE_RESULT:
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Profit drain of %s to %s found!\n",
+ TALER_amount2s (&amount),
+ payto_uri);
if (GNUNET_OK !=
TALER_exchange_offline_profit_drain_verify (
&roi->details.wtid,
@@ -1314,7 +1726,7 @@ complain_out_not_found (void *cls,
"profit_drains"),
GNUNET_JSON_pack_uint64 ("row",
serial),
- GNUNET_JSON_pack_data_auto ("wtid",
+ GNUNET_JSON_pack_data_auto ("id",
&roi->details.wtid),
GNUNET_JSON_pack_string ("diagnostic",
"invalid signature")));
@@ -1377,7 +1789,11 @@ complain_out_not_found (void *cls,
}
GNUNET_free (account_section);
GNUNET_free (payto_uri);
- break;
+ /* profit drain was correct */
+ TALER_ARL_amount_add (&TALER_ARL_USE_AB (total_drained),
+ &TALER_ARL_USE_AB (total_drained),
+ &amount);
+ return GNUNET_OK;
}
}
@@ -1427,6 +1843,7 @@ check_exchange_wire_out (struct WireAccount *wa)
{
enum GNUNET_DB_QueryStatus qs;
+ GNUNET_assert (NULL == wa->dhh);
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Analyzing exchange's wire OUT table for account `%s'\n",
wa->ai->section_name);
@@ -1460,92 +1877,92 @@ check_exchange_wire_out (struct WireAccount *wa)
* transactions).
*
* @param cls `struct WireAccount` with current wire account to process
- * @param http_status_code http status of the request
- * @param ec error code in case something went wrong
- * @param row_off identification of the position at which we are querying
- * @param details details about the wire transfer
- * @param json original response in JSON format
- * @return #GNUNET_OK to continue, #GNUNET_SYSERR to abort iteration
+ * @param dhr HTTP response details
*/
-static enum GNUNET_GenericReturnValue
+static void
history_debit_cb (void *cls,
- unsigned int http_status_code,
- enum TALER_ErrorCode ec,
- uint64_t row_off,
- const struct TALER_BANK_DebitDetails *details,
- const json_t *json)
+ const struct TALER_BANK_DebitHistoryResponse *dhr)
{
struct WireAccount *wa = cls;
struct ReserveOutInfo *roi;
size_t slen;
- (void) json;
- if (NULL == details)
+ wa->dhh = NULL;
+ switch (dhr->http_status)
{
- wa->dhh = NULL;
- if ( (TALER_EC_NONE != ec) &&
- ( (! ignore_account_404) ||
- (MHD_HTTP_NOT_FOUND != http_status_code) ) )
+ case MHD_HTTP_OK:
+ for (unsigned int i = 0; i<dhr->details.ok.details_length; i++)
{
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Error fetching debit history of account %s: %u/%u!\n",
- wa->ai->section_name,
- http_status_code,
- (unsigned int) ec);
- commit (GNUNET_DB_STATUS_HARD_ERROR);
- global_ret = EXIT_FAILURE;
- GNUNET_SCHEDULER_shutdown ();
- return GNUNET_SYSERR;
+ const struct TALER_BANK_DebitDetails *dd
+ = &dhr->details.ok.details[i];
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Analyzing bank DEBIT at %s of %s with WTID %s\n",
+ GNUNET_TIME_timestamp2s (dd->execution_date),
+ TALER_amount2s (&dd->amount),
+ TALER_B2S (&dd->wtid));
+ /* Update offset */
+ wa->wire_off_out = dd->serial_id;
+ slen = strlen (dd->credit_account_uri) + 1;
+ roi = GNUNET_malloc (sizeof (struct ReserveOutInfo)
+ + slen);
+ GNUNET_CRYPTO_hash (&dd->wtid,
+ sizeof (dd->wtid),
+ &roi->subject_hash);
+ roi->details.amount = dd->amount;
+ roi->details.execution_date = dd->execution_date;
+ roi->details.wtid = dd->wtid;
+ roi->details.credit_account_uri = (const char *) &roi[1];
+ GNUNET_memcpy (&roi[1],
+ dd->credit_account_uri,
+ slen);
+ if (GNUNET_OK !=
+ GNUNET_CONTAINER_multihashmap_put (out_map,
+ &roi->subject_hash,
+ roi,
+ GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY))
+ {
+ char *diagnostic;
+
+ GNUNET_asprintf (&diagnostic,
+ "duplicate subject hash `%s'",
+ TALER_B2S (&roi->subject_hash));
+ TALER_ARL_amount_add (&total_wire_format_amount,
+ &total_wire_format_amount,
+ &dd->amount);
+ TALER_ARL_report (report_wire_format_inconsistencies,
+ GNUNET_JSON_PACK (
+ TALER_JSON_pack_amount ("amount",
+ &dd->amount),
+ GNUNET_JSON_pack_uint64 ("wire_offset",
+ dd->serial_id),
+ GNUNET_JSON_pack_string ("diagnostic",
+ diagnostic)));
+ GNUNET_free (diagnostic);
+ }
}
check_exchange_wire_out (wa);
- return GNUNET_OK;
- }
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Analyzing bank DEBIT at %s of %s with WTID %s\n",
- GNUNET_TIME_timestamp2s (details->execution_date),
- TALER_amount2s (&details->amount),
- TALER_B2S (&details->wtid));
- /* Update offset */
- wa->out_wire_off = row_off;
- slen = strlen (details->credit_account_uri) + 1;
- roi = GNUNET_malloc (sizeof (struct ReserveOutInfo)
- + slen);
- GNUNET_CRYPTO_hash (&details->wtid,
- sizeof (details->wtid),
- &roi->subject_hash);
- roi->details.amount = details->amount;
- roi->details.execution_date = details->execution_date;
- roi->details.wtid = details->wtid;
- roi->details.credit_account_uri = (const char *) &roi[1];
- memcpy (&roi[1],
- details->credit_account_uri,
- slen);
- if (GNUNET_OK !=
- GNUNET_CONTAINER_multihashmap_put (out_map,
- &roi->subject_hash,
- roi,
- GNUNET_CONTAINER_MULTIHASHMAPOPTION_UNIQUE_ONLY))
- {
- char *diagnostic;
-
- GNUNET_asprintf (&diagnostic,
- "duplicate subject hash `%s'",
- TALER_B2S (&roi->subject_hash));
- TALER_ARL_amount_add (&total_wire_format_amount,
- &total_wire_format_amount,
- &details->amount);
- TALER_ARL_report (report_wire_format_inconsistencies,
- GNUNET_JSON_PACK (
- TALER_JSON_pack_amount ("amount",
- &details->amount),
- GNUNET_JSON_pack_uint64 ("wire_offset",
- row_off),
- GNUNET_JSON_pack_string ("diagnostic",
- diagnostic)));
- GNUNET_free (diagnostic);
- return GNUNET_OK;
+ return;
+ case MHD_HTTP_NO_CONTENT:
+ check_exchange_wire_out (wa);
+ return;
+ case MHD_HTTP_NOT_FOUND:
+ if (ignore_account_404)
+ {
+ check_exchange_wire_out (wa);
+ return;
+ }
+ break;
+ default:
+ break;
}
- return GNUNET_OK;
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Error fetching debit history of account %s: %u/%u!\n",
+ wa->ai->section_name,
+ dhr->http_status,
+ (unsigned int) dhr->ec);
+ commit (GNUNET_DB_STATUS_HARD_ERROR);
+ global_ret = EXIT_FAILURE;
+ GNUNET_SCHEDULER_shutdown ();
}
@@ -1580,7 +1997,7 @@ process_debits (void *cls)
// (CG: used to be INT64_MAX, changed by MS to INT32_MAX, why? To be discussed with him!)
wa->dhh = TALER_BANK_debit_history (ctx,
wa->ai->auth,
- wa->out_wire_off,
+ wa->wire_off_out,
INT32_MAX,
GNUNET_TIME_UNIT_ZERO,
&history_debit_cb,
@@ -1604,8 +2021,9 @@ process_debits (void *cls)
static void
begin_debit_audit (void)
{
+ GNUNET_assert (NULL == out_map);
out_map = GNUNET_CONTAINER_multihashmap_create (1024,
- GNUNET_YES);
+ true);
process_debits (wa_head);
}
@@ -1620,8 +2038,11 @@ begin_debit_audit (void)
static void
conclude_credit_history (void)
{
- GNUNET_CONTAINER_multihashmap_destroy (in_map);
- in_map = NULL;
+ if (NULL != in_map)
+ {
+ GNUNET_CONTAINER_multihashmap_destroy (in_map);
+ in_map = NULL;
+ }
/* credit done, now check debits */
begin_debit_audit ();
}
@@ -1669,9 +2090,9 @@ reserve_in_cb (void *cls,
rii->details.execution_date = execution_date;
rii->details.reserve_pub = *reserve_pub;
rii->details.debit_account_uri = (const char *) &rii[1];
- memcpy (&rii[1],
- sender_account_details,
- slen);
+ GNUNET_memcpy (&rii[1],
+ sender_account_details,
+ slen);
GNUNET_CRYPTO_hash (&wire_reference,
sizeof (uint64_t),
&rii->row_off_hash);
@@ -1687,7 +2108,7 @@ reserve_in_cb (void *cls,
"reserves_in"),
GNUNET_JSON_pack_uint64 ("row",
rowid),
- GNUNET_JSON_pack_data_auto ("wire_offset_hash",
+ GNUNET_JSON_pack_data_auto ("id",
&rii->row_off_hash),
GNUNET_JSON_pack_string ("diagnostic",
"duplicate wire offset")));
@@ -1755,52 +2176,19 @@ process_credits (void *cls);
/**
- * This function is called for all transactions that
- * are credited to the exchange's account (incoming
- * transactions).
+ * We got all of the incoming transactions for @a wa,
+ * finish processing the account.
*
- * @param cls `struct WireAccount` we are processing
- * @param http_status HTTP status returned by the bank
- * @param ec error code in case something went wrong
- * @param row_off identification of the position at which we are querying
- * @param details details about the wire transfer
- * @param json raw response
- * @return #GNUNET_OK to continue, #GNUNET_SYSERR to abort iteration
+ * @param[in,out] wa wire account to process
*/
-static enum GNUNET_GenericReturnValue
-history_credit_cb (void *cls,
- unsigned int http_status,
- enum TALER_ErrorCode ec,
- uint64_t row_off,
- const struct TALER_BANK_CreditDetails *details,
- const json_t *json)
+static void
+conclude_account (struct WireAccount *wa)
{
- struct WireAccount *wa = cls;
- struct ReserveInInfo *rii;
- struct GNUNET_HashCode key;
-
- (void) json;
- if (NULL == details)
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Reconciling CREDIT processing of account `%s'\n",
+ wa->ai->section_name);
+ if (NULL != in_map)
{
- wa->chh = NULL;
- if ( (TALER_EC_NONE != ec) &&
- ( (! ignore_account_404) ||
- (MHD_HTTP_NOT_FOUND != http_status) ) )
- {
- GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
- "Error fetching credit history of account %s: %u/%s!\n",
- wa->ai->section_name,
- http_status,
- TALER_ErrorCode_get_hint (ec));
- commit (GNUNET_DB_STATUS_HARD_ERROR);
- global_ret = EXIT_FAILURE;
- GNUNET_SCHEDULER_shutdown ();
- return GNUNET_SYSERR;
- }
- /* end of operation */
- GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Reconciling CREDIT processing of account `%s'\n",
- wa->ai->section_name);
GNUNET_CONTAINER_multihashmap_iterate (in_map,
&complain_in_not_found,
wa);
@@ -1808,16 +2196,32 @@ history_credit_cb (void *cls,
GNUNET_CONTAINER_multihashmap_iterate (in_map,
&free_rii,
NULL);
- process_credits (wa->next);
- return GNUNET_OK;
}
+ process_credits (wa->next);
+}
+
+
+/**
+ * Analyze credit transaction @a details into @a wa.
+ *
+ * @param[in,out] wa account that received the transfer
+ * @param details transfer details
+ * @return true on success, false to stop loop at this point
+ */
+static bool
+analyze_credit (struct WireAccount *wa,
+ const struct TALER_BANK_CreditDetails *details)
+{
+ struct ReserveInInfo *rii;
+ struct GNUNET_HashCode key;
+
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Analyzing bank CREDIT at %s of %s with Reserve-pub %s\n",
GNUNET_TIME_timestamp2s (details->execution_date),
TALER_amount2s (&details->amount),
TALER_B2S (&details->reserve_pub));
- GNUNET_CRYPTO_hash (&row_off,
- sizeof (row_off),
+ GNUNET_CRYPTO_hash (&details->serial_id,
+ sizeof (details->serial_id),
&key);
rii = GNUNET_CONTAINER_multihashmap_get (in_map,
&key);
@@ -1826,13 +2230,12 @@ history_credit_cb (void *cls,
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Failed to find wire transfer at `%s' in exchange database. Audit ends at this point in time.\n",
GNUNET_TIME_timestamp2s (details->execution_date));
- wa->chh = NULL;
process_credits (wa->next);
- return GNUNET_SYSERR; /* not an error, just end of processing */
+ return false; /* not an error, just end of processing */
}
/* Update offset */
- wa->in_wire_off = row_off;
+ wa->wire_off_in = details->serial_id;
/* compare records with expected data */
if (0 != GNUNET_memcmp (&details->reserve_pub,
&rii->details.reserve_pub))
@@ -1843,7 +2246,7 @@ history_credit_cb (void *cls,
GNUNET_JSON_pack_uint64 ("row",
rii->rowid),
GNUNET_JSON_pack_uint64 ("bank_row",
- row_off),
+ details->serial_id),
TALER_JSON_pack_amount ("amount_exchange_expected",
&rii->details.amount),
TALER_JSON_pack_amount ("amount_wired",
@@ -1863,7 +2266,7 @@ history_credit_cb (void *cls,
GNUNET_JSON_pack_uint64 ("row",
rii->rowid),
GNUNET_JSON_pack_uint64 ("bank_row",
- row_off),
+ details->serial_id),
TALER_JSON_pack_amount ("amount_exchange_expected",
&zero),
TALER_JSON_pack_amount ("amount_wired",
@@ -1889,7 +2292,7 @@ history_credit_cb (void *cls,
GNUNET_JSON_pack_uint64 ("row",
rii->rowid),
GNUNET_JSON_pack_uint64 ("bank_row",
- row_off),
+ details->serial_id),
TALER_JSON_pack_amount ("amount_exchange_expected",
&rii->details.amount),
TALER_JSON_pack_amount ("amount_wired",
@@ -1930,19 +2333,19 @@ history_credit_cb (void *cls,
if (0 != strcasecmp (details->debit_account_uri,
rii->details.debit_account_uri))
{
- TALER_ARL_report (report_missattribution_in_inconsistencies,
+ TALER_ARL_report (report_misattribution_in_inconsistencies,
GNUNET_JSON_PACK (
TALER_JSON_pack_amount ("amount",
&rii->details.amount),
GNUNET_JSON_pack_uint64 ("row",
rii->rowid),
GNUNET_JSON_pack_uint64 ("bank_row",
- row_off),
+ details->serial_id),
GNUNET_JSON_pack_data_auto (
"reserve_pub",
&rii->details.reserve_pub)));
- TALER_ARL_amount_add (&total_missattribution_in,
- &total_missattribution_in,
+ TALER_ARL_amount_add (&total_misattribution_in,
+ &total_misattribution_in,
&rii->details.amount);
}
if (GNUNET_TIME_timestamp_cmp (details->execution_date,
@@ -1956,7 +2359,7 @@ history_credit_cb (void *cls,
GNUNET_JSON_pack_uint64 ("row",
rii->rowid),
GNUNET_JSON_pack_uint64 ("bank_row",
- row_off),
+ details->serial_id),
GNUNET_JSON_pack_string ("diagnostic",
"execution date mismatch")));
}
@@ -1965,7 +2368,60 @@ cleanup:
free_rii (NULL,
&key,
rii));
- return GNUNET_OK;
+ return true;
+}
+
+
+/**
+ * This function is called for all transactions that
+ * are credited to the exchange's account (incoming
+ * transactions).
+ *
+ * @param cls `struct WireAccount` we are processing
+ * @param chr HTTP response returned by the bank
+ */
+static void
+history_credit_cb (void *cls,
+ const struct TALER_BANK_CreditHistoryResponse *chr)
+{
+ struct WireAccount *wa = cls;
+
+ wa->chh = NULL;
+ switch (chr->http_status)
+ {
+ case MHD_HTTP_OK:
+ for (unsigned int i = 0; i<chr->details.ok.details_length; i++)
+ {
+ const struct TALER_BANK_CreditDetails *cd
+ = &chr->details.ok.details[i];
+
+ if (! analyze_credit (wa,
+ cd))
+ return;
+ }
+ conclude_account (wa);
+ return;
+ case MHD_HTTP_NO_CONTENT:
+ conclude_account (wa);
+ return;
+ case MHD_HTTP_NOT_FOUND:
+ if (ignore_account_404)
+ {
+ conclude_account (wa);
+ return;
+ }
+ break;
+ default:
+ break;
+ }
+ GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
+ "Error fetching credit history of account %s: %u/%s!\n",
+ wa->ai->section_name,
+ chr->http_status,
+ TALER_ErrorCode_get_hint (chr->ec));
+ commit (GNUNET_DB_STATUS_HARD_ERROR);
+ global_ret = EXIT_FAILURE;
+ GNUNET_SCHEDULER_shutdown ();
}
@@ -2018,7 +2474,7 @@ process_credits (void *cls)
// (CG: used to be INT64_MAX, changed by MS to INT32_MAX, why? To be discussed with him!)
wa->chh = TALER_BANK_credit_history (ctx,
wa->ai->auth,
- wa->in_wire_off,
+ wa->wire_off_in,
INT32_MAX,
GNUNET_TIME_UNIT_ZERO,
&history_credit_cb,
@@ -2041,6 +2497,7 @@ process_credits (void *cls)
static void
begin_credit_audit (void)
{
+ GNUNET_assert (NULL == in_map);
in_map = GNUNET_CONTAINER_multihashmap_create (1024,
GNUNET_YES);
/* now go over all bank accounts and check delta with in_map */
@@ -2049,8 +2506,7 @@ begin_credit_audit (void)
/**
- * Function called about reserve closing operations
- * the aggregator triggered.
+ * Function called about reserve closing operations the aggregator triggered.
*
* @param cls closure
* @param rowid row identifier used to uniquely identify the reserve closing operation
@@ -2060,6 +2516,8 @@ begin_credit_audit (void)
* @param reserve_pub public key of the reserve
* @param receiver_account where did we send the funds, in payto://-format
* @param wtid identifier used for the wire transfer
+ * @param close_request_row which close request triggered the operation?
+ * 0 if it was a timeout (not used)
* @return #GNUNET_OK to continue to iterate, #GNUNET_SYSERR to stop
*/
static enum GNUNET_GenericReturnValue
@@ -2070,12 +2528,14 @@ reserve_closed_cb (void *cls,
const struct TALER_Amount *closing_fee,
const struct TALER_ReservePublicKeyP *reserve_pub,
const char *receiver_account,
- const struct TALER_WireTransferIdentifierRawP *wtid)
+ const struct TALER_WireTransferIdentifierRawP *wtid,
+ uint64_t close_request_row)
{
struct ReserveClosure *rc;
struct GNUNET_HashCode key;
(void) cls;
+ (void) close_request_row;
rc = GNUNET_new (struct ReserveClosure);
if (TALER_ARL_SR_INVALID_NEGATIVE ==
TALER_ARL_amount_subtract_neg (&rc->amount,
@@ -2088,7 +2548,7 @@ reserve_closed_cb (void *cls,
"reserves_closures"),
GNUNET_JSON_pack_uint64 ("row",
rowid),
- GNUNET_JSON_pack_data_auto ("reserve_pub",
+ GNUNET_JSON_pack_data_auto ("id",
reserve_pub),
TALER_JSON_pack_amount ("amount_with_fee",
amount_with_fee),
@@ -2101,8 +2561,8 @@ reserve_closed_cb (void *cls,
return GNUNET_SYSERR;
return GNUNET_OK;
}
- pp.last_reserve_close_uuid
- = GNUNET_MAX (pp.last_reserve_close_uuid,
+ TALER_ARL_USE_PP (wire_reserve_close_id)
+ = GNUNET_MAX (TALER_ARL_USE_PP (wire_reserve_close_id),
rowid + 1);
rc->receiver_account = GNUNET_strdup (receiver_account);
rc->wtid = *wtid;
@@ -2161,17 +2621,18 @@ begin_transaction (void)
}
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_drained));
+ &TALER_ARL_USE_AB (total_drained)));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_wire_in));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_wire_out));
- qs = TALER_ARL_adb->get_predicted_balance (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &start_balance,
- &total_drained);
+ qs = TALER_ARL_adb->get_balance (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_AB (total_drained),
+ TALER_ARL_GET_AB (final_balance),
+ NULL);
switch (qs)
{
case GNUNET_DB_STATUS_HARD_ERROR:
@@ -2191,13 +2652,33 @@ begin_transaction (void)
NULL != wa;
wa = wa->next)
{
- wa->qsx = TALER_ARL_adb->get_wire_auditor_account_progress (
+ GNUNET_asprintf (&wa->label_reserve_in_serial_id,
+ "wire-%s-%s",
+ wa->ai->section_name,
+ "reserve_in_serial_id");
+ GNUNET_asprintf (&wa->label_wire_out_serial_id,
+ "wire-%s-%s",
+ wa->ai->section_name,
+ "wire_out_serial_id");
+ GNUNET_asprintf (&wa->label_wire_off_in,
+ "wire-%s-%s",
+ wa->ai->section_name,
+ "wire_off_in");
+ GNUNET_asprintf (&wa->label_wire_off_out,
+ "wire-%s-%s",
+ wa->ai->section_name,
+ "wire_off_out");
+ wa->qsx = TALER_ARL_adb->get_auditor_progress (
TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- wa->ai->section_name,
- &wa->pp,
- &wa->in_wire_off,
- &wa->out_wire_off);
+ wa->label_reserve_in_serial_id,
+ &wa->pp.last_reserve_in_serial_id,
+ wa->label_wire_out_serial_id,
+ &wa->pp.last_wire_out_serial_id,
+ wa->label_wire_off_in,
+ &wa->wire_off_in,
+ wa->label_wire_off_out,
+ &wa->wire_off_out,
+ NULL);
if (0 > wa->qsx)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == wa->qsx);
@@ -2205,9 +2686,12 @@ begin_transaction (void)
}
wa->start_pp = wa->pp;
}
- qsx_gwap = TALER_ARL_adb->get_wire_auditor_progress (TALER_ARL_adb->cls,
- &TALER_ARL_master_pub,
- &pp);
+ qsx_gwap = TALER_ARL_adb->get_auditor_progress (
+ TALER_ARL_adb->cls,
+ TALER_ARL_GET_PP (wire_reserve_close_id),
+ TALER_ARL_GET_PP (wire_batch_deposit_id),
+ TALER_ARL_GET_PP (wire_aggregation_id),
+ NULL);
if (0 > qsx_gwap)
{
GNUNET_break (GNUNET_DB_STATUS_SOFT_ERROR == qsx_gwap);
@@ -2220,11 +2704,11 @@ begin_transaction (void)
}
else
{
- start_pp = pp;
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
- "Resuming wire audit at %s / %llu\n",
- GNUNET_TIME_timestamp2s (pp.last_timestamp),
- (unsigned long long) pp.last_reserve_close_uuid);
+ "Resuming wire audit at %llu / %llu / %llu\n",
+ (unsigned long long) TALER_ARL_USE_PP (wire_reserve_close_id),
+ (unsigned long long) TALER_ARL_USE_PP (wire_batch_deposit_id),
+ (unsigned long long) TALER_ARL_USE_PP (wire_aggregation_id));
}
{
@@ -2232,7 +2716,7 @@ begin_transaction (void)
qs = TALER_ARL_edb->select_reserve_closed_above_serial_id (
TALER_ARL_edb->cls,
- pp.last_reserve_close_uuid,
+ TALER_ARL_USE_PP (wire_reserve_close_id),
&reserve_closed_cb,
NULL);
if (0 > qs)
@@ -2334,11 +2818,15 @@ run (void *cls,
GNUNET_assert (NULL !=
(report_row_inconsistencies = json_array ()));
GNUNET_assert (NULL !=
- (report_missattribution_in_inconsistencies
+ (report_misattribution_in_inconsistencies
= json_array ()));
GNUNET_assert (NULL !=
(report_lags = json_array ()));
GNUNET_assert (NULL !=
+ (report_aml_lags = json_array ()));
+ GNUNET_assert (NULL !=
+ (report_kyc_lags = json_array ()));
+ GNUNET_assert (NULL !=
(report_closure_lags = json_array ()));
GNUNET_assert (NULL !=
(report_account_progress = json_array ()));
@@ -2356,7 +2844,7 @@ run (void *cls,
&total_bad_amount_in_minus));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
- &total_missattribution_in));
+ &total_misattribution_in));
GNUNET_assert (GNUNET_OK ==
TALER_amount_set_zero (TALER_ARL_currency,
&total_amount_lag));
@@ -2414,11 +2902,10 @@ main (int argc,
"ignore-not-found",
"continue, even if the bank account of the exchange was not found",
&ignore_account_404),
- GNUNET_GETOPT_option_base32_auto ('m',
- "exchange-key",
- "KEY",
- "public key of the exchange (Crockford base32 encoded)",
- &TALER_ARL_master_pub),
+ GNUNET_GETOPT_option_flag ('t',
+ "test",
+ "run in test mode and exit when idle",
+ &test_mode),
GNUNET_GETOPT_option_timetravel ('T',
"timetravel"),
GNUNET_GETOPT_OPTION_END
diff --git a/src/auditor/test-auditor.sh b/src/auditor/test-auditor.sh
index cb09a60a9..2cfea0532 100755
--- a/src/auditor/test-auditor.sh
+++ b/src/auditor/test-auditor.sh
@@ -1,4 +1,24 @@
#!/bin/bash
+#
+# This file is part of TALER
+# Copyright (C) 2014-2023 Taler Systems SA
+#
+# TALER is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 3, or (at your option) any later version.
+#
+# TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/license>
+#
+#
+# shellcheck disable=SC2317
+# shellcheck disable=SC1091
+#
+#
# Setup database which was generated from a perfectly normal
# exchange-wallet interaction and run the auditor against it.
#
@@ -10,7 +30,7 @@ set -eu
# Set of numbers for all the testcases.
# When adding new tests, increase the last number:
-ALL_TESTS=`seq 0 34`
+ALL_TESTS=$(seq 0 33)
# $TESTS determines which tests we should run.
# This construction is used to make it easy to
@@ -33,123 +53,101 @@ VALGRIND=""
# history request.
LIBEUFIN_SETTLE_TIME=1
-# Exit, with status code "skip" (no 'real' failure)
-function exit_skip() {
- echo $1
- exit 77
-}
+. setup.sh
-# Exit, with error message (hard failure)
-function exit_fail() {
- echo $1
- exit 1
+
+# Cleanup exchange and libeufin between runs.
+function cleanup()
+{
+ if [ ! -z "${EPID:-}" ]
+ then
+ echo -n "Stopping exchange $EPID..."
+ kill -TERM "$EPID"
+ wait "$EPID" || true
+ echo "DONE"
+ unset EPID
+ fi
+ stop_libeufin
}
# Cleanup to run whenever we exit
-function cleanup()
+function exit_cleanup()
{
- for n in `jobs -p`
+ echo "Running exit-cleanup"
+ if [ ! -z "${POSTGRES_PATH:-}" ]
+ then
+ echo "Stopping Postgres at ${POSTGRES_PATH}"
+ "${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ stop \
+ &> /dev/null \
+ || true
+ fi
+ cleanup
+ for n in $(jobs -p)
do
- kill $n 2> /dev/null || true
+ kill "$n" 2> /dev/null || true
done
- wait
- # kill euFin
- echo Killing euFin..
- kill `cat libeufin-sandbox.pid 2> /dev/null` &> /dev/null || true
- kill `cat libeufin-nexus.pid 2> /dev/null` &> /dev/null || true
+ wait || true
+ echo "DONE"
}
# Install cleanup handler (except for kill -9)
-trap cleanup EXIT
-
-function launch_libeufin () {
- export LIBEUFIN_NEXUS_DB_CONNECTION="jdbc:sqlite:$DB.sqlite3"
- libeufin-nexus serve --port 8082 \
- 2> libeufin-nexus-stderr.log \
- > libeufin-nexus-stdout.log &
- echo $! > libeufin-nexus.pid
- export LIBEUFIN_SANDBOX_DB_CONNECTION="jdbc:sqlite:$DB.sqlite3"
- export LIBEUFIN_SANDBOX_ADMIN_PASSWORD=secret
- libeufin-sandbox serve --port 18082 \
- > libeufin-sandbox-stdout.log \
- 2> libeufin-sandbox-stderr.log &
- echo $! > libeufin-sandbox.pid
-}
-
-# Downloads new transactions from the bank.
-function nexus_fetch_transactions () {
- export LIBEUFIN_NEXUS_USERNAME=exchange
- export LIBEUFIN_NEXUS_PASSWORD=x
- export LIBEUFIN_NEXUS_URL=http://localhost:8082/
- libeufin-cli accounts fetch-transactions \
- --range-type since-last --level report exchange-nexus > /dev/null
- unset LIBEUFIN_NEXUS_USERNAME
- unset LIBEUFIN_NEXUS_PASSWORD
- unset LIBEUFIN_NEXUS_URL
-}
+trap exit_cleanup EXIT
-# Instruct Nexus to all the prepared payments (= those
-# POSTed to /transfer by the exchange).
-function nexus_submit_to_sandbox () {
- export LIBEUFIN_NEXUS_USERNAME=exchange
- export LIBEUFIN_NEXUS_PASSWORD=x
- export LIBEUFIN_NEXUS_URL=http://localhost:8082/
- libeufin-cli accounts submit-payments exchange-nexus
- unset LIBEUFIN_NEXUS_USERNAME
- unset LIBEUFIN_NEXUS_PASSWORD
- unset LIBEUFIN_NEXUS_URL
-}
# Operations to run before the actual audit
function pre_audit () {
# Launch bank
- echo -n "Launching bank"
- EXCHANGE_URL=`taler-config -c $CONF -s EXCHANGE -o BASE_URL`
+ echo -n "Launching libeufin-bank"
+ export CONF
+ export MY_TMP_DIR
launch_libeufin
- for n in `seq 1 80`
+ for n in $(seq 1 80)
do
echo -n "."
sleep 0.1
OK=1
- wget http://localhost:18082/ -o /dev/null -O /dev/null >/dev/null && break
+ wget http://localhost:8082/ \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ && break
OK=0
done
- if [ 1 != $OK ]
+ if [ 1 != "$OK" ]
then
- exit_skip "Failed to launch Sandbox"
- fi
- sleep $LIBEUFIN_SETTLE_TIME
- for n in `seq 1 80`
- do
- echo -n "."
- sleep 0.1
- OK=1
- wget http://localhost:8082/ -o /dev/null -O /dev/null >/dev/null && break
- OK=0
- done
- if [ 1 != $OK ]
- then
- exit_skip "Failed to launch Nexus"
+ exit_skip "Failed to launch libeufin-bank"
fi
echo " DONE"
- if test ${1:-no} = "aggregator"
+ if [ "${1:-no}" = "aggregator" ]
then
echo -n "Running exchange aggregator ..."
- taler-exchange-aggregator -y -L INFO -t -c $CONF 2> aggregator.log || exit_fail "FAIL"
+ taler-exchange-aggregator \
+ -y \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/aggregator.log" \
+ || exit_fail "FAIL"
echo " DONE"
echo -n "Running exchange closer ..."
- taler-exchange-closer -L INFO -t -c $CONF 2> closer.log || exit_fail "FAIL"
+ taler-exchange-closer \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/closer.log" \
+ || exit_fail "FAIL"
echo " DONE"
echo -n "Running exchange transfer ..."
- taler-exchange-transfer -L INFO -t -c $CONF 2> transfer.log || exit_fail "FAIL"
+ taler-exchange-transfer \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/transfer.log" \
+ || exit_fail "FAIL"
echo " DONE"
- echo -n "Running Nexus payment submitter ..."
- nexus_submit_to_sandbox
- echo " DONE"
- # Make outgoing transactions appear in the TWG:
- echo -n "Download bank transactions ..."
- nexus_fetch_transactions
- echo " DONE"
fi
}
@@ -159,26 +157,92 @@ function audit_only () {
echo -n "Running audit(s) ..."
# Restart so that first run is always fresh, and second one is incremental
- taler-auditor-dbinit -r -c $CONF
- $VALGRIND taler-helper-auditor-aggregation -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-aggregation.json 2> test-audit-aggregation.log || exit_fail "aggregation audit failed"
+ taler-auditor-dbinit \
+ -r \
+ -c "$CONF"
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-aggregation.out" \
+ 2> "${MY_TMP_DIR}/test-audit-aggregation.err" \
+ || exit_fail "aggregation audit failed (see ${MY_TMP_DIR}/test-audit-aggregation.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-aggregation -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-aggregation-inc.json 2> test-audit-aggregation-inc.log || exit_fail "incremental aggregation audit failed"
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-aggregation-inc.out" \
+ 2> "${MY_TMP_DIR}/test-audit-aggregation-inc.err" \
+ || exit_fail "incremental aggregation audit failed (see ${MY_TMP_DIR}/test-audit-aggregation-inc.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-coins -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-coins.json 2> test-audit-coins.log || exit_fail "coin audit failed"
+ $VALGRIND taler-helper-auditor-coins \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-coins.out" \
+ 2> "${MY_TMP_DIR}/test-audit-coins.err" \
+ || exit_fail "coin audit failed (see ${MY_TMP_DIR}/test-audit-coins.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-coins -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-coins-inc.json 2> test-audit-coins-inc.log || exit_fail "incremental coin audit failed"
+ $VALGRIND taler-helper-auditor-coins \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-coins-inc.out" \
+ 2> "${MY_TMP_DIR}/test-audit-coins-inc.err" \
+ || exit_fail "incremental coin audit failed (see ${MY_TMP_DIR}/test-audit-coins-inc.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-deposits -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-deposits.json 2> test-audit-deposits.log || exit_fail "deposits audit failed"
+ $VALGRIND taler-helper-auditor-deposits \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-deposits.out" \
+ 2> "${MY_TMP_DIR}/test-audit-deposits.err" \
+ || exit_fail "deposits audit failed (see ${MY_TMP_DIR}/test-audit-deposits.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-deposits -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-deposits-inc.json 2> test-audit-deposits-inc.log || exit_fail "incremental deposits audit failed"
+ $VALGRIND taler-helper-auditor-deposits \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-deposits-inc.out" \
+ 2> "${MY_TMP_DIR}/test-audit-deposits-inc.err" \
+ || exit_fail "incremental deposits audit failed (see ${MY_TMP_DIR}/test-audit-deposits-inc.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-reserves -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-reserves.json 2> test-audit-reserves.log || exit_fail "reserves audit failed"
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-reserves.out" \
+ 2> "${MY_TMP_DIR}/test-audit-reserves.err" \
+ || exit_fail "reserves audit failed (see ${MY_TMP_DIR}/test-audit-reserves.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-reserves -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-reserves-inc.json 2> test-audit-reserves-inc.log || exit_fail "incremental reserves audit failed"
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-reserves-inc.out" \
+ 2> "${MY_TMP_DIR}/test-audit-reserves-inc.err" \
+ || exit_fail "incremental reserves audit failed (see ${MY_TMP_DIR}/test-audit-reserves-inc.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-wire -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-wire.json 2> test-wire-audit.log || exit_fail "wire audit failed"
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-wire.out" \
+ 2> "${MY_TMP_DIR}/test-audit-wire.err" \
+ || exit_fail "wire audit failed (see ${MY_TMP_DIR}/test-audit-wire.*)"
echo -n "."
- $VALGRIND taler-helper-auditor-wire -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-wire-inc.json 2> test-wire-audit-inc.log || exit_fail "wire audit inc failed"
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -t \
+ > "${MY_TMP_DIR}/test-audit-wire-inc.out" \
+ 2> "${MY_TMP_DIR}/test-audit-wire-inc.err" \
+ || exit_fail "wire audit inc failed (see ${MY_TMP_DIR}/test-audit-wire-inc.*)"
echo -n "."
echo " DONE"
@@ -187,16 +251,11 @@ function audit_only () {
# Cleanup to run after the auditor
function post_audit () {
- taler-exchange-dbinit -c $CONF -g || exit_fail "exchange DB GC failed"
-
+ taler-exchange-dbinit \
+ -c "$CONF" \
+ -g \
+ || exit_fail "exchange DB GC failed"
cleanup
- echo -n "TeXing ."
- taler-helper-auditor-render.py test-audit-aggregation.json test-audit-coins.json test-audit-deposits.json test-audit-reserves.json test-audit-wire.json < ../../contrib/auditor-report.tex.j2 > test-report.tex || exit_fail "Renderer failed"
-
- echo -n "."
- timeout 10 pdflatex test-report.tex >/dev/null || exit_fail "pdflatex failed"
- echo -n "."
- timeout 10 pdflatex test-report.tex >/dev/null
echo " DONE"
}
@@ -207,23 +266,63 @@ function post_audit () {
# before auditor (to trigger pending wire transfers).
# Pass "drain" as $2 to run a drain operation as well.
function run_audit () {
- pre_audit ${1:-no}
- if test ${2:-no} = "drain"
+ pre_audit "${1:-no}"
+ if [ "${2:-no}" = "drain" ]
then
- echo -n "Running taler-exchange-offline drain ..."
- taler-exchange-offline -L DEBUG -c $CONF \
- drain TESTKUDOS:0.1 exchange-account-1 payto://x-taler-bank/localhost/drain-target \
- upload \
- 2> taler-exchange-offline-drain.log || exit_fail "offline draining failed"
-
+ echo -n "Starting exchange..."
+ taler-exchange-httpd \
+ -c "${CONF}" \
+ -L INFO \
+ 2> "${MY_TMP_DIR}/exchange-httpd-drain.err" &
+ EPID=$!
+
+ # Wait for all services to be available
+ for n in $(seq 1 50)
+ do
+ echo -n "."
+ sleep 0.1
+ OK=0
+ # exchange
+ wget "http://localhost:8081/seed" \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ || continue
+ OK=1
+ break
+ done
+ echo "... DONE."
+ export CONF
+
+ echo -n "Running taler-exchange-offline drain "
+
+ taler-exchange-offline \
+ -L DEBUG \
+ -c "${CONF}" \
+ drain TESTKUDOS:0.1 \
+ exchange-account-1 payto://iban/SANDBOXX/DE360679?receiver-name=Exchange+Drain \
+ upload \
+ 2> "${MY_TMP_DIR}/taler-exchange-offline-drain.log" \
+ || exit_fail "offline draining failed"
+ kill -TERM "$EPID"
+ wait "$EPID" || true
+ unset EPID
echo -n "Running taler-exchange-drain ..."
- echo "\n" | taler-exchange-drain -L DEBUG -c $CONF 2> taler-exchange-drain.log || exit_fail "FAIL"
+ printf "\n" | taler-exchange-drain \
+ -L DEBUG \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/taler-exchange-drain.log" \
+ || exit_fail "FAIL"
echo " DONE"
echo -n "Running taler-exchange-transfer ..."
- taler-exchange-transfer -L INFO -t -c $CONF 2> drain-transfer.log || exit_fail "FAIL"
+ taler-exchange-transfer \
+ -L INFO \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/drain-transfer.log" \
+ || exit_fail "FAIL"
echo " DONE"
-
fi
audit_only
post_audit
@@ -231,136 +330,141 @@ function run_audit () {
# Do a full reload of the (original) database
-full_reload()
+function full_reload()
{
- echo "Doing full reload of the database... "
- dropdb $DB 2> /dev/null || true
- rm -f $DB.sqlite3 2> /dev/null || true # libeufin
- createdb -T template0 $DB || exit_skip "could not create database"
+ echo -n "Doing full reload of the database (loading ${BASEDB}.sql into $DB at $PGHOST)... "
+ dropdb "$DB" 2> /dev/null || true
+ createdb -T template0 "$DB" \
+ || exit_skip "could not create database $DB (at $PGHOST)"
# Import pre-generated database, -q(ietly) using single (-1) transaction
- psql -Aqt $DB -q -1 -f ${BASEDB}.sql > /dev/null || exit_skip "Failed to load database"
- echo "Loading libeufin basedb: ${BASEDB}-libeufin.sql"
- sqlite3 $DB.sqlite3 < ${BASEDB}-libeufin.sql || exit_skip "Failed to load libEufin database"
+ psql -Aqt "$DB" \
+ -q \
+ -1 \
+ -f "${BASEDB}.sql" \
+ > /dev/null \
+ || exit_skip "Failed to load database $DB from ${BASEDB}.sql"
echo "DONE"
+ # Technically, this call shouldn't be needed as libeufin should already be stopped here...
+ stop_libeufin
}
function test_0() {
-echo "===========0: normal run with aggregator==========="
-run_audit aggregator
-echo "Checking output"
-# if an emergency was detected, that is a bug and we should fail
-echo -n "Test for emergencies... "
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
-echo -n "Test for deposit confirmation emergencies... "
-jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
-echo -n "Test for emergencies by count... "
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-
-echo -n "Test for wire inconsistencies... "
-jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
-jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
-jq -e .missattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected missattribution inconsistency detected in ordinary run"
-jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
-jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
-jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
-jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
-jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
-
-
-# TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
-# TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-
-echo PASS
-
-LOSS=`jq -r .total_bad_sig_loss < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
-fi
+ echo "===========0: normal run with aggregator==========="
+ run_audit aggregator
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
+ echo -n "Test for deposit confirmation emergencies... "
+ jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-echo -n "Test for wire amounts... "
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total missattribution in wrong, got $WIRED"
-fi
-echo PASS
+ echo PASS
-echo -n "Checking for unexpected arithmetic differences "
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
-fi
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
+ fi
+
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ echo "PASS"
+
+ echo -n "Checking for unexpected arithmetic differences "
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
+ fi
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
-echo PASS
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
+ echo "PASS"
-echo -n "Checking for unexpected wire out differences "
-jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
-echo PASS
+ echo -n "Checking for unexpected wire out differences "
+ jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
+ echo "PASS"
-# cannot easily undo aggregator, hence full reload
-full_reload
+ # cannot easily undo aggregator, hence full reload
+ full_reload
}
@@ -369,121 +473,147 @@ full_reload
# transfer lag!
function test_1() {
-echo "===========1: normal run==========="
-run_audit
-
-echo "Checking output"
-# if an emergency was detected, that is a bug and we should fail
-echo -n "Test for emergencies... "
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
-echo -n "Test for emergencies by count... "
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-
-echo -n "Test for wire inconsistencies... "
-jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
-jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
-jq -e .missattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected missattribution inconsistency detected in ordinary run"
-jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
-jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
-jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
-
-# TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
-# TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-
-echo PASS
-
-echo -n "Check for lag detection... "
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
- jq -e .lag_details[0] < test-audit-wire.json > /dev/null || exit_fail "Lag not detected in run without aggregator at age $DELTA"
+ echo "===========1: normal run==========="
+ run_audit
+
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency detected in ordinary run";
+ echo "PASS"
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency by count detected in ordinary run"
+ echo "PASS"
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
- LAG=`jq -r .total_amount_lag < test-audit-wire.json`
- if test $LAG = "TESTKUDOS:0"
+ echo "PASS"
+
+ echo -n "Check for lag detection... "
+
+ # Check wire transfer lag reported (no aggregator!)
+ # NOTE: This test is EXPECTED to fail for ~1h after
+ # re-generating the test database as we do not
+ # report lag of less than 1h (see GRACE_PERIOD in
+ # taler-helper-auditor-wire.c)
+ jq -e .lag_details[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ || exit_fail "Lag not detected in run without aggregator"
+
+ LAG=$(jq -r .total_amount_lag < test-audit-wire.json)
+ if [ "$LAG" = "TESTKUDOS:0" ]
then
exit_fail "Expected total lag to be non-zero"
fi
echo "PASS"
-else
- echo "SKIP (database too new)"
-fi
-echo -n "Test for wire amounts... "
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total missattribution in wrong, got $WIRED"
-fi
-# Database was unmodified, no need to undo
-echo "OK"
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ # Database was unmodified, no need to undo
+ echo "OK"
}
# Change amount of wire transfer reported by exchange
function test_2() {
-echo "===========2: reserves_in inconsistency ==========="
-echo "UPDATE exchange.reserves_in SET credit_val=5 WHERE reserve_in_serial_id=1" | psql -At $DB
+ echo "===========2: reserves_in inconsistency ==========="
+ echo "UPDATE exchange.reserves_in SET credit_val=5 WHERE reserve_in_serial_id=1" \
+ | psql -At "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-ROW=`jq .reserve_in_amount_inconsistencies[0].row < test-audit-wire.json`
-if test $ROW != 1
-then
- exit_fail "Row $ROW is wrong"
-fi
-WIRED=`jq -r .reserve_in_amount_inconsistencies[0].amount_wired < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:10"
-then
- exit_fail "Amount wrong"
-fi
-EXPECTED=`jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json`
-if test $EXPECTED != "TESTKUDOS:5"
-then
- exit_fail "Expected amount wrong"
-fi
+ echo -n "Testing inconsistency detection... "
+ ROW=$(jq .reserve_in_amount_inconsistencies[0].row < test-audit-wire.json)
+ if [ "$ROW" != 1 ]
+ then
+ exit_fail "Row $ROW is wrong"
+ fi
+ WIRED=$(jq -r .reserve_in_amount_inconsistencies[0].amount_wired < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Amount wrong"
+ fi
+ EXPECTED=$(jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json)
+ if [ "$EXPECTED" != "TESTKUDOS:5" ]
+ then
+ exit_fail "Expected amount wrong"
+ fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
-fi
-DELTA=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $DELTA != "TESTKUDOS:5"
-then
- exit_fail "Expected total wire delta plus wrong, got $DELTA"
-fi
-echo PASS
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
+ fi
+ DELTA=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$DELTA" != "TESTKUDOS:5" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $DELTA"
+ fi
+ echo "PASS"
-# Undo database modification
-echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1" | psql -Aqt $DB
+ # Undo database modification
+ echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1" \
+ | psql -Aqt "$DB"
}
@@ -492,61 +622,62 @@ echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1
# lower than what exchange claims to have received.
function test_3() {
-echo "===========3: reserves_in inconsistency==========="
-echo "UPDATE exchange.reserves_in SET credit_val=15 WHERE reserve_in_serial_id=1" | psql -Aqt $DB
+ echo "===========3: reserves_in inconsistency==========="
+ echo "UPDATE exchange.reserves_in SET credit_val=15 WHERE reserve_in_serial_id=1" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-EXPECTED=`jq -r .reserve_balance_summary_wrong_inconsistencies[0].auditor < test-audit-reserves.json`
-if test $EXPECTED != "TESTKUDOS:5.01"
-then
- exit_fail "Expected reserve balance summary amount wrong, got $EXPECTED (auditor)"
-fi
+ EXPECTED=$(jq -r .reserve_balance_summary_wrong_inconsistencies[0].auditor < test-audit-reserves.json)
+ if [ "$EXPECTED" != "TESTKUDOS:5.01" ]
+ then
+ exit_fail "Expected reserve balance summary amount wrong, got $EXPECTED (auditor)"
+ fi
-EXPECTED=`jq -r .reserve_balance_summary_wrong_inconsistencies[0].exchange < test-audit-reserves.json`
-if test $EXPECTED != "TESTKUDOS:0.01"
-then
- exit_fail "Expected reserve balance summary amount wrong, got $EXPECTED (exchange)"
-fi
+ EXPECTED=$(jq -r .reserve_balance_summary_wrong_inconsistencies[0].exchange < test-audit-reserves.json)
+ if [ "$EXPECTED" != "TESTKUDOS:0.01" ]
+ then
+ exit_fail "Expected reserve balance summary amount wrong, got $EXPECTED (exchange)"
+ fi
-WIRED=`jq -r .total_loss_balance_insufficient < test-audit-reserves.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Wrong total loss from insufficient balance, got $WIRED"
-fi
+ WIRED=$(jq -r .total_irregular_loss < test-audit-reserves.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total loss from insufficient balance, got $WIRED"
+ fi
-ROW=`jq -e .reserve_in_amount_inconsistencies[0].row < test-audit-wire.json`
-if test $ROW != 1
-then
- exit_fail "Row wrong, got $ROW"
-fi
+ ROW=$(jq -e .reserve_in_amount_inconsistencies[0].row < test-audit-wire.json)
+ if [ "$ROW" != 1 ]
+ then
+ exit_fail "Row wrong, got $ROW"
+ fi
-WIRED=`jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:15"
-then
- exit_fail "Wrong amount_exchange_expected, got $WIRED"
-fi
+ WIRED=$(jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:15" ]
+ then
+ exit_fail "Wrong amount_exchange_expected, got $WIRED"
+ fi
-WIRED=`jq -r .reserve_in_amount_inconsistencies[0].amount_wired < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:10"
-then
- exit_fail "Wrong amount_wired, got $WIRED"
-fi
+ WIRED=$(jq -r .reserve_in_amount_inconsistencies[0].amount_wired < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Wrong amount_wired, got $WIRED"
+ fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:5"
-then
- exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
-fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:5" ]
+ then
+ exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
+ fi
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Wrong total wire_in_delta_plus, got $WIRED"
-fi
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total wire_in_delta_plus, got $WIRED"
+ fi
-# Undo database modification
-echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1" | psql -Aqt $DB
+ # Undo database modification
+ echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1" | psql -Aqt "$DB"
}
@@ -555,46 +686,52 @@ echo "UPDATE exchange.reserves_in SET credit_val=10 WHERE reserve_in_serial_id=1
# lower than what exchange claims to have received.
function test_4() {
-echo "===========4: deposit wire target wrong================="
-# Original target bank account was 43, changing to 44
-SERIAL=`echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql $DB -Aqt`
-OLD_WIRE_ID=`echo "SELECT wire_target_h_payto FROM exchange.deposits WHERE deposit_serial_id=${SERIAL};" | psql $DB -Aqt`
-NEW_WIRE_ID=`echo "INSERT INTO exchange.wire_targets (payto_uri, wire_target_h_payto, kyc_ok) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b', false);" | psql $DB -Aqt`
-echo "UPDATE exchange.deposits SET wire_target_h_payto='\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b' WHERE deposit_serial_id=${SERIAL}" | psql -Aqt $DB
+ echo "===========4: deposit wire target wrong================="
+ # Original target bank account was 43, changing to 44
+ SERIAL=$(echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql "$DB" -Aqt)
+ OLD_WIRE_ID=$(echo "SELECT wire_target_h_payto FROM exchange.deposits WHERE deposit_serial_id=${SERIAL};" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "INSERT INTO exchange.wire_targets (payto_uri, wire_target_h_payto) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b');" \
+ | psql "$DB" \
+ -Aqt \
+ > /dev/null
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.deposits SET wire_target_h_payto='\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b' WHERE deposit_serial_id=${SERIAL}" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
+ echo -n "Testing inconsistency detection... "
-jq -e .bad_sig_losses[0] < test-audit-coins.json > /dev/null || exit_fail "Bad signature not detected"
+ jq -e .bad_sig_losses[0] < test-audit-coins.json > /dev/null || exit_fail "Bad signature not detected"
-ROW=`jq -e .bad_sig_losses[0].row < test-audit-coins.json`
-if test $ROW != ${SERIAL}
-then
- exit_fail "Row wrong, got $ROW"
-fi
+ ROW=$(jq -e .bad_sig_losses[0].row < test-audit-coins.json)
+ if [ "$ROW" != "${SERIAL}" ]
+ then
+ exit_fail "Row wrong, got $ROW"
+ fi
-LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong deposit bad signature loss, got $LOSS"
-fi
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong deposit bad signature loss, got $LOSS"
+ fi
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-coins.json`
-if test $OP != "deposit"
-then
- exit_fail "Wrong operation, got $OP"
-fi
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "deposit" ]
+ then
+ exit_fail "Wrong operation, got $OP"
+ fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong total bad sig loss, got $LOSS"
-fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong total bad sig loss, got $LOSS"
+ fi
-echo PASS
-# Undo:
-echo "UPDATE exchange.deposits SET wire_target_h_payto='$OLD_WIRE_ID' WHERE deposit_serial_id=${SERIAL}" | psql -Aqt $DB
+ echo PASS
+ # Undo:
+ echo "UPDATE exchange.deposits SET wire_target_h_payto='$OLD_WIRE_ID' WHERE deposit_serial_id=${SERIAL}" | psql -Aqt "$DB"
}
@@ -603,42 +740,44 @@ echo "UPDATE exchange.deposits SET wire_target_h_payto='$OLD_WIRE_ID' WHERE depo
# Test where h_contract_terms in the deposit table is wrong
# (=> bad signature)
function test_5() {
-echo "===========5: deposit contract hash wrong================="
-# Modify h_wire hash, so it is inconsistent with 'wire'
-SERIAL=`echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql $DB -Aqt`
-OLD_H=`echo "SELECT h_contract_terms FROM exchange.deposits WHERE deposit_serial_id=$SERIAL;" | psql $DB -Aqt`
-echo "UPDATE exchange.deposits SET h_contract_terms='\x12bb676444955c98789f219148aa31899d8c354a63330624d3d143222cf3bb8b8e16f69accd5a8773127059b804c1955696bf551dd7be62719870613332aa8d5' WHERE deposit_serial_id=$SERIAL" | psql -Aqt $DB
+ echo "===========5: deposit contract hash wrong================="
+ # Modify h_wire hash, so it is inconsistent with 'wire'
+ SERIAL=$(echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql "$DB" -Aqt)
+ OLD_H=$(echo "SELECT h_contract_terms FROM exchange.deposits WHERE deposit_serial_id=$SERIAL;" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.deposits SET h_contract_terms='\x12bb676444955c98789f219148aa31899d8c354a63330624d3d143222cf3bb8b8e16f69accd5a8773127059b804c1955696bf551dd7be62719870613332aa8d5' WHERE deposit_serial_id=$SERIAL" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Checking bad signature detection... "
-ROW=`jq -e .bad_sig_losses[0].row < test-audit-coins.json`
-if test $ROW != $SERIAL
-then
- exit_fail "Row wrong, got $ROW"
-fi
+ echo -n "Checking bad signature detection... "
+ ROW=$(jq -e .bad_sig_losses[0].row < test-audit-coins.json)
+ if [ "$ROW" != "$SERIAL" ]
+ then
+ exit_fail "Row wrong, got $ROW"
+ fi
-LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong deposit bad signature loss, got $LOSS"
-fi
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong deposit bad signature loss, got $LOSS"
+ fi
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-coins.json`
-if test $OP != "deposit"
-then
- exit_fail "Wrong operation, got $OP"
-fi
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "deposit" ]
+ then
+ exit_fail "Wrong operation, got $OP"
+ fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong total bad sig loss, got $LOSS"
-fi
-echo PASS
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong total bad sig loss, got $LOSS"
+ fi
+ echo PASS
-# Undo:
-echo "UPDATE exchange.deposits SET h_contract_terms='${OLD_H}' WHERE deposit_serial_id=$SERIAL" | psql -Aqt $DB
+ # Undo:
+ echo "UPDATE exchange.deposits SET h_contract_terms='${OLD_H}' WHERE deposit_serial_id=$SERIAL" | psql -Aqt "$DB"
}
@@ -646,40 +785,42 @@ echo "UPDATE exchange.deposits SET h_contract_terms='${OLD_H}' WHERE deposit_ser
# Test where denom_sig in known_coins table is wrong
# (=> bad signature)
function test_6() {
-echo "===========6: known_coins signature wrong================="
-# Modify denom_sig, so it is wrong
-OLD_SIG=`echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql $DB -Aqt`
-COIN_PUB=`echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql $DB -Aqt`
-echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" | psql -Aqt $DB
+ echo "===========6: known_coins signature wrong================="
+ # Modify denom_sig, so it is wrong
+ OLD_SIG=$(echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql "$DB" -Aqt)
+ COIN_PUB=$(echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-ROW=`jq -e .bad_sig_losses[0].row < test-audit-coins.json`
-if test $ROW != "1"
-then
- exit_fail "Row wrong, got $ROW"
-fi
+ ROW=$(jq -e .bad_sig_losses[0].row < test-audit-coins.json)
+ if [ "$ROW" != "1" ]
+ then
+ exit_fail "Row wrong, got $ROW"
+ fi
-LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-coins.json`
-if test $LOSS == "TESTKUDOS:0"
-then
- exit_fail "Wrong deposit bad signature loss, got $LOSS"
-fi
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-coins.json)
+ if [ "$LOSS" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong deposit bad signature loss, got $LOSS"
+ fi
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-coins.json`
-if test $OP != "melt"
-then
- exit_fail "Wrong operation, got $OP"
-fi
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "melt" ]
+ then
+ exit_fail "Wrong operation, got $OP"
+ fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS == "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss, got $LOSS"
-fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss, got $LOSS"
+ fi
-# Undo
-echo "UPDATE exchange.known_coins SET denom_sig='$OLD_SIG' WHERE coin_pub='$COIN_PUB'" | psql -Aqt $DB
+ # Undo
+ echo "UPDATE exchange.known_coins SET denom_sig='$OLD_SIG' WHERE coin_pub='$COIN_PUB'" | psql -Aqt "$DB"
}
@@ -687,51 +828,53 @@ echo "UPDATE exchange.known_coins SET denom_sig='$OLD_SIG' WHERE coin_pub='$COIN
# Test where h_wire in the deposit table is wrong
function test_7() {
-echo "===========7: reserves_out signature wrong================="
-# Modify reserve_sig, so it is bogus
-HBE=`echo 'SELECT h_blind_ev FROM exchange.reserves_out LIMIT 1;' | psql $DB -Aqt`
-OLD_SIG=`echo "SELECT reserve_sig FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql $DB -Aqt`
-A_VAL=`echo "SELECT amount_with_fee_val FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql $DB -Aqt`
-A_FRAC=`echo "SELECT amount_with_fee_frac FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql $DB -Aqt`
-# Normalize, we only deal with cents in this test-case
-A_FRAC=`expr $A_FRAC / 1000000 || true`
-echo "UPDATE exchange.reserves_out SET reserve_sig='\x9ef381a84aff252646a157d88eded50f708b2c52b7120d5a232a5b628f9ced6d497e6652d986b581188fb014ca857fd5e765a8ccc4eb7e2ce9edcde39accaa4b' WHERE h_blind_ev='$HBE'" | psql -Aqt $DB
-
-run_audit
-
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-reserves.json`
-if test $OP != "withdraw"
-then
- exit_fail "Wrong operation, got $OP"
-fi
+ echo "===========7: reserves_out signature wrong================="
+ # Modify reserve_sig, so it is bogus
+ HBE=$(echo 'SELECT h_blind_ev FROM exchange.reserves_out LIMIT 1;' | psql "$DB" -Aqt)
+ OLD_SIG=$(echo "SELECT reserve_sig FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql "$DB" -Aqt)
+ A_VAL=$(echo "SELECT amount_with_fee_val FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql "$DB" -Aqt)
+ A_FRAC=$(echo "SELECT amount_with_fee_frac FROM exchange.reserves_out WHERE h_blind_ev='$HBE';" | psql "$DB" -Aqt)
+ # Normalize, we only deal with cents in this test-case
+ A_FRAC=$(( A_FRAC / 1000000))
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.reserves_out SET reserve_sig='\x9ef381a84aff252646a157d88eded50f708b2c52b7120d5a232a5b628f9ced6d497e6652d986b581188fb014ca857fd5e765a8ccc4eb7e2ce9edcde39accaa4b' WHERE h_blind_ev='$HBE'" \
+ | psql -Aqt "$DB"
-LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-reserves.json`
-LOSS_TOTAL=`jq -r .total_bad_sig_loss < test-audit-reserves.json`
-if test $LOSS != $LOSS_TOTAL
-then
- exit_fail "Expected loss $LOSS and total loss $LOSS_TOTAL do not match"
-fi
-if test $A_FRAC != 0
-then
- if [ $A_FRAC -lt 10 ]
+ run_audit
+
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-reserves.json)
+ if [ "$OP" != "withdraw" ]
then
- A_PREV="0"
- else
- A_PREV=""
+ exit_fail "Wrong operation, got $OP"
fi
- if test $LOSS != "TESTKUDOS:$A_VAL.$A_PREV$A_FRAC"
+
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-reserves.json)
+ LOSS_TOTAL=$(jq -r .total_bad_sig_loss < test-audit-reserves.json)
+ if [ "$LOSS" != "$LOSS_TOTAL" ]
then
- exit_fail "Expected loss TESTKUDOS:$A_VAL.$A_PREV$A_FRAC but got $LOSS"
+ exit_fail "Expected loss $LOSS and total loss $LOSS_TOTAL do not match"
fi
-else
- if test $LOSS != "TESTKUDOS:$A_VAL"
+ if [ "$A_FRAC" != 0 ]
then
- exit_fail "Expected loss TESTKUDOS:$A_VAL but got $LOSS"
+ if [ "$A_FRAC" -lt 10 ]
+ then
+ A_PREV="0"
+ else
+ A_PREV=""
+ fi
+ if [ "$LOSS" != "TESTKUDOS:$A_VAL.$A_PREV$A_FRAC" ]
+ then
+ exit_fail "Expected loss TESTKUDOS:$A_VAL.$A_PREV$A_FRAC but got $LOSS"
+ fi
+ else
+ if [ "$LOSS" != "TESTKUDOS:$A_VAL" ]
+ then
+ exit_fail "Expected loss TESTKUDOS:$A_VAL but got $LOSS"
+ fi
fi
-fi
-# Undo:
-echo "UPDATE exchange.reserves_out SET reserve_sig='$OLD_SIG' WHERE h_blind_ev='$HBE'" | psql -Aqt $DB
+ # Undo:
+ echo "UPDATE exchange.reserves_out SET reserve_sig='$OLD_SIG' WHERE h_blind_ev='$HBE'" | psql -Aqt "$DB"
}
@@ -739,68 +882,77 @@ echo "UPDATE exchange.reserves_out SET reserve_sig='$OLD_SIG' WHERE h_blind_ev='
# Test wire transfer subject disagreement!
function test_8() {
-echo "===========8: wire-transfer-subject disagreement==========="
-OLD_ID=`echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | sqlite3 $DB.sqlite3`
-OLD_WTID=`echo "SELECT reservePublicKey FROM TalerIncomingPayments WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3`
-NEW_WTID="CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG"
-echo "UPDATE TalerIncomingPayments SET reservePublicKey='$NEW_WTID' WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3
+ echo "===========8: wire-transfer-subject disagreement==========="
+ # Technically, this call shouldn't be needed, as libeufin should already be stopped here.
+ stop_libeufin
+ echo "FIXME: test needs update to new libeufin-bank schema"
+ exit 0
+ OLD_ID=$(echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | psql "${DB}" -Aqt) \
+ || exit_fail "Failed to SELECT FROM NexusBankTransactions nexus DB!"
+ OLD_WTID=$(echo "SELECT \"reservePublicKey\" FROM TalerIncomingPayments WHERE payment='$OLD_ID';" \
+ | psql "${DB}" -Aqt)
+ NEW_WTID="CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG"
+ echo "UPDATE TalerIncomingPayments SET \"reservePublicKey\"='$NEW_WTID' WHERE payment='$OLD_ID';" \
+ | psql "${DB}" -q \
+ || exit_fail "Failed to update TalerIncomingPayments"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-DIAG=`jq -r .reserve_in_amount_inconsistencies[0].diagnostic < test-audit-wire.json`
-if test "x$DIAG" != "xwire subject does not match"
-then
- exit_fail "Diagnostic wrong: $DIAG (0)"
-fi
-WTID=`jq -r .reserve_in_amount_inconsistencies[0].reserve_pub < test-audit-wire.json`
-if test x$WTID != x"$OLD_WTID" -a x$WTID != x"$NEW_WTID"
-then
- exit_fail "WTID reported wrong: $WTID"
-fi
-EX_A=`jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json`
-if test x$WTID = x$OLD_WTID -a x$EX_A != x"TESTKUDOS:10"
-then
- exit_fail "Amount reported wrong: $EX_A"
-fi
-if test x$WTID = x$NEW_WTID -a x$EX_A != x"TESTKUDOS:0"
-then
- exit_fail "Amount reported wrong: $EX_A"
-fi
-DIAG=`jq -r .reserve_in_amount_inconsistencies[1].diagnostic < test-audit-wire.json`
-if test "x$DIAG" != "xwire subject does not match"
-then
- exit_fail "Diagnostic wrong: $DIAG (1)"
-fi
-WTID=`jq -r .reserve_in_amount_inconsistencies[1].reserve_pub < test-audit-wire.json`
-if test $WTID != "$OLD_WTID" -a $WTID != "$NEW_WTID"
-then
- exit_fail "WTID reported wrong: $WTID (wanted: $NEW_WTID or $OLD_WTID)"
-fi
-EX_A=`jq -r .reserve_in_amount_inconsistencies[1].amount_exchange_expected < test-audit-wire.json`
-if test $WTID = "$OLD_WTID" -a $EX_A != "TESTKUDOS:10"
-then
- exit_fail "Amount reported wrong: $EX_A"
-fi
-if test $WTID = "$NEW_WTID" -a $EX_A != "TESTKUDOS:0"
-then
- exit_fail "Amount reported wrong: $EX_A"
-fi
+ echo -n "Testing inconsistency detection... "
+ DIAG=$(jq -r .reserve_in_amount_inconsistencies[0].diagnostic < test-audit-wire.json)
+ if [ "x$DIAG" != "xwire subject does not match" ]
+ then
+ exit_fail "Diagnostic wrong: $DIAG (0)"
+ fi
+ WTID=$(jq -r .reserve_in_amount_inconsistencies[0].reserve_pub < test-audit-wire.json)
+ if [ "$WTID" != "$OLD_WTID" ] && [ "$WTID" != "$NEW_WTID" ]
+ then
+ exit_fail "WTID reported wrong: $WTID (wanted $OLD_WTID or $NEW_WTID)"
+ fi
+ EX_A=$(jq -r .reserve_in_amount_inconsistencies[0].amount_exchange_expected < test-audit-wire.json)
+ if [ "$WTID" = "$OLD_WTID" ] && [ "$EX_A" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Amount reported wrong: $EX_A"
+ fi
+ if [ "$WTID" = "$NEW_WTID" ] && [ "$EX_A" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Amount reported wrong: $EX_A"
+ fi
+ DIAG=$(jq -r .reserve_in_amount_inconsistencies[1].diagnostic < test-audit-wire.json)
+ if [ "$DIAG" != "wire subject does not match" ]
+ then
+ exit_fail "Diagnostic wrong: $DIAG (1)"
+ fi
+ WTID=$(jq -r .reserve_in_amount_inconsistencies[1].reserve_pub < test-audit-wire.json)
+ if [ "$WTID" != "$OLD_WTID" ] && [ "$WTID" != "$NEW_WTID" ]
+ then
+ exit_fail "WTID reported wrong: $WTID (wanted: $NEW_WTID or $OLD_WTID)"
+ fi
+ EX_A=$(jq -r .reserve_in_amount_inconsistencies[1].amount_exchange_expected < test-audit-wire.json)
+ if [ "$WTID" = "$OLD_WTID" ] && [ "$EX_A" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Amount reported wrong: $EX_A"
+ fi
+ if [ "$WTID" = "$NEW_WTID" ] && [ "$EX_A" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Amount reported wrong: $EX_A"
+ fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:10"
-then
- exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
-fi
-DELTA=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $DELTA != "TESTKUDOS:10"
-then
- exit_fail "Expected total wire delta plus wrong, got $DELTA"
-fi
-echo PASS
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Wrong total wire_in_delta_minus, got $WIRED"
+ fi
+ DELTA=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$DELTA" != "TESTKUDOS:10" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $DELTA"
+ fi
+ echo "PASS"
-# Undo database modification
-echo "UPDATE TalerIncomingPayments SET reservePublicKey='$OLD_WTID' WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3
+ # Undo database modification
+ echo "UPDATE TalerIncomingPayments SET \"reservePublicKey\"='$OLD_WTID' WHERE payment='$OLD_ID';" \
+ | psql "${DB}" -q
}
@@ -808,57 +960,67 @@ echo "UPDATE TalerIncomingPayments SET reservePublicKey='$OLD_WTID' WHERE paymen
# Test wire origin disagreement!
function test_9() {
-echo "===========9: wire-origin disagreement==========="
-OLD_ID=`echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | sqlite3 $DB.sqlite3`
-OLD_ACC=`echo "SELECT incomingPaytoUri FROM TalerIncomingPayments WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3`
-echo "UPDATE TalerIncomingPayments SET incomingPaytoUri='payto://iban/SANDBOXX/DE144373?receiver-name=New+Exchange+Company' WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3
+ echo "===========9: wire-origin disagreement==========="
+ # Technically, this call shouldn't be needed, as libeufin should already be stopped here.
+ stop_libeufin
+ echo "FIXME: test needs update to new libeufin-bank schema"
+ exit 0
+ OLD_ID=$(echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | psql "${DB}" -Aqt)
+ OLD_ACC=$(echo 'SELECT "incomingPaytoUri" FROM TalerIncomingPayments WHERE payment='"'$OLD_ID';" | psql "${DB}" -Aqt)
+ echo "UPDATE TalerIncomingPayments SET \"incomingPaytoUri\"='payto://iban/SANDBOXX/DE144373?receiver-name=New+Exchange+Company' WHERE payment='$OLD_ID';" \
+ | psql "${DB}" -q
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-AMOUNT=`jq -r .missattribution_in_inconsistencies[0].amount < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:10"
-then
- exit_fail "Reported amount wrong: $AMOUNT"
-fi
-AMOUNT=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:10"
-then
- exit_fail "Reported total amount wrong: $AMOUNT"
-fi
-echo PASS
+ echo -n "Testing inconsistency detection... "
+ AMOUNT=$(jq -r .misattribution_in_inconsistencies[0].amount < test-audit-wire.json)
+ if test "x$AMOUNT" != "xTESTKUDOS:10"
+ then
+ exit_fail "Reported amount wrong: $AMOUNT"
+ fi
+ AMOUNT=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if test "x$AMOUNT" != "xTESTKUDOS:10"
+ then
+ exit_fail "Reported total amount wrong: $AMOUNT"
+ fi
+ echo PASS
-# Undo database modification
-echo "UPDATE TalerIncomingPayments SET incomingPaytoUri='$OLD_ACC' WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3
+ # Undo database modification
+ echo "UPDATE TalerIncomingPayments SET \"incomingPaytoUri\"='$OLD_ACC' WHERE payment='$OLD_ID';" \
+ | psql "${DB}" -q
}
# Test wire_in timestamp disagreement!
function test_10() {
-NOW_MS=`date +%s`000
-echo "===========10: wire-timestamp disagreement==========="
-OLD_ID=`echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | sqlite3 $DB.sqlite3`
-OLD_DATE=`echo "SELECT timestampMs FROM TalerIncomingPayments WHERE payment='$OLD_ID';" | sqlite3 $DB.sqlite3`
-echo "UPDATE TalerIncomingPayments SET timestampMs=$NOW_MS WHERE payment=$OLD_ID;" | sqlite3 $DB.sqlite3
+ NOW_MS=$(date +%s)000
+ echo "===========10: wire-timestamp disagreement==========="
+ # Technically, this call shouldn't be needed, as libeufin should already be stopped here.
+ stop_libeufin
+ echo "FIXME: test needs update to new libeufin-bank schema"
+ exit 0
+ OLD_ID=$(echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | psql "${DB}" -Aqt)
+ OLD_DATE=$(echo "SELECT \"timestampMs\" FROM TalerIncomingPayments WHERE payment='$OLD_ID';" | psql "${DB}" -Aqt)
+ echo "UPDATE TalerIncomingPayments SET \"timestampMs\"=$NOW_MS WHERE payment=$OLD_ID;" | psql "${DB}" -q
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-DIAG=`jq -r .row_minor_inconsistencies[0].diagnostic < test-audit-wire.json`
-if test "x$DIAG" != "xexecution date mismatch"
-then
- exit_fail "Reported diagnostic wrong: $DIAG"
-fi
-TABLE=`jq -r .row_minor_inconsistencies[0].table < test-audit-wire.json`
-if test "x$TABLE" != "xreserves_in"
-then
- exit_fail "Reported table wrong: $TABLE"
-fi
-echo PASS
+ echo -n "Testing inconsistency detection... "
+ DIAG=$(jq -r .row_minor_inconsistencies[0].diagnostic < test-audit-wire.json)
+ if test "x$DIAG" != "xexecution date mismatch"
+ then
+ exit_fail "Reported diagnostic wrong: $DIAG"
+ fi
+ TABLE=$(jq -r .row_minor_inconsistencies[0].table < test-audit-wire.json)
+ if test "x$TABLE" != "xreserves_in"
+ then
+ exit_fail "Reported table wrong: $TABLE"
+ fi
+ echo "PASS"
-# Undo database modification
-echo "UPDATE TalerIncomingPayments SET timestampMs='$OLD_DATE' WHERE payment=$OLD_ID;" | sqlite3 $DB.sqlite3
+ # Undo database modification
+ echo "UPDATE TalerIncomingPayments SET \"timestampMs\"='$OLD_DATE' WHERE payment=$OLD_ID;" | psql "${DB}" -q
}
@@ -867,340 +1029,312 @@ echo "UPDATE TalerIncomingPayments SET timestampMs='$OLD_DATE' WHERE payment=$OL
# In case of changing the subject in the Nexus
# ingested table: '.batches[0].batchTransactions[0].details.unstructuredRemittanceInformation'
function test_11() {
-echo "===========11: spurious outgoing transfer ==========="
-OLD_ID=`echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | sqlite3 $DB.sqlite3`
-OLD_TX=`echo "SELECT transactionJson FROM NexusBankTransactions WHERE id='$OLD_ID';" | sqlite3 $DB.sqlite3`
-# Change wire transfer to be FROM the exchange (#2) to elsewhere!
-# (Note: this change also causes a missing incoming wire transfer, but
-# this test is only concerned about the outgoing wire transfer
-# being detected as such, and we simply ignore the other
-# errors being reported.)
-OTHER_IBAN=`echo -e "SELECT iban FROM BankAccounts WHERE label='fortytwo'" | sqlite3 $DB.sqlite3`
-NEW_TX=$(echo "$OLD_TX" | jq .batches[0].batchTransactions[0].details.creditDebitIndicator='"DBIT"' | jq 'del(.batches[0].batchTransactions[0].details.debtor)' | jq 'del(.batches[0].batchTransactions[0].details.debtorAccount)' | jq 'del(.batches[0].batchTransactions[0].details.debtorAgent)' | jq '.batches[0].batchTransactions[0].details.creditor'='{"name": "Forty Two"}' | jq .batches[0].batchTransactions[0].details.creditorAccount='{"iban": "'$OTHER_IBAN'"}' | jq .batches[0].batchTransactions[0].details.creditorAgent='{"bic": "SANDBOXX"}' | jq .batches[0].batchTransactions[0].details.unstructuredRemittanceInformation='"CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG http://exchange.example.com/"')
-echo -e "UPDATE NexusBankTransactions SET transactionJson='"$NEW_TX"' WHERE id=$OLD_ID" | sqlite3 $DB.sqlite3
-# Now fake that the exchange prepared this payment (= it POSTed to /transfer)
-# This step is necessary, because the TWG table that accounts for outgoing
-# payments needs it. Worth noting here is the column 'rawConfirmation' that
-# points to the transaction from the main Nexus ledger; without that column set,
-# a prepared payment won't appear as actually outgoing.
-echo -e "INSERT INTO PaymentInitiations (bankAccount,preparationDate,submissionDate,sum,currency,endToEndId,paymentInformationId,instructionId,subject,creditorIban,creditorBic,creditorName,submitted,messageId,rawConfirmation) VALUES (1,1,1,10,'TESTKUDOS','NOTGIVEN','unused','unused','CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG http://exchange.example.com/','"$OTHER_IBAN"','SANDBOXX','Forty Two','unused',1,$OLD_ID)" | sqlite3 $DB.sqlite3
-# Now populate the TWG table that accounts for outgoing payments, in
-# order to let /history/outgoing return one result.
-echo -e "INSERT INTO TalerRequestedPayments (facade,payment,requestUid,amount,exchangeBaseUrl,wtid,creditAccount) VALUES (1,1,'unused','TESTKUDOS:10','http://exchange.example.com/','CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG','payto://iban/SANDBOXX/"$OTHER_IBAN"?receiver-name=Forty+Two')" | sqlite3 $DB.sqlite3
-
-run_audit
-
-echo -n "Testing inconsistency detection... "
-AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:10"
-then
- exit_fail "Reported wired amount wrong: $AMOUNT"
-fi
-AMOUNT=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:10"
-then
- exit_fail "Reported total plus amount wrong: $AMOUNT"
-fi
-AMOUNT=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:0"
-then
- exit_fail "Reported total minus amount wrong: $AMOUNT"
-fi
-AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json`
-if test "x$AMOUNT" != "xTESTKUDOS:0"
-then
- exit_fail "Reported justified amount wrong: $AMOUNT"
-fi
-DIAG=`jq -r .wire_out_amount_inconsistencies[0].diagnostic < test-audit-wire.json`
-if test "x$DIAG" != "xjustification for wire transfer not found"
-then
- exit_fail "Reported diagnostic wrong: $DIAG"
-fi
-echo PASS
-
-# Undo database modification
-echo -e "UPDATE NexusBankTransactions SET transactionJson='"$OLD_TX"' WHERE id=$OLD_ID;" | sqlite3 $DB.sqlite3
-# No other prepared payment should exist at this point,
-# so OK to remove the number 1.
-echo -e "DELETE FROM PaymentInitiations WHERE id=1" | sqlite3 $DB.sqlite3
-echo -e "DELETE FROM TalerRequestedPayments WHERE id=1" | sqlite3 $DB.sqlite3
-}
+ echo "===========11: spurious outgoing transfer ==========="
+ # Technically, this call shouldn't be needed, as libeufin should already be stopped here.
+ stop_libeufin
+ echo "FIXME: test needs update to new libeufin-bank schema"
+ exit 0
+ OLD_ID=$(echo "SELECT id FROM NexusBankTransactions WHERE amount='10' AND currency='TESTKUDOS' ORDER BY id LIMIT 1;" | psql "${DB}" -Aqt)
+ OLD_TX=$(echo "SELECT \"transactionJson\" FROM NexusBankTransactions WHERE id='$OLD_ID';" | psql "${DB}" -Aqt)
+ # Change wire transfer to be FROM the exchange (#2) to elsewhere!
+ # (Note: this change also causes a missing incoming wire transfer, but
+ # this test is only concerned about the outgoing wire transfer
+ # being detected as such, and we simply ignore the other
+ # errors being reported.)
+ OTHER_IBAN=$(echo -e "SELECT iban FROM BankAccounts WHERE label='fortytwo'" | psql "${DB}" -Aqt)
+ NEW_TX=$(echo "$OLD_TX" | jq .batches[0].batchTransactions[0].details.creditDebitIndicator='"DBIT"' | jq 'del(.batches[0].batchTransactions[0].details.debtor)' | jq 'del(.batches[0].batchTransactions[0].details.debtorAccount)' | jq 'del(.batches[0].batchTransactions[0].details.debtorAgent)' | jq '.batches[0].batchTransactions[0].details.creditor'='{"name": "Forty Two"}' | jq .batches[0].batchTransactions[0].details.creditorAccount='{"iban": "'"$OTHER_IBAN"'"}' | jq .batches[0].batchTransactions[0].details.creditorAgent='{"bic": "SANDBOXX"}' | jq .batches[0].batchTransactions[0].details.unstructuredRemittanceInformation='"CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG http://exchange.example.com/"')
+ echo -e "UPDATE NexusBankTransactions SET \"transactionJson\"='""$NEW_TX""' WHERE id=$OLD_ID" \
+ | psql "${DB}" -q
+ # Now fake that the exchange prepared this payment (= it POSTed to /transfer)
+ # This step is necessary, because the TWG table that accounts for outgoing
+ # payments needs it. Worth noting here is the column 'rawConfirmation' that
+ # points to the transaction from the main Nexus ledger; without that column set,
+ # a prepared payment won't appear as actually outgoing.
+ echo -e "INSERT INTO PaymentInitiations (\"bankAccount\",\"preparationDate\",\"submissionDate\",sum,currency,\"endToEndId\",\"paymentInformationId\",\"instructionId\",subject,\"creditorIban\",\"creditorBic\",\"creditorName\",submitted,\"messageId\",\"rawConfirmation\") VALUES (1,1,1,10,'TESTKUDOS','NOTGIVEN','unused','unused','CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG http://exchange.example.com/','""$OTHER_IBAN""','SANDBOXX','Forty Two',false,1,$OLD_ID)" \
+ | psql "${DB}" -q
+ # Now populate the TWG table that accounts for outgoing payments, in
+ # order to let /history/outgoing return one result.
+ echo -e "INSERT INTO TalerRequestedPayments (facade,payment,\"requestUid\",amount,\"exchangeBaseUrl\",wtid,\"creditAccount\") VALUES (1,1,'unused','TESTKUDOS:10','http://exchange.example.com/','CK9QBFY972KR32FVA1MW958JWACEB6XCMHHKVFMCH1A780Q12SVG','payto://iban/SANDBOXX/""$OTHER_IBAN""?receiver-name=Forty+Two')" \
+ | psql "${DB}" -q
-# Test for hanging/pending refresh.
-function test_12() {
+ run_audit
+
+ echo -n "Testing inconsistency detection... "
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json)
+ if [ "x$AMOUNT" != "xTESTKUDOS:10" ]
+ then
+ exit_fail "Reported wired amount wrong: $AMOUNT"
+ fi
+ AMOUNT=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "x$AMOUNT" != "xTESTKUDOS:10" ]
+ then
+ exit_fail "Reported total plus amount wrong: $AMOUNT"
+ fi
+ AMOUNT=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "x$AMOUNT" != "xTESTKUDOS:0" ]
+ then
+ exit_fail "Reported total minus amount wrong: $AMOUNT"
+ fi
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json)
+ if [ "x$AMOUNT" != "xTESTKUDOS:0" ]
+ then
+ exit_fail "Reported justified amount wrong: $AMOUNT"
+ fi
+ DIAG=$(jq -r .wire_out_amount_inconsistencies[0].diagnostic < test-audit-wire.json)
+ if [ "x$DIAG" != "xjustification for wire transfer not found" ]
+ then
+ exit_fail "Reported diagnostic wrong: $DIAG"
+ fi
+ echo "PASS"
-echo "===========12: incomplete refresh ==========="
-OLD_ACC=`echo "DELETE FROM exchange.refresh_revealed_coins;" | psql $DB -Aqt`
+ full_reload
+}
-run_audit
-echo -n "Testing hung refresh detection... "
+# Test for hanging/pending refresh.
+function test_12() {
-HANG=`jq -er .refresh_hanging[0].amount < test-audit-coins.json`
-TOTAL_HANG=`jq -er .total_refresh_hanging < test-audit-coins.json`
-if test x$HANG = TESTKUDOS:0
-then
- exit_fail "Hanging amount zero"
-fi
-if test x$TOTAL_HANG = TESTKUDOS:0
-then
- exit_fail "Total hanging amount zero"
-fi
+ echo "===========12: incomplete refresh ==========="
+ OLD_ACC=$(echo "DELETE FROM exchange.refresh_revealed_coins;" | psql "$DB" -Aqt)
-echo PASS
+ run_audit
+ echo -n "Testing hung refresh detection... "
-# cannot easily undo DELETE, hence full reload
-full_reload
+ HANG=$(jq -er .refresh_hanging[0].amount < test-audit-coins.json)
+ TOTAL_HANG=$(jq -er .total_refresh_hanging < test-audit-coins.json)
+ if [ "$HANG" = "TESTKUDOS:0" ]
+ then
+ exit_fail "Hanging amount zero"
+ fi
+ if [ "$TOTAL_HANG" = "TESTKUDOS:0" ]
+ then
+ exit_fail "Total hanging amount zero"
+ fi
+ echo "PASS"
+ # cannot easily undo DELETE, hence full reload
+ full_reload
}
# Test for wrong signature on refresh.
function test_13() {
-echo "===========13: wrong melt signature ==========="
-# Modify denom_sig, so it is wrong
-COIN_PUB=`echo "SELECT old_coin_pub FROM exchange.refresh_commitments LIMIT 1;" | psql $DB -Aqt`
-OLD_SIG=`echo "SELECT old_coin_sig FROM exchange.refresh_commitments WHERE old_coin_pub='$COIN_PUB';" | psql $DB -Aqt`
-NEW_SIG="\xba588af7c13c477dca1ac458f65cc484db8fba53b969b873f4353ecbd815e6b4c03f42c0cb63a2b609c2d726e612fd8e0c084906a41f409b6a23a08a83c89a02"
-echo "UPDATE exchange.refresh_commitments SET old_coin_sig='$NEW_SIG' WHERE old_coin_pub='$COIN_PUB'" | psql -Aqt $DB
+ echo "===========13: wrong melt signature ==========="
+ # Modify denom_sig, so it is wrong
+ COIN_PUB=$(echo "SELECT old_coin_pub FROM exchange.refresh_commitments LIMIT 1;" | psql "$DB" -Aqt)
+ OLD_SIG=$(echo "SELECT old_coin_sig FROM exchange.refresh_commitments WHERE old_coin_pub='$COIN_PUB';" | psql "$DB" -Aqt)
+ NEW_SIG="\xba588af7c13c477dca1ac458f65cc484db8fba53b969b873f4353ecbd815e6b4c03f42c0cb63a2b609c2d726e612fd8e0c084906a41f409b6a23a08a83c89a02"
+ echo "UPDATE exchange.refresh_commitments SET old_coin_sig='$NEW_SIG' WHERE old_coin_pub='$COIN_PUB'" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
+ echo -n "Testing inconsistency detection... "
-OP=`jq -er .bad_sig_losses[0].operation < test-audit-coins.json`
-if test x$OP != xmelt
-then
- exit_fail "Operation wrong, got $OP"
-fi
+ OP=$(jq -er .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "melt" ]
+ then
+ exit_fail "Operation wrong, got $OP"
+ fi
-LOSS=`jq -er .bad_sig_losses[0].loss < test-audit-coins.json`
-TOTAL_LOSS=`jq -er .total_bad_sig_loss < test-audit-coins.json`
-if test x$LOSS != x$TOTAL_LOSS
-then
- exit_fail "Loss inconsistent, got $LOSS and $TOTAL_LOSS"
-fi
-if test x$TOTAL_LOSS = TESTKUDOS:0
-then
- exit_fail "Loss zero"
-fi
+ LOSS=$(jq -er .bad_sig_losses[0].loss < test-audit-coins.json)
+ TOTAL_LOSS=$(jq -er .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "$TOTAL_LOSS" ]
+ then
+ exit_fail "Loss inconsistent, got $LOSS and $TOTAL_LOSS"
+ fi
+ if [ "$TOTAL_LOSS" = "TESTKUDOS:0" ]
+ then
+ exit_fail "Loss zero"
+ fi
-echo PASS
+ echo "PASS"
-# cannot easily undo DELETE, hence full reload
-full_reload
+ # cannot easily undo DELETE, hence full reload
+ full_reload
}
# Test for wire fee disagreement
function test_14() {
-echo "===========14: wire-fee disagreement==========="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-wire-auditor.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========14: wire-fee disagreement==========="
# Wire fees are only checked/generated once there are
# actual outgoing wire transfers, so we need to run the
# aggregator here.
pre_audit aggregator
- echo "UPDATE exchange.wire_fee SET wire_fee_frac=100;" | psql -Aqt $DB
+ echo "UPDATE exchange.wire_fee SET wire_fee_frac=100;" \
+ | psql -Aqt "$DB"
audit_only
post_audit
echo -n "Testing inconsistency detection... "
- TABLE=`jq -r .row_inconsistencies[0].table < test-audit-aggregation.json`
- if test "x$TABLE" != "xwire-fee"
+ TABLE=$(jq -r .row_inconsistencies[0].table < test-audit-aggregation.json)
+ if [ "$TABLE" != "wire-fee" ]
then
exit_fail "Reported table wrong: $TABLE"
fi
- DIAG=`jq -r .row_inconsistencies[0].diagnostic < test-audit-aggregation.json`
- if test "x$DIAG" != "xwire fee signature invalid at given time"
+ DIAG=$(jq -r .row_inconsistencies[0].diagnostic < test-audit-aggregation.json)
+ if [ "$DIAG" != "wire fee signature invalid at given time" ]
then
exit_fail "Reported diagnostic wrong: $DIAG"
fi
- echo PASS
+ echo "PASS"
# cannot easily undo aggregator, hence full reload
full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
-
}
# Test where salt in the deposit table is wrong
function test_15() {
-echo "===========15: deposit wire salt wrong================="
+ echo "===========15: deposit wire salt wrong================="
-# Modify wire_salt hash, so it is inconsistent
-SALT=`echo "SELECT wire_salt FROM exchange.deposits WHERE deposit_serial_id=1;" | psql -Aqt $DB`
-echo "UPDATE exchange.deposits SET wire_salt='\x1197cd7f7b0e13ab1905fedb36c536a2' WHERE deposit_serial_id=1;" | psql -Aqt $DB
+ # Modify wire_salt hash, so it is inconsistent
+ SALT=$(echo "SELECT wire_salt FROM exchange.deposits WHERE deposit_serial_id=1;" | psql -Aqt "$DB")
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.deposits SET wire_salt='\x1197cd7f7b0e13ab1905fedb36c536a2' WHERE deposit_serial_id=1;" \
+ | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-coins.json`
-if test "x$OP" != "xdeposit"
-then
- exit_fail "Reported operation wrong: $OP"
-fi
-echo PASS
+ echo -n "Testing inconsistency detection... "
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "deposit" ]
+ then
+ exit_fail "Reported operation wrong: $OP"
+ fi
+ echo "PASS"
-# Restore DB
-echo "UPDATE exchange.deposits SET wire_salt='$SALT' WHERE deposit_serial_id=1;" | psql -Aqt $DB
+ # Restore DB
+ echo "UPDATE exchange.deposits SET wire_salt='$SALT' WHERE deposit_serial_id=1;" \
+ | psql -Aqt "$DB"
}
# Test where wired amount (wire out) is wrong
function test_16() {
-echo "===========16: incorrect wire_out amount================="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========16: incorrect wire_out amount================="
+
+ # Check wire transfer lag reported (no aggregator!)
# First, we need to run the aggregator so we even
# have a wire_out to modify.
pre_audit aggregator
- # Modify wire amount, such that it is inconsistent with 'aggregation'
- # (Only one payment out exist, so the logic below should select the outgoing
- # wire transfer):
- OLD_AMOUNT=`echo "SELECT amount FROM TalerRequestedPayments WHERE id='1';" | sqlite3 $DB.sqlite3`
+ stop_libeufin
+ OLD_AMOUNT=$(echo "SELECT amount FROM TalerRequestedPayments WHERE id='1';" | psql "${DB}" -Aqt)
NEW_AMOUNT="TESTKUDOS:50"
- echo "UPDATE TalerRequestedPayments SET amount='${NEW_AMOUNT}' WHERE id='1';" | sqlite3 $DB.sqlite3
+ echo "UPDATE TalerRequestedPayments SET amount='${NEW_AMOUNT}' WHERE id='1';" \
+ | psql "${DB}" -q
+ launch_libeufin
audit_only
echo -n "Testing inconsistency detection... "
- AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json`
- if test "x$AMOUNT" != "x$OLD_AMOUNT"
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json)
+ if [ "$AMOUNT" != "$OLD_AMOUNT" ]
then
exit_fail "Reported justified amount wrong: $AMOUNT"
fi
- AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json`
- if test "x$AMOUNT" != "x$NEW_AMOUNT"
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json)
+ if [ "$AMOUNT" != "$NEW_AMOUNT" ]
then
exit_fail "Reported wired amount wrong: $AMOUNT"
fi
- TOTAL_AMOUNT=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
- if test "x$TOTAL_AMOUNT" != "xTESTKUDOS:0"
+ TOTAL_AMOUNT=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$TOTAL_AMOUNT" != "TESTKUDOS:0" ]
then
exit_fail "Reported total wired amount minus wrong: $TOTAL_AMOUNT"
fi
- TOTAL_AMOUNT=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
- if test "x$TOTAL_AMOUNT" = "xTESTKUDOS:0"
+ TOTAL_AMOUNT=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$TOTAL_AMOUNT" = "TESTKUDOS:0" ]
then
exit_fail "Reported total wired amount plus wrong: $TOTAL_AMOUNT"
fi
- echo PASS
+ echo "PASS"
+ stop_libeufin
echo "Second modification: wire nothing"
NEW_AMOUNT="TESTKUDOS:0"
- echo "UPDATE TalerRequestedPayments SET amount='${NEW_AMOUNT}' WHERE id='1';" | sqlite3 $DB.sqlite3
+ echo "UPDATE TalerRequestedPayments SET amount='${NEW_AMOUNT}' WHERE id='1';" \
+ | psql "${DB}" -q
+ launch_libeufin
audit_only
-
+ stop_libeufin
echo -n "Testing inconsistency detection... "
- AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json`
- if test "x$AMOUNT" != "x$OLD_AMOUNT"
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_justified < test-audit-wire.json)
+ if [ "$AMOUNT" != "$OLD_AMOUNT" ]
then
exit_fail "Reported justified amount wrong: $AMOUNT"
fi
- AMOUNT=`jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json`
- if test "x$AMOUNT" != "x$NEW_AMOUNT"
+ AMOUNT=$(jq -r .wire_out_amount_inconsistencies[0].amount_wired < test-audit-wire.json)
+ if [ "$AMOUNT" != "$NEW_AMOUNT" ]
then
exit_fail "Reported wired amount wrong: $AMOUNT"
fi
- TOTAL_AMOUNT=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
- if test "x$TOTAL_AMOUNT" != "x$OLD_AMOUNT"
+ TOTAL_AMOUNT=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$TOTAL_AMOUNT" != "$OLD_AMOUNT" ]
then
exit_fail "Reported total wired amount minus wrong: $TOTAL_AMOUNT (wanted $OLD_AMOUNT)"
fi
- TOTAL_AMOUNT=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
- if test "x$TOTAL_AMOUNT" != "xTESTKUDOS:0"
+ TOTAL_AMOUNT=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$TOTAL_AMOUNT" != "TESTKUDOS:0" ]
then
exit_fail "Reported total wired amount plus wrong: $TOTAL_AMOUNT"
fi
- echo PASS
+ echo "PASS"
post_audit
# cannot easily undo aggregator, hence full reload
full_reload
-else
- echo "Test skipped (database too new)"
-fi
-
}
-
# Test where wire-out timestamp is wrong
function test_17() {
-echo "===========17: incorrect wire_out timestamp================="
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========17: incorrect wire_out timestamp================="
# First, we need to run the aggregator so we even
# have a wire_out to modify.
pre_audit aggregator
-
- # Modify wire amount, such that it is inconsistent with 'aggregation'
- # (exchange paid only once, so the logic below should select the outgoing
- # wire transfer):
+ stop_libeufin
OLD_ID=1
- OLD_PREP=`echo "SELECT payment FROM TalerRequestedPayments WHERE id='${OLD_ID}';" | sqlite3 $DB.sqlite3`
- OLD_DATE=`echo "SELECT preparationDate FROM PaymentInitiations WHERE id='${OLD_ID}';" | sqlite3 $DB.sqlite3`
+ OLD_PREP=$(echo "SELECT payment FROM TalerRequestedPayments WHERE id='${OLD_ID}';" | psql "${DB}" -Aqt)
+ OLD_DATE=$(echo "SELECT \"preparationDate\" FROM PaymentInitiations WHERE id='${OLD_ID}';" | psql "${DB}" -Aqt)
# Note: need - interval '1h' as "NOW()" may otherwise be exactly what is already in the DB
# (due to rounding, if this machine is fast...)
- NOW_1HR=$(expr $(date +%s) - 3600)
- echo "UPDATE PaymentInitiations SET preparationDate='$NOW_1HR' WHERE id='${OLD_PREP}';" | sqlite3 $DB.sqlite3
+ NOW_1HR=$(( $(date +%s) - 3600))
+ echo "UPDATE PaymentInitiations SET \"preparationDate\"='$NOW_1HR' WHERE id='${OLD_PREP}';" \
+ | psql "${DB}" -q
+ launch_libeufin
+ echo "DONE"
audit_only
post_audit
echo -n "Testing inconsistency detection... "
- TABLE=`jq -r .row_minor_inconsistencies[0].table < test-audit-wire.json`
- if test "x$TABLE" != "xwire_out"
+ TABLE=$(jq -r .row_minor_inconsistencies[0].table < test-audit-wire.json)
+ if [ "$TABLE" != "wire_out" ]
then
exit_fail "Reported table wrong: $TABLE"
fi
- DIAG=`jq -r .row_minor_inconsistencies[0].diagnostic < test-audit-wire.json`
- DIAG=`echo "$DIAG" | awk '{print $1 " " $2 " " $3}'`
- if test "x$DIAG" != "xexecution date mismatch"
+ DIAG=$(jq -r .row_minor_inconsistencies[0].diagnostic < test-audit-wire.json)
+ DIAG=$(echo "$DIAG" | awk '{print $1 " " $2 " " $3}')
+ if [ "$DIAG" != "execution date mismatch" ]
then
exit_fail "Reported diagnostic wrong: $DIAG"
fi
- echo PASS
+ echo "PASS"
# cannot easily undo aggregator, hence full reload
full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
-
}
@@ -1208,64 +1342,67 @@ fi
# Test where we trigger an emergency.
function test_18() {
-echo "===========18: emergency================="
-
-echo "DELETE FROM exchange.reserves_out;" | psql -Aqt $DB
-
-run_audit
+ echo "===========18: emergency================="
-echo -n "Testing emergency detection... "
+ echo "DELETE FROM exchange.reserves_out;" \
+ | psql -Aqt "$DB" -q
-jq -e .reserve_balance_summary_wrong_inconsistencies[0] < test-audit-reserves.json > /dev/null || exit_fail "Reserve balance inconsistency not detected"
-
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null || exit_fail "Emergency not detected"
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null || exit_fail "Emergency by count not detected"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null || exit_fail "Escrow balance calculation impossibility not detected"
-
-echo PASS
-
-echo -n "Testing loss calculation... "
+ run_audit
-AMOUNT=`jq -r .emergencies_loss < test-audit-coins.json`
-if test "x$AMOUNT" == "xTESTKUDOS:0"
-then
- exit_fail "Reported amount wrong: $AMOUNT"
-fi
-AMOUNT=`jq -r .emergencies_loss_by_count < test-audit-coins.json`
-if test "x$AMOUNT" == "xTESTKUDOS:0"
-then
- exit_fail "Reported amount wrong: $AMOUNT"
-fi
+ echo -n "Testing emergency detection... "
+ jq -e .reserve_balance_summary_wrong_inconsistencies[0] \
+ < test-audit-reserves.json \
+ > /dev/null \
+ || exit_fail "Reserve balance inconsistency not detected"
+ jq -e .emergencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ || exit_fail "Emergency not detected"
+ jq -e .emergencies_by_count[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ || exit_fail "Emergency by count not detected"
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ || exit_fail "Escrow balance calculation impossibility not detected"
+ echo "PASS"
-echo PASS
+ echo -n "Testing loss calculation... "
+ AMOUNT=$(jq -r .emergencies_loss < test-audit-coins.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Reported amount wrong: $AMOUNT"
+ fi
+ AMOUNT=$(jq -r .emergencies_loss_by_count < test-audit-coins.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Reported amount wrong: $AMOUNT"
+ fi
+ echo "PASS"
-# cannot easily undo broad DELETE operation, hence full reload
-full_reload
+ # cannot easily undo broad DELETE operation, hence full reload
+ full_reload
}
# Test where reserve closure was done properly
function test_19() {
-echo "===========19: reserve closure done properly ================="
-
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========19: reserve closure done properly ================="
- OLD_TIME=`echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- OLD_VAL=`echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- RES_PUB=`echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- OLD_EXP=`echo "SELECT expiration_date FROM exchange.reserves WHERE reserve_pub='${RES_PUB}';" | psql $DB -Aqt`
+ OLD_TIME=$(echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ OLD_VAL=$(echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ RES_PUB=$(echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ OLD_EXP=$(echo "SELECT expiration_date FROM exchange.reserves WHERE reserve_pub='${RES_PUB}';" | psql "$DB" -Aqt)
VAL_DELTA=1
- NEW_TIME=`expr $OLD_TIME - 3024000000000 || true` # 5 weeks
- NEW_EXP=`expr $OLD_EXP - 3024000000000 || true` # 5 weeks
- NEW_CREDIT=`expr $OLD_VAL + $VAL_DELTA || true`
- echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" | psql -Aqt $DB
- echo "UPDATE exchange.reserves SET current_balance_val=${VAL_DELTA}+current_balance_val,expiration_date='${NEW_EXP}' WHERE reserve_pub='${RES_PUB}';" | psql -Aqt $DB
+ NEW_TIME=$(( OLD_TIME - 3024000000000)) # 5 weeks
+ NEW_EXP=$(( OLD_EXP - 3024000000000)) # 5 weeks
+ NEW_CREDIT=$(( OLD_VAL + VAL_DELTA))
+ echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" \
+ | psql -Aqt "$DB"
+ echo "UPDATE exchange.reserves SET current_balance_val=${VAL_DELTA}+current_balance_val,expiration_date='${NEW_EXP}' WHERE reserve_pub='${RES_PUB}';" \
+ | psql -Aqt "$DB"
# Need to run with the aggregator so the reserve closure happens
run_audit aggregator
@@ -1283,88 +1420,90 @@ then
# cannot easily undo aggregator, hence full reload
full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
}
# Test where reserve closure was not done properly
function test_20() {
-echo "===========20: reserve closure missing ================="
-
-OLD_TIME=`echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
-OLD_VAL=`echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
-RES_PUB=`echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
-NEW_TIME=`expr $OLD_TIME - 3024000000000 || true` # 5 weeks
-NEW_CREDIT=`expr $OLD_VAL + 100 || true`
-echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" | psql -Aqt $DB
-echo "UPDATE exchange.reserves SET current_balance_val=100+current_balance_val WHERE reserve_pub='${RES_PUB}';" | psql -Aqt $DB
-
-# This time, run without the aggregator so the reserve closure is skipped!
-run_audit
+ echo "===========20: reserve closure missing ================="
+
+ OLD_TIME=$(echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ OLD_VAL=$(echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ RES_PUB=$(echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ NEW_TIME=$(( OLD_TIME - 3024000000000 )) # 5 weeks
+ NEW_CREDIT=$(( OLD_VAL + 100 ))
+ echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" \
+ | psql -Aqt "$DB"
+ echo "UPDATE exchange.reserves SET current_balance_val=100+current_balance_val WHERE reserve_pub='${RES_PUB}';" \
+ | psql -Aqt "$DB"
+
+ # This time, run without the aggregator so the reserve closure is skipped!
+ run_audit
-echo -n "Testing reserve closure missing detected... "
-jq -e .reserve_not_closed_inconsistencies[0] < test-audit-reserves.json > /dev/null || exit_fail "Reserve not closed inconsistency not detected"
-echo "PASS"
+ echo -n "Testing reserve closure missing detected... "
+ jq -e .reserve_not_closed_inconsistencies[0] \
+ < test-audit-reserves.json \
+ > /dev/null \
+ || exit_fail "Reserve not closed inconsistency not detected"
+ echo "PASS"
-AMOUNT=`jq -r .total_balance_reserve_not_closed < test-audit-reserves.json`
-if test "x$AMOUNT" == "xTESTKUDOS:0"
-then
- exit_fail "Reported total amount wrong: $AMOUNT"
-fi
+ AMOUNT=$(jq -r .total_balance_reserve_not_closed < test-audit-reserves.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Reported total amount wrong: $AMOUNT"
+ fi
-# Undo
-echo "UPDATE exchange.reserves_in SET execution_date='${OLD_TIME}',credit_val=${OLD_VAL} WHERE reserve_in_serial_id=1;" | psql -Aqt $DB
-echo "UPDATE exchange.reserves SET current_balance_val=current_balance_val-100 WHERE reserve_pub='${RES_PUB}';" | psql -Aqt $DB
+ # Undo
+ echo "UPDATE exchange.reserves_in SET execution_date='${OLD_TIME}',credit_val=${OLD_VAL} WHERE reserve_in_serial_id=1;" \
+ | psql -Aqt "$DB"
+ echo "UPDATE exchange.reserves SET current_balance_val=current_balance_val-100 WHERE reserve_pub='${RES_PUB}';" \
+ | psql -Aqt "$DB"
}
# Test reserve closure reported but wire transfer missing detection
function test_21() {
-echo "===========21: reserve closure missreported ================="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========21: reserve closure missreported ================="
- OLD_TIME=`echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- OLD_VAL=`echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- RES_PUB=`echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql $DB -Aqt`
- OLD_EXP=`echo "SELECT expiration_date FROM exchange.reserves WHERE reserve_pub='${RES_PUB}';" | psql $DB -Aqt`
+ OLD_TIME=$(echo "SELECT execution_date FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ OLD_VAL=$(echo "SELECT credit_val FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ RES_PUB=$(echo "SELECT reserve_pub FROM exchange.reserves_in WHERE reserve_in_serial_id=1;" | psql "$DB" -Aqt)
+ OLD_EXP=$(echo "SELECT expiration_date FROM exchange.reserves WHERE reserve_pub='${RES_PUB}';" | psql "$DB" -Aqt)
VAL_DELTA=1
- NEW_TIME=`expr $OLD_TIME - 3024000000000 || true` # 5 weeks
- NEW_EXP=`expr $OLD_EXP - 3024000000000 || true` # 5 weeks
- NEW_CREDIT=`expr $OLD_VAL + $VAL_DELTA || true`
- echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" | psql -Aqt $DB
- echo "UPDATE exchange.reserves SET current_balance_val=${VAL_DELTA}+current_balance_val,expiration_date='${NEW_EXP}' WHERE reserve_pub='${RES_PUB}';" | psql -Aqt $DB
+ NEW_TIME=$(( OLD_TIME - 3024000000000 )) # 5 weeks
+ NEW_EXP=$(( OLD_EXP - 3024000000000 )) # 5 weeks
+ NEW_CREDIT=$(( OLD_VAL + VAL_DELTA ))
+ echo "UPDATE exchange.reserves_in SET execution_date='${NEW_TIME}',credit_val=${NEW_CREDIT} WHERE reserve_in_serial_id=1;" \
+ | psql -Aqt "$DB"
+ echo "UPDATE exchange.reserves SET current_balance_val=${VAL_DELTA}+current_balance_val,expiration_date='${NEW_EXP}' WHERE reserve_pub='${RES_PUB}';" \
+ | psql -Aqt "$DB"
# Need to first run the aggregator so the transfer is marked as done exists
pre_audit aggregator
-
+ stop_libeufin
# remove transaction from bank DB
# Currently emulating this (to be deleted):
- echo "DELETE FROM TalerRequestedPayments WHERE amount='TESTKUDOS:${VAL_DELTA}'" | sqlite3 $DB.sqlite3
+ echo "DELETE FROM TalerRequestedPayments WHERE amount='TESTKUDOS:${VAL_DELTA}'" \
+ | psql "${DB}" -q
+ launch_libeufin
audit_only
post_audit
echo -n "Testing lack of reserve closure transaction detected... "
- jq -e .reserve_lag_details[0] < test-audit-wire.json > /dev/null || exit_fail "Reserve closure lag not detected"
+ jq -e .reserve_lag_details[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ || exit_fail "Reserve closure lag not detected"
- AMOUNT=`jq -r .reserve_lag_details[0].amount < test-audit-wire.json`
- if test "x$AMOUNT" != "xTESTKUDOS:${VAL_DELTA}"
+ AMOUNT=$(jq -r .reserve_lag_details[0].amount < test-audit-wire.json)
+ if [ "$AMOUNT" != "TESTKUDOS:${VAL_DELTA}" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
- AMOUNT=`jq -r .total_closure_amount_lag < test-audit-wire.json`
- if test "x$AMOUNT" != "xTESTKUDOS:${VAL_DELTA}"
+ AMOUNT=$(jq -r .total_closure_amount_lag < test-audit-wire.json)
+ if [ "$AMOUNT" != "TESTKUDOS:${VAL_DELTA}" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
@@ -1373,35 +1512,32 @@ then
# cannot easily undo aggregator, hence full reload
full_reload
-else
- echo "Test skipped (database too new)"
-fi
}
# Test use of withdraw-expired denomination key
function test_22() {
-echo "===========22: denomination key expired ================="
+ echo "===========22: denomination key expired ================="
-S_DENOM=`echo 'SELECT denominations_serial FROM exchange.reserves_out LIMIT 1;' | psql $DB -Aqt`
+ S_DENOM=$(echo 'SELECT denominations_serial FROM exchange.reserves_out LIMIT 1;' | psql "$DB" -Aqt)
-OLD_START=`echo "SELECT valid_from FROM exchange.denominations WHERE denominations_serial='${S_DENOM}';" | psql $DB -Aqt`
-OLD_WEXP=`echo "SELECT expire_withdraw FROM exchange.denominations WHERE denominations_serial='${S_DENOM}';" | psql $DB -Aqt`
-# Basically expires 'immediately', so that the withdraw must have been 'invalid'
-NEW_WEXP=$OLD_START
+ OLD_START=$(echo "SELECT valid_from FROM exchange.denominations WHERE denominations_serial='${S_DENOM}';" | psql "$DB" -Aqt)
+ OLD_WEXP=$(echo "SELECT expire_withdraw FROM exchange.denominations WHERE denominations_serial='${S_DENOM}';" | psql "$DB" -Aqt)
+ # Basically expires 'immediately', so that the withdraw must have been 'invalid'
+ NEW_WEXP=$OLD_START
-echo "UPDATE exchange.denominations SET expire_withdraw=${NEW_WEXP} WHERE denominations_serial='${S_DENOM}';" | psql -Aqt $DB
+ echo "UPDATE exchange.denominations SET expire_withdraw=${NEW_WEXP} WHERE denominations_serial='${S_DENOM}';" | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null || exit_fail "Denomination key withdraw inconsistency for $S_DENOM not detected"
+ echo -n "Testing inconsistency detection... "
+ jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null || exit_fail "Denomination key withdraw inconsistency for $S_DENOM not detected"
-echo PASS
+ echo "PASS"
-# Undo modification
-echo "UPDATE exchange.denominations SET expire_withdraw=${OLD_WEXP} WHERE denominations_serial='${S_DENOM}';" | psql -Aqt $DB
+ # Undo modification
+ echo "UPDATE exchange.denominations SET expire_withdraw=${OLD_WEXP} WHERE denominations_serial='${S_DENOM}';" | psql -Aqt "$DB"
}
@@ -1409,50 +1545,46 @@ echo "UPDATE exchange.denominations SET expire_withdraw=${OLD_WEXP} WHERE denomi
# Test calculation of wire-out amounts
function test_23() {
-echo "===========23: wire out calculations ================="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========23: wire out calculations ================="
# Need to first run the aggregator so the transfer is marked as done exists
pre_audit aggregator
- OLD_AMOUNT=`echo "SELECT amount_frac FROM exchange.wire_out WHERE wireout_uuid=1;" | psql $DB -Aqt`
- NEW_AMOUNT=`expr $OLD_AMOUNT - 1000000 || true`
- echo "UPDATE exchange.wire_out SET amount_frac=${NEW_AMOUNT} WHERE wireout_uuid=1;" | psql -Aqt $DB
+ OLD_AMOUNT=$(echo "SELECT amount_frac FROM exchange.wire_out WHERE wireout_uuid=1;" | psql "$DB" -Aqt)
+ NEW_AMOUNT=$(( OLD_AMOUNT - 1000000 ))
+ echo "UPDATE exchange.wire_out SET amount_frac=${NEW_AMOUNT} WHERE wireout_uuid=1;" \
+ | psql -Aqt "$DB"
audit_only
post_audit
echo -n "Testing inconsistency detection... "
- jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null || exit_fail "Wire out inconsistency not detected"
+ jq -e .wire_out_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ || exit_fail "Wire out inconsistency not detected"
- ROW=`jq .wire_out_inconsistencies[0].rowid < test-audit-aggregation.json`
- if test $ROW != 1
+ ROW=$(jq .wire_out_inconsistencies[0].rowid < test-audit-aggregation.json)
+ if [ "$ROW" != 1 ]
then
exit_fail "Row wrong"
fi
- AMOUNT=`jq -r .total_wire_out_delta_plus < test-audit-aggregation.json`
- if test "x$AMOUNT" != "xTESTKUDOS:0"
+ AMOUNT=$(jq -r .total_wire_out_delta_plus < test-audit-aggregation.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0" ]
then
exit_fail "Reported amount wrong: $AMOUNT"
fi
- AMOUNT=`jq -r .total_wire_out_delta_minus < test-audit-aggregation.json`
- if test "x$AMOUNT" != "xTESTKUDOS:0.01"
+ AMOUNT=$(jq -r .total_wire_out_delta_minus < test-audit-aggregation.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0.01" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
- echo PASS
+ echo "PASS"
echo "Second pass: changing how amount is wrong to other direction"
- NEW_AMOUNT=`expr $OLD_AMOUNT + 1000000 || true`
- echo "UPDATE exchange.wire_out SET amount_frac=${NEW_AMOUNT} WHERE wireout_uuid=1;" | psql -Aqt $DB
+ NEW_AMOUNT=$(( OLD_AMOUNT + 1000000 ))
+ echo "UPDATE exchange.wire_out SET amount_frac=${NEW_AMOUNT} WHERE wireout_uuid=1;" | psql -Aqt "$DB"
pre_audit
audit_only
@@ -1462,29 +1594,25 @@ then
jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null || exit_fail "Wire out inconsistency not detected"
- ROW=`jq .wire_out_inconsistencies[0].rowid < test-audit-aggregation.json`
- if test $ROW != 1
+ ROW=$(jq .wire_out_inconsistencies[0].rowid < test-audit-aggregation.json)
+ if [ "$ROW" != 1 ]
then
exit_fail "Row wrong"
fi
- AMOUNT=`jq -r .total_wire_out_delta_minus < test-audit-aggregation.json`
- if test "x$AMOUNT" != "xTESTKUDOS:0"
+ AMOUNT=$(jq -r .total_wire_out_delta_minus < test-audit-aggregation.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0" ]
then
exit_fail "Reported amount wrong: $AMOUNT"
fi
- AMOUNT=`jq -r .total_wire_out_delta_plus < test-audit-aggregation.json`
- if test "x$AMOUNT" != "xTESTKUDOS:0.01"
+ AMOUNT=$(jq -r .total_wire_out_delta_plus < test-audit-aggregation.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0.01" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
- echo PASS
-
+ echo "PASS"
# cannot easily undo aggregator, hence full reload
full_reload
-else
- echo "Test skipped (database too new)"
-fi
}
@@ -1492,180 +1620,173 @@ fi
# Test for missing deposits in exchange database.
function test_24() {
-echo "===========24: deposits missing ==========="
-# Modify denom_sig, so it is wrong
-CNT=`echo "SELECT COUNT(*) FROM exchange.deposit_confirmations;" | psql -Aqt $DB`
-if test x$CNT = x0
-then
- echo "Skipping deposits missing test: no deposit confirmations in database!"
-else
- echo "DELETE FROM exchange.deposits;" | psql -Aqt $DB
- echo "DELETE FROM exchange.deposits WHERE deposit_serial_id=1;" | psql -Aqt $DB
+ echo "===========24: deposits missing ==========="
+ # Modify denom_sig, so it is wrong
+ CNT=$(echo "SELECT COUNT(*) FROM auditor.deposit_confirmations;" | psql -Aqt "$DB")
+ if [ "$CNT" = "0" ]
+ then
+ echo "Skipping deposits missing test: no deposit confirmations in database!"
+ else
+ echo "DELETE FROM exchange.deposits;" | psql -Aqt "$DB"
+ echo "DELETE FROM exchange.deposits WHERE deposit_serial_id=1;" \
+ | psql -Aqt "$DB"
- run_audit
+ run_audit
- echo -n "Testing inconsistency detection... "
+ echo -n "Testing inconsistency detection... "
- jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null || exit_fail "Deposit confirmation inconsistency NOT detected"
+ jq -e .deposit_confirmation_inconsistencies[0] \
+ < test-audit-deposits.json \
+ > /dev/null \
+ || exit_fail "Deposit confirmation inconsistency NOT detected"
- AMOUNT=`jq -er .missing_deposit_confirmation_total < test-audit-deposits.json`
- if test x$AMOUNT = xTESTKUDOS:0
- then
- exit_fail "Expected non-zero total missing deposit confirmation amount"
- fi
- COUNT=`jq -er .missing_deposit_confirmation_count < test-audit-deposits.json`
- if test x$AMOUNT = x0
- then
- exit_fail "Expected non-zero total missing deposit confirmation count"
- fi
+ AMOUNT=$(jq -er .missing_deposit_confirmation_total < test-audit-deposits.json)
+ if [ "$AMOUNT" = "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected non-zero total missing deposit confirmation amount"
+ fi
+ COUNT=$(jq -er .missing_deposit_confirmation_count < test-audit-deposits.json)
+ if [ "$AMOUNT" = "0" ]
+ then
+ exit_fail "Expected non-zero total missing deposit confirmation count"
+ fi
- echo PASS
+ echo "PASS"
- # cannot easily undo DELETE, hence full reload
- full_reload
-fi
+ # cannot easily undo DELETE, hence full reload
+ full_reload
+ fi
}
# Test for inconsistent coin history.
function test_25() {
-echo "=========25: inconsistent coin history========="
-
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "=========25: inconsistent coin history========="
# Drop refund, so coin history is bogus.
- echo "DELETE FROM exchange.refunds WHERE refund_serial_id=1;" | psql -Aqt $DB
+ echo "DELETE FROM exchange.refunds WHERE refund_serial_id=1;" \
+ | psql -At "$DB"
run_audit aggregator
echo -n "Testing inconsistency detection... "
- jq -e .coin_inconsistencies[0] < test-audit-aggregation.json > /dev/null || exit_fail "Coin inconsistency NOT detected"
+ jq -e .coin_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ || exit_fail "Coin inconsistency NOT detected"
# Note: if the wallet withdrew much more than it spent, this might indeed
# go legitimately unnoticed.
- jq -e .emergencies[0] < test-audit-coins.json > /dev/null || exit_fail "Denomination value emergency NOT reported"
+ jq -e .emergencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ || exit_fail "Denomination value emergency NOT reported"
- AMOUNT=`jq -er .total_coin_delta_minus < test-audit-aggregation.json`
- if test x$AMOUNT = xTESTKUDOS:0
+ AMOUNT=$(jq -er .total_coin_delta_minus < test-audit-aggregation.json)
+ if [ "$AMOUNT" = "TESTKUDOS:0" ]
then
exit_fail "Expected non-zero total inconsistency amount from coins"
fi
# Note: if the wallet withdrew much more than it spent, this might indeed
# go legitimately unnoticed.
- COUNT=`jq -er .emergencies_risk_by_amount < test-audit-coins.json`
- if test x$AMOUNT = xTESTKUDOS:0
+ COUNT=$(jq -er .emergencies_risk_by_amount < test-audit-coins.json)
+ if [ "$COUNT" = "TESTKUDOS:0" ]
then
exit_fail "Expected non-zero emergency-by-amount"
fi
- echo PASS
+ echo "PASS"
# cannot easily undo DELETE, hence full reload
full_reload
-else
- echo "Test skipped (database too new)"
-fi
}
# Test for deposit wire target malformed
function test_26() {
-echo "===========26: deposit wire target malformed ================="
-# Expects 'payto_uri', not 'url' (also breaks signature, but we cannot even check that).
-SERIAL=`echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql $DB -Aqt`
-OLD_WIRE_ID=`echo "SELECT wire_target_h_payto FROM exchange.deposits WHERE deposit_serial_id=${SERIAL};" | psql $DB -Aqt`
-NEW_WIRE_ID=`echo "INSERT INTO exchange.wire_targets (payto_uri, wire_target_h_payto, kyc_ok) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b', false);" | psql $DB -Aqt`
-echo OLD_WIRE_ID=$OLD_WIRE_ID
-echo NEW_WIRE_ID=$NEW_WIRE_ID
-echo "UPDATE exchange.deposits SET wire_target_h_payto='\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b' WHERE deposit_serial_id=${SERIAL}" | psql -Aqt $DB
-
-run_audit
+ echo "===========26: deposit wire target malformed ================="
+ # Expects 'payto_uri', not 'url' (also breaks signature, but we cannot even check that).
+ SERIAL=$(echo "SELECT deposit_serial_id FROM exchange.deposits WHERE amount_with_fee_val=3 AND amount_with_fee_frac=0 ORDER BY deposit_serial_id LIMIT 1" | psql "$DB" -Aqt)
+ OLD_WIRE_ID=$(echo "SELECT wire_target_h_payto FROM exchange.deposits WHERE deposit_serial_id=${SERIAL};" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "INSERT INTO exchange.wire_targets (payto_uri, wire_target_h_payto) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b');" \
+ | psql "$DB" -Aqt
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.deposits SET wire_target_h_payto='\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b' WHERE deposit_serial_id=${SERIAL}" \
+ | psql -Aqt "$DB"
-echo -n "Testing inconsistency detection... "
+ run_audit
-jq -e .bad_sig_losses[0] < test-audit-coins.json > /dev/null || exit_fail "Bad signature not detected"
+ echo -n "Testing inconsistency detection... "
-ROW=`jq -e .bad_sig_losses[0].row < test-audit-coins.json`
-if test $ROW != ${SERIAL}
-then
- exit_fail "Row wrong, got $ROW"
-fi
+ jq -e .bad_sig_losses[0] < test-audit-coins.json > /dev/null || exit_fail "Bad signature not detected"
-LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong deposit bad signature loss, got $LOSS"
-fi
+ ROW=$(jq -e .bad_sig_losses[0].row < test-audit-coins.json)
+ if [ "$ROW" != "${SERIAL}" ]
+ then
+ exit_fail "Row wrong, got $ROW"
+ fi
-OP=`jq -r .bad_sig_losses[0].operation < test-audit-coins.json`
-if test $OP != "deposit"
-then
- exit_fail "Wrong operation, got $OP"
-fi
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong deposit bad signature loss, got $LOSS"
+ fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:3"
-then
- exit_fail "Wrong total bad sig loss, got $LOSS"
-fi
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-coins.json)
+ if [ "$OP" != "deposit" ]
+ then
+ exit_fail "Wrong operation, got $OP"
+ fi
-echo PASS
-# Undo:
-echo "UPDATE exchange.deposits SET wire_target_h_payto='$OLD_WIRE_ID' WHERE deposit_serial_id=${SERIAL}" | psql -Aqt $DB
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Wrong total bad sig loss, got $LOSS"
+ fi
+ echo "PASS"
+ # Undo:
+ echo "UPDATE exchange.deposits SET wire_target_h_payto='$OLD_WIRE_ID' WHERE deposit_serial_id=${SERIAL}" \
+ | psql -Aqt "$DB"
}
# Test for duplicate wire transfer subject
function test_27() {
-echo "===========27: duplicate WTID detection ================="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
+ echo "===========27: duplicate WTID detection ================="
pre_audit aggregator
-
+ stop_libeufin
# Obtain data to duplicate.
- WTID=`echo SELECT wtid FROM TalerRequestedPayments WHERE id=1 | sqlite3 $DB.sqlite3`
- echo WTID=$WTID
- OTHER_IBAN=`echo -e "SELECT iban FROM BankAccounts WHERE label='fortytwo'" | sqlite3 $DB.sqlite3`
+ WTID=$(echo SELECT wtid FROM TalerRequestedPayments WHERE id=1 | psql "${DB}" -Aqt)
+ OTHER_IBAN=$(echo -e "SELECT iban FROM BankAccounts WHERE label='fortytwo'" | psql "${DB}" -Aqt)
# 'rawConfirmation' is set to 2 here, that doesn't
# point to any record. That's only needed to set a non null value.
- echo -e "INSERT INTO PaymentInitiations (bankAccount,preparationDate,submissionDate,sum,currency,endToEndId,paymentInformationId,instructionId,subject,creditorIban,creditorBic,creditorName,submitted,messageId,rawConfirmation) VALUES (1,$(date +%s),$(expr $(date +%s) + 2),10,'TESTKUDOS','NOTGIVEN','unused','unused','$WTID http://exchange.example.com/','$OTHER_IBAN','SANDBOXX','Forty Two','unused',1,2)" | sqlite3 $DB.sqlite3
- echo -e "INSERT INTO TalerRequestedPayments (facade,payment,requestUid,amount,exchangeBaseUrl,wtid,creditAccount) VALUES (1,2,'unused','TESTKUDOS:1','http://exchange.example.com/','$WTID','payto://iban/SANDBOXX/$OTHER_IBAN?receiver-name=Forty+Two')" | sqlite3 $DB.sqlite3
+ echo -e "INSERT INTO PaymentInitiations (\"bankAccount\",\"preparationDate\",\"submissionDate\",sum,currency,\"endToEndId\",\"paymentInformationId\",\"instructionId\",subject,\"creditorIban\",\"creditorBic\",\"creditorName\",submitted,\"messageId\",\"rawConfirmation\") VALUES (1,$(date +%s),$(( $(date +%s) + 2)),10,'TESTKUDOS','NOTGIVEN','unused','unused','$WTID http://exchange.example.com/','$OTHER_IBAN','SANDBOXX','Forty Two',false,1,2)" \
+ | psql "${DB}" -q
+ echo -e "INSERT INTO TalerRequestedPayments (facade,payment,\"requestUid\",amount,\"exchangeBaseUrl\",wtid,\"creditAccount\") VALUES (1,2,'unused','TESTKUDOS:1','http://exchange.example.com/','$WTID','payto://iban/SANDBOXX/$OTHER_IBAN?receiver-name=Forty+Two')" \
+ | psql "${DB}" -q
+ launch_libeufin
audit_only
post_audit
echo -n "Testing inconsistency detection... "
- AMOUNT=`jq -r .wire_format_inconsistencies[0].amount < test-audit-wire.json`
- if test "${AMOUNT}" != "TESTKUDOS:1"
+ AMOUNT=$(jq -r .wire_format_inconsistencies[0].amount < test-audit-wire.json)
+ if [ "${AMOUNT}" != "TESTKUDOS:1" ]
then
exit_fail "Amount wrong, got ${AMOUNT}"
fi
- AMOUNT=`jq -r .total_wire_format_amount < test-audit-wire.json`
- if test "${AMOUNT}" != "TESTKUDOS:1"
+ AMOUNT=$(jq -r .total_wire_format_amount < test-audit-wire.json)
+ if [ "${AMOUNT}" != "TESTKUDOS:1" ]
then
exit_fail "Wrong total wire format amount, got $AMOUNT"
fi
# cannot easily undo aggregator, hence full reload
full_reload
-else
- echo "Test skipped (database too new)"
-fi
-
}
@@ -1674,41 +1795,37 @@ fi
# Test where denom_sig in known_coins table is wrong
# (=> bad signature) AND the coin is used in aggregation
function test_28() {
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
echo "===========28: known_coins signature wrong================="
# Modify denom_sig, so it is wrong
- OLD_SIG=`echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql $DB -Aqt`
- COIN_PUB=`echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql $DB -Aqt`
- echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" | psql -Aqt $DB
+ OLD_SIG=$(echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql "$DB" -Aqt)
+ COIN_PUB=$(echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" \
+ | psql -Aqt "$DB"
run_audit aggregator
echo -n "Testing inconsistency detection... "
- LOSS=`jq -r .bad_sig_losses[0].loss < test-audit-aggregation.json`
- if test $LOSS == "TESTKUDOS:0"
+ LOSS=$(jq -r .bad_sig_losses[0].loss < test-audit-aggregation.json)
+ if [ "$LOSS" == "TESTKUDOS:0" ]
then
exit_fail "Wrong deposit bad signature loss, got $LOSS"
fi
- OP=`jq -r .bad_sig_losses[0].operation < test-audit-aggregation.json`
- if test $OP != "wire"
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-aggregation.json)
+ if [ "$OP" != "wire" ]
then
exit_fail "Wrong operation, got $OP"
fi
- TAB=`jq -r .row_inconsistencies[0].table < test-audit-aggregation.json`
- if test $TAB != "deposit"
+ TAB=$(jq -r .row_inconsistencies[0].table < test-audit-aggregation.json)
+ if [ "$TAB" != "deposit" ]
then
exit_fail "Wrong table for row inconsistency, got $TAB"
fi
- LOSS=`jq -r .total_bad_sig_loss < test-audit-aggregation.json`
- if test $LOSS == "TESTKUDOS:0"
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$LOSS" == "TESTKUDOS:0" ]
then
exit_fail "Wrong total bad sig loss, got $LOSS"
fi
@@ -1716,10 +1833,6 @@ then
echo "OK"
# cannot easily undo aggregator, hence full reload
full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
}
@@ -1727,27 +1840,27 @@ fi
# Test where fees known to the auditor differ from those
# accounted for by the exchange
function test_29() {
-echo "===========29: withdraw fee inconsistency ================="
+ echo "===========29: withdraw fee inconsistency ================="
-echo "UPDATE exchange.denominations SET fee_withdraw_frac=5000000 WHERE coin_val=1;" | psql -Aqt $DB
+ echo "UPDATE exchange.denominations SET fee_withdraw_frac=5000000 WHERE coin_val=1;" | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-AMOUNT=`jq -r .total_balance_summary_delta_minus < test-audit-reserves.json`
-if test "x$AMOUNT" == "xTESTKUDOS:0"
-then
- exit_fail "Reported total amount wrong: $AMOUNT"
-fi
+ echo -n "Testing inconsistency detection... "
+ AMOUNT=$(jq -r .total_balance_summary_delta_minus < test-audit-reserves.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Reported total amount wrong: $AMOUNT"
+ fi
-PROFIT=`jq -r .amount_arithmetic_inconsistencies[0].profitable < test-audit-coins.json`
-if test "x$PROFIT" != "x-1"
-then
- exit_fail "Reported wrong profitability: $PROFIT"
-fi
-echo "OK"
-# Undo
-echo "UPDATE exchange.denominations SET fee_withdraw_frac=2000000 WHERE coin_val=1;" | psql -Aqt $DB
+ PROFIT=$(jq -r .amount_arithmetic_inconsistencies[0].profitable < test-audit-coins.json)
+ if [ "$PROFIT" != "-1" ]
+ then
+ exit_fail "Reported wrong profitability: $PROFIT"
+ fi
+ echo "OK"
+ # Undo
+ echo "UPDATE exchange.denominations SET fee_withdraw_frac=2000000 WHERE coin_val=1;" | psql -Aqt "$DB"
}
@@ -1755,28 +1868,28 @@ echo "UPDATE exchange.denominations SET fee_withdraw_frac=2000000 WHERE coin_val
# Test where fees known to the auditor differ from those
# accounted for by the exchange
function test_30() {
-echo "===========30: melt fee inconsistency ================="
+ echo "===========30: melt fee inconsistency ================="
-echo "UPDATE exchange.denominations SET fee_refresh_frac=5000000 WHERE coin_val=10;" | psql -Aqt $DB
+ echo "UPDATE exchange.denominations SET fee_refresh_frac=5000000 WHERE coin_val=10;" | psql -Aqt "$DB"
-run_audit
-echo -n "Testing inconsistency detection... "
-AMOUNT=`jq -r .bad_sig_losses[0].loss < test-audit-coins.json`
-if test "x$AMOUNT" == "xTESTKUDOS:0"
-then
- exit_fail "Reported total amount wrong: $AMOUNT"
-fi
+ run_audit
+ echo -n "Testing inconsistency detection... "
+ AMOUNT=$(jq -r .bad_sig_losses[0].loss < test-audit-coins.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Reported total amount wrong: $AMOUNT"
+ fi
-PROFIT=`jq -r .amount_arithmetic_inconsistencies[0].profitable < test-audit-coins.json`
-if test "x$PROFIT" != "x-1"
-then
- exit_fail "Reported profitability wrong: $PROFIT"
-fi
+ PROFIT=$(jq -r .amount_arithmetic_inconsistencies[0].profitable < test-audit-coins.json)
+ if [ "$PROFIT" != "-1" ]
+ then
+ exit_fail "Reported profitability wrong: $PROFIT"
+ fi
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run"
-echo "OK"
-# Undo
-echo "UPDATE exchange.denominations SET fee_refresh_frac=3000000 WHERE coin_val=10;" | psql -Aqt $DB
+ jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run"
+ echo "OK"
+ # Undo
+ echo "UPDATE exchange.denominations SET fee_refresh_frac=3000000 WHERE coin_val=10;" | psql -Aqt "$DB"
}
@@ -1785,39 +1898,27 @@ echo "UPDATE exchange.denominations SET fee_refresh_frac=3000000 WHERE coin_val=
# accounted for by the exchange
function test_31() {
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
-
echo "===========31: deposit fee inconsistency ================="
- echo "UPDATE exchange.denominations SET fee_deposit_frac=5000000 WHERE coin_val=8;" | psql -Aqt $DB
+ echo "UPDATE exchange.denominations SET fee_deposit_frac=5000000 WHERE coin_val=8;" | psql -Aqt "$DB"
run_audit aggregator
echo -n "Testing inconsistency detection... "
- AMOUNT=`jq -r .total_bad_sig_loss < test-audit-coins.json`
- if test "x$AMOUNT" == "xTESTKUDOS:0"
+ AMOUNT=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
- OP=`jq -r --arg dep "deposit" '.bad_sig_losses[] | select(.operation == $dep) | .operation'< test-audit-coins.json | head -n1`
- if test "x$OP" != "xdeposit"
+ OP=$(jq -r --arg dep "deposit" '.bad_sig_losses[] | select(.operation == $dep) | .operation'< test-audit-coins.json | head -n1)
+ if [ "$OP" != "deposit" ]
then
exit_fail "Reported wrong operation: $OP"
fi
echo "OK"
# Undo
- echo "UPDATE exchange.denominations SET fee_deposit_frac=2000000 WHERE coin_val=8;" | psql -Aqt $DB
-
-else
- echo "Test skipped (database too new)"
-fi
-
+ echo "UPDATE exchange.denominations SET fee_deposit_frac=2000000 WHERE coin_val=8;" | psql -Aqt "$DB"
}
@@ -1827,30 +1928,25 @@ fi
# (=> bad signature)
function test_32() {
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
-
echo "===========32: known_coins signature wrong w. aggregation================="
# Modify denom_sig, so it is wrong
- OLD_SIG=`echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql $DB -At`
- COIN_PUB=`echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql $DB -At`
- echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" | psql -Aqt $DB
+ OLD_SIG=$(echo 'SELECT denom_sig FROM exchange.known_coins LIMIT 1;' | psql "$DB" -Aqt)
+ COIN_PUB=$(echo "SELECT coin_pub FROM exchange.known_coins WHERE denom_sig='$OLD_SIG';" | psql "$DB" -Aqt)
+# shellcheck disable=SC2028
+ echo "UPDATE exchange.known_coins SET denom_sig='\x0000000100000000287369672d76616c200a2028727361200a2020287320233542383731423743393036444643303442424430453039353246413642464132463537303139374131313437353746324632323332394644443146324643333445393939413336363430334233413133324444464239413833353833464536354442374335434445304441453035374438363336434541423834463843323843344446304144363030343430413038353435363039373833434431333239393736423642433437313041324632414132414435413833303432434346314139464635394244434346374436323238344143354544364131373739463430353032323241373838423837363535453434423145443831364244353638303232413123290a2020290a20290b' WHERE coin_pub='$COIN_PUB'" \
+ | psql -Aqt "$DB"
run_audit aggregator
echo -n "Testing inconsistency detection... "
- AMOUNT=`jq -r .total_bad_sig_loss < test-audit-aggregation.json`
- if test "x$AMOUNT" == "xTESTKUDOS:0"
+ AMOUNT=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
then
exit_fail "Reported total amount wrong: $AMOUNT"
fi
- OP=`jq -r .bad_sig_losses[0].operation < test-audit-aggregation.json`
- if test "x$OP" != "xwire"
+ OP=$(jq -r .bad_sig_losses[0].operation < test-audit-aggregation.json)
+ if [ "$OP" != "wire" ]
then
exit_fail "Reported wrong operation: $OP"
fi
@@ -1858,170 +1954,145 @@ then
echo "OK"
# Cannot undo aggregation, do full reload
full_reload
-
-fi
}
-# Test where h_payto in the wire_targets table is wrong
function test_33() {
-echo "===========33: h_payto wrong================="
-
-# Check wire transfer lag reported (no aggregator!)
-# NOTE: this test is BRAND NEW and expected
-# to fail until we implement the check in the auditor!
-
-# NOTE: This test is EXPECTED to fail for ~1h after
-# re-generating the test database as we do not
-# report lag of less than 1h (see GRACE_PERIOD in
-# taler-helper-auditor-wire.c)
-if [ $DATABASE_AGE -gt 3600 ]
-then
-
- # Modify h_payto hash, so it is inconsistent with 'wire'
- WTSID=`echo "SELECT wire_target_serial_id FROM exchange.deposits WHERE deposit_serial_id=1;" | psql -Aqt $DB`
- echo "UPDATE exchange.wire_targets SET h_payto='\x973e52d193a357940be9ef2939c19b0575ee1101f52188c3c01d9005b7d755c397e92624f09cfa709104b3b65605fe5130c90d7e1b7ee30f8fc570f39c16b853' WHERE wire_target_serial_id=$WTSID" | psql -Aqt $DB
-
- # The auditor checks h_wire consistency only for
- # coins where the wire transfer has happened, hence
- # run aggregator first to get this test to work.
- run_audit aggregator
-
- echo -n "Testing inconsistency detection... "
- TABLE=`jq -r .row_inconsistencies[0].table < test-audit-aggregation.json`
- if test "x$TABLE" != "xwire_targets"
- then
- exit_fail "Reported table wrong: $TABLE"
- fi
- echo PASS
-
- # cannot easily undo aggregator, hence full reload
- full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
-}
+ echo "===========33: normal run with aggregator and profit drain==========="
+ run_audit aggregator drain
-function test_34() {
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
+ echo -n "Test for deposit confirmation emergencies... "
+ jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-echo "===========34: normal run with aggregator and profit drain==========="
-run_audit aggregator
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
-echo "Checking output"
-# if an emergency was detected, that is a bug and we should fail
-echo -n "Test for emergencies... "
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
-echo -n "Test for deposit confirmation emergencies... "
-jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
-echo -n "Test for emergencies by count... "
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-echo -n "Test for wire inconsistencies... "
-jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
-jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
-jq -e .missattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected missattribution inconsistency detected in ordinary run"
-jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
-jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
-jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
-jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
-jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
+ echo PASS
-# TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
-# TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-
-echo PASS
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
+ fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
-fi
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ echo PASS
-echo -n "Test for wire amounts... "
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total missattribution in wrong, got $WIRED"
-fi
-echo PASS
+ echo -n "Checking for unexpected arithmetic differences "
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
+ fi
-echo -n "Checking for unexpected arithmetic differences "
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
-fi
+ DRAINED=$(jq -r .total_drained < test-audit-wire.json)
+ if [ "$DRAINED" != "TESTKUDOS:0.1" ]
+ then
+ exit_fail "Wrong amount drained, got unexpected drain of $DRAINED"
+ fi
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
-echo PASS
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-reserves.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
+ echo "PASS"
-echo -n "Checking for unexpected wire out differences "
-jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
-echo PASS
+ echo -n "Checking for unexpected wire out differences "
+ jq -e .wire_out_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
+ echo "PASS"
-# cannot easily undo aggregator, hence full reload
-full_reload
+ # cannot easily undo aggregator, hence full reload
+ full_reload
}
@@ -2031,21 +2102,18 @@ full_reload
# Run all the tests against the database given in $1.
# Sets $fail to 0 on success, non-zero on failure.
-check_with_database()
+function check_with_database()
{
- BASEDB=$1
+ BASEDB="$1"
+ CONF="$1.conf"
echo "Running test suite with database $BASEDB using configuration $CONF"
-
- # Setup database-specific globals
- MASTER_PUB=`cat ${BASEDB}.mpub`
-
- # Determine database age
- echo "Calculating database age based on ${BASEDB}.age"
- AGE=`cat ${BASEDB}.age`
- NOW=`date +%s`
- # NOTE: expr "fails" if the result is zero.
- DATABASE_AGE=`expr ${NOW} - ${AGE} || true`
- echo "Database age is ${DATABASE_AGE} seconds"
+ MASTER_PRIV_FILE="${BASEDB}.mpriv"
+ taler-config \
+ -f \
+ -c "${CONF}" \
+ -s exchange-offline \
+ -o MASTER_PRIV_FILE \
+ -V "${MASTER_PRIV_FILE}"
# Load database
full_reload
@@ -2054,7 +2122,7 @@ check_with_database()
fail=0
for i in $TESTS
do
- test_$i
+ "test_$i"
if test 0 != $fail
then
break
@@ -2067,62 +2135,121 @@ check_with_database()
-
-
# *************** Main logic starts here **************
# ####### Setup globals ######
-# Postgres database to use
-DB=auditor-basedb
-
-# Configuration file to use
-CONF=${DB}.conf
+# Postgres database to use (must match configuration file)
+export DB="auditor-basedb"
# test required commands exist
echo "Testing for jq"
jq -h > /dev/null || exit_skip "jq required"
+echo "Testing for faketime"
+faketime -h > /dev/null || exit_skip "faketime required"
# NOTE: really check for all three libeufin commands?
echo "Testing for libeufin"
-libeufin-cli --help >/dev/null </dev/null || exit_skip "libeufin required"
+libeufin-bank --help >/dev/null 2> /dev/null </dev/null || exit_skip "libeufin required"
echo "Testing for pdflatex"
which pdflatex > /dev/null </dev/null || exit_skip "pdflatex required"
+echo "Testing for taler-wallet-cli"
+taler-wallet-cli -h >/dev/null </dev/null 2>/dev/null || exit_skip "taler-wallet-cli required"
-# check if we should regenerate the database
-if test -n "${1:-}"
-then
- echo "Custom run, will only run on existing DB."
+
+echo -n "Testing for Postgres"
+# Available directly in path?
+INITDB_BIN=$(command -v initdb) || true
+if [[ -n "$INITDB_BIN" ]]; then
+ echo " FOUND (in path) at $INITDB_BIN"
else
- echo -n "Testing for taler-wallet-cli"
- if taler-wallet-cli -h >/dev/null </dev/null 2>/dev/null
+ HAVE_INITDB=$(find /usr -name "initdb" 2> /dev/null \
+ | head -1 2> /dev/null \
+ | grep postgres) \
+ || exit_skip " MISSING"
+ echo " FOUND at $(dirname "$HAVE_INITDB")"
+ INITDB_BIN=$(echo "$HAVE_INITDB" | grep bin/initdb | grep postgres | sort -n | tail -n1)
+fi
+POSTGRES_PATH=$(dirname "$INITDB_BIN")
+
+MY_TMP_DIR=$(mktemp -d /tmp/taler-auditor-basedbXXXXXX)
+echo "Using $MY_TMP_DIR for logging and temporary data"
+TMPDIR="$MY_TMP_DIR/postgres"
+mkdir -p "$TMPDIR"
+echo -n "Setting up Postgres DB at $TMPDIR ..."
+$INITDB_BIN \
+ --no-sync \
+ --auth=trust \
+ -D "${TMPDIR}" \
+ > "${MY_TMP_DIR}/postgres-dbinit.log" \
+ 2> "${MY_TMP_DIR}/postgres-dbinit.err"
+echo "DONE"
+
+# Once we move to PG16, we can use:
+# --set listen_addresses='' \
+# --set fsync=off \
+# --set max_wal_senders=0 \
+# --set synchronous_commit=off \
+# --set wal_level=minimal \
+# --set unix_socket_directories="${TMPDIR}/sockets" \
+
+
+SOCKETDIR="${TMPDIR}/sockets"
+mkdir "${SOCKETDIR}"
+
+echo -n "Launching Postgres service"
+
+cat - >> "$TMPDIR/postgresql.conf" <<EOF
+unix_socket_directories='${TMPDIR}/sockets'
+fsync=off
+max_wal_senders=0
+synchronous_commit=off
+wal_level=minimal
+listen_addresses=''
+EOF
+
+grep -v host \
+ < "$TMPDIR/pg_hba.conf" \
+ > "$TMPDIR/pg_hba.conf.new"
+mv "$TMPDIR/pg_hba.conf.new" "$TMPDIR/pg_hba.conf"
+"${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l "${MY_TMP_DIR}/postgres.log" \
+ start \
+ > "${MY_TMP_DIR}/postgres-start.log" \
+ 2> "${MY_TMP_DIR}/postgres-start.err"
+echo " DONE"
+PGHOST="$TMPDIR/sockets"
+export PGHOST
+MYDIR="${MY_TMP_DIR}/basedb"
+mkdir -p "${MYDIR}"
+
+if [ -z $REUSE_BASEDB_DIR ]
+then
+ echo "Generating fresh database at $MYDIR"
+
+ if faketime -f '-1 d' ./generate-auditor-basedb.sh -d "$MYDIR/$DB"
then
- MYDIR=`mktemp -d /tmp/taler-auditor-basedbXXXXXX`
- echo " FOUND. Generating fresh database at $MYDIR"
- pwd
- if ./generate-auditor-basedb.sh $MYDIR/basedb
- then
- check_with_database $MYDIR/basedb
- if test x$fail != x0
- then
- exit $fail
- else
- echo "Cleaning up $MYDIR..."
- rm -rf $MYDIR || echo "Removing $MYDIR failed"
- fi
- else
- echo "Generation failed, running only on existing DB"
- fi
+ echo -n "Reset 'auditor-basedb' database at $PGHOST ..."
+ dropdb "auditor-basedb" >/dev/null 2>/dev/null || true
+ createdb "auditor-basedb" || exit_skip "Could not create database '$BASEDB' at $PGHOST"
+ echo " DONE"
else
- echo " NOT FOUND, running only on existing DB"
+ echo "Generation failed"
+ exit 1
fi
+else
+ echo "Reusing existing database from ${REUSE_BASEDB_DIR}"
+ cp -r "${REUSE_BASEDB_DIR}/basedb"/* "${MYDIR}/"
fi
-# run tests with pre-build database, if one is available
-if test -r auditor-basedb.mpub
+check_with_database "$MYDIR/$DB"
+if [ "$fail" != "0" ]
then
- check_with_database "auditor-basedb"
-else
- echo "Lacking auditor-basedb.mpub, skipping test"
- fail=77
+ exit "$fail"
+fi
+
+if [ -z $REUSE_BASEDB_DIR ]
+then
+ echo "Run 'export REUSE_BASEDB_DIR=${MY_TMP_DIR}' to re-run tests against the same database"
fi
-exit $fail
+exit 0
diff --git a/src/auditor/test-kyc.sh b/src/auditor/test-kyc.sh
new file mode 100755
index 000000000..2c4fa6594
--- /dev/null
+++ b/src/auditor/test-kyc.sh
@@ -0,0 +1,751 @@
+#!/bin/bash
+#
+# This file is part of TALER
+# Copyright (C) 2014-2023 Taler Systems SA
+#
+# TALER is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 3, or (at your option) any later version.
+#
+# TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/license>
+#
+#
+# shellcheck disable=SC2317
+# shellcheck disable=SC1091
+#
+#
+# Setup database which was generated from a perfectly normal
+# exchange-wallet interaction with KYC enabled and transactions
+# blocked due to KYC and run the auditor against it.
+#
+# Check that the auditor report is as expected.
+#
+# Requires 'jq' tool and Postgres superuser rights!
+#
+set -eu
+#set -x
+
+# Set of numbers for all the testcases.
+# When adding new tests, increase the last number:
+ALL_TESTS=$(seq 0 1)
+
+# $TESTS determines which tests we should run.
+# This construction is used to make it easy to
+# only run a subset of the tests. To only run a subset,
+# pass the numbers of the tests to run as the FIRST
+# argument to test-kyc.sh, i.e.:
+#
+# $ test-kyc.sh "1 3"
+#
+# to run tests 1 and 3 only. By default, all tests are run.
+#
+TESTS=${1:-$ALL_TESTS}
+
+# Global variable to run the auditor processes under valgrind
+# VALGRIND=valgrind
+VALGRIND=""
+
+# Number of seconds to let libeuifn background
+# tasks apply a cycle of payment submission and
+# history request.
+LIBEUFIN_SETTLE_TIME=1
+
+. setup.sh
+
+
+# Cleanup exchange and libeufin between runs.
+function cleanup()
+{
+ if test ! -z "${EPID:-}"
+ then
+ echo -n "Stopping exchange $EPID..."
+ kill -TERM "$EPID"
+ wait "$EPID" || true
+ echo "DONE"
+ unset EPID
+ fi
+ stop_libeufin
+}
+
+# Cleanup to run whenever we exit
+function exit_cleanup()
+{
+ echo "Running exit-cleanup"
+ if test ! -z "${POSTGRES_PATH:-}"
+ then
+ echo "Stopping Postgres at ${POSTGRES_PATH}"
+ "${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ stop \
+ &> /dev/null \
+ || true
+ fi
+ cleanup
+ for n in $(jobs -p)
+ do
+ kill "$n" 2> /dev/null || true
+ done
+ wait || true
+ echo "DONE"
+}
+
+# Install cleanup handler (except for kill -9)
+trap exit_cleanup EXIT
+
+
+
+# Operations to run before the actual audit
+function pre_audit () {
+ # Launch bank
+ echo -n "Launching bank"
+ launch_libeufin
+ for n in $(seq 1 80)
+ do
+ echo -n "."
+ sleep 0.1
+ OK=1
+ wget http://localhost:18082/ \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ && break
+ OK=0
+ done
+ if [ 1 != "$OK" ]
+ then
+ exit_skip "Failed to launch Sandbox"
+ fi
+ sleep "$LIBEUFIN_SETTLE_TIME"
+ for n in $(seq 1 80)
+ do
+ echo -n "."
+ sleep 0.1
+ OK=1
+ wget http://localhost:8082/ \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ && break
+ OK=0
+ done
+ if [ 1 != "$OK" ]
+ then
+ exit_skip "Failed to launch Nexus"
+ fi
+ echo " DONE"
+ if test "${1:-no}" = "aggregator"
+ then
+ echo -n "Running exchange aggregator ..."
+ taler-exchange-aggregator \
+ -y \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/aggregator.log" \
+ || exit_fail "FAIL"
+ echo " DONE"
+ echo -n "Running exchange closer ..."
+ taler-exchange-closer \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/closer.log" \
+ || exit_fail "FAIL"
+ echo " DONE"
+ echo -n "Running exchange transfer ..."
+ taler-exchange-transfer \
+ -L "INFO" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/transfer.log" \
+ || exit_fail "FAIL"
+ echo " DONE"
+ fi
+}
+
+# actual audit run
+function audit_only () {
+ # Run the auditor!
+ echo -n "Running audit(s) ..."
+
+ # Restart so that first run is always fresh, and second one is incremental
+ taler-auditor-dbinit \
+ -r \
+ -c "$CONF"
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-aggregation.json \
+ 2> "${MY_TMP_DIR}/test-audit-aggregation.log" \
+ || exit_fail "aggregation audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-aggregation-inc.json \
+ 2> "${MY_TMP_DIR}/test-audit-aggregation-inc.log" \
+ || exit_fail "incremental aggregation audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-coins \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-coins.json \
+ 2> "${MY_TMP_DIR}/test-audit-coins.log" \
+ || exit_fail "coin audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-coins \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-coins-inc.json \
+ 2> "${MY_TMP_DIR}/test-audit-coins-inc.log" \
+ || exit_fail "incremental coin audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-deposits \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-deposits.json \
+ 2> "${MY_TMP_DIR}/test-audit-deposits.log" \
+ || exit_fail "deposits audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-deposits \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-deposits-inc.json \
+ 2> "${MY_TMP_DIR}/test-audit-deposits-inc.log" \
+ || exit_fail "incremental deposits audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-reserves.json \
+ 2> "${MY_TMP_DIR}/test-audit-reserves.log" \
+ || exit_fail "reserves audit failed"
+ echo -n "."
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-reserves-inc.json \
+ 2> "${MY_TMP_DIR}/test-audit-reserves-inc.log" \
+ || exit_fail "incremental reserves audit failed"
+ echo -n "."
+ rm -f "${MY_TMP_DIR}/test-wire-audit.log"
+ thaw() {
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-wire.json \
+ 2>> "${MY_TMP_DIR}/test-wire-audit.log"
+ }
+ thaw || ( echo -e " FIRST CALL TO taler-helper-auditor-wire FAILED,\nRETRY AFTER TWO SECONDS..." | tee -a "${MY_TMP_DIR}/test-wire-audit.log"
+ sleep 2
+ thaw || exit_fail "wire audit failed" )
+ echo -n "."
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L DEBUG \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-wire-inc.json \
+ 2> "${MY_TMP_DIR}/test-wire-audit-inc.log" \
+ || exit_fail "wire audit inc failed"
+ echo -n "."
+
+ echo " DONE"
+}
+
+
+# Cleanup to run after the auditor
+function post_audit () {
+ taler-exchange-dbinit \
+ -c "$CONF" \
+ -g \
+ || exit_fail "exchange DB GC failed"
+
+ cleanup
+ echo -n "TeXing ."
+ taler-helper-auditor-render.py \
+ test-audit-aggregation.json \
+ test-audit-coins.json \
+ test-audit-deposits.json \
+ test-audit-reserves.json \
+ test-audit-wire.json \
+ < ../../contrib/auditor-report.tex.j2 \
+ > test-report.tex \
+ || exit_fail "Renderer failed"
+
+ echo -n "."
+ timeout 10 pdflatex test-report.tex \
+ >/dev/null \
+ || exit_fail "pdflatex failed"
+ echo -n "."
+ timeout 10 pdflatex test-report.tex \
+ >/dev/null
+ echo " DONE"
+}
+
+
+# Run audit process on current database, including report
+# generation. Pass "aggregator" as $1 to run
+# $ taler-exchange-aggregator
+# before auditor (to trigger pending wire transfers).
+# Pass "drain" as $2 to run a drain operation as well.
+function run_audit () {
+ pre_audit "${1:-no}"
+ if test "${2:-no}" = "drain"
+ then
+ echo -n "Starting exchange..."
+ taler-exchange-httpd \
+ -c "${CONF}" \
+ -L INFO \
+ 2> "${MY_TMP_DIR}/exchange-httpd-drain.err" &
+ EPID=$!
+
+ # Wait for all services to be available
+ for n in $(seq 1 50)
+ do
+ echo -n "."
+ sleep 0.1
+ OK=0
+ # exchange
+ wget "http://localhost:8081/seed" \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ || continue
+ OK=1
+ break
+ done
+ echo "... DONE."
+ export CONF
+
+ echo -n "Running taler-exchange-offline drain "
+
+ taler-exchange-offline \
+ -L DEBUG \
+ -c "${CONF}" \
+ drain TESTKUDOS:0.1 \
+ exchange-account-1 payto://iban/SANDBOXX/DE360679?receiver-name=Exchange+Drain \
+ upload \
+ 2> "${MY_TMP_DIR}/taler-exchange-offline-drain.log" \
+ || exit_fail "offline draining failed"
+ kill -TERM "$EPID"
+ wait "$EPID" || true
+ unset EPID
+ echo -n "Running taler-exchange-drain ..."
+ printf "\n" | taler-exchange-drain \
+ -L DEBUG \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/taler-exchange-drain.log" \
+ || exit_fail "FAIL"
+ echo " DONE"
+
+ echo -n "Running taler-exchange-transfer ..."
+ taler-exchange-transfer \
+ -L INFO \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/drain-transfer.log" \
+ || exit_fail "FAIL"
+ echo " DONE"
+
+ audit_only
+ post_audit
+}
+
+
+# Do a full reload of the (original) database
+function full_reload()
+{
+ echo -n "Doing full reload of the database (loading ${BASEDB}.sql into $DB at $PGHOST)... "
+ dropdb "$DB" 2> /dev/null || true
+ createdb -T template0 "$DB" \
+ || exit_skip "could not create database $DB (at $PGHOST)"
+ # Import pre-generated database, -q(ietly) using single (-1) transaction
+ psql -Aqt "$DB" \
+ -q \
+ -1 \
+ -f "${BASEDB}.sql" \
+ > /dev/null \
+ || exit_skip "Failed to load database $DB from ${BASEDB}.sql"
+ echo "DONE"
+ # Technically, this call shouldn't be needed as libeufin should already be stopped here...
+ stop_libeufin
+}
+
+
+function test_0() {
+
+ echo "===========0: normal run with aggregator==========="
+ run_audit aggregator
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
+ echo -n "Test for deposit confirmation emergencies... "
+ jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
+
+ echo PASS
+
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
+ fi
+
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ echo "PASS"
+
+ echo -n "Checking for unexpected arithmetic differences "
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
+ fi
+
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
+ echo "PASS"
+
+ echo -n "Checking for unexpected wire out differences "
+ jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
+ echo "PASS"
+
+ # cannot easily undo aggregator, hence full reload
+ full_reload
+
+}
+
+
+# Run without aggregator, hence auditor should detect wire
+# transfer lag!
+function test_1() {
+
+ echo "===========1: normal run==========="
+ run_audit
+
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency detected in ordinary run";
+ echo "PASS"
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency by count detected in ordinary run"
+ echo "PASS"
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
+
+ echo "PASS"
+
+ echo -n "Check for lag detection... "
+
+ # Check wire transfer lag reported (no aggregator!)
+ # NOTE: This test is EXPECTED to fail for ~1h after
+ # re-generating the test database as we do not
+ # report lag of less than 1h (see GRACE_PERIOD in
+ # taler-helper-auditor-wire.c)
+ jq -e .lag_details[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ || exit_fail "Lag not detected in run without aggregator"
+
+ LAG=$(jq -r .total_amount_lag < test-audit-wire.json)
+ if [ "$LAG" = "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total lag to be non-zero"
+ fi
+ echo "PASS"
+
+
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ # Database was unmodified, no need to undo
+ echo "OK"
+}
+
+
+
+# *************** Main test loop starts here **************
+
+
+# Run all the tests against the database given in $1.
+# Sets $fail to 0 on success, non-zero on failure.
+function check_with_database()
+{
+ BASEDB="$1"
+ CONF="$1.conf"
+ echo "Running test suite with database $BASEDB using configuration $CONF"
+ MASTER_PRIV_FILE="${BASEDB}.mpriv"
+ taler-config \
+ -f \
+ -c "${CONF}" \
+ -s exchange-offline \
+ -o MASTER_PRIV_FILE \
+ -V "${MASTER_PRIV_FILE}"
+ MASTER_PUB=$(gnunet-ecc -p "$MASTER_PRIV_FILE")
+
+ echo "MASTER PUB is ${MASTER_PUB} using file ${MASTER_PRIV_FILE}"
+
+ # Load database
+ full_reload
+
+ # Run test suite
+ fail=0
+ for i in $TESTS
+ do
+ "test_$i"
+ if test 0 != $fail
+ then
+ break
+ fi
+ done
+ echo "Cleanup (disabled, leaving database $DB behind)"
+ # dropdb $DB
+}
+
+
+
+
+# *************** Main logic starts here **************
+
+# ####### Setup globals ######
+# Postgres database to use (must match configuration file)
+export DB="auditor-basedb"
+
+# test required commands exist
+echo "Testing for jq"
+jq -h > /dev/null || exit_skip "jq required"
+echo "Testing for faketime"
+faketime -h > /dev/null || exit_skip "faketime required"
+# NOTE: really check for all three libeufin commands?
+echo "Testing for libeufin-bank"
+libeufin-bank --help >/dev/null 2> /dev/null </dev/null || exit_skip "libeufin-bank required"
+echo "Testing for pdflatex"
+which pdflatex > /dev/null </dev/null || exit_skip "pdflatex required"
+echo "Testing for taler-wallet-cli"
+taler-wallet-cli -h >/dev/null </dev/null 2>/dev/null || exit_skip "taler-wallet-cli required"
+
+
+echo -n "Testing for Postgres"
+# Available directly in path?
+INITDB_BIN=$(command -v initdb) || true
+if [[ -n "$INITDB_BIN" ]]; then
+ echo " FOUND (in path) at $INITDB_BIN"
+else
+ HAVE_INITDB=$(find /usr -name "initdb" | head -1 2> /dev/null | grep postgres) \
+ || exit_skip " MISSING"
+ echo " FOUND at $(dirname "$HAVE_INITDB")"
+ INITDB_BIN=$(echo "$HAVE_INITDB" | grep bin/initdb | grep postgres | sort -n | tail -n1)
+fi
+POSTGRES_PATH=$(dirname "$INITDB_BIN")
+
+MY_TMP_DIR=$(mktemp -d /tmp/taler-auditor-basedbXXXXXX)
+echo "Using $MY_TMP_DIR for logging and temporary data"
+TMPDIR="$MY_TMP_DIR/postgres"
+mkdir -p "$TMPDIR"
+echo -n "Setting up Postgres DB at $TMPDIR ..."
+$INITDB_BIN \
+ --no-sync \
+ --auth=trust \
+ -D "${TMPDIR}" \
+ > "${MY_TMP_DIR}/postgres-dbinit.log" \
+ 2> "${MY_TMP_DIR}/postgres-dbinit.err"
+echo "DONE"
+SOCKETDIR="${TMPDIR}/sockets"
+mkdir "${SOCKETDIR}"
+echo -n "Launching Postgres service"
+cat - >> "$TMPDIR/postgresql.conf" <<EOF
+unix_socket_directories='${TMPDIR}/sockets'
+fsync=off
+max_wal_senders=0
+synchronous_commit=off
+wal_level=minimal
+listen_addresses=''
+EOF
+grep -v host \
+ < "$TMPDIR/pg_hba.conf" \
+ > "$TMPDIR/pg_hba.conf.new"
+mv "$TMPDIR/pg_hba.conf.new" "$TMPDIR/pg_hba.conf"
+"${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ start \
+ > "${MY_TMP_DIR}/postgres-start.log" \
+ 2> "${MY_TMP_DIR}/postgres-start.err"
+echo " DONE"
+PGHOST="$TMPDIR/sockets"
+export PGHOST
+
+MYDIR="${MY_TMP_DIR}/basedb"
+mkdir -p "${MYDIR}"
+echo "Generating fresh database at $MYDIR"
+if faketime -f '-1 d' ./generate-auditor-basedb.sh \
+ -c generate-kyc-basedb.conf \
+ -d "$MYDIR/$DB"
+then
+ echo -n "Reset 'auditor-basedb' database at $PGHOST ..."
+ dropdb "auditor-basedb" >/dev/null 2>/dev/null || true
+ createdb "auditor-basedb" || exit_skip "Could not create database '$BASEDB' at $PGHOST"
+ echo " DONE"
+ check_with_database "$MYDIR/$DB"
+ if [ "$fail" != "0" ]
+ then
+ exit "$fail"
+ fi
+else
+ echo "Generation failed"
+ exit 1
+fi
+
+exit 0
diff --git a/src/auditor/test-revocation.sh b/src/auditor/test-revocation.sh
index e8c548e9c..277b102fb 100755
--- a/src/auditor/test-revocation.sh
+++ b/src/auditor/test-revocation.sh
@@ -1,15 +1,33 @@
#!/bin/bash
+#
+# This file is part of TALER
+# Copyright (C) 2014-2022 Taler Systems SA
+#
+# TALER is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 3, or (at your option) any later version.
+#
+# TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/license>
+#
# Setup database which was generated from a exchange-wallet interaction
# with revocations and run the auditor against it.
#
# Check that the auditor report is as expected.
#
+# shellcheck disable=SC2317
+#
# Requires 'jq' tool and Postgres superuser rights!
set -eu
+# set -x
# Set of numbers for all the testcases.
# When adding new tests, increase the last number:
-ALL_TESTS=`seq 0 4`
+ALL_TESTS=$(seq 0 4)
# $TESTS determines which tests we should run.
# This construction is used to make it easy to
@@ -26,142 +44,115 @@ TESTS=${1:-$ALL_TESTS}
# Global variable to run the auditor processes under valgrind
# VALGRIND=valgrind
VALGRIND=""
+LOGLEVEL="INFO"
-# Exit, with status code "skip" (no 'real' failure)
-function exit_skip() {
- echo $1
- exit 77
-}
+. setup.sh
-# Exit, with error message (hard failure)
-function exit_fail() {
- echo $1
- exit 1
+# Cleanup to run whenever we exit
+function cleanup()
+{
+ if [ ! -z "${EPID:-}" ]
+ then
+ echo -n "Stopping exchange $EPID..."
+ kill -TERM "$EPID"
+ wait "$EPID"
+ echo " DONE"
+ unset EPID
+ fi
+ stop_libeufin
}
# Cleanup to run whenever we exit
-function cleanup()
+function exit_cleanup()
{
- for n in `jobs -p`
+ echo "Running exit-cleanup"
+ if [ ! -z "${POSTGRES_PATH:-}" ]
+ then
+ echo "Stopping Postgres at ${POSTGRES_PATH}"
+ "${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ stop \
+ &> /dev/null \
+ || true
+ fi
+ cleanup
+ for n in $(jobs -p)
do
- kill $n 2> /dev/null || true
+ kill "$n" 2> /dev/null || true
done
wait
- # kill euFin
- echo Killing euFin..
- kill `cat libeufin-sandbox.pid 2> /dev/null` &> /dev/null || true
- kill `cat libeufin-nexus.pid 2> /dev/null` &> /dev/null || true
- # So far only Sandbox gave exit issues / delays ..
- count=0
- while ps xo pid | grep `cat libeufin-sandbox.pid`; do
- if test $count = 5; then
- echo "Sandbox unkillable, failing now .."
- exit 1
- fi
- echo "Sandbox didn't exit yet.."
- sleep 1;
- count=`expr $count + 1`
- done
+ echo "DONE"
}
# Install cleanup handler (except for kill -9)
-trap cleanup EXIT
-
-# Downloads new transactions from the bank.
-function nexus_fetch_transactions () {
- export LIBEUFIN_NEXUS_USERNAME=exchange
- export LIBEUFIN_NEXUS_PASSWORD=x
- export LIBEUFIN_NEXUS_URL=http://localhost:8082/
- libeufin-cli accounts fetch-transactions \
- --range-type since-last --level report exchange-nexus > /dev/null
- unset LIBEUFIN_NEXUS_USERNAME
- unset LIBEUFIN_NEXUS_PASSWORD
- unset LIBEUFIN_NEXUS_URL
-}
-
-# Instruct Nexus to all the prepared payments (= those
-# POSTed to /transfer by the exchange).
-function nexus_submit_to_sandbox () {
- export LIBEUFIN_NEXUS_USERNAME=exchange
- export LIBEUFIN_NEXUS_PASSWORD=x
- export LIBEUFIN_NEXUS_URL=http://localhost:8082/
- libeufin-cli accounts submit-payments exchange-nexus
- unset LIBEUFIN_NEXUS_USERNAME
- unset LIBEUFIN_NEXUS_PASSWORD
- unset LIBEUFIN_NEXUS_URL
-}
-
-function get_payto_uri() {
- export LIBEUFIN_SANDBOX_USERNAME=$1
- export LIBEUFIN_SANDBOX_PASSWORD=$2
- export LIBEUFIN_SANDBOX_URL=http://localhost:18082/demobanks/default
- libeufin-cli sandbox demobank info --bank-account $1 | jq --raw-output '.paytoUri'
-}
+trap exit_cleanup EXIT
-function launch_libeufin () {
- export LIBEUFIN_NEXUS_DB_CONNECTION="jdbc:sqlite:$DB.sqlite3"
- libeufin-nexus serve --port 8082 \
- 2> libeufin-nexus-stderr.log \
- > libeufin-nexus-stdout.log &
- echo $! > libeufin-nexus.pid
- export LIBEUFIN_SANDBOX_DB_CONNECTION="jdbc:sqlite:$DB.sqlite3"
- export LIBEUFIN_SANDBOX_ADMIN_PASSWORD=secret
- libeufin-sandbox serve --port 18082 \
- > libeufin-sandbox-stdout.log \
- 2> libeufin-sandbox-stderr.log &
- echo $! > libeufin-sandbox.pid
-}
# Operations to run before the actual audit
function pre_audit () {
# Launch bank
echo -n "Launching bank "
- EXCHANGE_URL=`taler-config -c $CONF -s EXCHANGE -o BASE_URL`
launch_libeufin
- for n in `seq 1 80`
+ for n in $(seq 1 80)
do
echo -n "."
sleep 0.1
OK=1
- wget http://localhost:18082/ -o /dev/null -O /dev/null >/dev/null && break
+ wget http://localhost:18082/ \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null && break
OK=0
done
- if [ 1 != $OK ]
+ if [ 1 != "$OK" ]
then
exit_skip "Failed to launch Sandbox"
fi
- for n in `seq 1 80`
+ for n in $(seq 1 80)
do
echo -n "."
sleep 0.1
OK=1
- wget http://localhost:8082/ -o /dev/null -O /dev/null >/dev/null && break
+ wget http://localhost:8082/ \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null && break
OK=0
done
- if [ 1 != $OK ]
+ if [ 1 != "$OK" ]
then
exit_skip "Failed to launch Nexus"
fi
echo " DONE"
- if test ${1:-no} = "aggregator"
+ if [ "${1:-no}" = "aggregator" ]
then
export CONF
- echo -n "Running exchange aggregator ... (config: $CONF)"
- taler-exchange-aggregator -L INFO -t -c $CONF -y 2> aggregator.log || exit_fail "FAIL"
+ echo -n "Running exchange aggregator ... (config: $CONF)"
+ taler-exchange-aggregator \
+ -L "$LOGLEVEL" \
+ -t \
+ -c "$CONF" \
+ -y \
+ 2> "${MY_TMP_DIR}/aggregator.log" \
+ || exit_fail "FAIL"
echo " DONE"
echo -n "Running exchange closer ..."
- taler-exchange-closer -L INFO -t -c $CONF 2> closer.log || exit_fail "FAIL"
+ taler-exchange-closer \
+ -L "$LOGLEVEL" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/closer.log" \
+ || exit_fail "FAIL"
echo " DONE"
echo -n "Running exchange transfer ..."
- taler-exchange-transfer -L INFO -t -c $CONF 2> transfer.log || exit_fail "FAIL"
+ taler-exchange-transfer \
+ -L "$LOGLEVEL" \
+ -t \
+ -c "$CONF" \
+ 2> "${MY_TMP_DIR}/transfer.log" \
+ || exit_fail "FAIL"
echo " DONE"
- echo -n "Running Nexus payment submitter ..."
- nexus_submit_to_sandbox
- echo " DONE"
- # Make outgoing transactions appear in the TWG:
- echo -n "Download bank transactions ..."
- nexus_fetch_transactions
- echo " DONE"
fi
}
@@ -171,44 +162,117 @@ function audit_only () {
echo -n "Running audit(s) ... (conf is $CONF)"
# Restart so that first run is always fresh, and second one is incremental
- taler-auditor-dbinit -r -c $CONF
- $VALGRIND taler-helper-auditor-aggregation -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-aggregation.json 2> test-audit-aggregation.log || exit_fail "aggregation audit failed"
+ taler-auditor-dbinit \
+ -r \
+ -c "$CONF"
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-aggregation.json \
+ 2> test-audit-aggregation.log \
+ || exit_fail "aggregation audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-aggregation -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-aggregation-inc.json 2> test-audit-aggregation-inc.log || exit_fail "incremental aggregation audit failed"
+ $VALGRIND taler-helper-auditor-aggregation \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-aggregation-inc.json \
+ 2> test-audit-aggregation-inc.log \
+ || exit_fail "incremental aggregation audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-coins -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-coins.json 2> test-audit-coins.log || exit_fail "coin audit failed"
+ $VALGRIND taler-helper-auditor-coins \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-coins.json \
+ 2> test-audit-coins.log \
+ || exit_fail "coin audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-coins -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-coins-inc.json 2> test-audit-coins-inc.log || exit_fail "incremental coin audit failed"
+ $VALGRIND taler-helper-auditor-coins \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-coins-inc.json \
+ 2> test-audit-coins-inc.log \
+ || exit_fail "incremental coin audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-deposits -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-deposits.json 2> test-audit-deposits.log || exit_fail "deposits audit failed"
+ $VALGRIND taler-helper-auditor-deposits \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-deposits.json \
+ 2> test-audit-deposits.log \
+ || exit_fail "deposits audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-deposits -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-deposits-inc.json 2> test-audit-deposits-inc.log || exit_fail "incremental deposits audit failed"
+ $VALGRIND taler-helper-auditor-deposits \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-deposits-inc.json \
+ 2> test-audit-deposits-inc.log \
+ || exit_fail "incremental deposits audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-reserves -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-reserves.json 2> test-audit-reserves.log || exit_fail "reserves audit failed"
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-reserves.json \
+ 2> test-audit-reserves.log \
+ || exit_fail "reserves audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-reserves -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-reserves-inc.json 2> test-audit-reserves-inc.log || exit_fail "incremental reserves audit failed"
+ $VALGRIND taler-helper-auditor-reserves \
+ -i \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-reserves-inc.json \
+ 2> test-audit-reserves-inc.log \
+ || exit_fail "incremental reserves audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-wire -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-wire.json 2> test-wire-audit.log || exit_fail "wire audit failed"
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-wire.json \
+ 2> test-wire-audit.log \
+ || exit_fail "wire audit failed"
echo -n "."
- $VALGRIND taler-helper-auditor-wire -i -L DEBUG -c $CONF -m $MASTER_PUB > test-audit-wire-inc.json 2> test-wire-audit-inc.log || exit_fail "wire audit failed"
+ $VALGRIND taler-helper-auditor-wire \
+ -i \
+ -L "$LOGLEVEL" \
+ -c "$CONF" \
+ -m "$MASTER_PUB" \
+ > test-audit-wire-inc.json \
+ 2> test-wire-audit-inc.log \
+ || exit_fail "wire audit failed"
echo -n "."
-
echo " DONE"
}
# Cleanup to run after the auditor
function post_audit () {
- echo -n "Cleanup ..."
cleanup
- echo " DONE"
echo -n "TeXing ."
- taler-helper-auditor-render.py test-audit-aggregation.json test-audit-coins.json test-audit-deposits.json test-audit-reserves.json test-audit-wire.json < ../../contrib/auditor-report.tex.j2 > test-report.tex || exit_fail "Renderer failed"
-
+ taler-helper-auditor-render.py \
+ test-audit-aggregation.json \
+ test-audit-coins.json \
+ test-audit-deposits.json \
+ test-audit-reserves.json \
+ test-audit-wire.json \
+ < ../../contrib/auditor-report.tex.j2 \
+ > test-report.tex \
+ || exit_fail "Renderer failed"
echo -n "."
- timeout 10 pdflatex test-report.tex >/dev/null || exit_fail "pdflatex failed"
+ timeout 10 pdflatex test-report.tex \
+ >/dev/null \
+ || exit_fail "pdflatex failed"
echo -n "."
- timeout 10 pdflatex test-report.tex >/dev/null
+ timeout 10 pdflatex test-report.tex \
+ >/dev/null
echo " DONE"
}
@@ -218,155 +282,158 @@ function post_audit () {
# $ taler-exchange-aggregator
# before auditor (to trigger pending wire transfers).
function run_audit () {
- pre_audit ${1:-no}
+ pre_audit "${1:-no}"
audit_only
post_audit
-
}
# Do a full reload of the (original) database
-full_reload()
+function full_reload()
{
echo -n "Doing full reload of the database... "
- dropdb $DB 2> /dev/null || true
- rm -f $DB.sqlite3 || true # libeufin
- createdb -T template0 $DB || exit_skip "could not create database"
+ dropdb "$DB" 2> /dev/null || true
+ createdb -T template0 "$DB" \
+ || exit_skip "could not create database $DB (at $PGHOST)"
# Import pre-generated database, -q(ietly) using single (-1) transaction
- psql -Aqt $DB -q -1 -f ${BASEDB}.sql > /dev/null || exit_skip "Failed to load database"
- sqlite3 $DB.sqlite3 < ${BASEDB}-libeufin.sql || exit_skip "Failed to load libEufin database"
+ psql -Aqt "$DB" \
+ -q \
+ -1 \
+ -f "${BASEDB}.sql" \
+ > /dev/null \
+ || exit_skip "Failed to load database $DB from ${BASEDB}.sql"
echo "DONE"
- # Exchange payto URI contains the (dynamically generated)
- # IBAN, that can only be written in CONF after libeufin is
- # setup.
- taler-config -c $CONF -s exchange-account-1 -o PAYTO_URI &> /dev/null || (
- echo -n "Specifying exchange payto URI in the configuration ($CONF) (grab IBAN from $DB.sqlite3)...";
- EXCHANGE_IBAN=`echo "SELECT iban FROM BankAccounts WHERE label='exchange'" | sqlite3 $DB.sqlite3`;
- taler-config -c $CONF -s exchange-account-1 -o PAYTO_URI \
- -V "payto://iban/SANDBOXX/$EXCHANGE_IBAN?receiver-name=Exchange+Company"
- echo " DONE"
- )
}
function test_0() {
+ echo "===========0: normal run with aggregator==========="
+ run_audit aggregator
+
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
+ echo -n "Test for deposit confirmation emergencies... "
+ jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
+
+ echo PASS
+
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
+ fi
+ LOSS=$(jq -r .total_bad_sig_loss < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
+ fi
-echo "===========0: normal run with aggregator==========="
-run_audit aggregator
-
-echo "Checking output"
-# if an emergency was detected, that is a bug and we should fail
-echo -n "Test for emergencies... "
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
-echo -n "Test for deposit confirmation emergencies... "
-jq -e .deposit_confirmation_inconsistencies[0] < test-audit-deposits.json > /dev/null && exit_fail "Unexpected deposit confirmation inconsistency detected" || echo PASS
-echo -n "Test for emergencies by count... "
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-
-echo -n "Test for wire inconsistencies... "
-jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
-jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
-jq -e .missattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected missattribution inconsistency detected in ordinary run"
-jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
-jq -e .denomination_key_validity_withdraw_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected denomination key withdraw inconsistency detected in ordinary run"
-jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
-jq -e .lag_details[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected lag detected in ordinary run"
-jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
-
-
-# TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
-# TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-
-echo PASS
-
-LOSS=`jq -r .total_bad_sig_loss < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from aggregation, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from coins, got unexpected loss of $LOSS"
-fi
-LOSS=`jq -r .total_bad_sig_loss < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong total bad sig loss from reserves, got unexpected loss of $LOSS"
-fi
-
-echo -n "Test for wire amounts... "
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total missattribution in wrong, got $WIRED"
-fi
-echo PASS
-
-echo -n "Checking for unexpected arithmetic differences "
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-coins.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_plus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
-fi
-LOSS=`jq -r .total_arithmetic_delta_minus < test-audit-reserves.json`
-if test $LOSS != "TESTKUDOS:0"
-then
- exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
-fi
-
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
-jq -e .amount_arithmetic_inconsistencies[0] < test-audit-reserves.json > /dev/null && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
-echo PASS
-
-echo -n "Checking for unexpected wire out differences "
-jq -e .wire_out_inconsistencies[0] < test-audit-aggregation.json > /dev/null && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
-echo PASS
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
+ echo "PASS"
-# cannot easily undo aggregator, hence full reload
-full_reload
+ echo -n "Checking for unexpected arithmetic differences "
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregations, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-aggregation.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from aggregation, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-coins.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from coins, got unexpected minus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_plus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected plus of $LOSS"
+ fi
+ LOSS=$(jq -r .total_arithmetic_delta_minus < test-audit-reserves.json)
+ if [ "$LOSS" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Wrong arithmetic delta from reserves, got unexpected minus of $LOSS"
+ fi
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from aggregations detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from coins detected in ordinary run"
+ jq -e .amount_arithmetic_inconsistencies[0] \
+ < test-audit-reserves.json \
+ > /dev/null \
+ && exit_fail "Unexpected arithmetic inconsistencies from reserves detected in ordinary run"
+ echo "PASS"
+
+ echo -n "Checking for unexpected wire out differences "
+ jq -e .wire_out_inconsistencies[0] \
+ < test-audit-aggregation.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire out inconsistencies detected in ordinary run"
+ echo "PASS"
+
+ # cannot easily undo aggregator, hence full reload
+ full_reload
}
@@ -374,58 +441,84 @@ full_reload
# transfer lag!
function test_1() {
-echo "===========1: normal run==========="
-run_audit
-
-echo "Checking output"
-# if an emergency was detected, that is a bug and we should fail
-echo -n "Test for emergencies... "
-jq -e .emergencies[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency detected in ordinary run" || echo PASS
-echo -n "Test for emergencies by count... "
-jq -e .emergencies_by_count[0] < test-audit-coins.json > /dev/null && exit_fail "Unexpected emergency by count detected in ordinary run" || echo PASS
-
-echo -n "Test for wire inconsistencies... "
-jq -e .wire_out_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
-jq -e .reserve_in_amount_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
-jq -e .missattribution_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected missattribution inconsistency detected in ordinary run"
-jq -e .row_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected row inconsistency detected in ordinary run"
-jq -e .row_minor_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
-jq -e .wire_format_inconsistencies[0] < test-audit-wire.json > /dev/null && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
-
-# TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
-# TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
-
-echo PASS
-
-echo -n "Test for wire amounts... "
-WIRED=`jq -r .total_wire_in_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_in_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_plus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta plus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_wire_out_delta_minus < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total wire delta minus wrong, got $WIRED"
-fi
-WIRED=`jq -r .total_missattribution_in < test-audit-wire.json`
-if test $WIRED != "TESTKUDOS:0"
-then
- exit_fail "Expected total missattribution in wrong, got $WIRED"
-fi
+ echo "===========1: normal run==========="
+ run_audit
+
+ echo "Checking output"
+ # if an emergency was detected, that is a bug and we should fail
+ echo -n "Test for emergencies... "
+ jq -e .emergencies[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency detected in ordinary run" \
+ || echo "PASS"
+ echo -n "Test for emergencies by count... "
+ jq -e .emergencies_by_count[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ && exit_fail "Unexpected emergency by count detected in ordinary run" \
+ || echo "PASS"
+
+ echo -n "Test for wire inconsistencies... "
+ jq -e .wire_out_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire out inconsistency detected in ordinary run"
+ jq -e .reserve_in_amount_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected reserve in inconsistency detected in ordinary run"
+ jq -e .misattribution_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected misattribution inconsistency detected in ordinary run"
+ jq -e .row_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected row inconsistency detected in ordinary run"
+ jq -e .row_minor_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected minor row inconsistency detected in ordinary run"
+ jq -e .wire_format_inconsistencies[0] \
+ < test-audit-wire.json \
+ > /dev/null \
+ && exit_fail "Unexpected wire format inconsistencies detected in ordinary run"
+
+ # TODO: check operation balances are correct (once we have all transaction types and wallet is deterministic)
+ # TODO: check revenue summaries are correct (once we have all transaction types and wallet is deterministic)
+
+ echo "PASS"
+
+ echo -n "Test for wire amounts... "
+ WIRED=$(jq -r .total_wire_in_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_in_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_plus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta plus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_wire_out_delta_minus < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total wire delta minus wrong, got $WIRED"
+ fi
+ WIRED=$(jq -r .total_misattribution_in < test-audit-wire.json)
+ if [ "$WIRED" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Expected total misattribution in wrong, got $WIRED"
+ fi
-# Database was unmodified, no need to undo
-echo "OK"
+ # Database was unmodified, no need to undo
+ echo "OK"
}
@@ -433,38 +526,38 @@ echo "OK"
# Change recoup amount
function test_2() {
-echo "===========2: recoup amount inconsistency==========="
-echo "UPDATE exchange.recoup SET amount_val=5 WHERE recoup_uuid=1" | psql -Aqt $DB
+ echo "===========2: recoup amount inconsistency==========="
+ echo "UPDATE exchange.recoup SET amount_val=5 WHERE recoup_uuid=1" | psql -Aqt "$DB"
-run_audit
+ run_audit
-# Reserve balance is now wrong
-echo -n "Testing inconsistency detection... "
-AMOUNT=`jq -r .reserve_balance_summary_wrong_inconsistencies[0].auditor < test-audit-reserves.json`
-if test $AMOUNT != "TESTKUDOS:3"
-then
- exit_fail "Reserve auditor amount $AMOUNT is wrong"
-fi
-AMOUNT=`jq -r .reserve_balance_summary_wrong_inconsistencies[0].exchange < test-audit-reserves.json`
-if test $AMOUNT != "TESTKUDOS:0"
-then
- exit_fail "Reserve exchange amount $AMOUNT is wrong"
-fi
-# Coin spent exceeded coin's value
-AMOUNT=`jq -r .amount_arithmetic_inconsistencies[0].auditor < test-audit-coins.json`
-if test $AMOUNT != "TESTKUDOS:2"
-then
- exit_fail "Coin auditor amount $AMOUNT is wrong"
-fi
-AMOUNT=`jq -r .amount_arithmetic_inconsistencies[0].exchange < test-audit-coins.json`
-if test $AMOUNT != "TESTKUDOS:5"
-then
- exit_fail "Coin exchange amount $AMOUNT is wrong"
-fi
-echo OK
+ # Reserve balance is now wrong
+ echo -n "Testing inconsistency detection... "
+ AMOUNT=$(jq -r .reserve_balance_summary_wrong_inconsistencies[0].auditor < test-audit-reserves.json)
+ if [ "$AMOUNT" != "TESTKUDOS:3" ]
+ then
+ exit_fail "Reserve auditor amount $AMOUNT is wrong"
+ fi
+ AMOUNT=$(jq -r .reserve_balance_summary_wrong_inconsistencies[0].exchange < test-audit-reserves.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Reserve exchange amount $AMOUNT is wrong"
+ fi
+ # Coin spent exceeded coin's value
+ AMOUNT=$(jq -r .amount_arithmetic_inconsistencies[0].auditor < test-audit-coins.json)
+ if [ "$AMOUNT" != "TESTKUDOS:2" ]
+ then
+ exit_fail "Coin auditor amount $AMOUNT is wrong"
+ fi
+ AMOUNT=$(jq -r .amount_arithmetic_inconsistencies[0].exchange < test-audit-coins.json)
+ if [ "$AMOUNT" != "TESTKUDOS:5" ]
+ then
+ exit_fail "Coin exchange amount $AMOUNT is wrong"
+ fi
+ echo "OK"
-# Undo database modification
-echo "UPDATE exchange.recoup SET amount_val=2 WHERE recoup_uuid=1" | psql -Aqt $DB
+ # Undo database modification
+ echo "UPDATE exchange.recoup SET amount_val=2 WHERE recoup_uuid=1" | psql -Aqt "$DB"
}
@@ -472,27 +565,27 @@ echo "UPDATE exchange.recoup SET amount_val=2 WHERE recoup_uuid=1" | psql -Aqt $
# Change recoup-refresh amount
function test_3() {
-echo "===========3: recoup-refresh amount inconsistency==========="
-echo "UPDATE exchange.recoup_refresh SET amount_val=5 WHERE recoup_refresh_uuid=1" | psql -Aqt $DB
+ echo "===========3: recoup-refresh amount inconsistency==========="
+ echo "UPDATE exchange.recoup_refresh SET amount_val=5 WHERE recoup_refresh_uuid=1" | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-# Coin spent exceeded coin's value
-AMOUNT=`jq -r .total_arithmetic_delta_minus < test-audit-coins.json`
-if test $AMOUNT != "TESTKUDOS:5"
-then
- exit_fail "Arithmetic delta minus amount $AMOUNT is wrong"
-fi
-AMOUNT=`jq -r .total_arithmetic_delta_plus < test-audit-coins.json`
-if test $AMOUNT != "TESTKUDOS:0"
-then
- exit_fail "Arithmetic delta plus amount $AMOUNT is wrong"
-fi
-echo OK
+ echo -n "Testing inconsistency detection... "
+ # Coin spent exceeded coin's value
+ AMOUNT=$(jq -r .total_arithmetic_delta_minus < test-audit-coins.json)
+ if [ "$AMOUNT" != "TESTKUDOS:5" ]
+ then
+ exit_fail "Arithmetic delta minus amount $AMOUNT is wrong"
+ fi
+ AMOUNT=$(jq -r .total_arithmetic_delta_plus < test-audit-coins.json)
+ if [ "$AMOUNT" != "TESTKUDOS:0" ]
+ then
+ exit_fail "Arithmetic delta plus amount $AMOUNT is wrong"
+ fi
+ echo "OK"
-# Undo database modification
-echo "UPDATE exchange.recoup_refresh SET amount_val=0 WHERE recoup_refresh_uuid=1" | psql -Aqt $DB
+ # Undo database modification
+ echo "UPDATE exchange.recoup_refresh SET amount_val=0 WHERE recoup_refresh_uuid=1" | psql -Aqt "$DB"
}
@@ -500,55 +593,53 @@ echo "UPDATE exchange.recoup_refresh SET amount_val=0 WHERE recoup_refresh_uuid=
# Void recoup-refresh entry by 'unrevoking' denomination
function test_4() {
-echo "===========4: invalid recoup==========="
-echo "DELETE FROM exchange.denomination_revocations;" | psql -Aqt $DB
+ echo "===========4: invalid recoup==========="
+ echo "DELETE FROM exchange.denomination_revocations;" | psql -Aqt "$DB"
-run_audit
+ run_audit
-echo -n "Testing inconsistency detection... "
-# Coin spent exceeded coin's value
-jq -e .bad_sig_losses[0] < test-audit-coins.json > /dev/null || exit_fail "Bad recoup not detected"
-AMOUNT=`jq -r .total_bad_sig_losses < test-audit-coins.json`
-if test $AMOUNT == "TESTKUDOS:0"
-then
- exit_fail "Total bad sig losses are wrong"
-fi
-TAB=`jq -r .row_inconsistencies[0].table < test-audit-reserves.json`
-if test $TAB != "recoup"
-then
- exit_fail "Wrong table for row inconsistency, got $TAB"
-fi
-echo OK
-
-# Undo database modification (can't easily undo DELETE, so full reload)
-full_reload
+ echo -n "Testing inconsistency detection... "
+ # Coin spent exceeded coin's value
+ jq -e .bad_sig_losses[0] \
+ < test-audit-coins.json \
+ > /dev/null \
+ || exit_fail "Bad recoup not detected"
+ AMOUNT=$(jq -r .irregular_loss < test-audit-coins.json)
+ if [ "$AMOUNT" == "TESTKUDOS:0" ]
+ then
+ exit_fail "Total bad sig losses are wrong"
+ fi
+ TAB=$(jq -r .row_inconsistencies[0].table < test-audit-reserves.json)
+ if [ "$TAB" != "recoup" ]
+ then
+ exit_fail "Wrong table for row inconsistency, got $TAB"
+ fi
+ echo "OK"
+ # Undo database modification (can't easily undo DELETE, so full reload)
+ full_reload
}
-
# *************** Main test loop starts here **************
# Run all the tests against the database given in $1.
# Sets $fail to 0 on success, non-zero on failure.
-check_with_database()
+function check_with_database()
{
- BASEDB=$1
+ BASEDB="$1"
+ # Configuration file to use
+ CONF="$1.conf"
echo "Running test suite with database $BASEDB using configuration $CONF"
- # Setup database-specific globals
- MASTER_PUB=`cat ${BASEDB}.mpub`
+ MASTER_PRIV_FILE="${BASEDB}.mpriv"
+ taler-config -f -c "${CONF}" -s exchange-offline -o MASTER_PRIV_FILE -V "${MASTER_PRIV_FILE}"
+ MASTER_PUB=$(gnunet-ecc -p "$MASTER_PRIV_FILE")
- # Determine database age
- echo "Calculating database age based on ${BASEDB}.age"
- AGE=`cat ${BASEDB}.age`
- NOW=`date +%s`
- # NOTE: expr "fails" if the result is zero.
- DATABASE_AGE=`expr ${NOW} - ${AGE} || true`
- echo "Database age is ${DATABASE_AGE} seconds"
+ echo "MASTER PUB is ${MASTER_PUB} using file ${MASTER_PRIV_FILE}"
# Load database
full_reload
@@ -556,15 +647,14 @@ check_with_database()
fail=0
for i in $TESTS
do
- test_$i
- if test 0 != $fail
+ "test_$i"
+ if [ 0 != "$fail" ]
then
break
fi
done
# echo "Cleanup (disabled, leaving database $DB behind)"
- dropdb $DB
- rm -f test-audit.log test-wire-audit.log
+ dropdb "$DB"
}
@@ -572,54 +662,91 @@ check_with_database()
# *************** Main logic starts here **************
# ####### Setup globals ######
-# Postgres database to use (must match revoke-basedb.conf)
-DB=taler-auditor-test
+# Postgres database to use
+DB=revoke-basedb
-# Configuration file to use
-CONF=revoke-basedb.conf
# test required commands exist
echo "Testing for jq"
jq -h > /dev/null || exit_skip "jq required"
-echo "Testing for libeufin(-cli)"
-libeufin-cli --help >/dev/null </dev/null || exit_skip "libeufin required"
+echo "Testing for faketime"
+faketime -h > /dev/null \
+ || exit_skip "faketime required"
+echo "Testing for libeufin-bank"
+libeufin-bank --help \
+ >/dev/null \
+ 2> /dev/null \
+ </dev/null \
+ || exit_skip "libeufin-bank required"
echo "Testing for pdflatex"
which pdflatex > /dev/null </dev/null || exit_skip "pdflatex required"
-
-# check if we should regenerate the database
-if test -n "${1:-}"
-then
- echo "Custom run, will only run on existing DB."
+echo "Testing for taler-wallet-cli"
+taler-wallet-cli -h \
+ >/dev/null \
+ </dev/null \
+ 2>/dev/null \
+ || exit_skip "taler-wallet-cli required"
+
+echo -n "Testing for Postgres "
+# Available directly in path?
+INITDB_BIN=$(command -v initdb) || true
+if [[ -n "$INITDB_BIN" ]]; then
+ echo "FOUND (in path) at $INITDB_BIN"
else
- echo -n "Testing for taler-wallet-cli"
- if taler-wallet-cli -h >/dev/null </dev/null 2>/dev/null
+ HAVE_INITDB=$(find /usr -name "initdb" | head -1 2> /dev/null | grep postgres) || exit_skip " MISSING"
+ echo "FOUND at " "$(dirname "$HAVE_INITDB")"
+ INITDB_BIN=$(echo "$HAVE_INITDB" | grep bin/initdb | grep postgres | sort -n | tail -n1)
+fi
+echo -n "Setting up Postgres DB"
+POSTGRES_PATH=$(dirname "$INITDB_BIN")
+MY_TMP_DIR=$(mktemp -d /tmp/taler-auditor-basedbXXXXXX)
+TMPDIR="${MY_TMP_DIR}/postgres/"
+mkdir -p "$TMPDIR"
+echo -n "Setting up Postgres DB at $TMPDIR ..."
+"$INITDB_BIN" \
+ --no-sync \
+ --auth=trust \
+ -D "${TMPDIR}" \
+ > "${MY_TMP_DIR}/postgres-dbinit.log" \
+ 2> "${MY_TMP_DIR}/postgres-dbinit.err"
+echo " DONE"
+mkdir "${TMPDIR}/sockets"
+echo -n "Launching Postgres service at $POSTGRES_PATH"
+cat - >> "$TMPDIR/postgresql.conf" <<EOF
+unix_socket_directories='${TMPDIR}/sockets'
+fsync=off
+max_wal_senders=0
+synchronous_commit=off
+wal_level=minimal
+listen_addresses=''
+EOF
+grep -v host \
+ < "$TMPDIR/pg_hba.conf" \
+ > "$TMPDIR/pg_hba.conf.new"
+mv "$TMPDIR/pg_hba.conf.new" "$TMPDIR/pg_hba.conf"
+"${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ start \
+ > "${MY_TMP_DIR}/postgres-start.log" \
+ 2> "${MY_TMP_DIR}/postgres-start.err"
+echo " DONE"
+PGHOST="$TMPDIR/sockets"
+export PGHOST
+
+echo "Generating fresh database at $MY_TMP_DIR"
+if faketime -f '-1 d' ./generate-revoke-basedb.sh "$MY_TMP_DIR/$DB"
+then
+ check_with_database "$MY_TMP_DIR/$DB"
+ if [ "x$fail" != "x0" ]
then
- MYDIR=`mktemp -d /tmp/taler-auditor-basedbXXXXXX`
- echo " FOUND. Generating fresh database at $MYDIR"
- if ./generate-revoke-basedb.sh $MYDIR/basedb
- then
- check_with_database $MYDIR/basedb
- if test x$fail != x0
- then
- exit $fail
- else
- echo "Cleaning up $MYDIR..."
- rm -rf $MYDIR || echo "Removing $MYDIR failed"
- fi
- else
- echo "Generation failed, running only on existing DB"
- fi
+ exit "$fail"
else
- echo " NOT FOUND, running only on existing DB"
+ echo "Cleaning up $MY_TMP_DIR..."
+ rm -rf "$MY_TMP_DIR" || echo "Removing $MY_TMP_DIR failed"
fi
-fi
-
-# run tests with pre-build database, if one is available
-if test -r revoke-basedb.mpub
-then
- check_with_database "revoke-basedb"
else
- fail=77
+ echo "Generation failed"
fi
-exit $fail
+exit 0
diff --git a/src/auditor/test-sync.sh b/src/auditor/test-sync.sh
index 3ab6fa1e4..bcef908aa 100755
--- a/src/auditor/test-sync.sh
+++ b/src/auditor/test-sync.sh
@@ -1,43 +1,167 @@
-#!/bin/sh
+#!/bin/bash
+#
+# This file is part of TALER
+# Copyright (C) 2014-2023 Taler Systems SA
+#
+# TALER is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 3, or (at your option) any later version.
+#
+# TALER is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# TALER; see the file COPYING. If not, If not, see <http://www.gnu.org/license>
+#
+# shellcheck disable=SC2317
set -eu
-echo -n "Testing synchronization logic ..."
+# Exit, with status code "skip" (no 'real' failure)
+function exit_skip() {
+ echo "SKIPPING test: $1"
+ exit 77
+}
-dropdb talercheck-in 2> /dev/null || true
-dropdb talercheck-out 2> /dev/null || true
+# Exit, with error message (hard failure)
+function exit_fail() {
+ echo "FAILING test: $1"
+ exit 1
+}
-createdb talercheck-in || exit 77
-createdb talercheck-out || exit 77
-echo -n "."
+# Cleanup to run whenever we exit
+function cleanup() {
+ if [ -n "${POSTGRES_PATH:-}" ]
+ then
+ "${POSTGRES_PATH}/pg_ctl" -D "$TMPDIR" stop &> /dev/null || true
+ fi
+ for n in $(jobs -p)
+ do
+ kill "$n" 2> /dev/null || true
+ done
+ wait
+}
-taler-exchange-dbinit -c test-sync-out.conf
-echo -n "."
-psql talercheck-in < auditor-basedb.sql >/dev/null 2> /dev/null
+# Install cleanup handler (except for kill -9)
+trap cleanup EXIT
-echo -n "."
-taler-auditor-sync -s test-sync-in.conf -d test-sync-out.conf -t
+function check_with_database()
+{
+ echo -n "Testing synchronization logic ..."
-# cs_nonce_locks excluded: no point
-for table in denominations denomination_revocations wire_targets reserves reserves_in reserves_close reserves_out auditors auditor_denom_sigs exchange_sign_keys signkey_revocations extensions extension_details known_coins refresh_commitments refresh_revealed_coins refresh_transfer_keys deposits refunds wire_out aggregation_tracking wire_fee recoup recoup_refresh
-do
+ dropdb talercheck-in 2> /dev/null || true
+ dropdb talercheck-out 2> /dev/null || true
+
+ createdb talercheck-in || exit 77
+ createdb talercheck-out || exit 77
echo -n "."
- CIN=`echo "SELECT COUNT(*) FROM exchange.$table" | psql talercheck-in -Aqt`
- COUT=`echo "SELECT COUNT(*) FROM exchange.$table" | psql talercheck-out -Aqt`
- if test ${CIN} != ${COUT}
- then
- dropdb talercheck-in
- dropdb talercheck-out
- echo "FAIL"
- echo "Record count mismatch: $CIN / $COUT in table $table"
- exit 1
- fi
-done
+ taler-exchange-dbinit -c test-sync-out.conf
+ echo -n "."
+ psql -Aqt talercheck-in \
+ -q -1 \
+ -f "$1.sql" \
+ >/dev/null \
+ || exit_skip "Failed to load database"
+
+ echo -n "."
+ taler-auditor-sync \
+ -s test-sync-in.conf \
+ -d test-sync-out.conf -t
-echo -n ". "
-dropdb talercheck-in
-dropdb talercheck-out
+ # cs_nonce_locks excluded: no point
+ for table in denominations denomination_revocations wire_targets reserves reserves_in reserves_close reserves_out auditors auditor_denom_sigs exchange_sign_keys signkey_revocations extensions policy_details policy_fulfillments known_coins refresh_commitments refresh_revealed_coins refresh_transfer_keys deposits refunds wire_out aggregation_tracking wire_fee recoup recoup_refresh
+ do
+ echo -n "."
+ CIN=$(echo "SELECT COUNT(*) FROM exchange.$table" | psql talercheck-in -Aqt)
+ COUT=$(echo "SELECT COUNT(*) FROM exchange.$table" | psql talercheck-out -Aqt)
-echo "PASS"
+ if [ "${CIN}" != "${COUT}" ]
+ then
+ dropdb talercheck-in
+ dropdb talercheck-out
+ echo "FAIL"
+ exit_fail "Record count mismatch: $CIN / $COUT in table $table"
+ fi
+ done
+
+ echo -n ". "
+ dropdb talercheck-in
+ dropdb talercheck-out
+
+ echo "PASS"
+ fail=0
+}
+
+# test required commands exist
+echo "Testing for jq"
+jq -h > /dev/null || exit_skip "jq required"
+echo "Testing for faketime"
+faketime -h > /dev/null || exit_skip "faketime required"
+echo "Testing for libeufin-bank"
+libeufin-bank --help >/dev/null </dev/null 2> /dev/null || exit_skip "libeufin-bank required"
+echo "Testing for pdflatex"
+which pdflatex > /dev/null </dev/null || exit_skip "pdflatex required"
+echo "Testing for taler-wallet-cli"
+taler-wallet-cli -h >/dev/null </dev/null 2>/dev/null || exit_skip "taler-wallet-cli required"
+
+echo -n "Testing for Postgres"
+# Available directly in path?
+INITDB_BIN=$(command -v initdb) || true
+if [[ -n "$INITDB_BIN" ]]; then
+ echo " FOUND (in path) at $INITDB_BIN"
+else
+ HAVE_INITDB=$(find /usr -name "initdb" | head -1 2> /dev/null | grep postgres) || exit_skip " MISSING"
+ echo " FOUND at " "$(dirname "$HAVE_INITDB")"
+ INITDB_BIN=$(echo "$HAVE_INITDB" | grep bin/initdb | grep postgres | sort -n | tail -n1)
+fi
+echo -n "Setting up Postgres DB"
+POSTGRES_PATH=$(dirname "$INITDB_BIN")
+MYDIR=$(mktemp -d /tmp/taler-auditor-basedbXXXXXX)
+TMPDIR="$MYDIR/postgres/"
+mkdir -p "$TMPDIR"
+"$INITDB_BIN" --no-sync --auth=trust -D "${TMPDIR}" \
+ > "${MYDIR}/postgres-dbinit.log" \
+ 2> "${MYDIR}/postgres-dbinit.err"
+echo " DONE"
+mkdir "${TMPDIR}/sockets"
+echo -n "Launching Postgres service"
+cat - >> "$TMPDIR/postgresql.conf" <<EOF
+unix_socket_directories='${TMPDIR}/sockets'
+fsync=off
+max_wal_senders=0
+synchronous_commit=off
+wal_level=minimal
+listen_addresses=''
+EOF
+grep -v host \
+ < "$TMPDIR/pg_hba.conf" \
+ > "$TMPDIR/pg_hba.conf.new"
+mv "$TMPDIR/pg_hba.conf.new" "$TMPDIR/pg_hba.conf"
+"${POSTGRES_PATH}/pg_ctl" \
+ -D "$TMPDIR" \
+ -l /dev/null \
+ start \
+ > "${MYDIR}/postgres-start.log" \
+ 2> "${MYDIR}/postgres-start.err"
+echo " DONE"
+PGHOST="$TMPDIR/sockets"
+export PGHOST
+
+echo "Generating fresh database at $MYDIR"
+if faketime -f '-1 d' ./generate-auditor-basedb.sh -d "$MYDIR/auditor-basedb"
+then
+ check_with_database "$MYDIR/auditor-basedb"
+ if [ x$fail != x0 ]
+ then
+ exit "$fail"
+ else
+ echo "Cleaning up $MYDIR..."
+ rm -rf "$MYDIR" || echo "Removing $MYDIR failed"
+ fi
+else
+ echo "Generation failed"
+ exit 77
+fi
exit 0