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.am76
-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.mpriv1
-rw-r--r--src/auditor/auditor-basedb.mpub1
-rw-r--r--src/auditor/auditor-basedb.sql15904
-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.sh325
-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.sql15920
-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.c1442
-rw-r--r--src/auditor/taler-helper-auditor-wire.c1105
-rwxr-xr-xsrc/auditor/test-auditor.sh2810
-rwxr-xr-xsrc/auditor/test-kyc.sh751
-rwxr-xr-xsrc/auditor/test-revocation.sh953
-rwxr-xr-xsrc/auditor/test-sync.sh184
48 files changed, 7558 insertions, 36725 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 1ef5111d9..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,32 +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 \
- auditor-basedb.mpriv \
- 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 f9d27a09f..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/DE471160?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'30820122300d06092a864886f70d01010105000382010f003082010a02820101008f361aea2e49a8e0cb4d171cd620687ea7f6ba16948c9c19708995f328ea3590eaffbab67c01619b79eff54dd3e2d5db235e9ddbe773ce38a01bf06ecf4727fc0e218e357c812c897ab43743f39a42b9a879924e23eebdf0104a90b04c0c840ac79903f4fb74a01062d94bf2022733b985f1c9e608707e59c1c28e6fb62221f34fe8b47f6e038c2b7435360e376b86520f51047800287aaa5bde8b39d4634ed36f81b7f7c221cebbd2984c279796f3556b46d631b6f74e40c700ae299ceb9a7fc7b76a9a0670380d34328335b4699af88433033ed149e1061d6b65f88e070cd22d305a757956450bc4ac5c1e33d52f150152b93cf38f645e2644c9049cdd5e210203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(2,X'30820122300d06092a864886f70d01010105000382010f003082010a028201010098de1ce451c26f798e3878c22f0babe20f455c058f0220bf417fbbb139a452853bb01630e09d7dfbc1f0d43e34e70d8b4f44b91d63d350c0195b20e8d835bd4fdf3d0c19ad696e5c5a0c042474c65c9a56a88e8e8b90d24448a58078c512f0bad5c0e580855064734db6aaf9bad048cd114edc831ac546d4e302f8bc18e839060b62d118d1980bb33e50bbf5074e0b717abd862ddcd0ff5f285fd5ce68f8e708e2231c61290d731dea24fdb6d91ee53b4d501c3fe7e23bb5b6395264a8371593e854ed9a8cda83fda172721b3da6353c40df4ee674ac35952f28b2ba4d51964b0cac4234920601c58f66fb5ee2f4a655486a798d1b1cdfdf6ee425053faa14430203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(3,X'30820122300d06092a864886f70d01010105000382010f003082010a02820101009eda7985dc8cf6137e3fa652617f38d831a2f2322e551a01eb41a5cae37a326b99be1e5febe0f5bdff4f3cf4a0872440bbf45e7d94c20be2d71d209f3c3fbae1dff3788fa5db17667f076af85e42268d43eb3fbdb5b9b59c0d5adb5f7c351f3b17c81929a10d7d60dff1276eea8f11082142f1ea274e21e227564a7cea5c4df3147b0a6cb60d01d9a2b7f938e117a441269c078b6c9504cfc4c37f0783d282009664803cd6dbd2827345b2a43e34d33bdba79fb388a638c54c2f0e040055bb3afcabf2c516be88b6da6409a4d4a80c288e68ee820f919c08c0a4690e1806cc957ada81d87c89fbde078ea6b73c642f41e0c8b8aa5e6e3d50828e8c2ed73bced50203010001',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,'DE471160','SANDBOXX','Exchange Company','DE236345','SANDBOXX','Name unknown','QMGEMFDMCHXBTH3V1NZVBFWE1JAV69FSBPTQ9ZQ47D1VT15A1PVG','10','TESTKUDOS',1660654404619,'EUNCGUQX',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(2,'DE471160','SANDBOXX','Exchange Company','DE236345','SANDBOXX','Name unknown','QMGEMFDMCHXBTH3V1NZVBFWE1JAV69FSBPTQ9ZQ47D1VT15A1PVG','10','TESTKUDOS',1660654404619,'EUNCGUQX',NULL,'DBIT',9,1);
-INSERT INTO BankAccountTransactions VALUES(3,'DE471160','SANDBOXX','Exchange Company','DE209794','SANDBOXX','Name unknown','3T6WV8QNVR1J7GQXSFX54Y71K91ZHH6K22840EM1GNSA4EBYC900','18','TESTKUDOS',1660654412000,'F52CKZKJ',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(4,'DE471160','SANDBOXX','Exchange Company','DE209794','SANDBOXX','Name unknown','3T6WV8QNVR1J7GQXSFX54Y71K91ZHH6K22840EM1GNSA4EBYC900','18','TESTKUDOS',1660654412000,'F52CKZKJ',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,'DE722747','SANDBOXX','bank','bank',0,1,NULL);
-INSERT INTO BankAccounts VALUES(2,'DE846799','SANDBOXX','fortytwo','fortytwo',0,1,NULL);
-INSERT INTO BankAccounts VALUES(3,'DE539394','SANDBOXX','fortythree','fortythree',0,1,NULL);
-INSERT INTO BankAccounts VALUES(4,'DE471160','SANDBOXX','exchange','exchange',0,1,3);
-INSERT INTO BankAccounts VALUES(5,'DE738355','SANDBOXX','tor','tor',0,1,NULL);
-INSERT INTO BankAccounts VALUES(6,'DE740674','SANDBOXX','gnunet','gnunet',0,1,NULL);
-INSERT INTO BankAccounts VALUES(7,'DE507411','SANDBOXX','tutorial','tutorial',0,1,NULL);
-INSERT INTO BankAccounts VALUES(8,'DE889443','SANDBOXX','survey','survey',0,1,NULL);
-INSERT INTO BankAccounts VALUES(9,'DE236345','SANDBOXX','testuser-05kjxdzp','testuser-05kjxdzp',0,1,2);
-INSERT INTO BankAccounts VALUES(10,'DE209794','SANDBOXX','testuser-nsqdub8m','testuser-nsqdub8m',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'308204bd020100300d06092a864886f70d0101010500048204a7308204a30201000282010100858ce8c54e7620ca6a7f8f647735ec2fa2371c10cd0b82deb97e17dd482c598f563f2370c19c68dc7f2db6544e9bc466b0df5110d7e8c2542d3b0c42831cfad1d916036beb19b6e1782d973d399cc4c4c90d5b684112a55afff1a06b0a423a33306354316833d4fb83029196c886c14052ea106871c676df39719b65ad28e3f668c3061f28f7edb265d39ed30a649f6e8fe8a4b79feea9ef3d2d1db15931943863a49a5043aafa941da6bce039a3728de73d535758426f08777b0d5ebc77842c0b4ef7e80a4205f9e0956bcae4ff7dc4a6d07ecaaeae1c8cbb49e8dd175217d9a1e0fb969bc0e7acddd04b99ab70ef3a09da170959a79cf80cd2276b52777ab3020301000102820100299b8701c1ba27e92858e991c15a396575c279a9fa57f5c3f24288a8d64d8af18f4b487d5eb49e2ee42897bf98660b407b267819294b490ff4af8ad846050757cdac80106544b3a7774bacecd4403545a1e5d96e97a77980ea709b2bfe1c3809aeafa39169078cf9770d9bd240534b6e00e70f899ab8dc5c1b877b84a7f82f5d2856e4eafe61b33b3541a3f326eb0b3dc685faa1652b0a1be37c4157daf2829dc7b712401a2ce8a732cba607a499f6216fd31f475b1feda44b597bce76fc248713c0ad805a86dcc3bd249383cb7d1645b45c6e90b9388873b3886767099948e5aab71c4261c0a3ed616fba54076db1af6c2296208f8fff7b7a372a600d100fe102818100c25bcba147ad4b64f6dccdcfcdbe34da6c6269d3832950393b063e181faf0c8166f7d6a025e33aa113dde881d8185452606d03fe54bfb4bf1b2e60d943569687f5a08febdf3efa0bceeb777dc19c682a9298d68572b2c84e04a515e66359f4508495cb92f6552b1d0fba693cfb774ab596b2c100acc0c90e7ca31c5ce79121ab02818100afe807166689474a64a5b4b1270ea7a73fe365cdc5b3ae549e5f7c054c565a12af7b03a4534793904bd2e654f83ac40455c885c811e35c530704e464232928c79d1e8e1665a6330a74c28ba7a652898b001ad55e1653b9ccab1b8bfb14280d7b60b02186d7dc5b4455a1c923847264ef99f8975e09a6852162d03947f2e293190281805004c7138195216352179a4ca1e25b9449e742b6a85b8c01e4012ff372a7f938159298349b24b070bce331e4b37960ce01912081c7969dedc85d11d6a158b6e50705b1fb64906316157cf057402d0addec392ca9088dfed5d027bf9a78f1021b5c5ae7d37bc398da802d3942b82d66fed82a8437a8e83e5ece85c119a6e523bd02818100a896edac076bcc9abd299fab25aec2f9e59e70a4adb58f0064a548fcdef3e7f1fea31c937289a820e4bae5ac4c182e63a53fc110462cad009a3a93167228718016d30104f03940b3e5c1cb0d4bb7d1411a419d7b4654ca3f21430e7efe0b81185d4b9166661e388e9eafa751d60fb93376532de79fc22bd81a974c3eebc7418902818027592e34cdc06cbb02523b8ecf7ddb93c6a9941419fd119165929e20370fd790d3ba4123941f17f774beb9ba78011dae6bb6fe5fff61a3edf05b693684de5c25b88fda5b04f98d0b548e98dcca49509f18091a0a24a30209ccd7c2259a43ab81934e1f0e4d57cdcb0117d997aaaa2392e53ce0a3b5ee24e5da9f6b68f2f661da',X'308204bc020100300d06092a864886f70d0101010500048204a6308204a20201000282010100827428aae70a10161398e747b8e0bfff43480914d0bddbe3699f31931551eab603d5c2f6b647f8406939086915f94b80f9836393045c475e3d7ead1896254bb1a952a696e57d232cfef6687b0f091dc6275eea88caecee2bb3a5154192d160cc9ec965e5645f439ad6a90ab6a4cafc31f8fa50f31dacee2bb09a630a7d294679552522fe42f6399b7ee0bb6a7052ed671bea616d0a2d57a0b9e1d5058c6d813fb35ea6cd01446b90697193951b8be230b4bdbede531960e1d4650e38df40afa7c3018e63615c731967df6299327e7a0d59ef0d0e07212387b7194d7cb0bf48c6350ce0c4006e2ad14dbf303479ca012cd375913e2fc9430ea53c1cb709aa6b5102030100010282010009428d90740df6ce5a5dc42d07268cfa65a03b64cadc6f3b5947ff90dd368f5e942f1c43bef4a4de8d998acb4ad00358085e17375c5be085040075f104d768e4178cd25e6bb3d2476361c250d9e45fc4ad0ec3bf2a085f6fa2b4d9296a6e8a5c7bf8f7ceacad46733b418c8d226d763165e6fed0030f3f68c28472fb4f9f1a6d7072f9d548dc00db225c6e0235415d80348b13fffe5e6589aabe52e07405d0842a6ab30349c4ebdc1fc570c334f6f9d24f57174e35a80f5a286ac8ec8f9a817f26fdf0e0a83ef196ca93fa370135bfdf0a36caeac84d640340789762a214dcd271a93f8cbc0a52692ab47fdd318f3116d3332436040811c9eb1d8346f08b214102818100be15e72c8d3fdc2594e50217fbb09c6ab3bdbda1da479ba5dcf0e781005db56b1c584cad1b9e7f61e09c57d6122a3667ad2e9e332c865b6f3b9ddb8d8403d68cfc91cae909c733f844652fab5216503f2c0cf76ae56b4aa145b10b3da4e264a0601a65631411061c8b82ef4e30a70da7f977c5b6bb28b0c771870012056dcf6d02818100afb0ad2ab5dc9256427ee5337589bb37ba193d44c8878725c5638577d737d416063f8132581965691b58d603d6da957b7bb49f62e5f4424c875633ce5395b755bd925464edba203794e8372ae1afa496d0738597821d10fed988677d427aff7b1a14f96602352aad6ef02bacc1856b5fa2a2098a156ba470509314ea5d4588f5028180102295d3ef4d7b67694323315bf8fade07d1d455f7cc5a46f30133f57c4d7807d6891c41197613c40027e540d39be7b0573ffcc7c540c66423c05b91a0a21ec52aef49350cd26ef3e5025dd0821048d183f0b9d3c6139c6b221a4c24f8690b379dd0bfc8703c9db3309875adc26d7bb84571c843a1916ba81257ee4699555fe50281805c680acc9a16c7894334470d47d707778a14585b63359569d26643ff025dc4d948b4021a1ea84ce47993c20d06e6b514dbbde6cf37afbf674d0f93f403968d75355e4fb13e30555da69e74d5c31a84f125f67cdf717a244446da2dc47e40ff3b1a3ec9e65366ef69851e217a9dd6b4e0fa434bcd2af310ec5a14e23d5a8d86390281803c82302edd6b9347e6736cfb676ea278db4cf80feb0cecca6a3353a33925adb31bc962d752043b7ae1eb864bd6d2c9871c24e976af0d747ec3cacb0bb8fb71ddecf2728995b17b967b582d77b620f0fa9eaf80f21bfdbf396a15458febae680d600e8679021b610b93d9ca3ef70e9eae4faefa1c3ed4ba950c48059e002337b7',X'308204bd020100300d06092a864886f70d0101010500048204a7308204a3020100028201010096ce919bd54c4d0cb54623238d010d1899858f251cd73d7bef09d1ce4ad19b1bcf1bf8018b493d162837eed7010ff56f4b99062f92827ec261fcc7baafd8e18912a882443c0f34a20c41af878252740af2099f517386c4d23b0344a457d520cc7568eec9e7a840ea748f3c95e03a380a68087b885d59e3e3ce553e922effdd1a20970ad08b4162d1869222995a5fcefff95e559fe98e86e74bcac6c4a56cdf4bfdcafc6a38a4e09a00155bcbc3865f24e3f6c1df71d87cba296ea9e45d8701b72b439748330c884898d41ca5ef2d41c9151413dfc5a2dbfa1db9dfadf1cdd47052dc05bb173e2975ff863d72b4654e8fc5d338cf18585276f3ae2f3da3a18a5502030100010282010033fd1883715ff17bfd0e25d4feaa2b1a9cea4733d3227ca6b9fc57a0d7783511bc2f772b091a817d9ef5d157bb9d05ce8d703e8aade660cea03b259bbd3d765aebdcbdb3ca44afaf61ac4f57d6dc97f6a2042131523356ace6fd346fb77bd8e7c35e1e5bea89bd7f56197f1868098a02446510392d7d6cabbf18f20e3137b1bfe5773975eac6f71b22b398aa20bc1f892a66beafcb2e1c325966fd365a86db13457f9b4346e802cfbc8b2e7c3a8f0fff2fcb8e187391c4793dbc144c6e1401478763ddbb2f9befa434fb2ffc393537c8596b8d92fb95ec9c588eca9aed05ded3ea346972934125cb19aca512182e14292f7be4dcd59a5221ea81d815101d8fad02818100cde1927276207582ca4ed73dd6e3dde5b1068fe3b868afdb014d257864f3edd22b2f3ec94f391c52b2914a1d46429fa9d0b7ccebcc10e756e1bb26336482d9bbfe62dbadd2b236a22a53ccb7f65df678f11bd4a476ce6eb2fcb48de24041faf5424d61b019a4093fafb89b5c56d736b4889878d1f77a39b49def210f1d92a9ab02818100bb84cb14f0481f3dec26855d1b53c829235efa56adf877775f78c8e82e0ea9dce4da4199f3e332b390e1188555b762a1d737af0179a1bcda77c93f2dbbc47eb0d91a8da1ff8d19f4f87f0e0bfc42bbe4104ce0bca33377f5b9bfbee4a8ea1736d16adf794fe3f8133cb6a829e8928ad9e512e80bf77669065bd289b675709bff02818100bfb8fe4dc51f790ef122f6624a092d0cc70bdb572ed59e5e0e1a2f78ac5a53efd1f34f3edc9dcc785e7dda4ce4af0a4c736796574753be7b33feba1645d56cba1aad28f1f831a99ade5be75ab0fcd397d0c020077ff3c136c109cacf1513dc8624d636d06d304ac499f90a04b581f919a9d28340d47b67dd80edbd157c6ea5bd02818052e4ca0d9086a160f342b813c79fcaccfcb8e0bb6e9e76d94b580ea02cb408bd0061c73c32470e43b8d8f8c9007257e4a94a114ffa9fd7e74faaa406288a1d633a25f5d4562edef99edc33ae72ae6176d909d31330a5f0f2ac512a26d4d0dec039e51fb2f5f115da132dbfbafef7c0efbfc712d32f6aa5d4ccc48e621d1a51ab02818037a498582bdd58c499ae940fe73d70e619da0fa459d0990cb28037c9ccc9cb5663d6a0e5ec7570351f00aa5fe4eb3470cf2e288c100c938bb0d3f35709b3b361f2cfc56eb756d06b6c4724d13c5d5b05d6d8e15b2fa7e3c74006109101adcde2e4a56fa6731c9eae29724827d79633ea00462acc7e54af46dcdea3e125ee38e5');
-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('9D85400B26E51F1BB01ED0A2B6B437C4','HTD',1,1,'f7E6QnoF6DgeAO2vqv00GMH+D93Whi3CXF1nQIKRmRcKJ4CLd5afnLPP3OXZ4ooefQDl9SzKgJ09wpbBWsqtvD2QKfoafkVbIqF7gFkFY3jJzSz1zXAt47Zl+7fsuFin9IwB2WjyLGNTUuR61oSiCuryJvDZElA6eCzKh5D/7DHR2OO0Wu3G/XbedgyFKgUvHjob3jus5e5kJH6/hBVAKlkrg5CRoOeYOqCwEpyjaB9NM3oKtEkjjOaiEGi+x797H3/Px+2dnuNaEIuuFubkW9EFN+YS1sFbsJ8Xc8VipZ7MqN8AoxX+Ol1RnTu5YlO5rThfPHfIncQ6++d2l4WCWIkjhm8wpZGsLjSJhb+zj16pnKeZSGo1IM0nL7v9AjnfgTmedTJr2qMPreN5MLpJiY2NwyiND2hwTojlOor5Uv8+qg5QF9t7o1ULIKBhQGrk7OnWJ46wZExTe1mYFrYGdK5FhpHvooeJqxOvHA5WlxsKyburKVnvDHaGAKBBJnsgnsooXMFXArR17n7/Tqhbqv3x/mcRQpBq/KinXhL8VQCIjVJxLdmD2a7lqSQDIcAsAESPpOzHXqmMeaHQvRg52Z+4tmBWSAYEsBUpi/Ovx8Ru2KYFEfTq4tFQ0rpLUCb1O5RNn2aH1jniZVhWg06RCqIhZRkMlNw56S5bj2BVF+vnfODVyKTIE058eL8bsPHvvHZvDtchnmZ6BWSow4HUWw==',X'4b752aab6d45eeadfbee59989bbfcc2fb6e42ed770443178af5a316e8d0e531635bae91dd0cc2bc40fcf59d84e96880f2c04f6c1ea956bf1bb1bf1b512cdda0c5db317137be9418fa96c2796d56a098e2cbc7ae0f31dcd9930b7e54ec136d3262fc969d798aba4897105039326b6241063092435c14239c8b7231609e9638a170e4c37b978b83c32b5d1ac395f611b80f8ebba7af20561ffccfc1ed19a2527aafe9da5b8063e5bbe7ae82d4a85fb603c1dca754ea91980a4384dd881c2ae25ae1653e587ddc8c480afee27ed5228705fee69c68e3d4116958808b0129ef500cf685e2fa3c96090810e503a7544d60861660784815a4a3ac65c1051c0d27c3afe',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('017283C647830FE03B9A1B1BD1D61296','C52',1,1,'cyh5LC/vFUygRtSNOPbMHdZxKfa4oaZ4Qjp5l2UvjgzkzcITe8UY+tesPuMVajNAMDmBoqatfyYPsHQvYxEhLZ914EigXsReZta9PyFQprQ+s+APB0zpTC/00SoVqgZIA1gyJ1rSwvN1k2VmYbxmGK4uUWkfmIurmc+YZoFsu4dZ6bJSrkeXwBNLKWznCm5SJiw+mc/zJBCcBT5MrkRSpHOh9Ll1wPRNOLHG47blvdOxObwb5QK3WfL8epko67pSJpaf+Z1cDT14JArnb6edlG/f6+rmhi8vx0uFSwk/EDVXPHKLAu5lAjp/fgw8hex/BFaPq/3fJVggG/IYY/yRubdl8aHXz4g4ngIcqq1hgCYkeakHgOiErx2ugCkBeXQz1hZ2jXn5T+H9BhgomObVUPHuYLDlUo9sMbEJ6D5Wf2oGRcE2SU1y7unaWV4KJ2kIN4vruCI2ewrRqxGkI42IYXJfhtBReduCQYFokfEK2u6s87X0OYv2KKjhxGg90wt5xwr9rU8jJvl14TBU5KKF3w70UkmxD+2Z+IiY6yuJUg1KDHJYHOeLG7pMNX1p5o+MiT2jEvsQnHlvBFlp8Iby4H/uD1AxnCbfxCdwjikyQ+yOdqw4lR1xJR7Wg3R65wXZLblEmjSx2FnSWX+KGgpXn9LZucC4lXHeMeldbCYe45vpdyqlP1tW2vO4nVr0sTusyPzIbXVbcnA5p1vCZ0qfRytqqtKUkvDct7Ot0iewWoLI+bNIChRhYSagFDBEbZq9cMVGAKCMRGFLGQft/6Kh7aoEAGpt8C8Rl+uru/fMowh2hDca6TyrxfhouMPFQRkK8LtRtkOYD93DhcZ7LnrU+dfosrdkh2qtOAIbeK89uaM=',X'11c120c9d71f3b588dc76646077eeb5890a063b39c694b469aca807b4f4c148d5089a447a4714b45cc3fcf405e4aff09a778af235ace80ec8ca83bef48fea9d1c133afbcdd25544a0d47f8421d758b0eb88c60690ad030de63e1a3d49fef7e14cba54f68d2f595282349b9b2563be5752c8905e1a3505185a88b54035128ad43c57cb40533f4a1ac18a9dd960d60a8b8c355a765fa976225090703aca0c0d21e3e7b04b55d939720216253746c916b1110514907a119a85550ccdcf25aa5f27b8334834482ded818b900aa05c8af824a6938053d861dfd44e031db3e2a049513d02a11b9a89cad6ae4cda17021c07565c1f0f2755f112a4bdd8502690ed6ccc2',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('032766A47D3CAF2236DDA082C3109CA9','C52',1,1,'GlKlvqb9EQz5oM3Dw6GR9LgmS+6jojp23uXgsCheGIM2e9Z70VQBYa2MZZKjdMrs5DHD7OoT1iWggKCzG8MikFarvrdJix1+KZBjyejOaKeWC2aPhe8v8hkvmWwK+bqRu+MBRMgphQmuj9GzGL/DF1voRGDr6oWQHre06qrVm2C+Mk+Sj+qIvNo+1pz354cUx6G0n4b4X3TOiWFV2t75aqYHDyw3yPUqMeMPgCXaxHNfdj5zrB3/as4AwXRBRH3J570O8Z4TY+x96mLa1iLRKG7QCb/m1+cgkTY0084NxDYTY7A3Xm0bjVkn0D3hSyCuOMOB17B3LxjqLaa4N9Z33h3TLkz9JITrrHo22/ccj/dtynA1UruisE8/GIFxcpgNiMDq8GyckYkXeIX+lMWAGBY5LqnUgozgG0jxwUEdcuQjHiVM/UVJhmwNH7v8Qat6hZakMMW9JgVoJkQavx55lvFLL1PRHsy5NC8x3hSMwwjOPTjyQG5zo5VVIcybipvCGrJhySuDa/tekWnRz/1jS4V4j7/mVWX2ux3QS8Tk1KdFvWSzv4U5lmD3yTdzqmWy0jLT1sD/uks/uTNZ+c2YmcjZ+9zILKfgs/LmUuFDJSIHX/Wqe1jeW/MHrbEp8qfAOf48kHGUbhN5zcXVif+Zp9zzE/Q1SzQlbwo0WMCl8RHZC7Syn2/00b3dAr4dDrHYGGyDYKuzQGMZ0JXlbcYBXeZDy2ucURi73WizP4Mfwt+go8o+4IZmxfGkiIKDk8RfjfApIUG/IGDBzM9avy4zWi1zIdx+nMZfUzJLOxcG+SIFeMXinhSfnq58jxs5aa8KleEz6bhUlYUd3fiUne8ITqHkz5yY5KKMWGzbOxx2V4Y=',X'444f6d4e24750aacbb4c75ecf556928c1f46b0878cceb6c9ee75d2df4e3535bf6863c5d687c81668ddd1c036d332fc3af1926faec0ca8aaddbe4507f1d42b308ec1ce1a1ff234fb367541bfc1f149f69bf83420ea8154a8618d25b45da462817acc5b6a89d4b87246db6bc61f8d2895c124163b3cf2f30dbf64aab133798c55b55ba62c03e00700880fd08ae2b8c5e8e40c3508019f1d476a1b272ce6b93c713ae4015de168ca4a9acec060dade3efccc03b91bf83833f29ca3a8b3d66bac8084a1fb3b49009a87e53d998b19d9ffed1d33d6ad25a3102449b9020d419a8323b18bd88fd6b6b587e904656c9dc68176cf531d28d8ef5b346bbe1dd6a58663f1c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('64687E9EEF749A75C825040D13A61A81','C52',1,1,'qp9v1/3eqInEfxd4rguDb32ZrfplxkoHhSCrI8MlBizMJhKZcpJVxqA4teMhyjE1YmNb2mgbq4RSR0ObL3pWkuD4ScKOKJjjiEsYFURv6Zf+P/NIOVIGnIEuT3b7WcbsN88MT4DPH64GaH0unxrzVDMUdBNri/544xXGUk0gXtH4+T8isOHHXL/h022al84IRaLXVP7tnkPdyNd1b8g15nbOfJtm8FRv7CH0aOyw8wCV6wBUPxjOCmUzysvDfINJu5nIc6dOJez2CvkMFqwI7kSimL8Ns+SZJMnzVCsHV+ppBvxzwvQhbaZWmBqioS4EGcHMNxDjOc6UizU24FZjt8md2Lc8ciLE8RK946puSqL4ZjGOZ5BDRP7J4itr/WpF3gWzThG2KAQLmuZxyIIpEKBpkINmg/p5YRGqlYRKLirGV6jsTZk1Wi2gWsyXrxpD/GWqu3M60ZnuA8Gc+i0RB1ZIlTCOi6xhmO5UKyXQ8HGMujWr+/thwSY9TyFNRJdVckv8zem1gQL86wPAPVQxNOIumu2C3Qmoz/bZ1S4a26LJ4tEJQGeIMExSLAf/7LFkPtAJEOvjOVtcAcBbyF7ZfscL906ttMzOJiQ+zE5Az3Thia3DzXnhuX3bTGZit74sTxsYqsHXBzR1PtDSV3+0Q+00P66XAnEZoHT7O9cvAuNM3ZzS5Md7J1CncfEFQonLc0o6C5lQCAHCMcq3RVXcEoscUfPF8jXt5fIxQTpjR4jY6jTGoSHAHfaWG8Fmm0YpGH9ss5My0kq5r5DfYii56dU01NaVEP8HH7V9GWGeYX+7W6RRNegYW5UCyKRc+szJwwWb67JpzLJKYrgMn6r2cWb3s7Ydv0b+eBIE1JM96zQ=',X'5669a0253eec03e45ede03ec9cf9c3ddfc7721c627628d5b7f8491f0c4b30a8a1e0803c111a9674939163276d26c9ca89dcd3ac7b41467733530720048cfeecb0c23667f7a5d39a4945f097eab67e51de356039eb4130d2863e7506a3c22a4e112f64210a22c965edeb4ee7c331a544b01f6de2aa9b97bdd1f32c0c4392700f4c4deda795cd5380f78014cda41fee3e99545e15b030fdaa8267353b06eae2f633e9e0f2adfdf6793af2806c2f94ed31c8ce2074667fdc71fe4f237661c97a4ec1c3b5e1c57794c14307c82b7580ebdf777c9c434bce0f7161083c0bf1ad32df57e85c8b82b27cb2370dfe8f15e566564a572c138c7d3cb06b2eb20ef5219ab98',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('54F60EB72467867368A646182D0FE1A9','C52',1,1,'X1i8LvJmW3CX2Vho18NBfagyIjc5jaOwLK0dDH6F4tpyIrzkL3JN+vd20J+Pijr366TFD5MKL9LkfUJm+eGOu3w9QSalUuVnK1QUZwo1Hvs0Bv/dmAWKnHPhygXRLqLev9qFtiEu1LZ6wnN/BFZnmxTO7CUm7dxbgUv6xHhTOm1/6u7jCcTAanCFixRFEEF2whiPcGHnYGoU/gj5ffW5Ax5lmUILJnkvEm6q4ipnGk1Q93067ao+LYDeR2yxz6aWLJbbhu/+EwMBCGv+rskaHjV8OLXwEUfXurahOoQGPfFOmBHLLu34W9i7btbhDOC41aI8lLxjdYyG5G2ktQsokOLkxSI9/JcShf44H7m/HDhAAIsavvQl4AlQsNnVPWddySS6pe2vgfqqvT3ukOZ22V9h193BnONNEU7j7lC5o9Au+g3xoNBKQ8fjuA55dVuQdTFvZ/4BczqPHJq+Ck4RIL/N7vA25cdAty4rUmUXLrc8b1JpxB86XiT2cJD+PgppRvrw8c7jx3puUhWNutmMq3oFU3/dzw/1e7OK+y6/s2Zgqkdairyutyc4v9VmxaUD+YI0GSUx+ZgefMH5/rrZGO99lv4oU+uPUygM0ExPQE7b0ppLs6k7xmvtuU4HUTNuegmIOB2X5iShv0LWWM6HZclzs/4Bg4T6hhnF9FBMhSsWLA3Cj0FvtWJywxr3ueurFK7LODtErQDlmEw1UkAqZJzdu2zkM8HYkCYuyzWxh5zMVgmfK2HPVU0NAVrcn0q5MAc/EqKtquye8c/rFAFJrpDVYj2/sfxiiRmzL4FOOYPu4akPE6XBBLI6tX1tyEej3GOeFclvtfQUGHNLjMVGrR1kxRnOpSyC+jKzhdzEbEo=',X'495c010d744e3edc36a63242307d8153de13afc0c78dd29432c9d1266a4930e3690a9ba3df5ca774d3f0636dd274e7a3050b401efa656d66300f5fec28f346a461c94c9c0526bb4d38f45e2319d7d5332e3cb4727b46642f906a256f0cf3ff29dee5d0f3fa1030250760263224bc26034754932b3b696b9ae63681a3767be0bba5e69add3cbd311ae2d2df18f1063148cdd511f051bad0c6ebfb1a7998f84c4818e807757d7452f6ac22cb514fc6478909be2904e3151ebede4807eac0f40b09113da5bbd02bdd1a58cd0bdfa6d3c3c559f42be3361d7cd03956125a9c8f96cac370a3665d9af64c1d6d4933af579ac4344fc84c19a4503cdcfbb14f35774311',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('456EE4EFB76CC5B74AD49DDA834A12BF','C52',1,1,'Liy67YujaTTT39PGBZXxj8xcQNKZgDX7Om9Hv8sEOEGqJKpI5ZnIrNuQMFEINF8sQLs2fDwIM6TFPAye++X6SOIjZL9+OGKp5U8JSAHpaaJq5Na6rCaaWDA3BZbKc0iYCM+fMh9fDWlCGxvY9UfEVWzH4oFrJTDnzMvCSmlTa0YufANZlzuNQSCykObftU/Ewzw0vU4m1qgISyyrQY3Smu5TTpDZAM+Xy8K9gRHEkqKTj1ikjeaLOvoRos/5uLv2urjoh8+0VOjIN1D7GjsdDjW2uCj+IbIkm5oEHOoS0EPysBulFIeZLGpKpEncjsrbJmCX72OjPZ2fhZEkvaWKHNFG126DpOgc8vTopZjSI6YqjNkmdfJlOUKOUcXoi/kgbdOZWItPA1Z2tgyGA5WZD9+QwfhFdACAFamLVF+7P4h52AG6PYz6ohD4YgjQdRC7E7gwTjbpO5NVSfPf4pHbEaXd9QAfrb5DC8p1Ne4ZNXQgwxpgpAf3QyunTkqWlwhhFtnqjARPlMr022xu285Jwn/Q7dTpMQFIHNfNPgmvPcQxcp9GLX15A+klvV3q0kp7H3JVAhMeLVuskJ9QO1mtxafzCoGCo8SjLecnxKlitJEP1Whdq/RZy70z1hl6xzokUojPTiyP319zOzXANGm6jdoKWGv8Eh/0jlf14bL7skLTSCEmIqg9+X04x+C2JxqKBT29VsYwz8l6Oao+0TmMl9dvwCfER+bWP1qCYjoUfNUcaEUVtwxJZaFm9iGmTwnRsAhMUiH6WPdDgXZrEgsISn04EG20fGCq0hEeFDjsIoI8RVgKNdrg0MsRDtnouaEjGfBMx2PHfAdIpJDM1LvOPamIWX2UeUH8qaaHH8zkxlg=',X'61485c2f68e8daf3f97b1dae499df4e7be7359c71f5eef51f987ff17af7ffacf1599be19fa2dcfc8794c193a408bbce528c1807d2b01cf673e457844130bc3d46d4068e3ad39f2c932b41231cbbe0630260da9baa7e8672f36292b3b60d6cdb2c797cec38a33023ea4eeb9c9737c957666a275cf05b310921a2711fcf270848ee88ead5d1316e299c238e312685e56a7a60e4713a3ff49219a614b69c0aea872d2f3b397c8a354a84abb56999526e338727e12ad58c35c487e5992015ae17acc3c38704aec371f8e3fa08b32849bd0848b44dfb4be46a5cdcafadfc4bc602ad5e2cb711086e15f7b2fbeeba3ca53169359b4f14faf7d89766db4e4f28c09369c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('DD15754D999087DE11227F0ECFAC9E53','C52',1,1,'3w7El8y20EEOLkoZKwfw4aYsTQEeo7mLXL+7uv24L1nkCXVMu2p/rcEdjB7M9Y1DBw1X5l2yDfCFJf0rpEzI+5cEZI4khR76lM99QFzWoA5khPj2C6nYD4UMsu3Ew21CDkpv7PeKsy0Fnp5Z2kGmAzcXiO8OuU0xfJQN1SdhVz9Hw7mXM4lcz/4GJFQgcI0BbKsjxMUfORkPAZRQG1qTuePXqWaYYgDiZM0YWG6bp//CmbktOTp/39uzy/o9JMk/CfL2rBEd3CWDxwuBi0Z9HqRAI2nCzDp79priczVrVgo1uvHabrvI7HiM2uKJrr+m7uscatv9v7QJQ4iFAeNBH2xpA/ZczZIrWC7gvL+G41aEpX59iU5DO5xte/1lwOYp5K+rDj2jdEWh9pecxqzfuAiB5XTyqdVr6QTrOFE4jxlUsJEUSa5BqKsyrHelmqXN+0iCPNn47oszPCz8/3DKLDq9fMJMklL7MLF0iYhYCy94T40bc1RvtVIdVyZUUbHTA36EPnd2PF0UID4yEhQ+TJ7dL0WhQo1nj3Afk3e6OukNcKCvqsEjWfWwhtmrQIxHWIb9NN60vfnhJKxqlmiaxueZPmpNwZHM5rGjJBx9kbehKKZ4O0whJeLXP7X85B9712FDjgHVf0aMxD5ZoBtn0ZwypyQktIAqaTx3KFgfy3cMJo8tBl1FO4AHtxvPJbX2p+KyFHdoU2Rg66ZDMWXvAQqyOmUtJtRaZqbSL/vQorCwAoXkLYHt5Ad8O9tJ2xGBForrNDiyAUsAwmSxHEQU6CeyRKTHZ+HZZILu5xQljZa+krmDPylBTano3zJeL7CAvjcBrwr5c2/GGyShc4SY6rQ0TA2GST8kgiyUDTRikRKEXOWzABTqaQ7PRdGDn4gIZY92vqw8TsefrymWKdlM6Chk1nJcYgGLMSGw+5iibC7uS1ghzVNV/OKI+HRWPQuuexGQS3wt7YentYcr6PWhcLKnvW9QpVFmwYOa5N15E1T+I+QrOoWWHSgBAxsxBZVDoKMbnNJ19X5WYR1vIXZC4x2IIo2g5YEwnc694PCEOZgRIQCEjWEABBveDQQdcrxa2lLcMY6KXElULHDo1i/d1MkqRObq6oYkaPwDHq3IuYFS9dlxvAp0YzQz4CWOIdBcZZ5vaF/0YQjlmR3F7PRE/c3Y3LYYPn6haHszgTdBLWBJhU6WrwGUORNecd5S3xxad4g2alrfM5XjXkSC/qVtHv/9z+USpPtMqNbGAVdoBLGJnaumI1jyK6BofOxnbfkpiZIKB8WrnA9ds+Ch9+Xp+3y1XjuwNyQsmZ+zNCxUmHS7jkqSyWoXK8A6nbGfYRO1Br+9zIm3jCz5vr3yEGUP7HPrT3etaQrfy/b+8vmeRwINQXauhB3CxAjI15MsmJf4vzJ8AmQK95Nv+k2rHnwvtjBN9tloRchYeKbTPXyV5GFz4ixXlt7XsuXsAMmkLBnjUw6yt/HYNlHUNRPzcGSO2g==',X'6e66b907c28935ec0682096ca9fcad087e2730736867719dea0a33fd414497b7ea00493ed51e16786914bda17c1ff4ef75ba2145db1e63cf4ce9723176e5fdd74580a8011975a50475d06830d4244f1335c92e0fbde6e07ee58abc34aecbc7da4d0cb5fe62d4b60c3850be07fb1214634458cac5ab2b99ccf76f582b5492bd550d7d332fda430976451aa3024027c063ccdb2d28211205bee4d152fe67fe811927e241f838fbb9fd12add0d441f065679071af4546610b4a0a4a87c7181e41d4cc0120f73d3b96a158db4bade7500f4eba9bc8539c23c0802ff3d6d4ebc10c8c1f434a19b58e87136a964ad2d4e4c2f2d2eb0f0974f6eecef87ea9811e485fce',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('E12EEA4FFD73AEE5F4D2D371821F99F9','C52',1,1,'7DBZiRDwBwzHXgLhKw01pQbi4BXKMP8qUSgnBxYSLeFbTIlKaQ/w8glsszNctukg82YY6vr+hbf/+PAG0JnaFFYEyggncr0i4kQmv3I/VmEuAAPBeoqDGbyd/glMQ/1Wz0pLm0J2ee+PVJCE1j+g2+E6FgOokioc+SiveNfTfVNUYn8+ZIXoIrfkX6/ECLF3T/ZDcY/5DEX6R3KPwas5DA8MxUYbdINmkyQXWSAJu2ERrdqSgFlbr3Lcb84sEqr250bw1xklFnfsRRyyn2RCTAnstgCwcCo4NZ8B34fL6IH1R3IeDoCgQ02Zt2uLsMbjKd2ocHxedtXmDcuJhalHL96X2oAtO7f1l2KDPgCnDriBJiZn4Ma784pVTfmunaVv/YHT93c/w9VAN57G5tGiRwEy+FxdFlcHFSg/UP1gR3uIE7CYk4aOjm2CM4runyC2QZrJU1pj1Y6Hb6Cc8o0UghBwXkSpwktWLTGjTJgcpMWDbbUQqMbBl+Q2CTUmL0Bz/MMzb05hOZf4IK1nT0oPShHeDPGo8KL+r6wfeUmUOdUVdhQqiTWf1c3xLViM2fH3fapo8j26wlEfIoBtFIU4ycJZLPQlSxD+9Iqja5e1ZHbyH+gmaEt+hQ7lSybumHrLlpE9Uq1u9esId2XuL+UZ16dKYMB2307/XcLLMLn0xv90Tod1W4PQ5TutcTye86c7pA6n2K0kFe4MFxezwp6BnI16BMe1QOnX/d2yvWOYBQTNYQgaYdcDJJUGhQSRBU08BzA91Ix/Mgav8/3kd8rEtAZRGUyveT8OKwQ+ByiboEdvSBwfOeoqAeSP5fUfJKwI99xSjJuVaVjQvhivw5GpY+qjSCTu7bRa0+6aYPd5K6PiO7eOoohIZgo7FE2NuPpedp5xfBH8Ir9D/xqh5b7OVQef7Imc320gTIK7fKSQD0YT86IR36fRWZ/l/pUfM1nw881LuWIEhImErdndwvlZEbHWRPfqYGm9B+56T2sai6qvce5Ba6sPjvTvtxkHcrL4lFt4YRvVODVyyNMEIjLCyAAIkDfaCDwROCPGK8Nlj5k9dwteoMDQBsCwRZsr6fwF1/ZDbTsjTiGTNm3wwyHysWU1tnWXm1MA12113r7bCeg/VI5qMAnGCQaUwfBUsRO82UXGrx0lg5g+3GV0e322siUX6BJTBJI7iHPsJ9zEiZOo+MKKRRXV3CkKva7oaf1hIXkSuvCf0eoA9NUcfDryI3uIZowriesFZC5xUiFqkNZiup2IYU7CxI5opQK8rmmwZfxecKK8+EbqnfDnazAsvVK2n9JboOZ1WKWxQEDAQ9PWIDCUPkT3hb8v6fC3pgJr9/lQsTM6x1lWmY33JjuJPET89jiK0h/bqqSuQtqk3ovK1luIDVhH8RGBMCao4eIdjk2VHH7mPErs0415aOS5M/jEmYEnCjc8BpDgn/bjA1Cy808TP/pwVBNJ3ByPfSz3hwRjtyjOgCQueTPC20XGaQ==',X'0f3ec5accd2b185e149012aa8a2a84d9c2642cf22053f4f0e8ab857c08955bf3d2e909f41224a0b49df4100dce09787053f52f6c1a1b091d4cd118bbb5475c256df9f7d709abc2a28688a2c47568d26422b6e6d51eea321c5ede8748343ebf53f3d3368f4232f0a95e7c8a50211c4d87593461c42a8271026d6e896545cd47910e633d9e0b684dbe4e436f7a580b9f1927e1e73e3893e06d76c4425db9660506a59f7e90903603e5ab863a962e20762c76b40d5eab5ce456e7a1721328b9c6d276ec1cd0a010888d02da716241c85a143326759ef19b800b5c097ad5532db4e73be001664f3538412895828de34b0906c7ae139b39293a9713da04df82de182c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('D4AF6513CEAA1C61BE159E7EB95D5798','C52',1,1,'ti7UdoGvl8W8NEqjTQI16O+u1C1llucxyTxRyHSbTJTDj5EYI7bj/Dzt701Q97t3pSM8iUEew284davWj3aKiIdLDxQrb+lKUlgJKgnCC7v3gf0q0gVqL3XQ4rzyNuPzPt3cMi6F0Zmve7L/c5BZuQPNQRziml+eptPQHc1U1U39yKabon20MII1mHePGDRDiC4sXmFAOu0BH0C7AuiiJDrei60z+trKqiXzN9IjAHXNypkV0mTdmBTHBkQlrHX3xnnrRsaZcwrdnni1HeV3Per7dIO25FrLvg3UNA1OQIVlmd6ryXj5KHXbmf0UeKOd4PVaMr/HRb5K6pB1tZ168iDbc2+EaevKhOXw7VeGUXEe1AqSEWIqc/nQiLCD8jrw768RyBJdV0NEyeQyjHFOF+CkJH90NpZFDxhuqFGpNH1XDMf+or2oTc2kaQvlVVNAAJO+0aRknX/ksLSRrEKzdkg+w6amlTLZvMp+ts/4P7F06Eo1SvQ2fl0eKbaeo4gTqcOxqGVKZOO4r4vGgXIkFubJJdyvET2RZidXDACBk6+AvcrZto8/P/zUT1nyGMKJCwjV5dIdIbVd19mTzHI2KJkScP05LVUumWcKW49qjJyBx4UY3xVCugRtcvfZ0nqslXtOjs4ZpRl6Rq6CsWeFZ2T7IS9hwA9I+xSjakKWpikBggP/bxeKBW6djC9Ok5XhS1iA17tmlpxc+N1iyUxUUDK5SdfKUlkEcxh2yGGXYIYUCp1Pr5i9yR668SoS1zJZfdCJm528r4gyLbrD6YtwtyzkXlwtgf0kAQVNzyK0cDahhB6D4viyNfg5qdPbDOSNZMbN4IBc4TXVpr0BT68gUqLxCP8e2bk1v+zvrswrbkTlsXYiVZEkSsDal+YH5hHn/LA/FCOcGNvTW42fr2+RtQcTpVeBpJ+fho6r33MoBHz0c++/rVyO6H5EYEivmU91yw9i53T6CG3er9qMw2jzUUk5VIcy0QuFjSCTB3nNzjam+s1uvvYcqh4isECGb8T4Sarly8Y7ydHz35qTs0iLMIGsUNNasc2t6iMsAFH16ZIxJAWdHiyuH55GmyK9fbrcryz7RhVY9snoNHWmZpH/EE4a2YFktPVn9f8gzWGstKO5Uv9FjAhkr4Pj4TuPhqFU5d2nd3FvYEisR01LSnpQoofmYa8uuihRTrIGXwC9+wac4kzaM+aq4m0gvK8AFHSCKmtlL6HiBu0sIHc9qLlE3cHaaRsfVMBdskNvwT9vKpz2169u7W8IxpJ39W1vQrXxh8kSDTdUCy0hpqCY+HZsOegLQekwCbwgSbcvOzKDX2evF5CP9Ej+T/1Qa76KhYySHci4g4AE0/98tLPCIqOY4C2PVboWFKgq5grQpUN/p7CcgcsmsBHoLmSIDNG9rIb9aLA41Oky+RgilxY4Y0R80nFrDaAJgNLu4oSBsB4tYeQBFCyLjS2X4yx3DlZ95wz30xtQAv30+52ogCMVSBJKew==',X'72b172b57108bb13afec70a02b5cdb7f90fb7b74e64f94cbc14f55a6e2ec7db56a5b54c66a6aa0c2fcacdcda689d880c27de789b78a85b191bba097ccf17624e81c48ad1dcb83c6b2831153a7fe5b692ccd637e1ef29c88b6b0c747de611355b0f50ad1f8fd1027cfdfc96125eefea3c333ef0d7e966d6c73c2884b0972b0988aa2a71150761d19365cfb66cb2d3e7a2048baecea35346263de2021cf7adb5aa9d81d22e4fb4eb17ecb95d2e093689e32dd974df91d30467947418b2186cbf7f5e575e64ae87f9836e70cbaf7d862d5c55e5421b4b6600ae77ed7a3cd2ee365266c256263b20d0ef5a8da3eb41bbd18e2e6227cf01dbc13a380021b2245be71e',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('88039702B99B98A548973EE31CD3054D','C52',1,1,'q0Z4lgqjaxhgjH3tifcCD0A3aT+rBIVzGpg+Cogm3hNOmcGqCoFJTOfm5OkUl1dOUmTJEvM+gbzBXP+5hKZL4d/Aif3SjKKQneGxcnPJeMo5/Y/7gm4u1Qj+P+nFt7DgOebd45rnMpNvM8KHnthxpk4+AiIsbHf+6DuTYCYJDDwoju9w5CAJypBoloLJh23lSY4Rav3aOzS+6ySVuGxb9deW/C/FjS3QRfQzeMLKsUs1ikRuEz4vtBj7s0LXOAY4jAaEALn2u593Bs6uL+wWsTzInDYHbBaNoCvLiAFdP1TSSEPCOqU9hviYcoYmSA9iuTQ14KJ9zbowEgciDudD2iDC2laiSAqSwJCybIZ2sqsaBVdpZzWFTyMmxpk6qrq6utpvD6zcMmVxij7P9Mkyy5g4OGDsRn+agaYskFjMyeOOLcnVnXvqhy5+M41jkS0M/VKaSyWO/g4Rg1V1M8LQBoSwWaSq6A3nRcQAEy7o5wYLGMFkQG7lzhS0/qXn2/dxYx8EVAECd9Rz2BoOn82MmTO2aZBkJBPTvu5hp3kwnCZrIatUhE/P6qiF7B5IWlkq2zXrBUdJn6MtdY7uBf0N5zwS9sxN5TQuvpg4B6edwRKlkT6ZlltMDO05y1jkkY3fEmC/ll/TtWlBbcFEH+1gggXpmbiRXABHEfxJEsdMBSWuVcSDb37PUdY6UfXxFDhNSbg8Y2nLSlRg3dJLfjZtb7Q0Y4g8mXWxTPU7UZyCb/DLXb+lgZjW6mTqUk4uo/m6HwICLgeh42najBoM73msE0Y/Lw3DZ7Tgc7Q6BQPFjz+inQGfWh+JZUmbYgG2lnbsqgOaRqWyub7PKaoPFVJ6135pIELiEi+6R1dJ7YKJ2Tpx8kj0k1li/32GhjwuyFTdtk6RyI8zVEmVQrLpp5pZVYtrNx9zEgmmU8qEMLemrgKjEho5/dtOKkJ6nIriwg4TMSVA53ZAPuo1BozXK8yJY9x5lrorNHAA0UnKWCARFBbp7i+yMFrqWiW794v7jzr1Q/t6gyJl1L1CmigB1LGeykWvkWUgGzXexfX7EpMnk7XVx6136CMAoCSDQzdTbM8aHpJpEfmNJH+i86uEfcUYsXZ+tV/F5yCBTW6cEOV6E6AGVbefC5oKGu/Y/AJmFOK7fPsreDyrJuUW4qRbKrocwQF71WAqH/DxTx3B6sdk2fzQeBmlgZv5AfgRHMSZmqmt4uiYigVV1OZA6tDNkkVkEgxB+A46MpvcIGGXGF+SsgrnXcULpL9Ao7fQjzMcvET8KftSoOMn3PIUUUfEB8ynh6czwpabizytRsk8m8Opv7KPgXhhXwROvFqkefIo3jEWJLy/EO/3FYB+OPaaxq2sDgd6a7QKlKxKSOajCXy1vPiXOdJ3Ol+cs5jDCsHG38wJHS+6TvF8hYQciZpBP9IDVFcOD++TJmfSLqR1IVRO3hAXtBcfwPYHuFHDVKULVDxYdlXMCAk8mKJoukDUOWjWxQ==',X'07b9fb8e04af93dd5552fd5ca152d7e1dc0435373e9f9f9cf24bcfcba8ca14d84b800c69fc4eb6a86722ac975b0cd8e303cd28e8fccb7e04aafd7d2718237abd78b9655bc7c7829998979c295748994e0cee8e6fe106de80aa280c80726c0a5e1e4a9698ed471e3e4cbbb98a067033fcbdc942b40c4d0b1b5651e11073bd422a9352c8aa7c28ebea8c26d54362b00cf7089f3f2ca28aa10fc83194c9eca478a953173460c44216decb59b9bd02f81990ebd3be3b475789c6f798894da584b8c9fb5ed2ca56a47f8f8e59d0b49463f4f2877d93aebb8a253a51037d5b3fae421f0db3aa5ca10e4b74ac7ff1e8fa7653f5e46ad3d04ab02771821cc37c58aa9252',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('9F9C936C72230C787CDA15FAAC270E9B','C52',1,1,'alfzL7iY9xdKB1ceIMMXq0d+ZVYK54YX6wdUTgoGWAfGpKZRnAvR+n2juKKVWsvkJYAkZ9uCQ1NpQm+i5HA8u7HnjLWyhY5wIu1Fy+YyvTshOG0p5CKM0JFkzLLzGj0SQ6/rApt5yvoLr4P8hLWJ1LMCPir5ySXt4Qo3Vb+4YPd/UuqY1N8otzX2Wy8QxtQmOW+D/6iPhb17/6RTaJfoW6lJ2y6dP+WZx/y73fOnaiCoWi8GPtlX0hHBUw0VLvtLu1MhG/QNkTnUwOpDhmr9PZK6D9QwzdBYPN+KGbEgtVOjYCBMgj34NSJzRyZQGG35Wd5dO+I/aKRXs2qynLIApjF/sXqAdHqqU64Vq2h8QXoUcA7OxNpc3JJZQDPab/2Y1vCBXfdRA9UHKb9+6jk2Mcfndgw5ERZ0tD86MhjHR4yk0p5Xq8ErhpPbSlAvAmVj+mS3ugf6XIan1eUcSfTLIbSPBDsu68LgnQfrQj/4NeMNHTOXbVYkMxLY6r2YiMcUh8B2c8iZVEuXNPIcYQbQnLRBapMIl96AL57rf+Q9n8AOBV6E1EzBeovA6MTYAS5AzSqxBD7zIV/g9u21rBtuGKKJRZkuHzWXIcBitKlApRmmTvqh5rFPDccl1paCE57SuoLbesgzr7VpbOEWK7tve/fUf2MwUiOzjIEWrZSEQXTfJtjQAmF6OkU09m2CaRx3TlaIs+30IpYM84+j+eeHxVV4gdJUG0J7WG5kBTgaCdYNoYcjcTecdf8SW+NdGovu3itf5ZKPGdpkgUlbS8HE/JsaZYtAkHqazzU3OYRdLv0qRh2arDRNu5NE89uBiYpYTfH6ipD/h7Ptywd9NfqAsZ5LpsFd9CJDncUGmmitIsy+SWsxC+mGpInLCmaahY/NMDINxiQ/V4B8qh/NyEsPHMvbb/mxr/XJMBx1zXOkP+EUd99Y0mFOX1/XNR+cUgF8+C5x6JWHQUJU1eim+5L8MV3kX04uAZAZR1J+X8XfsdQCzrN/cG5dvFDNv3/s5cnopPeIRHIIUBihks4eZ2let57ISwXodl4jzwDxr7qk1FKrjVINVHmanN9Om72NCdYQoq908BM2wgu7M1pBjqJKDXmEUeVHOejXvBK7CZ8CwDpS4aFh4lKBj4MtdzVZs2XX0g7SMfUqWEKs0JwN9Q4UbH/e4Kr9oHbRRdQcx/WvhZ25PX6qjRc8Y69S07F2fZmA397uyyf0PA1yZ/pV1obFrlB1Xk9mXVrbFeUq7rYbEUhlfGF0UUTTTgJw0OMVSOiac1u1ues+TyBYziJvwhOCrQos8FLPSxralxvoQHNOugQw31MWBdl78CugtjAj2VV4x4tpSXyVAz6ILJOAVsjx61cjf8RGnUC2yEQXrXPzHDUX+9Ex1e46AAb+aPmxC04yLEmiOjMsn1Qy4Um3gszciuk1FBs29Hfd8AZCOJKkg9ftY0vjJ4xZRDv2uOT6fN3i4TSlLEbsMRmTm7DpMID69k4z88JVHseDOQuriUJV9zbH871EdyL6IszMar2siiMuH4oFvLQp2tsKTBuBa+kUlMZn1+iNzkMWSoNPyk1kJY7cuySThWSsg5yBu3odznBNoliFNvfVBdh99S7Jio13oJzhSrQ153K+dXS3CIdHJmk=',X'93bf78c909eb118d5c89d5790bf7d021a251f7afedddfb384ec61edd0eee2cdf60c2511b11eed6ced1e4348ddfe21c55dec1305e651170e4158c6b8f67a5303568c8595b5181ed306c173ae2ba6a589d71257f6381af68af4ef4e348c1a384391da5ed3a838ad0c7e5bea0e001ab47b69d8deb2eeaae96fc397b571d8a3f0443bf4665b69c1e69c8ac314df9cf8148ac08eb0cd14856b0d03b34c49c168b008dd5f99cdc5b8f9d1f6f2f82556dc8d9905f909ce1c2553b70705a9cacbca6c259e307c8a0047fb63a9358ee4aa0f0ea7ae9dff1ff99dfb7511e5fbfcbeabde0ea845361cf5fe59a17c24b656b27a2ce08dcce16928ab3a4e40d302f354508e8eb',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('DA4D111ACA589C697AC9914BF8B04FAF','C52',1,1,'9sniFixjoope2b4MemA80A2JCDUi8XS44ek7J4MJ34UcM65oajBrjGwLFcZ8FEi4kIGLm0NJHdTG63V2esQshEi/UhCNLhCEyfF36FYAVgFnfTOwmBKkMmYVHiFKdikdUFzor6OJI0z+7GLF8rwxEDYzZK4SaRKr8VexqcA3x2d0WOmF3yvJGOqOhkb45zy91u3fzAmnX8OMSzl3GsaOrL7MpvrizpkGHllSJA3gm4XhDR4+xyqgRpBUDG+SmRKgtreqYWByrCL4e9hDLjW0bAvBIZQMAf6wVzQE1rElEbXmwtA2eRS0FIS/xUO7B8Z4l62VcJfH6NKpPmnEI+YuHwVLl+PjiocHngbJqnAAdyw9BbzYdKMkno7Rcm5LDQbXtQ39+Iy4V7LaD4SKLGQVuN3y7OSGvuBvtF3AHR2pREmlzeYq+1mX+O7wJIROBRJA0pCeYSJrWpU4z8de6IggQyX8+FeVu83bN82d57YHJiI6z0CTp5rpcspK4tF8EAM0MUbh9wj1g/AOeCaTJ9yglk0775bFzPKBQYx6R4XFCu00SdHplGvtlkClyEspYkqzRCYWxq/R5UQ561FKUfDV1qrSkilJBB3gNp0x2M69m5YMgt+y2IiYUsZt3soOvUxgiu01v8cdwZcLdjQOlvty1SmFEgnAYzA20TdRbgLhe+ySFTKmksqcBcJWt/wUfUYHEQ4a4o+mfLoX2+nGjmAx4YBjRkpiOXE580HzzogJfU+XhnnwBwtfb3XH90A2+y8yLsL83I6rCo0qJJHpv3A6uNxqN2dzr7D9CTwZY9Wc0BLM/rMpEb/mq3Igw6+7zA1Dg70MBFoJBwshdZS3KF9wRoFKMBXUNZgZRlqSXBKUbBlXeimaa9f4oI4QOwCpdrpw7wb5ok23GNtTYD2R+qWirrD99zuoDJJn1rd/7L46XgBus1+GRscj4AES+TRDEVByWTTW+/yOLME3dSNbEUK0jt6Hc27oIJt6GKPODs/q/Ww7El5+m7+AIBXAIXRa1o2+j+zDHDKYp8hf00gWJG29vEgHsAtfpcYQl0ePZFffgy9Kg7i2DtukI6hRC6jXCPfZIUfEGXOdaNglHmPqGQ+29cKPaFEYkQpIqAWX9rsVP+vnApu+jwQA5hHmVWtWObhm5pRCAGcp6zfxz24Ylfk3JoTqMJR6+6YuNVe/6IwrpG2bSvJszQ9r1oQujwZw+wUd7UZ1Zqxfdczt+G32k1oHD9TJis6cgY3Eaa101w5yk8HcepypugxsbPYO4abBrWjwn0fcaPXH/Fr/3lRJ1vzxJ0tg8CRdqrQoCUB9gwdi5oQkdlm3WW81knHaQaMANapk4JNUImc4b5uuaL6RfkHdOhJSuBIlMkathlrhtpaCrkbuLeDc/hoO/XxtHa3unxU/A+vodMPamOE71kkjlF0TyFiYBSZGYGYK8gXpwqxvjv4DVA5YuO2Wfi8Wgv3pda7hcRzKcRenFFqyaSKnpgJW2pkTZ8WKyFV+CxbCFnhcgfeBGN9yVgpyZ4SBX5PDnkJ/pHqHgajOWIiveCTiIC22DcDKn8Vw6g4Cjh5K1O3UJCh+/dooDJxiBWJu/MFWo6NL+drAImM9O/s1889StE/j84cnJ5j+OPPpkxqohgDEzN8=',X'1dfe3055918ac0b98541128757dee76a4d4ba62e6af1414db056a78a3fe905054e260ab332697be218af0745b87884890c87874f5d1814e7cc81bce52759e3675ea91762c388c48e44c2292b3a0dabf217016537a13b172d6747ac01d6cdc82d47c3df4ba4162124803355129a6271c94e6c7df4aba94e220262ba2609fc87d8c144e0188117ec5f2052651da049fe55bc00f36790b6c90ec1f0595d59bea4c93d8633a6063ec2d4e5c4ecc9c99eec724974bbb262d1eb8b12d159ac72353ce211f66df67382bf20a4434bd7676a4069454ce27ca92b8e43ee896167e86a294b6389e1a1d2387a92cceb09a706a64f4ce774f34eaacc306da0d88bddce03ae71',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('967DEC80124FF4A12E19A5EDF363955C','C52',1,1,'D/a0e1SQAazMdiZCdslGwKUAlOqjxhnEtCX0iep0ku6Mn5HSr5Gr9aTY1MAQCtfofSV79gN4yDZHYnN1mcHcvEezP+E7ZU8xCIOLlGmeCfQmXJdcvM7pHubBjCDahSUh3fubrDbfjaO8Hapucr7DDKlQ4nsnC4/iovKmKnvv/nb2act9E/aPaDfK9CMD+ZX/aYhSeAULHs/gPgsOi4AaasA9njSA9VRgRSXF+IUHEAGQuXi3fweZdR3+YFEG1QFzwgNjT/daH2giVo/hDf9Q3LFI4NcRYlwod5J2W7W9XnmiNdimr8q9xjb6DHYCTdGvJC2a3sUc7lDal5ldUJ6SuuFJLC4/stL5kdA+YYuLX0RMXv9AOeceq+NxzLlZHa4Av00yz/eEGoUppfuWSYu4CrLIY+UidQoEhgAJHZzyVuw5ABS3JdzHGmoj9jSlhelr945JNHrKWXHfP/Z2XmQ7vFVVhvw++7tULXnoFBWVMJhz4qFAA5MOlpRALQNR/RNRQSESv08JX6Vhsrd+6zFDNumTn3lci02Uj60dlCo1VA0IPEppExJ+zNUQFDbvT1srJ2aRnhhpI2jJgo9bSxxnt4O3VaSb0YArf1RWySJh/5cJ/Yoq82xA1MECCFJF+uaMgP1FGU8gxpQFnjZ+Zi1mTdTpDepGea4VjkJnwbSKwbQUM8WIBkFSftohWyfY2OzQ07rNw9A+Bl1NPwunS0qFfN/gtMscqS+FCDFxoAgIfzEnxvbEO7BUpjQQ1wCsffvhBF/7X0nWxdY+UpsxhbxXNqvlXaXdLl36uvnM0KfAeuMhFu8vaCrSprnWUSYVQgmQ4DoAMrLI+eyPsHoMn0i6saTOxZJHUGg2pdWT9m/a5oaVBDQZC9uco3ftFJ+yG5KwQMB2QVJ4YNPvY7bXR7TttTl83nAHsmyoE3x780NwIme2oWtm489FMkU1KCp9ojaw6vcnRY5NUyTAuu6/fapDi42jvckoIEB6+dVGbCFW5JBcYQYPOfe46QsVs5/9i5J7gZHe1Gv2SvjX1qvSCf8KVcDd1vTSyFO6+HmPVc0sPzgpLpW0hELMWMgOjdfHLUL14cbrg/7tXXJSjn2NvRqa28DWqBgWbIP6P5cplcRFHgOLrTEnkldXwLIYVDA1XnbSowlt+g2QI6k1mF9dOCjGZEOCAU2v9M3rV6wMgshYibnXJG2ZOFRdAZss1vtr6UTc7L+AwwQUXsR3G571aRVnknSTG0UP5UDLKp2u3nA6ciShHIfHqqwu385+UhZQokRKXBxgR5R29hJaBLsdpeKal/HGs7oqLLROI9eDlqC3hP/dJ1qQmvp7bb1EJRohlUBMQZhTy3vOg+TbUwMJS607Qf2pa4Z/ux7+5Szle69GpcPc+tOFeYs7hUlOJeKXfbKeiVki7X0n1n6F5BLr9xgKP1PLxgMwEVGSf8zAbs+w3IvbU4huBT58/IGj75pPp8zsZmNaEX0YkULJmQY4CNU3T9Z+fAaP3nSjSTOX/pG8V4Z9WEMMCTXk1+DD3TImZtEhs55H6QCRZ8qQReLCG4ePdvPm/S7VWtOxX0iSqCA76iZci8TOkNXLowa4I1ErMnTGJTzm+JbftmQ1MEMYVfYt8ycdty+j5a7yhbgA2vG6k6A=',X'4b67871f77e6041f8fe6f2ebe3eda4af11b63c997182202f75bd11ed1bd52817cf620f51c4eab9a4c06c0b18ec759dca482dc3dcf08fb3891f737f903246602f09c5a4ed15522b218dce2a61b15708f71a6199aa92a9bfe21ddb6b031cbcdc38871a2f8b353dbcb4c9e02d3f69fada4d33f337cf0c303a88ed5e2db23ce321e749727aaff25bd1a30c6c4b2df5caa0693721b619f3ad3132dd0aa4597765ae2ce4b1d297eb1c0011fdce6fcb19ef13375aec2bb1f7e6b83dc6da6770c9b32b226eee73684ef26645753d9ab005e96394290e05f2e9bb6b27df1671e4b5f1cdfd16b939f65494214c9efd6e1d77b42e2d97e7abe1d96b54f8ded8d97e8bd5cc59',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('337D5A9403B79B1FA548D8BE0646E7CE','C52',1,1,'O4xgg42QITyRvA5uq0KlrMeyT84f2z8xoxwt2g81j9KhVXw53zjr1DFxkO7Hc6BO6uSAGQoTac2i5UHJwzXPp9t9foLoA9Um98Pq9ai0GOnMiQ6gYUopXAod+sJsNxM6vPIqqRwvbGTi60Q7df9b4O2/kJTG5kH/HxSXtW05CcyecvNud0hTkADUHhtKNrRTazsWFMGkfAffTfAlIKN2bg1g1U0kY9X2sOErX16nwFGIm1BE28Td/Oto8ad6o2xNy4Vd/ZOk1k7cTmoos/Yt9aVbwH8QtSynY/5y4052awqKGXi3NNhuQd/Smb2PVebzBxm9zBj6JKLpXeAGKtZjAxjn+dzjje5uNFG+QpRb+8dnmGn9f/gaGAKTQKF4k9yQUHPuXEA7eQIU3o1dI6O260FCHQtedhHmYzlxJoS5DB92m41aG4oMyr4KqNyLClAW2jgcekKcZYoH2lD7jcw5k6daCGcXh+Bqbql41J+lYtRoZLA/gHh4HiDkAlKTeCAGUo2arUAJS633XYYEmEyeuBF6w0t+e66scUOyd+sUj+b6iup2YmXAN3jG1jJxX+f9XmehppilbnFB2Pl92Aqp6uspSiHP1w8VdPZ00x1nCVvtijtd/J5NkPMCpOwFGDP4CEOKzGBGlP3rLQEOoM5JVwzwjRAf/VPT8YXSKcReTbDDyd208HzD6huPfIEOEAKTarHkg9vx3xA8zHHvnAJ2gM6NesCdh5awxF2T8zD0PBoyna/LbMOEAaW3xqFYXeOSC3SaAMM/F444h64xZrZ7L9cUGZUnGfRwjnqIdSO1gFnMrkAlcGTH9iDiYejPjPpYDYm1rgQz5NOGirVveFckQ8P6dT4ePMkLmsflCmKTPnZX5tT0CFNbomv2y0ktituBoBWtLNEnsgbecjV/kwNiX73TxDT4yTmEdhLaa/P8vjcogO6CHbwnOlzAunX6upSE8ywcFNXP5rdtyqBwL5FSRQu4xvhdIdoJvsWOqUueHwPgBs1ZTlUeOl7OsMCCX6n2tHgb+wlxXn8VS/fZxUMTgnKkzXghNjjSskBp9Uoz3YDJfHTYFAchB9RBkYzy8yRUZi1SI7DG/OKyZq0dQWG52eoLsvWic4whGoC/2KgV8mP20XbiwOD8ToMcc9NFp4JcuAFCldN1+XliKrw/Hp4DFqoMl9XpjUw+OLBZA8pjzkVCV7XYoLsE9jkbiU8TXLX0KjqGhvLVvI9IoJD0Dih+XWcnkCm/uYlk/ZToKzpvPgANDvtgyHWLdgnPbheZplZ0ArxRqylCnWlh13/Q+pM40iKIN7CfVoR+mnLc/wuxXIhQa5b9VsGwAwdNqvkRdkLzwbKnt5PTO3fXmgAIzg9Kb7r2W1SOEFiWDtjTvS+0i1le0S9EfX7VN6dCSPl1O4qqzLQJAAE/DXMGgNGYrLfiPePadLFDfobYRlVcZXpEHeM/sxzU3XNQgZ9/CFvbr63NbtkRbTHrQrT2c2HtvUSnMwXrdDiKE0Fw1spgSUFaKqt20v8yow3oY4K1fbIcaZZKflpQeAaN/aWBRwMHykIcWHvKPFQoN+TO9Ny8UDkWKu+RMizjuRNTRvunVbOocxLJ1KcHHlVm9y8KJpsPfuqL36gqQ8ix2BpacuD1s31dN7c=',X'4a12807439e461e6b902d141b3bdb954d9bd536e2f299cd58ca4584395f5847bceb67bfc300bd00c82058056705ca08db4e4fe8a7feac5cdb64c34c03475503e2f49672022a39045a6a1ba6ba8a29aad1f230c0523869e3a46d3950a6fac5d2fee5fa58d4fbc35121a45aa3aae33de75e0a6990b1b54cb7719b24242c98d66f56d8309e24177bdfc7740de22967c93574edc1c4f3efb2668156ef513e2937c3bf27ceffc4523e42994b0c2662d0813ddbd488f28f25abd9969c69f7e4df45618e3da532ce07dd962f20cfbb9b0de75759014b3b7be531953f59e8abb19f2e7dd4a24cccf41a4920ed681b0c4142a5ac680aa173743826652c0549f8e3353c2f9',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0CA0FA2EC9FEB912A35E8DD40A6067CB','C52',1,1,'sZlgE5KXVxkG5eNZtyE//ia0lJ/grZpIEZBa6K46HZGE0qjhla59dLIgg23k2rynpb4mJ37VS8d+y4NW0POIW+DCAH4hKykL7QgrS2YKSNbTm8WIayfSRmS7ny0wAJdBOZ7Pdj8xLkNSJzfeooNsyxU6154hTDsIpu2wLkGEfOmvO0l21a57Vi3KNwKUBEterejLo5EANRJIJg9DXUotDjDPA+UVWPdJOPXas65BLO/licloBaauoxYI1nQ14DAORayQujBBxdJBPx35FlWtPtfHEl0NY/9OrKN2CjGX/YWREk5x/eLZ7sfI866ug/+5rkz4SDxitnu9gQMxc1iITRv95g8UmXFnOdb+E8WFmaY0ssWZw5DFMgXAhRNyLbSZuAr+i+gy862o7OfUJ74cTvvUpXl+2IFF0DcQq2LG/w0SauWhZPx0qJ4zyAbEeAcn39AOTYn7r8hFG0jYioYFqcTCQOM/Dic8kjMqWmuObKYifycFPB7+gA4dznHP/9IjJ6PtQXUerQPmlwEALLmU+PVeYaV4T3Ho8JcSQ4c2Y5Q8ifJS08iBIAZtKJOibZ3Ww21HQDLtJ3/B9Il0QFqGCfyzfxzLDXx4tcwH2NpNJKvJQPzVo7N2xMnmwAGg5+lrn86tVMQGoBLG2CO/K0H9zhQwYk2FE2C5AbyE4Em7vqqAj8oneEJt762S1Lkg5Ed2/g6xClmYxnIrZsEv6qw98b6M6lQwW/oCpz1iSqpxAbKOYx3fJv4j20xLc2tiY+wjIMgmEVZawR2dOr1YCoaClEsJyNoEqqzAnAUd2gAClbA9w6ABxnEKJVNPUrT0Pw3/fiSWadMSApbvxMciNPDcT2b2jeFIwuFSAEgRADJeDEEur2dWnax2YvwhBAvbFadEXkh1E+D9zgJmtriJC7egCfS3hCVH4KcyD7vKXCW/X5VYwRc4PC63vcEHV2ILs4B6liHwlctheAHiCDjkbSsi5jG9dKYAsMPppeZCWkaCt1fImW8jA6EsLO3xaYTv7+ZxwNRbiBh8DitKuNE75abe8XbOQ+v9iBhDJEJAJg9loFDRDLW6QV0PnJpG7sTJCwSiHFZciUpaZ/FCmN+22f37mj87n2VU/q9vuP1+66vMkWyDs6hXzxKOYsin/mH2MIP2RIiFnBnW2AzeOq7BFxO6CfulXEzHXT7l5u7digj8zFPjPwxAwdrobls+kbExeJgcLjfrwsTYl5f+jWa95CAlh/GrGt+Ptwi0+8+c1eH4Fc5ckCOyFfKc0BVUcGJaeKXQBxVWeVcYZh7RKl2Amht0cVcOjNHBszAOdgJb7fDnJAkLvf8WreEUlLssSUvx+xelQ8gFXmzEj/B3U6JMtGX7u7kpfGWQW0ELIgR31DrPA+BzNe5KTNBukFVR3qE4qgkzrgYuunY0Jl+Aco9OTHPUXmz9X5Okmh709KoGy5VNxSpFbSMGwgzNlX9hogmMHrVteVIGQmOoi8eaO3Y4dntI8cDNv5xkzqW2IQx+oIhQ0HC/FqS1baGCQPBVc8jRx2qNbX1o1KX03e0hZf4NVfDv99lP3wm4uni2a/4uASgDGtB1yCPU3i+FF3+m48m0plmp+5Q+MV0IcppIRqB/Xajc0Sr5XayAIwLELCZ+vVwuTpQ=',X'6379dcd93b9beec5fb4a7ebf1cf4ac7e3c5c8162256294e4ba9204b6e3716ae61e396ebef22415e1568a900e87effd9452fd7b2bf920950c465b9242ea8fd93ae1017a45b70774b020e5d4442416fec262a3551dd77fcc68f046d3d941d6da86ff1781ecd6f56d37c42cebb5464f710de1ad4d1041a42029deb72953e8b9e024d4c494059fca23078d13f1571a0d16fe2e89fabe72c2d7966269e3459f373b7c71f734cb747262eae77fb07564c23f72c88ce5c477e3cdc9171713d9b8d1f846d3395cb550d9e943e777aa3688fd6816fa5454fbe47a0707766b6529a1aafcf0c482814b28b55999b3e10ee49f11a2ffdb7e408311214e1e750c5caf85b1f311',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('751AF9580AC97C9C5247FB7CA6DAB871','C52',1,1,'IRegaN/dA0ullHQc/qChsejBQmz47bLgY7vc6PT0HRw4AbNred+jY2fxrDmRx0QRrmNSuEcl+1un50cE7722XGdD8iUPX1I8rmB//mdlQN7hYwFtm7TYq97sWmRtMp+Nm5i9lKHTismrLeWbFBUAqt4gEDSBl+uLjCwhF0k0GZpUl/8A3jpqfdI/af09nKV86eUdgSHY8ovYlbZr1to0QUNyk3vX2Tc5kUfUKmYUmPIS9CrRMZXD8N53VUewWOx0oKx3Qa6X46kz4OOGOQGNIeTZiguuMR2+dDgVRYZp0DG3b1cGgw6YJmftUTf4qndFZF4n6lG/fB4B1c7AK7FF2xoU5TlD/+S7kkf2demHSUI7Hy211OAe5KNbn6ZXqSpEWSql13rpNzNJHa+jzEyfp6zDLKg+/ocLXLuGhD9MStzErg3sl2ukh3hF53piKYXHE9dCqeCCnaeg9c0CUp9pJXIK+FpmeX+bYqmEvDQPVBAWPejiMxcQxsKbP6VspNGm3+vhxAuMUbn7X+JL/je3+T9dtZ0sLfh42zx7DzBXZilJMLtePDtesnGh/zvsIHFv/L+28Jh5Wk1QVFn6jVBjiJfmXeGUjIw3iha+hAaCUSRJuiD47QwCSRTsVbghleuFxXa5U23y/knGElps3O5ZX9YUM/CqN+i4D5WvDS7ufgUettkyP1vTrm+VMt1Mc+ITnT1ZKRF6PHXzLcRiDBoTRbe6W4PqufTjvXLNBAwmp+Mz8JAU9wvUcQ+9TG/1ris+bUGZKjNKugff+lKdQ0+B9NG+mjX0qPpTkUcDxU2sMNMopGl4J0PINy+93UFCb9NXn9sNYzCe4wA6p6UVVxnbaQmdDSZ9zzpS2WsFA4b0JsNylJlS3UYnz50eiuc2WdqrSE6f+EV06m/5mXuaIZaI5e7Wz2tMli9S6Br6Et8KRTbjwpx8TRIuM+pPrTt+g8iVDEvDosy7I4zPvisQ4NnUjf9j71zV9vfLdi6homDQle1R39kemuGnVANJaQagFCQDlh6fzMFl+xndzMSGp1QjtsJtZsMJhT+xASCRH3YQlnBr21He+lGWU54gtjDRMTRHC4vWvXeG1L3FovSO49exITmqTWOF8r+Fwh49a494Iw2aXRGI/kIPM4YhPCx7iUZVsJVlz+HdgxZD5PpiOZ624y2s9cK/IFtFs+86GvYvq5eqbJQGYIQQ7HKFhqSHqEL4+BrEjr8O2gM4nNht2sQPzq8CMMHhCjjaIX8aRHH+i5MSFQ5FL6cDpijvPedwnGa/V728eXeHQ0YxaW7a7ZBviZqobzZwCLDHQ3MPJNBA2kcEhOcearpkrkRvnZLDGQupM3/36tF//ShRVNQk8n3KkT6Pxc+a8JhdNX3VCkRk6OcGPKHIAQZwS5kjlSWz2GAQqjaVU32SHBSOcBNG3KCRLgISJy6DjbW4Ih8rLephjcKOnHhOc/pNJI+Bzwm0DXLTY/vmuSy3o0KXnBE7Zm/y7usMm8Aso3KjbugDMB72i9TpKfs8IDI/unWwI/AErC5p5Mc0wfSOZS7/xQVQdm03SnkwOyF7HVWEELjJw/ClotjgQ4s0FfwmoG+ADq3hFMPneqzuIdPwEvv7lrOCc/3ypXcgSZJK3xUpj0iEhFMpJ3I=',X'4ed40f558010072dc9ea08d99c4a5a36451be125af13e8f36483c4772b002115e4c15e41475ed7d16a5af30f18a733559c7a9f64cb9b19f92c0cb377b909f67fe9cde508a2913853fbb83b009ce2b1b98277de81dee1e156f102e88636c8f66411e60838ab4653561df5dabc2130508a624a8372e54d3cba519a3fd90f16599be35a9b07c8ecfe63cc13ccd411075cef963499d4cd15df2648cce30794d6c3f7526c5c7989a61b4600d45d4c1a8c535a4a92291669a4d21fc1158025a2f4380d2c055e0a61f0afed10e5c150b21b6b8def9bf57b396b302bd5a9186810f8da4a34928d170ac612e39fbfe12ad785fba8851646dbf747c247506e0db58776987b',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'79214bbf10fa4265a972d565e12534e1','10',1,0,1,'QMGEMFDMCHXBTH3V1NZVBFWE1JAV69FSBPTQ9ZQ47D1VT15A1PVG','payto://iban/SANDBOXX/DE471160?receiver-name=Exchange+Company',9);
-INSERT INTO TalerWithdrawals VALUES(2,X'fe8e4ea1f83e4ca1b107616cc256c1d1','18',1,0,1,'3T6WV8QNVR1J7GQXSFX54Y71K91ZHH6K22840EM1GNSA4EBYC900','payto://iban/SANDBOXX/DE471160?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$w2YJDwQzx7k=$HwtctDe1xBIDUN18wKb02HSRW9T1a01X/EjlBXhnuz0=','Forty Two');
-INSERT INTO DemobankCustomers VALUES(2,'fortythree','sha256-salted$FN/tM2NFehw=$10WGlVUGmH99n6HWSQMw5flCPqVIYqG6QksLvBty/48=','Forty Three');
-INSERT INTO DemobankCustomers VALUES(3,'exchange','sha256-salted$ihjHrbgp+fE=$GHVzx8c9JbdLRGDsCLIK9uYUH3axQl/+hTphsdFUX5g=','Exchange Company');
-INSERT INTO DemobankCustomers VALUES(4,'tor','sha256-salted$1wNXSIK8Ru4=$QyraBwUeZul0iGig2NAhU6EK5LISmLgORkY2wPCIM5E=','Tor Project');
-INSERT INTO DemobankCustomers VALUES(5,'gnunet','sha256-salted$o8HTQe823bA=$BLrqJ1gmBHWfwuwsD71ftoYnMHKCRL/+FZoOnSUnGzM=','GNUnet');
-INSERT INTO DemobankCustomers VALUES(6,'tutorial','sha256-salted$2wFyeDqeZ9k=$gOr2dZ1/mNiqAgt9o0Et7YVJyCtJz2PQrGn1o/DU7bg=','Tutorial');
-INSERT INTO DemobankCustomers VALUES(7,'survey','sha256-salted$ag1ujsDylhg=$b9qHTZXjTyONPdxGVyJYLD4V7uyVnOrNOHrlmEa8KDw=','Survey');
-INSERT INTO DemobankCustomers VALUES(8,'testuser-05kjxdzp','sha256-salted$jSnyNDDR5WQ=$MyCHnUqttikHqLDVjg2pR3iKjYrXBmlhzl3pggkctnE=',NULL);
-INSERT INTO DemobankCustomers VALUES(9,'testuser-nsqdub8m','sha256-salted$WZ4YZLdsJHs=$rK7TtQrmw60hn4OiZHGjVV95/97uQF7lqDH2FkOKyEk=',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)),1660654426,1660654424);
-INSERT INTO NexusScheduledTasks VALUES(2,'bank-account','exchange-nexus','exchange-history','fetch','* * *',replace('{\n "rangeType" : "latest",\n "level" : "report"\n}','\n',char(10)),1660654426,1660654424);
-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$fMxHi58kwPQ=$BbH6wyk+BBABXse+tYLjMCi3LuQCVEDYL2OQh3982mQ=',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','DE471160','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:EUNCGUQX',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-16Z",\n "bookingDate" : "2022-08-16Z",\n "accountServicerRef" : "EUNCGUQX",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:10",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE236345"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "QMGEMFDMCHXBTH3V1NZVBFWE1JAV69FSBPTQ9ZQ47D1VT15A1PVG"\n }\n } ]\n } ]\n}','\n',char(10)));
-INSERT INTO NexusBankTransactions VALUES(2,'AcctSvcrRef:F52CKZKJ',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-16Z",\n "bookingDate" : "2022-08-16Z",\n "accountServicerRef" : "F52CKZKJ",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:18",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE209794"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "3T6WV8QNVR1J7GQXSFX54Y71K91ZHH6K22840EM1GNSA4EBYC900"\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'308204be020100300d06092a864886f70d0101010500048204a8308204a402010002820101008f361aea2e49a8e0cb4d171cd620687ea7f6ba16948c9c19708995f328ea3590eaffbab67c01619b79eff54dd3e2d5db235e9ddbe773ce38a01bf06ecf4727fc0e218e357c812c897ab43743f39a42b9a879924e23eebdf0104a90b04c0c840ac79903f4fb74a01062d94bf2022733b985f1c9e608707e59c1c28e6fb62221f34fe8b47f6e038c2b7435360e376b86520f51047800287aaa5bde8b39d4634ed36f81b7f7c221cebbd2984c279796f3556b46d631b6f74e40c700ae299ceb9a7fc7b76a9a0670380d34328335b4699af88433033ed149e1061d6b65f88e070cd22d305a757956450bc4ac5c1e33d52f150152b93cf38f645e2644c9049cdd5e210203010001028201001074ec34daead60036fc7dda6f74bbed4a09dd2a79198b5a95070a772dcd74285a08d700df511d514b7ada9a7dedc41b717e0eefd5320691953c80ad8b1e27271ccc9855e71fc4e96b73482283dcc72c24830bdff4db1b7279bcc7d1aa7b89b4df68e2fe84e2cafdf70df75f310626387c7ee36f8eaab6aa43ccc2a76dab90710366803491ca8f7cf4ddeb10f03bcf9f4e03abcbfe2ababf7669d361015658cdb9c145481370ffeb4905e0aaf0a87fd41262cdbf05c2d7f1fc264b3b0fa142b86d21d5cc98e46d1db328a2da6802a183d2a08e3a8c9ee1ff7efdb153b51616f8c8c4f35a55f540f28bf284b5494b285132c7e15bc889d421bd8f1c3907a9046d02818100ea58467a8aa4a86594b08713133232cb08d1e27132aa6f6b6eb0d545f313db4739350ab326294b8a24bc6564957ee35a9ef97e12eefa4e7a2660b24a798a8375f1587dd66f35c9c9c2979231315e0ff6e00e94785db39eeb8a089a7120c4eab1404186214a69266a7428572dbac23466d14da113f14224f0e7d6d27ec9aa92df028181009c71f39bc84ed5eb97d4e8abf6462e330a9c4e206f3d5bc4aecabb0ead15dcdae2f300a400a7aa4f640e15d917aa1cf20dfb025407dd882080528054625b66ba6f65cb32cab14da8f8944ffdfd6b02d0d298ffc0451aa3a67d9710b0d999b26601fbc6ca3ad6731bee2363af1acc03f2c822986d33bd923f774dfbaf558f2eff028181009de175322fdff917ded2035ea58b274f4494eac32ac84aa28d83935c3a0501b17d682fda3c768bcef92af80088fb60bef7e5ccbb82c79e418b43903abea1c4299cbceaa2a270118fdd8af2523419541616239c816f578954d4bd3117d064fa5d0a965a80693a68484613bb9032878e784ac0cb29bd5bbbb995e8540e595d92ef0281802fdacf88d49200efcb06ee9143891e32b0c93540c8a63d3f01b4b3d97e6a949f4412cf1c5bb2edeed10d59f38940991015e4b5469d0d4fc9995723382cca06b77ac1e99144dd4d83255ec0c551d27d0f018c9996e7cc8948b15c1757f188094118d43a6fbbe5c35a44d300781cbb516ddf786da5e1d0d83e9fb0f40f231de46302818100b238969b46809f2b51dfbb0db0ce8a044c8a8fc3d4d7071e49ad75c379684f7cf1dbbb84d4572968d35a752d5f4bb348f3854c7758882034f14a429abe8a26152b3963411d68aa9c403934ba7e14c42c9e7a8d4d19efab91461d16e320498c664a762d8dff0fd034a0388055521cd4468765fefc952ddf6d89017d45dfeff30f',X'308204bd020100300d06092a864886f70d0101010500048204a7308204a302010002820101009eda7985dc8cf6137e3fa652617f38d831a2f2322e551a01eb41a5cae37a326b99be1e5febe0f5bdff4f3cf4a0872440bbf45e7d94c20be2d71d209f3c3fbae1dff3788fa5db17667f076af85e42268d43eb3fbdb5b9b59c0d5adb5f7c351f3b17c81929a10d7d60dff1276eea8f11082142f1ea274e21e227564a7cea5c4df3147b0a6cb60d01d9a2b7f938e117a441269c078b6c9504cfc4c37f0783d282009664803cd6dbd2827345b2a43e34d33bdba79fb388a638c54c2f0e040055bb3afcabf2c516be88b6da6409a4d4a80c288e68ee820f919c08c0a4690e1806cc957ada81d87c89fbde078ea6b73c642f41e0c8b8aa5e6e3d50828e8c2ed73bced502030100010282010051ef281d165c12948d5ab123eeabdb1b0fc7171b30f0ae206d42880c34f69349129c90383386edd998f53ae086680e17e19a329e9d7ad4fca4ad9e64e3838f95ef983a0805a912d1c815806428e1ffd67f40b8b8d621ba7d8a19e1eac73af327dca555ed35e7aa52ac4f4b629753419aaae547b7d99c2037f0c83e555de04c47935795516dc9ee95c21d889b2d78503a64d9153595d1f555510b3ccbddeda9770a1a4081691f9dfd6bc30cbe42ae35cdb6492671c2dde5f78c244190c1a0bf809536771b429882e6f2e6c82ce9647630ebd1648b2973dd97296712341173ea16906f1f078fd19b18db7d26e99a09a90aa1aafb30deae3ee89642b348fe65842102818100d5c85437dda87cc59ef370f084d1020a3f5863832cd4a2a40a8092bc6fe5ac703da3302bf66d1f51b66239a5dc70b40634768cf36ab3788ef96809bb1674b4a152724c0ff668dab5ec79d8d60a547eea2b90bf4f9a3467ead859f97c64a607667175646475f0060f4365bdeaefc8e6b34ae41b21bee3e70734e3d96e6294852d02818100be393b2bae484c85ef381a57e67839d1a00a9738817dbad25a30a46df4763024876d57d2d2edd4fb6c7ab70c00c769a206b6f4b9181c9ff444ad6bd597f6639907ebee81215dcb646030b47ab704ebe06c98b3c93e23b111809c523c9a2aa99d0318ac9f0350364c5f581492d36e91f29200d793971e356d55f8f6cec5884949028181009cc0b52ff971af7b601f7472879091845e0a3b7d5583dc7597d5cac22cf2254c6f8596aec59421e0d27097808c707f30058bdfb2244cd05b5578f9999acf9c1aa5cf750247557ef8e21a3dea43ccccfa7b533953eee7fa4272bd1678257caff467c10209bf886d89078c34836daacbae2f7dae7f41eeedd994e874e7c194d14902818051d9404b883f15a61f8b6d525b196a0f77a476f2da4ce620f2abb1649a666c4a9b7701edf5d25ded1cfd245be6cde6f6cf9ad36bfd22fbf457c4a2fc91d9737b7a3c1b30b6d1abdd71c22336161fe8fa74dfb3a428b7a4cdda1fe906a87328ee2551ed9cb2094683d0168f2baa0c0e82682e32940fd6f0b82de0e5198d4719f90281802649d753bd95819194e02c5396dc09b603dbb31d7a7679b3142674697faa2635948278cfbc9d34823ffde5df917aacc70b2cfeba63e18532ec4c05bb6ea693851d03c0eb9c02e24e25a1acbb5ab16c1873e3bd7e83d290bba5f34f7bd4a6b53423758c4baade25edbc3b17d78a3c7ffe4b6c51cf145a1cb3ebe025df23c2d0f1',X'308204bd020100300d06092a864886f70d0101010500048204a7308204a3020100028201010098de1ce451c26f798e3878c22f0babe20f455c058f0220bf417fbbb139a452853bb01630e09d7dfbc1f0d43e34e70d8b4f44b91d63d350c0195b20e8d835bd4fdf3d0c19ad696e5c5a0c042474c65c9a56a88e8e8b90d24448a58078c512f0bad5c0e580855064734db6aaf9bad048cd114edc831ac546d4e302f8bc18e839060b62d118d1980bb33e50bbf5074e0b717abd862ddcd0ff5f285fd5ce68f8e708e2231c61290d731dea24fdb6d91ee53b4d501c3fe7e23bb5b6395264a8371593e854ed9a8cda83fda172721b3da6353c40df4ee674ac35952f28b2ba4d51964b0cac4234920601c58f66fb5ee2f4a655486a798d1b1cdfdf6ee425053faa14430203010001028201007df7696f6b400183f501ebe077cbf25351aa21ee22adea362fcf05e7404c7c0375efe0195ebde8b6b055b74f9b6059f4d5d917817465094182a36936f6133270c2d0174c816d4397ae4c008dd9fc2b0ab3262a72a3e72e9d3e0fc311c1b39dd31798e0854b55b7b09bf54e6682de675f3447fbc5bd259afc8a2444bb1afb2120e7a38157878a5914297f5ebdc6586a3f4f0c12f0491d07b909f138062d028fbefe9f6f5c2b6972fdd163425fd491e4fa2689d8e7369bbe621e7469272bbbb2450533fa1b65c0141f9b9e3f097e8e438544601192a825514db3d422c4ae30d565d81e96dbb80013d8981d79dd724703c57d4b57db1f90ac257d55ae6a94ed7f2102818100ce983cd6d7a5b35b5d274a9e080564cf6928fcac905cd716eec1d7e8b06cc432fcb3d2c4d21c1e59470478bd3489670301af272a8a0b540b00e7009491de2d88c64da468e5debb5e8e783c13245fec88709400260d2f947e326deac2db68cd0d3cf4ab16d1c555f58a9d99daf6f7947d791c0ee0004af0e68f7f179abdeb9bef02818100bd6cb22072b90f2d7cfd7d1c0a6287d73fecd9c48462545ba2415af1d03ef0a30c8f52bbab80ea65b1e49a1f228993ee40b9d1903d61d9bd7ec6b04329299b5730b331d6166c4fc7e64b900165d2d1357928d386c59cb49165ce4c994bd8a6d9f8ba9c2b02b1e42e9e3b93b63030eb7b3c024cafafb02eeb53ba52def8c8c8ed0281804c74eedf1bc3c912e0f0af9eb89d3667c425550d9007abda62d5fe4fb12b2f9927086dd24567fe9b4fbb09ec0bcb660228d7678948b9548b15f467b4941f437ec0d4ef299b18c902ff7ae3d0b9bf7e4c284dbd98577cea59a1d427f3a13bb1d75a5dba0ba1ea841b71074e6f48c2eb835c14d434762745ec2de2fd1b597a1ea50281802163a78250b68e165691d81bb938e4f8ec2bb3b7101ec4ffe1f9e32dfca71b83a21321623338e61846e324c7982ee804772449ec42e59c9bea5cdb74fb2c7a55442052088aab4ce4cf93422efce3cc3cc0be918a900aaf4971c88b77fa06966295954f31c5a7d5b0e1f35e761ec880b9983a4f8a284dc5f7752ac2b0cae9998102818100a240138ccc66b411e73d7d5235c8b708a8d126b08074731edef1a9ff091af1f56fddba66ff147c732fa6dce070aeb692d2a58382f932ef8a61c2307ceecb860ee707e453aa37556d1d9b3a66a5e901c28e11bff9a009e6828b84d4652eadb28d61f9fa3a8bd7ecef6af037c15a6c5f03ae7ffdbd2ee426a6820f87f9aa67c6cd',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100827428aae70a10161398e747b8e0bfff43480914d0bddbe3699f31931551eab603d5c2f6b647f8406939086915f94b80f9836393045c475e3d7ead1896254bb1a952a696e57d232cfef6687b0f091dc6275eea88caecee2bb3a5154192d160cc9ec965e5645f439ad6a90ab6a4cafc31f8fa50f31dacee2bb09a630a7d294679552522fe42f6399b7ee0bb6a7052ed671bea616d0a2d57a0b9e1d5058c6d813fb35ea6cd01446b90697193951b8be230b4bdbede531960e1d4650e38df40afa7c3018e63615c731967df6299327e7a0d59ef0d0e07212387b7194d7cb0bf48c6350ce0c4006e2ad14dbf303479ca012cd375913e2fc9430ea53c1cb709aa6b510203010001',X'30820122300d06092a864886f70d01010105000382010f003082010a028201010096ce919bd54c4d0cb54623238d010d1899858f251cd73d7bef09d1ce4ad19b1bcf1bf8018b493d162837eed7010ff56f4b99062f92827ec261fcc7baafd8e18912a882443c0f34a20c41af878252740af2099f517386c4d23b0344a457d520cc7568eec9e7a840ea748f3c95e03a380a68087b885d59e3e3ce553e922effdd1a20970ad08b4162d1869222995a5fcefff95e559fe98e86e74bcac6c4a56cdf4bfdcafc6a38a4e09a00155bcbc3865f24e3f6c1df71d87cba296ea9e45d8701b72b439748330c884898d41ca5ef2d41c9151413dfc5a2dbfa1db9dfadf1cdd47052dc05bb173e2975ff863d72b4654e8fc5d338cf18585276f3ae2f3da3a18a550203010001',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,'QMGEMFDMCHXBTH3V1NZVBFWE1JAV69FSBPTQ9ZQ47D1VT15A1PVG',1660654404940,'payto://iban/SANDBOXX/DE236345?receiver-name=Name+unknown');
-INSERT INTO TalerIncomingPayments VALUES(2,2,'3T6WV8QNVR1J7GQXSFX54Y71K91ZHH6K22840EM1GNSA4EBYC900',1660654413731,'payto://iban/SANDBOXX/DE209794?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-1660654393506','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343339333530363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31332e35303635385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31332e35303635385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(2,1,'sandbox-1660654395844','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343339353834343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31352e3834343731335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31352e3834343731335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(3,1,'sandbox-1660654398068','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343339383036383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31382e3036383431355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a31382e3036383431355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(4,1,'sandbox-1660654400272','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343430303237323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32302e3237323833395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32302e3237323833395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(5,1,'sandbox-1660654402454','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343430323435343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32322e3435343431335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32322e3435343431335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(6,1,'sandbox-1660654404657','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343430343635373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32342e3635373230395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32342e3635373230395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(7,1,'sandbox-1660654407039','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343430373033393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32372e3033393835345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32372e3033393835345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(8,1,'sandbox-1660654409241','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343430393234313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32392e3234313930355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a32392e3234313930355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(9,1,'sandbox-1660654411421','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343431313432313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33312e3432313436385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33312e3432313436385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(10,1,'sandbox-1660654413591','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343431333539313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33332e3539313435385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33332e3539313435385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(11,1,'sandbox-1660654415794','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343431353739343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33352e3739343336365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33352e3739343336365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(12,1,'sandbox-1660654417968','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343431373936383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33372e3936383137385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a33372e3936383137385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(13,1,'sandbox-1660654420140','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343432303134303c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34302e3134303134345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34302e3134303134345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(14,1,'sandbox-1660654422308','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343432323330383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34322e3330383237375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34322e3330383237375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(15,1,'sandbox-1660654424501','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343432343530313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34342e3530313933355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35333a34342e3530313933355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453437313136303c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e32383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e45554e43475551583c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31303c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453233363334353c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e514d47454d46444d4348584254483356314e5a5642465745314a41563639465342505451395a51343744315654313541315056473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e463532434b5a4b4a3c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e31383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453230393739343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e335436575638514e5652314a3747515853465835345937314b39315a4848364b3232383430454d31474e534134454259433930303c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',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,'DE471160','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 1f180b301..000000000
--- a/src/auditor/auditor-basedb.age
+++ /dev/null
@@ -1 +0,0 @@
-1660654426
diff --git a/src/auditor/auditor-basedb.conf b/src/auditor/auditor-basedb.conf
deleted file mode 100644
index c06c86847..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/DE471160?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 = 3NVBGMW8SVMKA4BSBCX9HZ23V7KBXR0ZZ02JWVXBCRH6RNYSM57G
-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 = 3NVBGMW8SVMKA4BSBCX9HZ23V7KBXR0ZZ02JWVXBCRH6RNYSM57G
-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 = 8X7G2HSYZXK7HW18Y24GF2TTV5QTN1DPET4TG8KR65P54990EAMG
-
-[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.mpriv b/src/auditor/auditor-basedb.mpriv
deleted file mode 100644
index 933eb1437..000000000
--- a/src/auditor/auditor-basedb.mpriv
+++ /dev/null
@@ -1 +0,0 @@
-³mH;§'ûÞ£š¶fÍ’/CêŸwŒwX3Â.í%¨ \ No newline at end of file
diff --git a/src/auditor/auditor-basedb.mpub b/src/auditor/auditor-basedb.mpub
deleted file mode 100644
index 0ca1d8388..000000000
--- a/src/auditor/auditor-basedb.mpub
+++ /dev/null
@@ -1 +0,0 @@
-3NVBGMW8SVMKA4BSBCX9HZ23V7KBXR0ZZ02JWVXBCRH6RNYSM57G
diff --git a/src/auditor/auditor-basedb.sql b/src/auditor/auditor-basedb.sql
deleted file mode 100644
index fd8bd8f6c..000000000
--- a/src/auditor/auditor-basedb.sql
+++ /dev/null
@@ -1,15904 +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)'
- ',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'
- ') %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, bigint); 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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;
- 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;
- 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;
- RETURN;
- END IF;
-
- -- "success"
- out_conflict=FALSE;
- RETURN;
-END IF;
-out_conflict=FALSE;
-
-ASSERT NOT my_finished, 'internal invariant failed';
-
-
--- Initialize reserve, if not yet exists.
-INSERT INTO reserves
- (reserve_pub
- ,expiration_date
- ,gc_date)
- VALUES
- (in_reserve_pub
- ,in_expiration_date
- ,in_expiration_date)
- ON CONFLICT DO NOTHING;
-
-
-
-
--- 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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); 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, OUT out_no_funds 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_reserve=FALSE;
- out_no_funds=FALSE;
- RETURN;
- END IF;
-
- -- "success"
- out_conflict=FALSE;
- out_no_funds=FALSE;
- out_no_reserve=FALSE;
- RETURN;
-END IF;
-out_conflict=FALSE;
-
-PERFORM
- FROM exchange.reserves
- WHERE reserve_pub=in_reserve_pub;
-
-IF NOT FOUND
-THEN
- out_no_reserve=TRUE;
- out_no_funds=TRUE;
- RETURN;
-END IF;
-out_no_reserve=FALSE;
-
-IF (in_reserve_quota)
-THEN
- -- Increment active purses per reserve (and check this is allowed)
- UPDATE reserves
- SET purses_active=purses_active+1
- 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
- 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, OUT out_no_funds 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, OUT out_no_funds 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: 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 integer 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,
- 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.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,
- 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,
- 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: 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,
- 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-16 14:52:56.703394+02 grothoff {} {}
-merchant-0001 2022-08-16 14:52:57.777958+02 grothoff {} {}
-merchant-0002 2022-08-16 14:52:58.191824+02 grothoff {} {}
-auditor-0001 2022-08-16 14:52:58.341164+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;
-\\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f 1660654391000000 1667911991000000 1670331191000000 \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 \\x3e222dc7d5df2768e32c4067e9dc2e1c6edaf955299c10474b6ecb24c9b0ca33b2c6ec9637e330e03c6bce795f3ce5141eafb254d98de97596fa0a693913430d
-\.
-
-
---
--- Data for Name: auditor_exchanges; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchanges (master_pub, exchange_url) FROM stdin;
-\\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f 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;
-\\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f 1 \\x827f73b62cdbab20753edd20919233608f6e3d166b5dd5d1f63b7e9ea866fd183c6c4113576dd85e6f6b9a16d3852008d47007ad9981435d78d9375b35110ae2 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\xa2de7d3db3c3095c9c37f0b4cdb56614a64c8ed5235a1032d4bc94ab0eca424b31c52a5fcf29bd18d1d9b9a2bc88166531db9ce649435fb809547d7b001d9058 1660654409000000 1660655307000000 1660655307000000 3 98000000 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x9c632360d0c900fb2d148afada5dd65cb2d0002d0e0d32d970ebbac05b163bf06f79c0e68f75a813f012e00cc00096f32cf420a9fc05ceb076dddcb5a2899104 \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 \\x10655469fc7f00001de9c1e3b15500004d1f3ce5b1550000aa1e3ce5b1550000901e3ce5b1550000941e3ce5b155000030a33be5b15500000000000000000000
-\\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f 2 \\xe7c8a519ecdd88502897c79378308b3a8f2be183147fcc56fca83b622ce4f99ab34a46ea3b4b9b4b53892bf843a591fe57730c9cd883ee498da05376448e3508 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\xa2de7d3db3c3095c9c37f0b4cdb56614a64c8ed5235a1032d4bc94ab0eca424b31c52a5fcf29bd18d1d9b9a2bc88166531db9ce649435fb809547d7b001d9058 1660654417000000 1660655315000000 1660655315000000 6 99000000 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x0594eed06b2991af84673626b6eed133274bc63fc370c5f5145d3d732319b2d94328af0a90b45fbc787db69cea4d51a692e9a2c2b8ca81a610a2082d4ec1e70d \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 \\x10655469fc7f00001de9c1e3b15500006ddf3ce5b1550000cade3ce5b1550000b0de3ce5b1550000b4de3ce5b1550000b0003ce5b15500000000000000000000
-\\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f 3 \\x7d17d97ddede1070c10c51a33e9491e94302d74014620018f0f54bc991e493c0c33cf0d5c483444e6c5dc3c258246849d19cf15170774f361db56ae6fb724e97 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\xa2de7d3db3c3095c9c37f0b4cdb56614a64c8ed5235a1032d4bc94ab0eca424b31c52a5fcf29bd18d1d9b9a2bc88166531db9ce649435fb809547d7b001d9058 1660654423000000 1660655321000000 1660655321000000 2 99000000 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\xe881e2b2cb12b6d6539f51aad37e39c247a2288bd24d26efea90c013058353327aacb578a138011a70390518d22cdb06099cf5e6648af4628396eb5206505d08 \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 \\x10655469fc7f00001de9c1e3b15500004d1f3ce5b1550000aa1e3ce5b1550000901e3ce5b1550000941e3ce5b1550000500e3ce5b15500000000000000000000
-\.
-
-
---
--- 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 94 \\xbc6d87365b70384641decfe1b948be21aa78799eaa8fe9950c6b1ebc7375fff1ae04c0a2d7cc30ffccc2db5188d469305dc6a4ceb76bf5c2773ae71c21d81f05
-2 1 289 \\x6da61cd2d9431eda8da6456124813d65b584dd517a2e3340d0df717d3d1faf25634a582785ffa5a22a6c89e9fc5066edfb32aeeaf44e299d956445bb6e88100e
-3 1 409 \\x7043c679407a962faf8d37d7357c94f7d99d76fe8c0092d4494893340bc99cb2a6b8d7bff63afc84450750620554a334c27044296f7db1559e42ed0d2f489f05
-4 1 421 \\xbc551b6a573b3459ad04167535c88d60a3281b2956a8a09bb6d5859d176146455d4009beb07acc7db8d35c433dd4fceef9d87f7f8fee36e54f14ae820bdbce0e
-5 1 121 \\x2251b0e768766daa0a60609937d6c5b59cdb071249462d1ed89a0570384e665a39a223318b33876a738bc71523b409d70804fec3ae4333389ada06c7d7acab0d
-6 1 291 \\xb424270d3e964180a8ed11349ab94c62ee88fbdc9e24d5f7cae537434b78a3721885ef700bb5f5cc227f08599365b5e5558414807c54f156cdda59099d09f00d
-7 1 412 \\x1be5b5484e4f1eb5aec2df8787cfba93af10064c630e94ea66b05891974826f429def6f98217ee90b23486f987af982e0be5b4f4efcd69d12755bae22b43b200
-8 1 341 \\x3979cfcdf8075c345f2cb9953c19a8c092eaebb4238c9442b0c851560669fefa445969189e508871896af5b6157b1ce7336a62a395820c3319f07f1c58193a0e
-9 1 303 \\xdd983ac538f71f09e3365c68d47ae37278aad86ecbe5f5198c3c93f0adc1ad56caef9d3892ade037e6ed9c23f152e7424413b137e34da5ed52a1bb4486305405
-10 1 100 \\x0f369a5cbe7f9b2aa19e1593065dd4f70fdc1e7f0b751123ec119330fe59c57af226be4faa02b46e11bcfa55bdfba6d38346e5dd22f89c1b0f23c874d96e5b05
-11 1 154 \\x164f34d791f4a3fd65b9166f2f09af64d65e62f8c164d18a9b9f64b9391bb11603d602c348a57d77da1e7a82e9462acc331c5d2bac77f2b9f018859bc5cd2400
-12 1 192 \\x478854ba20aa6bb06d8eac1c37aff3398e3e7aa51d9d64d1c77bc7e73cec64bd8421053a16456b17d1857990909acf52203b16739b57667b39657d65e4db5b04
-13 1 117 \\x29cc55d9a0d6120807b8467d08abd1f9f092ca3d273c890d0571cd0d508eb58113877158aada41c531175f15da961084ffa90566c87db813945872049b617a06
-14 1 29 \\xc7c22fc9d3ac7c09d90f65c9685f2e244530fc45424b7488167d2931ac1ad5385342798dc6b41faf4c46b3f5141153f6ad4e577db1c9034b22f230c606836509
-15 1 242 \\x56a66c3c79f84b8833ac39395e8d434270acf54a7902d3581beb1251556aa4b36651539996ef6577c9e39aa0b2ef119b552dde843072b187c4a6de5008d6d403
-16 1 220 \\x9d00ec74f3eb6587895d07feffaab45baca2cfde2b6b6502db498cdb5886b16ed2e992d0bc736f20b229ef22bce1e69aae8f91387976aa74f3d67a6a92d05603
-17 1 147 \\x07a3bbbc41c3451973f37da20a21981353b0a87e15c1b353992b6a7c2b6c5d750528aa906dc56f04a067d80b46e21a1df04418e91455fb655fe8ae4f9f83e003
-18 1 170 \\x8b299e528c1f16cf6026624b6584539df897bba02ee3eedaed20d0d17880f2cbdcd10f2b5f10d82f699b6b32c3416c35d09635ad0793af87c50b948044629b0c
-19 1 344 \\x9bc747e11c12592a3ee9bea75a981ae7405dbd0b9d2669c5f32dd66c07fdca85356cbe6530e04f7364fe378d251bac549f79b9594c2df38d543e1c0dc785c10a
-20 1 60 \\x26207cedd493d62a1bbc4c92bf41f97b71c91d995400418edb85bc9e7f4018825830995e2db723587fc2fcde6c1fc982764cf698dfdc2b3cdcffdd1f9efe0103
-21 1 86 \\x4918571831d78dfdb0c6c41e59ff8a219623d27c435e4d9a7b03ea751ef2cd33745bc6ddbb21c5a654b91a74a31d6738d5525bd0e19cb36a5f2a5a7d7861930d
-22 1 352 \\x4b9551752b43e0acbe4a55842ceb7719dd4ee82e6376326793f730b7b1fc777289ce3c9bfde5a49246e58bfee215738679ed97e8bc83c05249cc500cf0f04d0d
-23 1 355 \\x18054d00050123ca3bbe97c12bf11a5756d56d61f16cbbaf6da6b7487c759bc5a6beda6fa77577ff54a0914c8a9b7a2fb4ca703bccff7a270cb33234e2da310e
-24 1 377 \\x5f774c3c3e6fd294cad6f55d7ec1521f4e643e831a4e951b92cdf26c8c5040d4a3ddcd12bd3b8b56be5209bf89c2638348219063b4215f822d3df1256c7b5e06
-25 1 405 \\xa98983dfbb885240991afeab7a33b6cffb6b3988267aeed6a323a272c39bdf776d2a2b20f72cf74190519baca4b51c5cb2da2d0b9c1720d050271ef920d2f901
-26 1 189 \\xbb3c5f9adedd9b41e1d7b1fa31a87082cae45bc27cf4caf11ae6de55fc98b0ceaeb5f87da78ce49b15b5b8cd59d53ca0e3fba4f873f78bac95c66b88e4a37101
-27 1 77 \\xa30f09ac192c0c1e7a700e45b233a9b170a682467be3d7dea24387de3cc083eca7813a1e25ebd90bb40c85a52ff83f37a3eb909178dbeedb117986c6d3095e01
-28 1 290 \\x724e16374f01269a1587e5333d8796ee72d3fd0ab94b8dd5fe1565362e116f88a88e0b94483335436db862028eb896d652c580486a71b0d446215991942bb10f
-29 1 116 \\xa56a5746554588fc6876ca5505c5f9840c8ee0e8d4d92948555053dc918f51806ebe92532aa022456405d3a88b24cff9bf60c0798f34a99773802d139540c60a
-30 1 62 \\xb669a8c1e080b7339dc98aa888563e694e7439834acc47e27c142d07bc6af92f7578fbd27501c870593cea77187e7386a7243afc548e1de518aed9c1dc7a1e08
-31 1 131 \\xb1b9e73fb5167a4b92bc3d37d3f164efa2d5177e572148fd37b64f1885254501fee8b834d9b8b6ba281a7ce076a335bbd3f8bcad29ffba6f8307f05a0e542602
-32 1 297 \\x37c8bc15334058ad90f9db474d71df679503c5cae0318bdb7dcfd4bdb7f33b9a22c5c945c636b30bcb3889fd3a09902d2468b8c63fa6a8f163dd4893c13b180c
-33 1 72 \\x11da371e254091d3c096b1d97dd009f3cc7a76e0674bb386abe5498468c6602d476ebd1d24b16abf8232725f29b5858146d519cc12128ab444bae0972ba4ee0d
-34 1 329 \\x21c7f847dfa1911fec7885e6a1be5f2591c1866dfcdf9bab2bbb8bc48062d38d1d272d848e09848ee82ebb0305855e643b8b3846a3521c645ed175d9a8c63f0d
-35 1 24 \\x3e957d00ede8fb3a0130c434441e9f09ec3348111b0576048a8e7a8668b5755e3aa02b5cc5fda10e7707f25a522cf8016ebf903ca13e0f73dcfb57acf7b21909
-36 1 45 \\x0bba8aa64e2d485c36cbf9e8e71dc222c6b67cf1116f4803dc8c6d8df16b90d0e8b95d8dc866752f89e06cf6bcd56f8653442dc3db7f1ea57b4678a487e13c0e
-37 1 253 \\x3129ddf4be5c1070f5699440acd40d40d4a4a6e2b3363eaeffbd79ba7a5a17a61032acda556bad1d6585f53aa9d104db4f880d509c84df5fd60e108905f51200
-38 1 402 \\x64a547bde6888c1515f86702e6993ce8c3fe725b966b9f31a25071874c499cbb8d42b33d8d9673868f9204954fd6410bb0f5cd48c1d1706ce77f79b70b328908
-39 1 284 \\x97cac77b20cc0662e2f9ec3637773568d4e3345e93e02b0256da13676330ac89ee5c3a144ba829b2f6d6c698c6681e1abf8dc6d8941e92256b8b491aad16800b
-40 1 319 \\xe739288df16ae6b6399b71632fb3cd1e3bf3ba92bf90a901f28fc8e73d512e73a7294def35caee6487ccf46937d98f2de11c678408716a07e9589e4621192a05
-41 1 337 \\xf410c2342120ad06cdf6d67c0644b7881100b0e25b59ebf54dcae369a905345ae83012bcd6ca72363bef2fa046cd1bdd4ae12cf22ca491691e95d60492e3130d
-42 1 138 \\x90dae9f172ea968522d7674dd419bf70be103896b82c5f918512982cfc22dc1e4cbfc18756dd7436231b47a43bac6046be62ca44ffaa4c0ae831fbc2a57bcd0e
-43 1 294 \\x6064d64d9b18e5838f3c39391cc776345d57186a69bf4aac4b4c6d6ab11efa8c65fbcb1d29299efb579554c6608c482237f20dcb2de95f04fbce65ce9f7d6b08
-44 1 227 \\x42f2e7c72114ce498eb67669aec5fd8f5e977af4ee901cd9b7891bfbf5111b328bc6280f3c88c26d955144314ddaef160f7756de17612b1e881640f7e5662b02
-45 1 422 \\x49ffaf9d465f52c65df85a02ded4100ecd1816be21790716f0619a14a1992f55a65be49bd8a347c8b5714417544ad31000d2b5fa3d07157c576d561747e0ee04
-46 1 38 \\x02345784a9363d29bd39ee023687b131b06f9d9887d2b13c70d732fdb97bd1b1469b2e20aa4f849a6748184a5174be19a1ea1fb0963fdffcf1412deb622a7c05
-47 1 196 \\xabd55761d924ad9cb5bb98b0b780bb1182cb622b9b2e590dad48375f40645a7fb6bb5ef22c63387231fb0de36d3714a04c55a8932dd16df9758fce853a90290c
-48 1 207 \\x0c4240a7c423a106ae1b57df47806e2bc0083bf36fb364aa088dee89860af4036434f67203c6797e53b968813c6536b88d3fd2120fcdeab1cede5924deba2005
-49 1 372 \\xb9d69548cab877e17d86f719d2d54b49dc7827f59a6d6c2589c2a37e01f6c976040fe9a8d514340df1626c7e6767c3d5eea0c10bb037843d9c7e0325028c8807
-50 1 292 \\x38988187b867d98a59c29a9e26f949512adaeeb324e9fab3d2525aeca1bf8bf7895e6abf61f7efc909ea2985dccd6eeeac3485e9e10726ce38e27034b61f8c05
-51 1 108 \\x97c0ec341350df1f85cbf07e27599f61468429341303bfd0084e50caa20292ed90f47f9ac0667860d9866ea694ab4d28b298f7eb1cc0326ccc9a55ee88267a0c
-52 1 201 \\x64d6402bd4e69900f345277aac56c5b51ef832b932a835ab639d69b13522ba5e6b75d6156826ce8512cfd0d0b3de6af05dea332ac11fefb1418422d3fdbef008
-53 1 300 \\xdbf9f87d8668e91107909f5a3fa894aec8410abd0bb182c0d18874ce1ec3fc552ce3dc7a575fe09301ffc293a1bba3fa543276bd4fa4eb006db791577134660b
-54 1 264 \\x741452d3517148a154710aa2e594db04c9349c8510c534c0c6df48f6a1a4283c36499844512089bed4144265781e3c87d453e9aa1a7eb33ae6e782e26756620a
-55 1 26 \\xec13cbf436471257f3321e72bdd21adeb8afb48d8f59db65f59fc3141a905af8686ac27059162485b7d738ade912ee09ea157c6f4f1315d0588ad2de7043e30c
-56 1 130 \\x836bdfd259448d2686a202d9f468e194a08c35ded23ba0d7e31cb56eeb87bc9a6a83632c86b1e7fd5795186bfe1b90d47b21b63052256c17d262077b5a2d670f
-57 1 234 \\x67d5792103302898eee1811972dcec5032599dacf39ebc7f8b40ac6b0403132fe3bb4b165368835f1f4a4274c1bc9592e098786ceadd36ea70cfe7c163bd4e04
-58 1 151 \\x5c3a3514e8db08c3d3d56f2bb9972cbcf36935e5a11ac807c1109305f9ac4d5d5fef2d1f6f150e4814cb3213a730e4c1ea4194b611e6599f2490020e8bf9f101
-59 1 190 \\xd9c38f9d52c47945c5f579c6c43a429c710d74773a0bdf1c8ecb4f68e049537d294e29f98c2defc48bf2c888cf11d625a635e985c557a112661b795a04508206
-60 1 96 \\x9107072abd81d51af51217bbe784631842d341d29cda589928b8866dc2bd1066119555e3463fad905d64cdefb1b48ddda7b3581d97f56a6872afe50ac9479502
-61 1 102 \\x51c4fb6b17498aecc44bfa8b9762e00623804031e6e97dfd4b8938935e19d3953ce708b68813deacb01132aa9e511d20b3382b9fb858c866177224a81453d606
-62 1 299 \\x2e50056d4ceca57a162e357e5bf828ad16c7e6013f565e436996f5024c9a93b813bf7288493af5364c0cc8f2e7b1b95f1ecc4849f023976c6ed995f57699df0b
-63 1 49 \\x82d705f6d28f62f91449a7a30db941c253dd8fdc39a96c8ca9273e15784c58e17885f853f54230a5cb54ea85ddc35d31bd225b64941bf5d3c47a65c84424390c
-64 1 59 \\x6f84b0c18bdfed146b4aaf6c36f71f7e10f1a0143f30e34def8de4005e01cca71fb2ae0680e554adb8c674177b10904d4a78e59b5ca33135a2adf295571dab05
-65 1 238 \\x3508ec96a3fbf3ea52f7dd6ab356201d83d60665be2aeb8403d6adc2d29e661f983d9771f583d6aeb42ad8ab595b492fec5c641a60858e42b0a08d2aad09920f
-66 1 91 \\x58a9a35ea87d566efc6c15d2fe1208d9bf6916e2bfcaea555c5688517ca26f5d8cef5413471d058ef8d2fca9df43cee791c553019b0ae4da7074ac231730510a
-67 1 53 \\xee2d0ac26c05924067da2a0a3d3ed15db1a4b9d09eaf6554d6735bf09e0cf72b3577e192dd0ad812138e4c33a5ab10dc1266dd45cdc6b62e64a5ce931e61dd0b
-68 1 33 \\x961774b9f6e6fede5bd22669ae8ee1fdaa6e438ac78020ae2d80cb6a7198a01bde678c0f1aeadefbc646df6e445116f3517b660335f71604c80048a53d494b0a
-69 1 171 \\x105fdbd480f302736bb28851452b1f1552f605b6ac3771f34e0f9459fe3f90b77d31aaff0c35a05be9ec10052de64b03c234cc85694caf6c9673b66c99096a05
-70 1 127 \\xe502944f1ba5698f282c509a12d15f34da79a8d3ef1e405edead5875ecc0f9bb267a3e032f1303d49eb0197c7adfe50516e634abb16dc58dda75f954a48d7408
-71 1 251 \\x8790192631ab1917f8890e72e81e494d7ed224e5d1e9b4f18c7df2d39daa40ed0aa3687fb2e5131210fa49a22a9113f640ce5aaec21da08837786e4b214bf80a
-72 1 327 \\xc227072a5020a38901ac10c1aa2199d672b8779c4adcb73e1163f2ed121a540aa7c0904dc42c23ab0bf053f9a8e563f399e89089ac8da453c1ca79e335ea7607
-73 1 269 \\xf0385f6233a364023d710b51af2605b8f47d1d639e40fbedab7b704204629ec10e405539fb3e2497451bfc0e9f1799755a8833447e807cb376e711d6c362da0b
-74 1 85 \\x89cbb7e0e7f2b2520055b494bab0145ee32d0016e67bf2b3c518a8179a8e0aea47bb2f0adaaff33b4354ac0aedec99f386f0f0086e3668d6c410f0fd3998be0e
-75 1 99 \\x3c7d82ce28175b34b4031298e65b743a69fac66d9b64a5703d9dc8ea1019cb319a2ece228365e58ae6855a877cb2c702533880218c7b059dd776f460a693d10a
-76 1 169 \\x1d727d6fda46363ed2dece115df8c2c729b39ca2b5269ea00cebd0390809101e44df27a878b30fb4d8fbaf065dce88042530d612ffa25e892d643fc83af16c02
-77 1 420 \\x802705f7d3b71bcc6b3496fb3dd89082f5468066905c683db0cc71185ccd74af8b90928aa14828b547af97ca284d956a0a16fbfd9d25e97b829342006c61c506
-78 1 8 \\x9d00e40af81ac5387aec9cc7973dd25f12ec673fca0f4219874ed764b9e720d1b304d8a3d5967741798090882df84a0ecbfe828aa49b1ec889b756d100bb610b
-79 1 13 \\x0dedef5d253d1b2aa1822548da5bb8eeaa5b624cb63f8cb9850bf44fb716eded2af90c7b29b3e7e70301b2a78497567fe79b8f1a066c3e30c9190afa2685fa09
-80 1 88 \\x18814277fb7f1ab4ccf527c57f6a9a0003e8d636799b6eaefca4cd3677860861bd37b542c1410de9576d5a14692af96b6227ec38224beaeeb4a310db409cf20e
-81 1 68 \\xb0b8d95895b31a16578822885d829b5ff61a79c80d653d079d9ea871a2b3dd38e28415213d202fc3f0d30e524163725be40e7ad0df190f26192fd83e4ad13c0d
-82 1 199 \\xdd048450cea415b1f5237b345f288525db5e0a8b67d33e2bb4c13823405d1c4137b7c98de40ae21e32cceb435934018c7af38ff6b60b3d806a90609c524f3802
-83 1 172 \\xf0b4ef2038c216ed3e26b073b41350a423971abc2fbc94eee2059b2c0550b3277187e3ed5aa6436d1e618f487d6d403926d399e37ca40f9bd3d17b1520fe5100
-84 1 144 \\x6e9a4cc97be3b1b88513ffa4f1c0cc1be48c5d4a36514751dac1393295aa3e1b81de637abddf4435899e4ffe161b32879a579c85d85876a2dd4b3c040efd4a0c
-85 1 403 \\x39de3107bb71a119cf9f1c7c32fe1d869742d292de1f6f2303a94b8d8d3696906a9552ec35623669c3eb41e50e58bfbde4486300df0665f53dddbf1fc717d10c
-86 1 314 \\x5f06e91aaa98b78e9f1da6af1af3dcf8bdc1fd151240ad0dbcac2ee5a58a62c3b6730fc529db5685aca5b98f4c570ec54fa34cb37320c55c032c6d2fef18b407
-87 1 367 \\xeda4510a50a9cd6c4c239e8f0678336fa04de7ff129e0a0507265cb62974cd9f7c611ac1598594f80d86b53c6f8c7edf54e1dab27c17b77ee8f2d3e1e0ea4e05
-88 1 166 \\xa6ccebea305c6988c1ce77ffc576159b958457071c9e4f3b6e0ebebe0a646c61c0f3e37d798b4f21405237c40a1d3b06a00d0b01218f4d9c385b51893cc69509
-89 1 37 \\x0d711c0fd6a6e68787f6e1159e06b12a76c0d62894e5de3436d51bab4a6098d2c1883c42c875c7ea674b9a69dcc8a986b05339fa866cc99fbe1fa5aaff562e08
-90 1 118 \\xf40e250415b0c558cf65a190eaf76c9ad498ca4bdf434f7ad9a7fa9abe5e091779614eccd4b0b3051b52d8afbfcb2ab63a8e43fd890bf71298bef05c44244405
-91 1 119 \\xcb7f3fed19cc6a73d70f6a776b1ce7182e5a68075358dde22293cd7bda63fcbab28e99d69515f85ad36ff4bd4b988dd6cdaa5838dd0d20b085f2be2bb1030306
-92 1 39 \\xfb5cc8da7b9bb07d5169d0c50405e5930ac7a834f2d116d41b02f24c029b861cd3c89f82dfeb64c960f3972fabad1c3294926e6de856908d39b3be2db17ffa07
-93 1 218 \\x036e7ff7da4bb8aba2d94ef7b9e1f4614cac8d4cc65e566e4b8e04369bda5e24f21fcd75205de78cd769a475db82fb98d91e2548280f20eedbb8f485b0ed6609
-94 1 194 \\x0b6ce5bed7a74cb4cb1d9a0ba3794912cf44a7af041466f6d9799125d999bda771ca0ca5125df3e4dd973d72d7cbd4cb8688bb1fae9a4d43cfd62dff9dc9680f
-95 1 195 \\x690b09133b5fa58c6f65117143c270de912b62fe2a6d4d0b61d2abcc21653c03512bdb1024417b48525c8dec1cc124cb8a94112b82a84dc13934e28b258b720e
-96 1 66 \\x4f2692c42e3e23766682c3aaa9b5986c4c9cfb554e090a4d7c61fdb06f7df04ef4b6e3e99812bd6e0ebfacfc82cfd6e7e2159709e65e0330de8fe12080621a0a
-97 1 254 \\xe15b2830e60f1fcde2a28ed037012b49dff6f2b77d9bbf897abe7b980257193b97a283baf0b762d58ffb81a75ad91888cd296985b94111b843478c158514640b
-98 1 250 \\xd2b193212a1ac7a40abff386c75718ce03e5f4a92571223b3ef7806b32ddba6047ec64eab12d39ff2133d61925af65658a3261c10f140e3008ac9992f4c7080e
-99 1 167 \\x55bdd80941f9162a1886efa6de6aa83afd4a61a9cf99f3379810bf4112236e1e1fdd10afc556c807d330d882770ad54f96b5fdca9392bd06f7569ff3ef4f6b03
-100 1 275 \\xd2205f7b702632551c1470555be10f84156b5c22bb3d0955c4350e46b7047150652604da12b4ce80e1e874f054c47c4bc67b4e9c9755713d1f4feef618d5a208
-101 1 15 \\xc3583ee368a17f0044db6f38af98c88ff6f4bf98502a31a941620ee790f55bf33c9d5217dbbcbe9be84c5c5a5ac9e552adb650d9ea35209c5b972c4a0a1c0302
-102 1 213 \\xb4d9d6e70f5af60641b486d87ead857003dad4ec66358c6d2685ac2dd631064a1892f35fa32cbfdd9a53919c80c087b33cbdf3782b9d9eaefef884a1273fd802
-103 1 41 \\xc558f412a36da4a6e65def5b38cb6f9cf3d49cdd2fb86515e343dc8f87a61c3bf402c20c4d5e6f46dccedeff2aab5e17895f3ab6fe982e64588577aafd718f0e
-104 1 224 \\x13691955334d97aca115348102453531932c3a0a94341d99ab2700460209e0ecf9ddf721df51bd716eaa48337f3671661672d674b5dac63755d0f5a2f41bc30c
-105 1 176 \\x4e3d1ccd2b778eaf500782990dc3408d55234299308e48bb7a73cf7a8774bb1e965a5768e01b88969fc92cbce3d7434e79a85e882adff0bfaff2ac1c58340904
-106 1 61 \\xb6fd7d73db0262ae51e9b9b255640ce3016a705da3c77af18f3bb3f80e83bfde5c75cc33f452b90d2d594c3c40ffc97151cc7eedde7a4334dd246925e35bc10e
-107 1 357 \\x4b3dc34f9a78407a993703cd8685d7643c31063c457d310adc9349459a8635fd561da53f8fdb45c5c340bc50a0858d9ef54785539a9de1b9350f77e78397380a
-108 1 310 \\x954c4f48dd8354bb1b4530a8798e2869b571e37900c8b677374734f26a00cf532e00dbdc8eca7be3ca58aedb1a2e15ca165644938223a64c3cd26496e3527a00
-109 1 183 \\x0d64366df0828fdb674497e5ffe525f6015af43800cb645fb09e8719c8f2b4d6e3d2b87ada90db6f9a44e654cf053e600b37d6afa51d6534d474d3e3cf311d07
-110 1 226 \\xfe0aa93b0d23ad1fc9c9316fac99e6da7989f9e735ccc21ea6016cd6f712a197ea5de77890b0240d6021ef67df318ea6d3f405e1938bfbbd001605c1c04ee70b
-111 1 281 \\x4e1ae9702f88711b05eccaf337bc10506a00e78ed55a758d07cbd8bd7a1e8387ea56072b84a385b4f4d9b08ce5bd0e1aa131f6e6d36707778f3fa60c538fe50a
-112 1 286 \\xce80efb371ebd1fdb31125be0be6e684ccd5686932280cad5d82a9402509cf98385dacaadedb0f371be88e2858c39aea5185324e854f6948788364791aa8f601
-113 1 353 \\x6bab374a6ee366f5159c5eb9cbd644c929ad5efca795e841224780f1f565c2184d8e6f2e5b3113872640e6b4b504914ecfd9f59d0d5ed8b6f0c9b9e0f12b8a0f
-114 1 97 \\x83fab93d39d29751dd84bab57675c514e5eff5f964c8bca2d6af5ed35f0cad3479c4f663fd93d3e6ae4b32b5c8002e5302bdf4df1b8a7f449ae8dd3e3b7a1c09
-115 1 187 \\xeff0c0ac56ab4580c30d16f1a8bad864638bf3ae699af02008996648028520b38a4f83bef9e17943dffaece92bb62204f017607cb602c1c52f12673866c56f03
-116 1 379 \\xf0d67c6f613029565dea4872ec7c492f217744e15fdaed69ca5ea2f408e8b7db59b5110853fa5332de13e6eb1e67a2ec04599395640be18dacc02ff0a16b5902
-117 1 361 \\x8b56e1875dc97d062d22e3de8b722462746faae6b3def483f4b3689bb4e07eb7a5d82c7f02dfe5cc951182810fd237564b145618f2387d736d606c6fb435b40c
-118 1 78 \\x903746aaae9e006641c79cd29d3b40729921bffe226cee553eadebadb08ae471c6008fd4ea4d5e2d51f0bc0210efd9d0c97f7842b17f8e6b7cd93827ae083402
-119 1 43 \\xa1b4264475b8a721783318db9997c8c40001c95c255c25caaef95b324a235596cd37fd3459d9c2cd860a898c2c094a694bd2d3b6e67e78353b352e7897fb3d00
-120 1 55 \\x4be6733e01e8a26e1ad786bbcfb03714ebfef38846ffedf2ce323ba7af870e0221446e38b17371b1e93eb7a17178a4c5cc367c7d82ba26a7ef76b61cc02a8b07
-121 1 70 \\x945f331a5f1abbbb15ece49ad46168062c48ea97bc6b93b5e5cf88b30beba9efb532d963d995892f0951f4df3396d66b3987e405be48f7ccb2f3cf3e09a3d805
-122 1 101 \\x0b7e9837c9d2b32b185a3eb3568c60c905ba6367b2e0e458f6b88b5ea0bb2a08d6bcfad45519b91c252f61276441f3ae450241bb9bb7d33ee80a0e02f82c6c05
-123 1 322 \\x1159406b9a5c9ece4daba9c28599a09d4499449504ba37fac3bccddcc67145c54e30b416770f3755711c8279bd49ac34ef2979505cf3249b21b5cf6537b11208
-124 1 383 \\x4f8a85b2920e2f22b8a045a773bf9332f6036f91d10dd0b2af1586caa56901f0b37e39a71407f1c9696fe540801fc08938aef74dcf7847f866ef4ac433a5df02
-125 1 332 \\x6d95c3f686df26e1448aeb0c4d56f31170cf970ec958e6f28d1e1753f59c6811fd7a7552b556dede4772fc091b90c3344b6e24fcf7c9a507eca000c3b7bf2a08
-126 1 407 \\xacd69dac53a0de0ad3e9b4e53a463aecec4d34f3e2d11652269e1a0fd492a0d455c3cedb494319e7de48311cc1a87efe7a7267253d3c0554ca7947d15223a200
-127 1 164 \\xfb517771664860125f775e48ebefa2fee7021205f4f7cd26c2cccc9682b775c38c411564f9c72ff9363ecc465eb2f27db2efc7afe6eb902596f5065eac262d00
-128 1 75 \\x3ca8fa2422c07fcd3b14b3ab072436c4093f0fd2901c409811f82f4c5c59de9efc2d10d08436f75d58531b6741ad50f44170b9bfb3b6c56b558ca7042fa6f504
-129 1 73 \\x0a1e309d0a436a02169ce4ffb7c812f93a2ac0609f7910c25f4c6aae233dc231e7785f22e154a712dab73b2d6611aef2f26f290b438a7aa5f57b9768e92d9908
-130 1 272 \\x05a263c4c2f60a47151a63eb73294c4d37334c9c927052f8a5ed9ac79cbee550040250049c4cac3a61148dc61074b18a1ba1f99dda1201de67d2774e1f7bbd08
-131 1 304 \\xb49e7e930d3572d1f0ae9b82816244e52188ec0a2c59ed08701570b30cc8f2a01b38b53382380aafafd88391e2ede502ec939b183bf4d88698ba1477ba933802
-132 1 296 \\x1d56da75425a358383ef3ddb15333ab8f430adbd840e528d11b2951ae3e1a8eb32b03a83ae8129c1fa69421c3fd51012c008276b3a1b329f03fcd8aece9a8105
-133 1 123 \\xf8b6530a85c2c9289b45cded642910b07032df1af71e258fa342a21b2c07ddb9d0795e2757d154b6692a2d6321f6878fe5d6b832ee269a15bfb8b0f9fe7ac00b
-134 1 35 \\xd912458ab42cf8db0ee4a046284cc0f4c4166f4d5b5d4c5dac659acda63ae710948a772e372866705dbf842ef93b6a6333ae0c54f46d73e79b7c426686aa870e
-135 1 257 \\xf9bcf0c1e9b9be3c34dfc4e1c578753e3a80d17f6b9150d2275a1efa0287f61454d03d9c802d134104f3cf4c59bc97812924a84032a6de764500d9a2011f7d0a
-136 1 324 \\x2beb00a0eeda96241520203d231d549466d090661c948a1186cb28b03a16748dd279c3a274c3ee15f6f07b0152fc2f75693b704aae1532947b83031acd5e3600
-137 1 107 \\x5653a6e7f40ba81d2ea7ebdd1c6ccbc17e83aeb213b542310b0dfa8c0cb3ff68021d4c9913829743f95e2386de99be872a8bdb921f7b33ddb56661fe8137220f
-138 1 346 \\xc292fd79d21fe315af5caf56eca59d45d5b629727a238ae1fce6ddb0c814c026b64d05c3b9eee72ca35d5af2e25550b870025b9124dbdf31ff9a024df44afc0a
-139 1 247 \\x5c601b650a20743d851ed62dc3d67cc98c7d106f6f36c2194c8911319895d34b08d7a08957ffc4b0840991bb37001b5741a4bd3bab8971a2c1dbc0f536b71e0d
-140 1 148 \\x0ce017fa6f0214089a7ae4c15a6d0c6d1401f6d92d22658aac3adc60ce0de5e118e01af4e0f4e4d91b3dda078178c620b81456d2c16c3bcdefb49797ae24e205
-141 1 230 \\x10dd8bc1cb2454d7d087fbb10ea8f144e8e31ea6a2974a7ca21c3081fe886dc594b5bda10fbc824a74186318cd08c36ed82fddf1e080b87be00fb4e96b94530d
-142 1 9 \\x4c09ee6e0e6aee6603ff787576c8ba5d0a557268d94d5465a4797faee3e90120e14fcc1e9ee289fed4b2f2cfa8ada5edbe9b56f0858d78f449185eebf2ee070c
-143 1 211 \\xa74df4952d4cd54643b4eaedf04f39d9a7f74ae3439e1d794c81b50144d0b55bb91888b025dc21bf93bd78961c7c4e727ca5032b30804895fdd14e5cf7572304
-144 1 384 \\x1816b38764aa1c529c13bae2f4319211c3373f0610de35f2a8578ef92c078c90d6c06c3d00241b0c3ff2852e7e7afc0d388fd286673aed9389ad5062ae863008
-145 1 69 \\x9c7cd606fc296a0c4b402684c15fa341964c3f6dfeb5d88a7b16b852a88a9a4d4f19998de2730c5fc2593d82664f92ce9b698a7e3013eaa89a5f432b3b2a9e09
-146 1 16 \\x6f567e08993ad3b12cb432e3b249f8eccd8634e2c7afd6e38a8eed464cd6d7d7e335a4d0d386d33fcf4ddeabd13c40e7809134bd01cec5362cf786e470d5b900
-147 1 316 \\x114631e49bfd9ed48c0d0a22a8c159f29f4c48d9c76d418968bdfd27cb26ead2a19632d11da051620d18673bf3d4654045cbfa9023921bfc02b15a099c87d805
-148 1 374 \\x01a7ad82ac73f78ec1663ed5f533a43bd680115903e10995eed68c445e98254dad2308baf41721ce2125028debe693cbdb9ea5c6bbd6ff243f39e1dc67f86902
-149 1 278 \\x1f41422d925ff37a8559e5d86523bdaa839a23d04d13bdd6f63cbdb595e8dbcfae04a00a07e2b102dd38e5802c19e2c0638cc3be8853ff79303f2e9530ffca0a
-150 1 178 \\x02dcbd9a6de426a349dce45edef11a3512a11a81b8a184e51d162dc23ea209b2c2c66969623a4e0808dface4a6d2d2976d957f67f460a55f9cb38d7f6cfdd305
-151 1 333 \\x771556da6be86a3fb9c2e874846fb620d2c69ed6df8b303aaf271a4ff97798e09be97eccfbf8bd90746ba6dc5c2145d71806836a1383639f4ca2bd93738cec0e
-152 1 411 \\xdcb294b7e2eaa695027ebacd1e2b5d9d24d2dc7b2a86fec060e5b1a30cc4406f6d90059e4f78403b131aa9d681d1514a4bf21b145b3ee9b314fc5142301db205
-153 1 56 \\x98744ad758760fafcc54933c9b57195f06c2a66f73f7e6790e3e061ef9e82b65ad38bf358ac5e2d7c619ea1399f99cef098eaffaccb212bc0dea666576ace708
-154 1 22 \\x7148e332c8f1ec40a07a585cdfc177c4fae7429ca6ad5ac4bef988d338f9004f97be73e6264945ad29a1873d7d712f34e8899978c941c2f97565555ec414ef01
-155 1 410 \\xe94e1fa61c73ba09eb6d7b020c88028822ef2cabdce1ddabd2ce5067c2839ac58e62150d0f2ae3fd5b3ec7f547cc1a80da6438e48bacd3257cbaba3e218cea01
-156 1 343 \\x25d01c1e78da687148012b39f42c51c4f233759ae84911ae0f134663b7d7df498ca80cfbaf0601c35b68811dfc7a427d13cf44b67077496aee2055886bc23707
-157 1 47 \\x84d3bd7e14ccbc2c82558d7dc946012e6c0f11d45011462b5315a8e5a37e88bf3373965c50c60870610f704b914ce628699c5e2a83b2d729b56151efe28e410d
-158 1 326 \\x984438dce1dc581ad6f93a5075c41129ed2a6b8fb832d5dc3d6c700fd4546fea2b1fe945ee4c05fded4dda709a8bd8a374d5b7d26b093ce35c279670672b6a06
-159 1 17 \\xb93b7512b4fae2c7eacfe6bde1fffd967c0d2c2ee169cc53fdf02e36fb7a3733da6ca490635b08bc135b7b48052104e032e1b103211d7fbab8621157cd48bc0b
-160 1 398 \\x2d5ca3b5d5082559ec53daad114263ca028b9801acc675b2aafaa5e7ac4936e19b1f544dd54ab01966fa00193462ec7b16f57052353d153fff6bbb309dd4e901
-161 1 245 \\x241222303210798ea83810c1db030403322d58b77371cb5ba9ec77a64e46e923730ebfd9a8746aee82cc4537e8ee22e94348b4766440f57a8a370ac796559209
-162 1 330 \\x8b436dd3fbc13722c3cf1114467c186b036826c0a474a9c89d890f51ce14c50e7397dd5e0c917296346908e3a25ebc1b524eb16786a1d70eeca05b15bc13be04
-163 1 419 \\x7b0fcd096e954477445faa91fb64201dd160599db52f77ce1061157866cbb86faf065f954afae74ecc17f6a210467948cc9b55580a76d4b28f936fc3a95e050b
-164 1 122 \\xdfe05412fd1b903094f6a809b090150ac05d2c21e5a9afad3b9e6293691910cad8171fbd19a79bab6e89af65b51a5b7146d1ba8f5027e5bf50169f010c893003
-165 1 184 \\x5fc81eaa47e6921d1bca144653ace24fa7f73bd69e28b90a82e2e51ab268e573704c1a4f124d604f6fe1d408dea0dc9fa5c784dc93360de46f4a2b9273e61803
-166 1 5 \\x425c6845cd49a0e64d015c3764ce4be7ab8994b725da74a0a4636b4c26f1abd0461c339c58b6535f6b30ab7b8df0f42631f3bada42bb014f2f3f9cf0a1376802
-167 1 260 \\xe613d814573cfbe7b3b7dcc0a611430331c14901d1ecf0b920361284bac554396cb091ade53dd73d806a30863d03df89ae1165baf69910a4a17d418624597e0c
-168 1 193 \\x8ac964770c78b85d4c2ca95f32ce9e85bbb6181e61debca7cc830401d2891c7584cacc6a13cfabc51fbd9878ddbb99fc2285ba3497b68b260a51ef7e833f880e
-169 1 51 \\x4a9a62410ebf3041599b4bc2a05573499577753fdead35246aa35eb50bf4b9011b66ec18c94ea08e0ba7ae86eb9315d3a998521d585d7cdf3d5408235d82a001
-170 1 82 \\xddad716c43dc3f2d0f7da249db2bf9de900781713f9f40188f74dff5b0be444f9ce3ae27c7a024717ff08db3c10fdc39c2df1ee17d9d05d17b09d6d70aa18a04
-171 1 115 \\x43a2f59fcd9b62e3a3abe023b815b172cfdba0f6f15dfd1f0bc0b03d177b06fb6dbaaa92cee50241c1b22da58c1fe5f18cd4898c8a411c7851f4334e5ca12c07
-172 1 67 \\x9389a23c1da2c743d93a029fe0a441cade7eed25ef94d1e9bc7f812acbb650d4520c4ce9028fe568f57aca2f81769a61bc784fc83dcfefdc6217b853dae11e03
-173 1 111 \\x2cf11385e75deadc59795c30d1735bd249af4e2bc65e214e6167e17eee78ad533f0524e7bf2e7e02af6f59c27c57a31cac91f0a7616409203b454d4ebf99370a
-174 1 210 \\x816403b5ed59f0f502d36b88d10192a17ddf93c3ba6948b06dff4d9bc21957db25e6496d2f3d361914d20305e5cac54ab662ad5fe512e02d71a44d71f626f304
-175 1 302 \\xd0db64670baeba7a9ca3727aa8c00ab89725b70a0d8cbc09dc55073a36849e4ca1b4cc5b2fea5d5428ffc68e666ac29dd933a4606ed9f904c34e70e5f034f60f
-176 1 87 \\x9e1b5c22acae6b04ab9af0b0db0ba1d480142afa3bd5d34ffccc240d7b8bf7e1f8fa8dd640d9e5a491b01c4ab4dae1c181a4478e0ff4817c245c942d8151a108
-177 1 313 \\x77724e3d4538296067fac32a14ecf0ee67cb7769ca2875860879029118f6d628393708962e77545a2c8bdb327a760ff28694690a1aae093f012db91bb1c8ae02
-178 1 373 \\xca9a1a077b22fc462bb43913377620729691bbb4f1e51bc7e99d1b0ca0912528934866639ed9898c71c2c962cb65339711e64747079791ef306ae1cfeb35e302
-179 1 168 \\xbad73902e5761523a4e150a57adafad79c610805450a6621c3b154a2ed5f3850df10fbeb2d29d208966a257757011d8c6ed38616c09bfc448cdb3d917a92f70e
-180 1 153 \\xf8de157038e811d4d6200af44f2a94e38ce69f7ad02310aeb629ef82eaa656db94264e32043d55684ec20ae0c303878008e7cb8de9362e417a9f1efbddaf4906
-181 1 126 \\xa735cae1c90e6cfb3ffcb9ec0741e70fbbe2461e58312fef56252e50982000a70efb302169c4da92f6289acecce55a81d4d9279097260002b47191cca79fe401
-182 1 109 \\xf87bd2308169ea46bc2c654f0bb9716cfadbd8b82113d777862940aaacdb63fdc7cf3bb16bba7e07ba8fa16faffbe05a7558c00650974bea1878de00a6cd8508
-183 1 381 \\x07731a0125ea073e540210342b1b135a4027ead080eea953f4e4c24fc971e6fc2541e5a02f89fd26a963f10a59babb63b04a4436c0ae2dc7d1aa2dc3d3f8fd0a
-184 1 317 \\x110f57530eb51bf7e77be2cda01cd404935809ea101b5ec0092f5a3b709ede0d2c8b048b70ed2938f1ad33e1b9d3aac74f0f11dd9ccd70a29f0f5920f548630b
-185 1 205 \\xad3b45ddcb27bbdf0f0d305898feb7095f9ba00dc3bd315355872f16e200b86aa3ec9b3360e330fe8a6d69f503950bca0ce94162b1efd9ce5f3204ada720c70a
-186 1 397 \\x946a797f7185e5376783e934473a8645366f58c31a1466a0e28d58b05d4d27db5a89606d7b15c431e79914543cc31976f73ffe52b16256b211d6dfceea88e100
-187 1 364 \\x9615d1eeb54b5e433a8b67470b56217c2ba728f7b829ffdc96701eaae0147224df0268288cb33d64c8e43ee19f32e0c59b357100941f3504ad74d0362f6dd30e
-188 1 273 \\x65ffb69503076f3c4781ed3e8eaca03148c3b1cf6e679fc8b765a9119d84e351af857f3138d9a291dde3f7efbe0046a489b1d59e5ac949c187607ec2df2a7d0d
-189 1 2 \\x704bb7f7caa9575fa20fc0141bd512abc88f421036ca866cefb533a41c6bd42b3418532510949f9a8b7a04cd3b23920b7bf70309f76dcecca8f33e89f6cdb60a
-190 1 350 \\x1365852ad476fcfa4511e9534747c78f49ebf1721cf657442ae280e1b1681d7a51557ff01169ef397fbddde0566fe37a3bff4557b2cfd44ee2607f5bd23b210c
-191 1 345 \\xb1ab3b241f39b15eeb6017c162ad1c55a472d34efd7dba9be6bc44fbd00a44dd5090ea5040bd8fd6d88c2024b327ca831c31be2c51a36558435b3ef06090b60f
-192 1 268 \\x53e171d963b13cc1cad284fbee7bd875a9893b34ecdced11994f04b13f08be66d8157c5daf5a5273c3d28831b563502c808d54bf57b0aa766f723e2389a30202
-193 1 394 \\x181af2895656b95f6bbd4b0e3faea1fe4b1a7216c3abb7e33236e1d9bae7495c6558bc33a49436eca8a5cc5dc351e03d8a9e5bc7e5ca51b43d3884ba34c8e805
-194 1 54 \\x585c434d20962fad1323c2c6b02aff13a884d0bc26e5adc8a892a4cccc9e4f4d240a7e1b84932aed890a2b898eab33a656ef958f954de4b6698ba57546457c04
-195 1 225 \\x5f01083a513355bf37a9ee86b762b501c6a1e3bfd5d7f55bf9c339b2a1a5e1b8759a585d480d4cce276ba9329aaac69f8eda394e63bbf579ce0b35a7b0483c03
-196 1 276 \\x0e5387dae9398be525f7fc57fd030f086dcf0cf1678f2e058bfefd98dd43b4f29dc6f88b6acdd3930a6fdf1da5e429ed4324fac2710f14cc2e1df8ddd8a4c103
-197 1 395 \\x0e08ef0c06bdfd349d2df6161963dfc2b8936e19d8939865a25373ffac0df641d200f45ed21a0d0465f20bc2c3f621d660fcea104f1f8673b24cc022bf74ea00
-198 1 152 \\x5f18e3cb167d299082e7e6598a66d1f58c08271af9a2ff50c37cc3200ef414cf60c3460a518b65798ae11b9bd2034c1e7596bffd9891d0c74a98ca4a9b73c400
-199 1 219 \\x5e731fbe1e79e4cce1a2b75a6ebcaa8af1796b490650944d7516ae1af34625052747d5fa1f37e11b198af4b9f3e10c36e6bcfdbdaf867da7c0e73f117af4ec07
-200 1 340 \\x8e7ce7bd2fa7f6899d0a7a6b1f03f1c511a5040d5638191df0c9481d8f3028612cfe0dba4fab958afa8df46a85ee6cf70646c2bbe39e74c488633557f182dc01
-201 1 320 \\x4f8a4a411d57b24d722b1d77f34b5fb72304f68fc7c313bff7535024b58b2a5ab2f1df5c291fc39ed13ccf709adc4659d3fee70314b6ff0bc64c8d74588ba00b
-202 1 71 \\x37d89ab9b6cb6a579eba41ae91ce952b8339419b6e07b173c301c5b2bb6e8902da1ba64f459e4c92382773a2f14898c3b93763fe601ef7a27d8667532a3b2f0c
-203 1 128 \\xd30bd12061911bd32a8e97f436af36302439718dc39b96ee8ae21d9ebf597726a128405b6ae2fc499fc85c63201bc070f13beedab148e57af63ebcda822b410b
-204 1 212 \\x1e8285e4b5937e473e7445e390c657dad8b2e21834abb0c0d90756f8a2be16e2695447b2dfb1fe0d12a22386bcea60a24617da2bb3be6493c20962f3c7732708
-205 1 244 \\xf0cd06a17da0f9820b66bfe3c7748cb672ea31bb322e6e48474a62ac55502574afc704407c8eb6f2c30364992668aaef97326551d2e922b1f938998dcfbe050d
-206 1 423 \\xba403fcc45f41bc4233f452e4dc79b72d3d0cf0715ba8776ee5489734a1afc783c392511271f68dd89f3d632bb5c68f1a6f514535da066d0d5ce94bc79e1750c
-207 1 258 \\x9547df35b5118582e2a614a6323dcf0216e8f3292ea086b16f3ae1abef139c9819960c572997e5acb4dafa7c58cc726dca919f57caad00c2de12e998f4e05909
-208 1 282 \\xe453ebcae9f9c4006a809edc53caebbdb16a20fe0fabff34bc9f8b5653bf6e904728ba5536ff6ce578ca12bbd3155baa7acbfbeeec6dadfa4b30b7201178fb08
-209 1 203 \\x3ec8f9e305809729b21d5602cb1ba8ee96e71e31a95b21c523c5b5091004ff9d16594ba4d3985d6b8be4c97fea8c7dfe1859d4748f18aa6805c806ce59b07d0d
-210 1 137 \\x69e9ba81e036ae3345a391440227862c7c6361e33866b7155ff5186a01dbf87436c792c10bb3c2fa89095953c161686551b7430e9a83ca98cc464923a5e51908
-211 1 7 \\xf0afd6283f3c45ccbc51d131b70cf05b67b43aa4da2549639d34ae447da302eaa42cb5502a04bf811953dfc481f60c89fa00acdfa2199254a7ae19cd3047720b
-212 1 387 \\x300995368a3236be9762ae0b97bc0aac43ad79fbab49235c42766b89c8f1fac44641a8aaab5438f31263b6aab93252afd0af27a99e0df3f063ef8feb850db306
-213 1 318 \\x734b19dad16f25aaa39013fd3a3a93484d3161cd3f1a2d1302fcc6a3d0a66abe2ce486fe5c31f1fceef4b0a431432f5e2c0f24c9bf78e8196a3c2088993f3c0e
-214 1 356 \\xd4b1848f6a05b3b4b307f881a50ba72171df26dc15aa673145418dd3746184f8745effac08c0580384d52f1d2e52634ffd47d9e20b12d1fc303c93bbd4644a05
-215 1 173 \\xc8919d52ebd81fc857a5248b9df3a43817614599dc88e215a901b376c88e8a2d00438f81c53a0cdf1baa30740f2a6ee6401dabf795ba7848cf9944798a361a0f
-216 1 404 \\x119f4cecac7bf5c2e676fdc5ca1aa734d64ae6f73f483340b8e2ffa420e773a8ede38023a7af1b040bc10f8981e67df07ab84c805a7e57e978f467ab75dd8602
-217 1 64 \\x9388f16d27fb0d7cffa6b693a189aa680efd5ad035ecc7c7f383c621afaed74a25dd6e8cde2584dc2be9e967e6565b753f8a81baec6b9dc9cee6ba4eab648309
-218 1 146 \\x10d148630de3850286faabc6eec9baaa9eec49d847c6343527fe7f46aa7093b6a941d927fba0b88ba1f0626d9c832f3020d1914261059c0d8087000652b67d0d
-219 1 305 \\x350ea5cf3d6a0e86d27ed93a377443f4e3e9d3b05ac137e12b54d77eaa55f4e8213f4608bf6db8e87918ef93a37526bfc8de8d2ee7cf81abc71fffe6ae8bc40c
-220 1 334 \\x379e81631551baf1634d9b7f6d652b4259052b68f5d971c3cb4dfb75cb59a9b89db57217b5d51b697290b2c1a8416ada0113bb650353b5815bcc1e4a18fd130a
-221 1 365 \\x315ee4a79605932a398ff2bd8bea935496f5955e265c63e8e1bd5e7e0339a1e4ffcd1ea330acea09d9bcbfa002138bec1868394d3cea985ae68321cdfc7c480d
-222 1 370 \\x18feeb909526f480fba8a89204bb53e22af0dfd8037a185347cd1352d902334084075795d59eb8f0e8111ad1de1f02de4b4e7d843f6ce979702e393dc83a200f
-223 1 208 \\xd5da9891d3c073f320afd87a94de0fac31f07d7761b058c9fbf4f2d6bc53a55e6fae4eb8862de1b0810adb4f4982d31773f0f72c9d42094ec1c24d5adf79ac0f
-224 1 125 \\xdfe93a51baf4d2359ea21544cabf10b06bdb0af0c5b8db70f1fc7b681eb85c0140bd5cec506a9db7de622d33bec0ad21602c140ec67a260975f784ac75980d0d
-225 1 389 \\x74b9f9dd22af3683e44891b5288ff05d0c6c426ee888d355e9eef06cc4102cf33ce6ddc0740db4e6b563638eefc58485d318f292cb4569322fa8b00831428f01
-226 1 288 \\xe41c0aff3b886f00d3b07aacf4225be6988bf3ea862f4547e4a6746c2854a246e73e94dae6645c62974959ca565c9d112c44f59f5a0c544c6ceaf9eec9b6b801
-227 1 382 \\xd5fd17e82a49ca49a13450c51e4f4a02af43938c20829025bd68403a75d0518f2c2623abbafae2796fd99f1f6a0dd35c920e8bb3c2fd2c4e47b3c268dd147f04
-228 1 80 \\xc0ac40b26bc8aef05e4fdaf915445f8f8d2115e619de51e552ac93d96f8b8c237e7a82aa27f4a8d675d8fd551472f6bec1dfdf6766bdc6678f2c54db24fd880c
-229 1 328 \\x6c1909d60e91ca5445bb23acb57230259677327609d0661a90ffed7b0ecdbe865bd2b160d7e72e4ffe576d45f9820c0a9df0dffd8d4c1f37eeb035a689c01105
-230 1 174 \\x6da86d46b709e346882de55180c5e224da793043c3550409502316ab9d90ddcf6dff9b68ac150e3d227f110915b5be2dd309caed07dfe6935e5588f142dfa70b
-231 1 18 \\x7ad5d930850ac3ff2026df6ebeeb22ab819ca69ee9e6bd2066da12c62a55eea14a22284be596d195e26d3c61c7dc78da4ada2353e6638b1a1ba816e7843f5f0f
-232 1 267 \\x411515a0d6ebfdde6cf8b5f2f611ec16175290b3e8f81bf34ef687490e529c9922174a0b8cad9787eaa0aa316fcea280a79df79f194455fd7cd1f66692e7de0e
-233 1 354 \\xe32d8edff65ebec2e669ff2dbba061e84345eb930b96e59b48699e816b74e7094ec6824c3a5795b64970de939e1bec1355a920a610c290f1317c4132490c6c03
-234 1 155 \\x158de7c336086fb5d312fe1fdab47b766da5f6969633d2f40e471b1bd173dc7db71ef3ff265568eaf96041670f8360dbd9bd61be657a392afbce9f10e14edd07
-235 1 63 \\x5ec491faf332258dd19af7462533d792c880697b2acc72539b9c1ec6c10847c017ca8a1583578d2675310fb7588b8b1d04bb872c1805e1c169b8187c7ff4f209
-236 1 34 \\x38200b7d2c965be6bd31a7c2440eb6a125262fe9fb2edbedf9e191f2861575f2f7f0cd4ea70ef723bb1c24be2d283553857fd29184add2413b0679260b60be04
-237 1 202 \\xac05a0fc5059d7e8c80d39469cd5568d2c11329af1aed38b6e6eb9159447104bdefda060abfc2d72ec8f09d0f7f90d77f0c289cdcf635861a67b72c695945606
-238 1 295 \\x69cbbda1b7a21ea6815b39a63facd45c025403de1786a29347d7499cf831cdfea828a3f05fa4e02d83f4211bf0ca14845a3f9b587576749341d0b83d2f281906
-239 1 235 \\x9e0412e8821540f9a08652c6d0e23e377581b7692837f391c8a612905943c681f45d7d49d52e577761ca68a4a41e3eebd2fc2579a9d865faaa4e7e1355c44907
-240 1 149 \\x3027149791388d24aaf28dd475a1d4f642a69064723653317064c34babb015fdd187394a3767ef1ce310282de63c2047604a3af1e923adf9e0ea8859d2cd3f0f
-241 1 309 \\xef80c8fda01478e2015a951e98207a9a53386fc329e8e3b03702e2ba295478c4c56558b314659f94455be19eff947cf8d41776477eddbca39ee8ee9ffbf78708
-242 1 418 \\x0b30912ab8ec1464831a64641e1f3a3dd383d5b78c17c37b9293ddc5186e904a920ce63dfa818c785abc388d8f87971cfeaf0b387478519f288240b27075d005
-243 1 181 \\x81ce91d47dd40e6e95a183455fb2b47bade325b51e6ef11c8662c37f3bc7da945bfa8c40b8723e8c701baa4f240fd55670675261c397528ea4f05e7d73673e03
-244 1 307 \\xa684f03338d830b5a432318b71621266dd679b4875c0f3c4bac601136384328f2d62e962206fa7a41be6205d746446a4311a02723e6dfb346e212135d9ec3608
-245 1 335 \\x7267edfa467bd23a1276a3d16b08a088b3f11eb84085ab4c75cf95c9f0d9f010018d65c17e4bcb0e83e2a3be55c6a452a2497cb402757b839546850a857a6c0e
-246 1 21 \\xca8f94666e6932e3f31df8483b6806c22b87e567e52d0365a0a2dc4a7d9494f6238fedeba7c25ee50eba2259dbcb7bc3d0395778ec7ced15c679b1573d2d520a
-247 1 285 \\x90497f7204bf68cd728cb61c77d4e89dc304bcde5ffeb97ebad8dcf8cfd30fa26be67dd7b2adf30f12447ec9b3c527f664a30f1d1e8deec24e8d97b932f5510d
-248 1 376 \\xcae2ed6528f02bff77007779b584acc5942d6e8832072e814dfc3fef73bbbcfb54ea447fb768659901c926b14f19dc46ee75f934f61f6077f8317c90bd85c005
-249 1 32 \\x5e63daf460398dbedb34623f338f5fe8589b7866d55023fdaa7f1f31f08692f74ecd61b0c82591420ff3f28148de0414d8ed76888fd998d68aa4884343d5480b
-250 1 12 \\x6280f5cb079c24e8fc00ee7b5d05a4fe882ca9668da82df885e3e3a99630040213f19d6100aaaabf8063794bb4fad2b3b97d438e574c390752b51455f1198e0f
-251 1 6 \\x940ad6d0568faa9fd9c8446f222057f99be7e37053bbb72d6f232e23d7ec070b1ce810ff829d5d0039cf9db4e1278011d81807c96bcfd4220a798ae8c448d00a
-252 1 255 \\xb2d4b601c0592369707b23c7e7e612ad94127514c443082f782fd3afa5d5f974eb1420f12dc0c83609fa6df411be0ec7f39c72ebef4af4e8fa68926503334601
-253 1 129 \\x1108372ed05809b703eb416198c681200a909923267f52466048788a9f3f3d03d46da1d212a3f5b1a786b4b77aa89fc6e00e12b0a6cda207f547d69e54c1020d
-254 1 229 \\x89011ac351a5dfdbebe1d7582300e3c7e2f6210b7502c2c292dbd3f8996dea099ae6b7056683a33215e0ac09e38062e3beb44a228f17ae5b629e06571f13c306
-255 1 3 \\xd4e76ff817bc1a0574f68a91a60b235dee8469a090ec138cd5039fbc75202cd987b7276bb6c185ab9355cc5d0b9f1ecd060abab8511d7bf7e34c2bffea0bcd09
-256 1 312 \\xb8d8efbd8eba667c9cbcea464e37c2e6a560abce121398a4bef052dd259e30029c4aa8fe4481f8685212bb7c1f87c06e064c8a835d5d81b4380ffef0d19dcb03
-257 1 347 \\xa341acf12daf89eb5906c5dde588cc7c39091d39f02ec3c0e50ca0025c7cbf19330d9ba5b7984b3ee11addc6d8ed0359f6f7409dff503cfdcfe7b135f703160d
-258 1 84 \\x4ac50cf12f4b1d9487a46fad88098807a85ea3364449cb82561df79f1e543f25cbf941e0f4d1c5d20d46f4a52d6a5636b83be403f10a39de1c90d513ebd0780f
-259 1 277 \\x53498bd3e81e600c58d544b85a4bf219cba10d2c23d9f1625e8166e349862e56f42577cf7bd731a69a43d64569983dcf91cb0099a482c7bf606698cb601efd01
-260 1 321 \\x6fbc3ab87a15ef44f6ab00333d87d798ef0f5df4d0d554a373f89cebedd8e295c649ca080e15c111ce68a3dee9359d97172fcec79142eeafac554a7f03862d02
-261 1 92 \\x5fb12efbdd762adfe9206b930bb4f26bffcf17e98053a32f44f6f30bec9328df4e40643e24e738ec9f75ced733d9a26b3343aab8e41f60540564003db632af00
-262 1 206 \\x974d9f62d01be577fe3a3eec1593c59c2a9b7090b369a34403bac2013fd40c7099b4dd574c07da2cd6f1a9f15da921b576cddb19e8e5abee68e048d82e00570d
-263 1 57 \\x83d9b2b1ac6984716db66a8b0fbd7073c8db284c0e32439d1d75baef7365757d14ba5980b74762e4fa51b01a8b54a3c9a61ed08a10f14ebecde8f9dbdcc5c008
-264 1 283 \\xaf4f8267d5dd56a5ba3ce214baf449d24e9db0a05f922b6c247e6d78e11785728d41737007f2e5fe4350f4eee113db33657c9887f1b7b482c331d8907cce720b
-265 1 31 \\x61ae71e80dc0ba6310162d0effcc99c9f30afb203f65b354120be1f3bb8b8dcda68a634fc1b9402c6aff70fafa8dfb839a12ac5dda1b7e82df0721551d25bd00
-266 1 58 \\xcf5e5aa18c04bd4231bfbc28ea1e312d6e970c9dde2d54a203b5f532701808b6eec94d4f113684d177ba39683a78eadbcae598d01a5a9bacbab26468eed21e09
-267 1 236 \\xd5d231e4af9e2247d72855abc48f4e8866abe4d0cdf02b80a59e33fe56d3bf7595febfe06e5d2ad6989b5ed59d1ca36c775727cb0bfa00f2b7f91f595ebd8e0b
-268 1 228 \\xafb7c8de734006382ee72b15f0879433025dbc1c951feccf45f855aa5a2ecb0f8b0b2c48ef4f2ac01ee1c62007abe32bf054b400daff9d6c0d05ca44bfa7c206
-269 1 36 \\xa0b979c048f8d4447dd040e2652b2b7e5fbc1e0a444684761dfbb071ae47beb65a93d2e4d22014b8a5d3338860e3de3374a3101ac87d9b43188d8dced85e1707
-270 1 182 \\xd1a41305160f13c16f610f95a70384b73bb935b404796dfcdf91402b32b183020756a7b0debfc975871a515c8716811167b4096cf5ac283c69f16ebcac2aff02
-271 1 89 \\x77ae5e94430939d2a5ae1c2109fd4bb2724925781ac62814eb3f8e78f6e82dfff5ec88687216a0d3f33dc18ec845188069b2f393c7c6f4f297bedcb5c763df0d
-272 1 83 \\x590fb730475d936fc7a136ff1af02d3752ece554a89c22aa737dbb5929aba72219da6133cdff048609fa0b07354e1233ddc665c4bd34e2f063031179e459f30c
-273 1 139 \\xcdadbdae6c502566370004af6d94f2a198627dc018ab7bd55cfd6d46688fb633a65a37f0670b2b98fb324a694cdae7ca4fea5f54f77d271c816ade2b3d471d05
-274 1 145 \\x4951c03289811442e5fc443445fea4c417caa8ef75b6d0148c824c2a611d24dbb82614109904c6bea5f3289235d48da280b94f9c690cbf763ed3e8382f03ab04
-275 1 261 \\xab5c2e0008ccac0a778a089504e82acaf42e1214750e1aff145079624e1b6cf1811af86c6fe540ef6e51d1d12f3952354d9d3bb8dddb27df1c4c7abef6a0ed0c
-276 1 106 \\x94c3ca02c67bffe324108cd389ed99c573d7b9a7cd338e911ac49f6302f8ef9b3cd0a098ee3694fd0523494a193f37a722f91a374d31b5222b9ef9a0707b4d0e
-277 1 162 \\x1a8d6a72e4c9725c22fb2b8f118f48e953824acaa2613b52d8a98916bb9d131bae020abbbe33b21c324cce76dbdfe1884be610e1309250f0d71ba63bc163a80d
-278 1 158 \\x0adafabb4ea29a88d6cb64d838f4fc929cc56776bb5a4addd11998c03612768e40823f0067cf52f3654177954369cd8fc48508b433911fd41b81cc1a0e8d2903
-279 1 358 \\xecec0ac6ea8362d1bbbfd0b043a90ede30e3b6ead5f587dbcdf52221166d21f4f2d493c31e9eaa027ca6870e524888e907d2821db38a604946c4ec185176d80d
-280 1 81 \\xd2ab97e6d1805984b58ceb3911a2fae6dc5b212d85eb81e5a658dd358ab390012da27fb6e3bf3a7a4b33afc6b542639a1dad9409073d2f2e7b31aa45ca1dcd03
-281 1 385 \\xa6dcc57114bcc75fa1e32f43349ffbb27913b69f1c1f0d7ed07ed81d8d43721592583df468ca3aef3a955373f527fa18a590abca9b6e8bd7e3b35f006802ba09
-282 1 371 \\xa5bcfe8ca2d2a447a3be4c8352d4a61ae1a7e7cdbf5c20114b2fb82d04efb8ad6f2e40107ba7e5c9d76b0ef459d4231172237181c3eebb8853813a7a4e505f02
-283 1 239 \\xac9dfdad0c5a3d3d157c5fe4f31fed64d8b20186d968b88300ec17d252c9b5c3aed24b582ab0659b5eec2c6bc4513ad02c87319f89ab3350b7503cc99b0d300f
-284 1 150 \\x8da087358bf168e9f296b8228fcbb2d101b3cdf4c6abaf27d9b621201c70d999157b3641547e7acb3589a649c8da2c9da4a7d2e1b6d5308c2ca93e38a82be00a
-285 1 141 \\xa5ca5eff0a8d5d4ce716d3ea2ba3ffbec7340ff4494cc65c6d084578ac4b93f40db9e1b1f8b4dbf78155b90329183c822a2a1dd7f737d17afc4e50201f3fa906
-286 1 177 \\xa4bc7c44520b48bbaae9e65fdef50dddc559f19fb288154b660e09c559f19b26115c11cfba995313b33f3f41260664aad2856fa8c8dc844ea63238840329c507
-287 1 360 \\x7511840b45e6df19ada19e95e08484288b1675d23bd53fe76031f2bf96b980b49c27a56cc6a1e1782c133b347986d73090a1d2425c4fb701d799dce8c5b24d00
-288 1 222 \\xcf2f40265aab21b339f409f3566e4b29c41c42d66f599c22e4e485a9ef230ed14117570cfaae486cf844029b317fa1940220fddb75c5f5546fa8640c2220be06
-289 1 363 \\x35441c6c8dd5a945229fad1ca5a49cc3088b2e7f5c999954a6cfbba18a956c0c33147fe880a825794b9f4f1959ae02111be20bdeaa94bf9be884975848ac6d06
-290 1 175 \\xdc9e0c1020ec9564ae0323650ff2ca8e5a552363a9bb639ef675a9e375c27083cb37dd10646beffe004a6fc11be672b76671779fceae4361411504f492fc6d0d
-291 1 359 \\x229f160b871a5493ad2d3bc1d08cd75863b93b0e421e02078cd5a997718cdb81229a6843f3993e987f1f350f3877de3687838d3f8ba94aab00ba2af8d1bca705
-292 1 23 \\xbea81bfaaabc1eaef2d9710b8816faa99f707093f94c6402272bce0528cedee8609bf42d278ef2ee7c55630ed5466bf8990c62b75b12373d1cb8b709799e3000
-293 1 400 \\x0c699bdd99a3e108991b9f8339c276788719dcf3b0ed6ddaba5484f379e90bc698bce05137856fb88ca77a58d75980dfe7ce6b1632a22d86d92749a6ce895101
-294 1 393 \\x42a3c0eb114f7cbbc326702328f33bef3e3f7f1a635570b75e20013e2a69aedd76eef46e42b4fa7ca9cf515df52c74f8fd29c05bcaabd64178e839a201c1ab00
-295 1 11 \\xcba7ef2994bc9eddfd48bde8893376d9d544b057ffdf24992e6efe298654a3f2954a29401ef06e3e83aac2c4870f3c7845e242f459cbbc9a8c3abb4d274eb60a
-296 1 136 \\x763de73bdab060c50701ded0e037e130f2521644ad43329a36b253a4dfbcd8340bd774ad00bbc357e54fa410b827b4e85dd07a6a2ef50c0f278939e1417b0e09
-297 1 132 \\x0fb528ec132410dd4990b4f7daf0413999af2518319cd0e8cbe41e7cffd761e87c3c7abd0a6c3e57d60802614a5095787845d4a70b5956b9de36954122d4c600
-298 1 50 \\x537d187bd265b5d66c5478fa82d33bc7a4add9328442a906b634e09b85a9a013378f428cdebb05ed7e9cbe2bed07a52ba92a2f663dd186be42d985c3fd58b809
-299 1 270 \\xa0afbebbd6a731a2e0f7fbf28f234cd7c6f51f3a0a1cdfa4b78dca9cfc4280ff2d66e79ee093e1ee20c1189ba8c47a14ae72bb86690740c2ba1c47506a63020b
-300 1 133 \\x2996ab72ba6b7b6767994683964596cf08b375cca744d40d6df44e047703e5b8f0193e53b11b5325b6758f1c1c8f82391b9e434bff305ae4813ea4c1519e0409
-301 1 298 \\xe3151adb4e99a6c337d831d4531a9c06820605711b1f733c3f77d9bcb21d0cb2b0c7300dd075125bfbdcc4c7da17cdfda16cf9d1465804773a1d882346d5df08
-302 1 1 \\x83f3a0219a6a5a7feccd1ed575f904d823d9ab43f07d91115798829059a0bc449bee1294dbfc9687145b6c892b21e144a01b4f61a2b3d3aac13a9f261229870b
-303 1 180 \\x60e9e1767e5c33418b68439b27a71271006a5c5d50ba36e434b833a1b66e011200d2d01b67c832b5d68b37ca70c9785c364038b8a7dfd1afdef4867340241502
-304 1 165 \\x1079c9260b65b32cbbd17810de9965513e659e146ecc1cd8d6f2c7f040b7f37a39f41a773df541844880acbd0c2edabee07f659882d50a0b99daf2a041715202
-305 1 10 \\x9c96df390f815fd23c82a535229877d8ea10cd600e99be0413b505d8b32e4c59d67e56d85d771c58d8af27821a37c7405c5e8c1e7721b6958c112d7c2f7b2a09
-306 1 113 \\xfcfcd6b40fb7468624729095bab7883a21706d7e98d58f6644aee5eaefac9b758bf56a2f892be061a303f48707307328fbbecc31a5e0b25640cda56993a9030a
-307 1 232 \\xa14fdc8b0449056daf95f06368adee9a7f161417245b4a7b4239d4405980227edf2e29f6bc410ed6f408ecb87ef15d4cd26c663ed445f718f28e7f35d666a602
-308 1 191 \\xe3171867ba26ef63bf33fa339640f2f74413a578222578ebf51235ab2124d798bf31db4330d32b31a577a3f7c15739f89d181de62f7110e1b0c81e1bc441ba02
-309 1 392 \\x863106fc9931a243f2cba922fc79e8e5689622ed484c8dfa66e662469ea3b879fc2d22e04b7c9f7245908e8e43758fb93de90e5e1f4ddf761be751ae705bf602
-310 1 380 \\x8d0a58799c94b62a868dfa81b18156df015c2b8287500aa6a1b335ee13f41f0147f52b8312de0198e58a28ecb5fb995780ee1bd8800beee0b261c18256015900
-311 1 30 \\xadfab146f624f8b0b0271c3e4964e764b19138e37f5909aa0f3f04703295d21c2286e60f6e440a755ad83a64275b7107644d9a31e46645e92cfbcf3193a9d504
-312 1 336 \\xf5302407a641bfa1f8c8e829bee29e2dd3b681cf302dcb68a0fbb644a3d346999ec415d1b4cd78ef1fbc600cdbb55c9d178692529500896f5570f4bc3c14ac0f
-313 1 415 \\x78df463fd1933a98b1f5013ea7a787e0723c07164d8f5cbc2d7d94ce499691cca276a1cecd71234b16d287b0aebd1eca1fb4799cd5b02e02960a551f3b902507
-314 1 362 \\x94d1152317080be6b6a3d82b0aa40959b65321912638eda764c8b06f11ce02ec303448b6597c6302fb154e3d4b62d48dd390d249c4f982561b6ee10d7e6d0e0f
-315 1 256 \\x99012a39c6597abb6e74f6f08fe9f0cfe0e69c9096aa906359c691a16f0fa41a661113e27c9cbb096220b1a0c5e4420d93d38783e4f8081fed56f52d9e03ff07
-316 1 306 \\xdf9136d8c333f1fe669ef259bd0608355150e72bd3e0aa17ec27cfa68551cbb48f6e332ffb5ba39afcd85b47a5d7b7aa8798794d86b331adfb00226ff7843c05
-317 1 331 \\xfc4380f50c41e93f276a336ac4fff9c781ab49f20d03a8b10c1c4725e5775321ed46d943cb4343d20012e0045ba960ffcd3771988d3f539b44f91c2346d9e609
-318 1 48 \\x52818487963ff8b3fc43f2f4e3aafc0ba82a251b7940aee0c6b7600318c3c517cc3c60f2bcebd6a633ff0f635e8ead2e9e1a1ec2d9c063382699fdbfb437510e
-319 1 369 \\x25dec174b47cf5adc4b56daf550ec75e56ece0ec392c6a62c3eebdb1071b207f37745bac6f04ced2e56ed66079ec5abd88f7ab00dff4eba3eefbd6afda04b20e
-320 1 42 \\x42385e7e146026bbcd389656cd4ec1ac55fac1a64b05d35c0d7e81c8ac06bdd705b0660d3c617a4c544df2204e0547709e622fc235a0b4018560e4c1eaa3d60b
-321 1 103 \\x4fc415833affcac1675b2eabeb69f06460f57251d8870c4f41c8517bc3cb8cc3fabc0103d3bbe19ec7f9fa96951f44edd4e70a01482d49d6fccf4a3f674a660b
-322 1 4 \\xa493a1a98a9177560d029b25c5a375bf771ae70b92ca7bd1718f2fdf6778dcc1b189ede87162e0c6aecfc0da2b5653c26bf015e7024868d4325087aa992c8304
-323 1 76 \\xd051276d2f12d691ada7ed2394987518aec58374eacd949466143b53031b3a3d06997c27a19820ca20efb9644962afa2a7b8f9297525ef00700f820bd454390f
-324 1 217 \\xdbb8cb5dcdd782cdcc57a30aa09c11942dfb28e18e186f3c02b6a3ad00cf4ba4eef62c65865f9b960f872528e9989a892e03a78af8da6902b512b039d422630e
-325 1 266 \\x2c5b502ec0070ce448f26b4979a626f30cc90cbe442a09a191e72217bd7ad99f1b7f4d9059fc267cef0d5819cad9ba9ea330732ae62315e0cf96bde437ac0e06
-326 1 315 \\x4da86229d6cdb7004706dc6053d4b27c0ed82efaf0a63703c0fe117c4bbcb9fc00b4408ce5de169514f4ea29ab2c4c87c594b2db696fb82143e24d7842fd410a
-327 1 140 \\x33517062ce127541baa6ebf10373949b22d23ec9336ffd60d6255874f5b74b32133ab90d8197cc3e034017819e540f655cc31c1d8b8976fae8759f39b95c1d01
-328 1 19 \\x57bb74f474e83c88644d63f5211bed0f9651e1f9959059e3e2c59822311cafd7b38ab3666ea246887826a4a8fef853735639aaf0fa625e575bebb9ad6bb65107
-329 1 287 \\x9ea876cb146a1f2e1b75301c5b85bafcad25500e24497102b2171ad1da924c0a76a89cfbba95705a2f3a4d3a6277034d506e49eb260b60d63864127d9d35890f
-330 1 134 \\x0eea3e593dd795f16aff6f19b49d47352761dad6fe938bac843ebac9d3667fd2e6bce254b2251c3035f3e2345c2ff56e507783ac94a203401e37484806fe040a
-331 1 348 \\x76d65a266cfed55f326c0ab7be5b5b370c42f2c863eebebef3c67e89a5e5d167e6c5cefdd278f99c1c90ec3d5a4b584e3e6e2124d9dbe1a683f6ef079bce8801
-332 1 105 \\xc33394b92df3ed333f160db566f56da332eaa7970b993b872c6d9ff102ad8e89727f12784e2428b82a261cdee7e530a41c864218a3fe4744a066f8860dc66906
-333 1 248 \\xa3be236eaef21e54da611c6ba46789ceec50ebb232e8b74c8dd24ad7080cfaedf40f9e02f2703b8fb6541538b0c5cf7462b4e116ebdaf3731b7a09309738780d
-334 1 339 \\x13eb04d2561b1d77c4d740a93df85a04ec4f6766e10cd82b5ded8e4f5ef9d75ceb0062a9d36c88c0462ca552ac1401587cae3ff0f7e0ee86b1fb28b5ed40d806
-335 1 243 \\x52c83d73a3c57bcffe6680207d235fd9a8f1a89ce09d639b8a1563550f1b20853a16b51312f701e5f5abdfb48883b866c776acd88c2d0fc475176fb0e5cec80b
-336 1 52 \\x26915bf571b6ef6f79bc305fe65bf3030a6ce186bebc37ea18a3c0bc1e7ccaf512f7e848f5cc1f381e7e1913cf7c652091ccf84e879042bb18c401bc399d650a
-337 1 342 \\x3adebd8a7df1890ad98cadf103a592ce0014a69751aa04c044b1371ba8be3471977453cc7bc62d2f22397682af3b5e25332712aa8f9c3a35a5be91834f30af00
-338 1 401 \\xdfa32bbfa0ea3310fe9ee13a6cf7f42efca863163cc5829c147b6a215b58d0a6130350b5ade3dbbe505e808540a8d39e4f3770706621d15cde12dad15fe11307
-339 1 214 \\x5a2191778a6b67bf0253fc9d82149bcb56f9e774f9b890f2bcb2e7dabc0b6d7066607c28b5d675f3eb311cb32a1e50eaca021343754528567f344dd212fc6d05
-340 1 114 \\xfbc9c9d3508dfad12c79eac425a86f8cd2852b065c60a5bf09423e73699962601e48ec9d4e883bed227ce49b6eaf2b0e509c360e3dd0a6213f552d38ba478503
-341 1 204 \\xeac05bde2f3cca93d45e3cef69b3850f0e0344d2faa1f26c2c058f5d8a688a9076031aacd6640f7629f9a8cf5ccb8552a684b45423663f3137c246111dec7200
-342 1 349 \\xebaa538a740c6a5c6f97abbd8fa42774d4fffad07026a1ba5139a5b19124db8ef809fd276f62a56387d41d384a6782e6259fdce3056aab2a84616cec1ee81608
-343 1 366 \\x04197719f79288f07618f5fc9dae4f9233d977d43d0541d3195a076d24a8aa653870abd322d5fe4b933af26c79b003a3db051f1a5b5c7ef9dfcdab8a4459a200
-344 1 390 \\xfe4a803fd22c58ed8f9269894c2cf871cb380e1a998812a8d737e03dffb039bfcdd53a3477ce9d39a4930975e77da091712aae6cf32b9bb5abf6aad02e5a7904
-345 1 104 \\xa1c4cdd8d4033afa7d9519a18a99d8cbda1ad585813fc29c1ae70566c0eed9ddc77b9ca0ac851ca082951544cce95a4401e71247adc63a7563c3294dbc2d960a
-346 1 259 \\xa50de3c88157260791be8b16c4f1f7f350d05bd0f70a35f7366c2746774c93507659f0967c440039ca1994c048c71dea76a19d0d502c08ca3e2e319661936903
-347 1 274 \\xc6c96192b9da79467ed5d1c8d91745e29495de31b192d0c9ab0c04d3a85963c88adab88f90c3b7d92528819e11320184c2debba7224d49809a610c9013683708
-348 1 413 \\xc7c2d7c1d6fe3b6b88192751c089a22c9661041c184e2335a041cc90d456f741ed269936309e24353b846861a40e7f75e17d6924bc3e914f0a17efa1115fd709
-349 1 263 \\xe643c8c3be4619ee6cab8a1de41e79dc29649c146172daf56af54fe5fea44fb9f941b5f4f9d75d65ee8a9857a60f6c4324499abcf46fa0d699240a44765e8d0f
-350 1 301 \\x8445327c8141d0ec215d641de1f2559576e8be0c60e6fab7ab5a01bd75858aa96e385cb23b08227f6a833dc8532077e524e39a564b25c05054415f0c8086d807
-351 1 215 \\x43477ece5dd42bf81e13fb4cf6d6bb991c43eb900c80e99d65815be9126c67b8a82a58a3b8da9e9a576dd4346dd56553eddf157f6e1e4abcfc47ac3d10bb980b
-352 1 159 \\x8bf3157ae51ca8b0d670437ae71a8811a83d066fdeb2c15208a61b2df1f6d36713daa23807d6f3fccd6c5a86a1e612ca61f5719b11effe19ee6da1f22c95d709
-353 1 323 \\xe78afe0e6e5ccc7e1b01db15eb7ffe8db45d3f2fda209f5eda22ba024702f6f893da6ce1eaa8604f82be218fe4672cc46508e15260dbfa7a02ebf1a4ba608703
-354 1 237 \\x9d01b943a6dd8564f00f81ac7ff1180527f1f89c70b46d973ead9b98ea9edfbacdb29a80ccebd5838c32fe01ba75036c1f0fc22d12e9361742b48d5ada4d670d
-355 1 98 \\xa35c51f0da579c649f1ff8ab310b95834b92db5254b0b004b19ff65ba23df75662a63f8482c35d8dbd50c04194de527ce3673fc3fb07c150155994e2bf6cc60e
-356 1 179 \\x7492b1814e4c9e170d918d51cc2f523c8d32238ec906d19f28a60289d78e416a9ae7edc951a60edf07adb9d3023bf9cb6986659b575f8167d83d8dfe27fec90c
-357 1 74 \\x76c20ad6976b9cda2114ae307a057c8c1467b9513785b0c646a397392d12c7cfe0037f11da31b7af91155a4bfd836c9a199b579a22896c824cc33508d2ea9c00
-358 1 416 \\x8d71a1463d36e7d88d3877bd6aa34f947f3f2d74ce9482ed5c7a005415c270eecf5db7a2fa673c0458301d3e4c1102bcf3487f1338ff56cf9c01fa367f513807
-359 1 311 \\x66787995c6e03136ccb7d11422b1bc7b14fadde3b19c45fa6f1874ab5a7f6fdfd0173d8f79cc90c9fa6f15bde18e206ef328d9510e7bff7731ed70947a62e50f
-360 1 351 \\xa62ae7aef403ec6b4df930a2e3b3e6f361ef95169084d68a46f9c8ab2e148ebff553b4eb36051fd02b8d3b55c026709b670df73b708fd33600b0f811e3d9a201
-361 1 200 \\xb904b27a9bd4f5f34f5a02eef43967044e8ed6a6299d953da22f4560f2dd3cf96b70cacc2e84242c64e3bdc2151608e573b2b1fd7bfe3d3af23d61856ea2ea08
-362 1 241 \\x4f200b0c2451293d884e24d8edf319150a99e444c6867829b168c60040178385c216b8eff51ffa647b78768fb397697f898aa399768d574d0d0a4d5a4494d208
-363 1 246 \\x161764eda33c48c9e9264899db5a995a5a8013f752fa942b65a370e2854e723b1705ddb174970165140b49ff4e5785f5d199665c9e7d5f3717928401702f4909
-364 1 308 \\x8799fdfae44907d0ac823405e217f0fe6a9985a070c8acb8d0570f0704f6b4d4e6200d388cb028defbe173e87d5380914960ea50ed5d1aecebc1034f0e66f90c
-365 1 188 \\xc0cafb07b057c0d062e30391b733ef789bbc48d0f17d65e2c59117e52e8adc16c983a2b79d77c3766ddaf7d447f5b838bab3d2f23cd4c63c5fd60adc430dec00
-366 1 233 \\xd23ed297300b9e358033d2ce04b955eebf878ee7bb3d909479ae97011a7e52cae1bcf929550689ee0f82b2031d682494d883ef6c3470195ed13cb77fae89500e
-367 1 280 \\x0c5c905521e262babe9a7139b6fd3be9e9508eed960b25a8be7e238c7ce0029c43d581117591656f2f9c09b526ac37d8afb275651e976c69927ee843acaf5806
-368 1 161 \\x6b79f93a946aa0064581c5021b3d735e27a6392c0359c76a5849b16ceef6eb66d2c301804ef965376dd02c5d30ff22f71f36c371eb199f3f0ba431011555cb0b
-369 1 44 \\x2c005daf923d310baaab3e2bc2de9b54dc763c08cf3d03460211f742f6e67d729a798d058d85f44ba6d39aa383dec1bdd639b1bcefc32c64f5df5b549a95130b
-370 1 93 \\x9336a387bdbc2e3f0c38ea5af6c63d35ee3bea31ab7fbde0a9555e8905eaf9faf95fcffc661788014625070a91629b4ecb6b2023118a433f4d0c741c9b5ddb05
-371 1 28 \\x94d102ff90986a599df0b5e1068d98b9ee5aa8902cef7592f6c61e2b4b33728c5ae2612b0f69f89c89c9115e14d70bc89698e4263c6cf1e9191d999569fd9507
-372 1 338 \\x972c539961bb985dbecb5457b4786a1e7ad94202a580a4e273eb3852deec83c96f3582423465d62ad074923543af4b8e3a0cfdd6fa0042b4b8ef9a7f5183e904
-373 1 249 \\x8898d6c077ee72bc6b1ee14d1a90cad2dcc0b345d5966c2373f905a688c09af3d42b3ae878498998dba888eb7ac37d5bb837b706ec328b9ceab064b3b148310b
-374 1 90 \\xdebf811d87aca48d54ed44cba0011cf7b37373c6ae035a41c55a8092ebe453a9e35506c83c516e2b9ab55510637249b5ac786851f56fe63743e8a4276d992103
-375 1 240 \\x64abe4a44ee01f55411dd89feda78c7bf2a43ea9de94e8cee059c6ec06f08b43b0a77602f1c61fe70229b7f4c38956afb772d304bb973eb4e2057c8834ad410c
-376 1 25 \\x1638dc2438ef409b10b1d2d80f8f2f67c6e71e03187f9986e09571a9b64839186e3bead4922c0dc7a78043756d80210a6da9969985a69320dd5254c4e16a2801
-377 1 325 \\xe6029421930867277d74f0ba743bdb78ae0cb3311d50d40e16073ef77058d91ab512ffedb5fa476348294cf5677624ea607c76e967e376c2df08b1aa788a930e
-378 1 185 \\x5c44227bfa4ab5380eb9ba42f0d6b5cc7b18a1b9d4e4ea1b0c155ec6f75d986b3e5edf8f8bfc59dcbd76733decfe0f62f7ad8d289f704be4da0168a43c14fb0d
-379 1 186 \\x480e858255bd9301972193335c7bf9b9699bb3c695b06b1930ca1e0c8205f4a60707cb254856326da5b6d86e0d8d9251596a6bbacbc2016541ce6545929dcc07
-380 1 396 \\xbaf2264c239e1a77b1f36ecd47e5775028e9aa029116d480067dcab88f050e14b7a9c6a1c34e7034451708790dae59994b8e5f7f593e212f098f784559c3500c
-381 1 27 \\x8f335024ac72f59528c0f5c23c3bdce257dedeb245c04d2298dffb4d677c2f187d7c38abaffd41b7e2d763918750590f6fe5a53dcc36e8d3ff61f7a22345520b
-382 1 262 \\xcf0e2f914f2ae6b37deb8eedb188b9ad90e6d9152ea4770109d8820d80a46cebd9915fd4c1064b1b3f160be239a93d35ca72ba67f5442291cc1d8a646ca76802
-383 1 279 \\xba2c87d384b452fa3ee5b6b9b25780fb78ea28623439c966f8333733a08f95a90093cd81ce8d013aa53d4fd8638b5e3884f5b2bfed5ab8aca76c5fdab505f209
-384 1 417 \\x5f812e386e2324ffa093aea1961d889d5aab4e026385121856254d2a4055a2c2a855676151e664a35df5fe438a61d8e0d6bdae87b4c6f4277c4b97236fc39e0a
-385 1 271 \\x1410e7da204a770d0443fe1cdf014c0305efb2ce9eca32bb5b8eb420e240358efd2c7e9c3f5ae268944f16160665b71559ab0c4132fb2bf1fddb7c90589a6303
-386 1 46 \\xf5c90636f91a1bbaa7bf9ae954cbe2de623ef2822a30c86a6c7115f49bf71a8a5dd6e5e0f8c535b9ddf88a6b5db11e1e35fad092a7e375934323853937589b02
-387 1 209 \\xc912900220f9efdb1765d1dadb1445ce311339275695243146ddeefa0dcb3ec3259eb279809444722f563d939e9c6b7c8d18a432651951302dcaafbd1de60203
-388 1 388 \\xa8c8e1343439f4f5c55b4096d7d8414789abf597ea6f710063f0d133d18ba36aef73409d94e718b41e386b6dcf9a94c740b91670c74d2525abc55312ae8a2c0c
-389 1 221 \\xed25169486a0b1e4985b619f28d803e1730b986222229e7d27ca5c85a398495d448a13eacea8683b810ea76c46e78d99ce65a92f46bfa02bc15cba57289bf602
-390 1 124 \\x8309e96144b77c3bc8dfa3c5c11812dbb56308c0bce56d0d9d4c25fea82c55dd64f1271d924c3f2fd1354f07148a61a9e5fc5d3f0ce4bc98e600deb3883e5c05
-391 1 386 \\x8b57da29934d4571ce8f089df3880fb4134b006093a36a0f3928367e06da8f21e1ee727df0c3b51ad8a09a5f1a98252ba48e9fa0e568c95a99b3caf67182630c
-392 1 20 \\xff8f33f1b951d9cfd334519c80f79e9f6fa668f9d31b186000f8552be7e4c13ef2b3ea2720c3a1a447fdb5c64d74b5b3db76580a0b426b3b07f8faadb80fca02
-393 1 197 \\xf31d15b8a372fc115070f315a936b36fecc5129e30c1d05674e9406c083b75d3e11b79e4f0dc7c8de30583b92ceb457d4a7b766e99f1563ddfe685565af2a101
-394 1 142 \\xd615d77059eda634385892dd1379fd3579745da291700d140c2ecdb980a33d1c29c95d381868ae23f54c7e3a484f4ba86d3813c059041e51b38f7196d45b2108
-395 1 143 \\x015d3df7e2445abfe785960d03064f92417f1012c1aacdfacc83f41827d49851fcc413d04c800b483c3c5ce89c8241808e93011c134b3a4f2546887e6f59050a
-396 1 414 \\x6b8957993007fde40d3d06263f4dde43c0e5eb6505ea93918ed11c8d2044459052eca4bfd22163e7079f42c8eeaf0c0918cb66dd4319300896258d0481c5e50e
-397 1 408 \\x50241e0b913b8f51c4a8d57854336988eccdf1b635a1836cae9bb05844b3cf717016d79112a48bee6e2222efa9da2b239a4f70a695ac05f2dba8633f3415400c
-398 1 135 \\xd6548a0311b4659820eb0574ba63bdb0d66948a3984fdcd68ab7b03b9051945edcb75e7a37b5cbb7bcf50e4f9a958ca12e1aec491d02afac1b000d441e271c06
-399 1 110 \\x787a2b695636d39dc2f04787c2ef280cc57d2844f2aa4f29f8bf400a4bcb74ef87a1a35d0ee9bd30bffdac81203e34eed5a928c376c2dbbe04e8b60c5e58870f
-400 1 399 \\xc26befa49582deec43e324a6894cba27539d3cbd17bb7f4f304d044af9547652c5c47c62cad4515349e38a024305b1b80fd78340f9a7eab811018dc47725530b
-401 1 198 \\x0d565c1dc6d643791da129dca804fbb2c8b3a4ba4a0258ad63eb28afe1bf9d179adb98de8f2eca9e2bb5855de70caae369e26b59e2efb636fa0f64dfe0108701
-402 1 252 \\xb11a96a4f8d458c25369c5aece2a06cb9e362b04163dce698a5429eb9a9aca5abc485dc2afbc94d17f601dbcd0a9d03416178a15abfdc4efee96289605e70a0a
-403 1 40 \\x8d508ec81ab5b3c9ac6eef0533c02fbacbb01674fa7adc359b53f02dc7aed1eb1fe4c4df09aec6e2437b74c35e4add80e8fe8e750d3c18d8d4d91aeded168b08
-404 1 156 \\x1246fe2eb4dafbafbe385dbe91e155030f29b9717bf642659dd7da36ce1ed31f5160d47217ba606e78c82093d1e702eac2f605a9fc28448d9b8edc84f1336e00
-405 1 231 \\x4b549a95360f7fd09b46325e3c34864332e7af8742ae0cebf1cc2cb127c41edfb8844aa82c08b8fd0a66256d3ccf8ec1f357faa05cd1e21b30282b56ddbcf405
-406 1 378 \\x296181cf72c78b2473aee71fcb3f00e5f9ce63367dd17ebec5f7966167aff185833e53e703fbe6a74f6d1cc545cdafb588785a71abdbfaf26b6d66ce00f0ea02
-407 1 265 \\x2cc27c59ccc00aa7a20d8105277691d5d8865ddfb43b5616196dcb5437125d402c496dcaef59a8b81157f281ee1927701c7074884c12189170e9b8b10f57650a
-408 1 163 \\x354a2ac2138309c2af6c560337625264f6e320c279cb2f396b7bf3351c163bbc27ea086631d2ca59a9ed0e379a549df06539f8456badd7a143443c3eabcb6b0f
-409 1 375 \\xdb7c505fb6969a601ba5d30e431c1b50276475ee588aae12fccc635bc4fca28ae47f512a3abdba832bfeeb62b0baeaec9cce2d8201958c5a31e2f7d8dc932409
-410 1 368 \\x61565610a696d5cd3356444fffc8e3d063bd1eef83166f922db87bfd9eaa6b7ae69de9ee86abd8b07f7d1716cd7346c245c76309720695af0c39a5130cd52002
-411 1 293 \\x1156a9876a497ad2923b4d18903177089825f950ee8da0abe2ddfaedc8a787db5e013ec5ffb799b2c19d4a08412888bbba1c1b0e9079cdfda263e8c7b629050e
-412 1 157 \\xd412ccc06df9e202f36d74014b8f63d3bb4491dc332f593100ca2b84ec1e26ec89a404798767b901cddce90ab26261932cc44f7b102a09b074e98be34abd0b0b
-413 1 79 \\x67f2c613a754a8e14fc38a52cafc2242dd81861f55ebc2b680934aaa1f948f30e07cc57992114d1f111c717d8d48fccf9b130fc2a6e34ed35af2910d227b2902
-414 1 95 \\x75e04ba5006ad32433b08ed69f5e0466f367001a4d8ac4d04138996c2237b3cfc534c10e961b1fa86d0a4cad27f41e6d4d930db30baef8adc016452653ebba0b
-415 1 424 \\xa8905b7ee6983164c971adda56be2ceefd6ab884de1e80f913091d6131cede879b091458e3844363afade377b0f422b5a9f5295538e328f6b4fce65e4bd89608
-416 1 65 \\xa738389850c021c300aec7042458cb1c008cfd51d48df6923aaa3b5608df381f003e5be8f6138b3d9e815f1d4feb80e6c5a299679f29767f5432f4373ba45702
-417 1 120 \\x287662e90ed92f72eaa91ddaf072423450a02dcf49d7137b9af635bd966ff48b3b73fe5a8f3125e3357fa839f3564a514c2117c4faacea3b53d8997dc9db4408
-418 1 14 \\xef05f9493e8a305436a517364aa8fbf6776642f422ad2780fc6022e30384041ecac0910968ae5a65eaa4b33977fa87d8ae322d0f70a88863c392ba9bb8e3a803
-419 1 112 \\xf45a029d1655c3cf90e4994e3301320c57806f8d2f526e25d18d5933bef8e7ea2dc9eb968a4216263ba731df38ddd4065b8d6cc4ddc607cff090f5ec4ed87008
-420 1 216 \\x18a0865f04dae7cdeba9fd9c667c83680364f217d55840bb104a04c8b7d17a9e09970810489c245cae8ce262e6ae0f121489b430f88f89cd2223e4ad71bab30d
-421 1 223 \\xbaca3ad591fe06e2a3032b1c5a0aff996e798a21a56dcc89d24d4bab7df926b27217eeb5ca9bb525e4603c1c5d2e2ffd85842ec7b0265e202adac8d324f6dd0b
-422 1 406 \\x1c0d73b27e481b088e161ce88af9864a03f83ca3c00970218bb5573def77e13348b19c4ef74ae60c7603f3c78116816056b9e8f6ce46afa06eca613218e3e70d
-423 1 160 \\x8fe3937f1ae92502a0e41f162940bfd480933fb92ef989f1f7d5d5a4f4a33f5e484c049d3413da274b7e7ceaff2a7ea4fdc07f9705fa273e9a6ebcef0555f502
-424 1 391 \\x9ead8457b6e58e31611fe4b98fa5d0200d787e63235214f149ddfe3b26df465ed694a1631a544e98834e77ed9abe1294d727eb78711c045b4e5e695d7c06f00d
-\.
-
-
---
--- 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 \\x474f01473eff6678f028f089078b5ad96faa85b67689a82278316c52252072a9 TESTKUDOS Auditor http://localhost:8083/ t 1660654398000000
-\.
-
-
---
--- 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 \\x013c0226d53305f1d800c64f1530f3a0500c8092c46dc8264cd84cee535e62fd5e7e34d4c96f47d6289a23992fe6700a428143255ac651791103a09fe73ec762 1 0 \\x000000010000000000800003efa2bca7cd5ac924ba3230f981c43630aa2a197c86e5f11fd027e66a4292f33cdae59a506e1863f603263d792e249e2e596c357102a6e1c25a05acbc7d0ebdf0229500bd8cac0ab772ec0a55f1a64daa02f0496f7962a81848c43d8643a10d642af37af66e2645d4dfe4e3591739a244f2370a7e631ed5496eeb655c0dda2531010001 \\x1b849daa1e74e257698a42736af4993658b53488c938817a078c53f4b32d9cbe2fc531eff0626bd06b7e0ea735aa71dcb8524a63e8a041964b4a25bee8735405 1669721891000000 1670326691000000 1733398691000000 1828006691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-2 \\x026ccd1a3c7a1f9515ae760452977818e88b38c50ee1bf9f1f3ffffc9677797d6da639df83e07cf80936bec19083f59669675ef7c80075a72b45c48360617329 1 0 \\x000000010000000000800003e05f0ce66d4e9fee84cc7a2af58591918da3108d7339aa48e39731a05fc213d76136ec97627e46a928f4603cd25a35e2de11b1172b4140d831d4b10a4b6b8d8b35cf111509d5a8440a9e8e7f31696f9d2d6c47c248ee13873cefbf60b690e1adadb9d6c77f4508e15ba32ef627e3459525f6b86f58c77e6e0dd8604d21acd173010001 \\x76695a37c1c76b1873796f6c6b51c531e33d09fce37e3dea7b4d21983bf04635e9fef27c5fd59fc97d4f1b0132aa273a5e2d7a34336678893fda9a10aa61ab02 1678184891000000 1678789691000000 1741861691000000 1836469691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-3 \\x04b4a14dc072f4c27cf04ba6506dcab0bc0753f37c9786aface5bdfa54393a12c6527fe8075650185d13fc7baeec841ebda970104cdfd8ee2118c80003493ff5 1 0 \\x00000001000000000080000397d1ef4b2df2866d1a597ac3dad8c18d2f97d261c4428322cf2bb1bd231a2961128627fdb905220dcff8cd86e1ca37c499d4f316b4d9560db400644cf72086638bb752c10cbab196b2504420efc34dce98c03dbf9a3ea3d9372249dc4bbb393deed60c7298031f93444da21db746e2e709359b9bf72ee88f89708f669f98223d010001 \\x90063c8e6ac1719c46a5d4f866d428bad0a2e2533903e72442d2072bd99d35b7ec17a45d2c6bb053d726becf2bd99bd3b5d55dd8244ef685cfa75353c4d9fd0d 1673348891000000 1673953691000000 1737025691000000 1831633691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-4 \\x04981b0782b736e1e115b2fc2e55a6eeb0b592df544ec732d58ef2a674680ac83f8d7a30fef356d64ea125a2705f45a179e8be0ee1ff80a7b6013e5cef35ec0f 1 0 \\x000000010000000000800003ed69dfcc37d9f86d9b2af49d24224a06a202a19bad0e00ef5b63cc503000254b86379ce424d941ad718c4c3c55ad09a07a156588ffd1fcec9cf880aee23fb5b350d075d83f6e13a5a89073d6f11bdd3cf96e21d3fb4be33cda1aad7167d0c752e4a553b03ff08b5249f1a5be9682a2190db7b1ea07f238b56f49ed7dc3ac7513010001 \\x932aa2191cfa67c2c8d2286d42029daa2bd21836360227cfbf2e67747d37136411c23a75b93278ee67f030059cffaa35ebbed56d27fa7c23485bdd7c76d8df0f 1667908391000000 1668513191000000 1731585191000000 1826193191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-5 \\x0b44d378bf437ab21013f0ef39ad4119a4f9dcfbf4e66689f60c5737cddc0018bffd1a66d451069db258bf8bbbf1dd0b8d67157c704b9b3e51710775464506ae 1 0 \\x000000010000000000800003c54b5df7ea6c3b672633f7b6aeb77df4bbcc426d6162c480c52792ca9366f06b5cf27d2a661a8206d68e166064804dbc9609a5717cf230457e3245add816793a9c00fdffd63bea6e8d3c840a70990c9a058ea060856ced0638c0c243b38ee96ef51ce56b5c04af1231a55ee43b2aff1f5a222246a62309ceed574f0461166bb5010001 \\xc584fad787c66c0b27fbfd619365505fb14545c9208a1aaa5f3d14d3d1b934116573487188a2ecb5fd00716cbb24b6b6e75ede3d851bb9474ed14df646dad90e 1679998391000000 1680603191000000 1743675191000000 1838283191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-6 \\x0cecd07d7c6f9baf12f08791560a8d065cffc8d965692c67473379b5cfe7a68181a12ffff4862213258c48801309348bd91c856be1070f4e37dc3bc82c674ce5 1 0 \\x000000010000000000800003d56cdef611a868fe99ba90cada90436df283753fb199a9a210f63fdbf6d8622ffa82e92af5513ede436e989d10b3a9d08ed299316755819a62257c6ec61d5efa30e50d3941989b6116a14be2efc1aeced5b55ec17f1f20467881bb52a7676125122d25481888dcf77cbf5172d96352b3a0c2e10bda91073a3ccc8e90fcf3459b010001 \\x435cc06bced8e5f48a49dee59263d03a5274ea917f7811fe2041052d535c4a6d7fd46809afe517db7f88da32ae94771374ccb704667c8c91223ea721d6eecf05 1673348891000000 1673953691000000 1737025691000000 1831633691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-7 \\x0d10b04fc4b615c8a312d6eadc4d9e8a318cb599cee3dfbabd609139aed4092f16244bcf37cc8a423cb3a07b56f13bec5026b12cc2e753803fa8e0cb86bb8f42 1 0 \\x000000010000000000800003c2b44c85a2d36603447ab7748ae2f45446bbc04a97779f68f5276fef062c84b4e1aaac1715e676b24ae2c6c150808e9d9f4033b4687556671fc216ffe3bb7da7a6d564b356b2c805834fa18e1fc0de58dc2ffe59e71ecbd61246530f06f7d3fa82f84382e68dbbb484ee80a2d915e1574dd7ee1abb1c99c37018167d873f8b11010001 \\x116d295b3080d252a284c267cc4428add313dcdd1a794871c951bfe6da4d8ebfd863e2cb2f3310bc31d5fda36a600997291fbe340f0da05decf638e1e9bd0907 1676371391000000 1676976191000000 1740048191000000 1834656191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-8 \\x0fec7423fadd645c16269e69d451acf8bd7ffabd57ef5610727591e89c92457d6f3470546e276d5e219579c0381dca7fa02a90720fa305f55cd8ac356c1849e7 1 0 \\x000000010000000000800003aa9e317ccd5ceb503520c2f980b58e1ec91ae8af563560782a12ee4b794ae66f4bf8c8cd483802dcc9f734a79f368a56703d835ee1c0625a02884ebca329e13db676b79363134ecfc1773a17bac6def223d92808b5443b6c9b849312f2dac43a6cb7680874b045bbbf2e98cda9fbf65259b0ec1dd1302ed8aa7e81caa04e4255010001 \\x79c05e38a9c1f0dfcd54c6db06fd90d0e55cf4982c7dab385c230ccdbf33037d935c7748a75696979b96b860d2fdfc3f95bbbd9b3031b6048ab3b7d34b49c00a 1686647891000000 1687252691000000 1750324691000000 1844932691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-9 \\x111c42febc820a69edf51ecb845d6a65bb2828c946bf3c857fdb74a44ed82427890a8d531584acb40cb879bf0a7cc8bd5cdcd1f581e6f827db81aed8fcb2631e 1 0 \\x000000010000000000800003984f43937232aa5f470dd10a9e254bc0c502fe62d0178a45305787967a6389bc573b3fa595889f69d2578980fc3628162c43bf2b0f0c503cfbc1937093dc34b30e073ea07254386e90873ba4cc45680b50dec96f62f051bc8862a81c499b45fecbd39000cf3326addc7336e13dd430e1e9fc8b4da538265eaaea6d19e21a3965010001 \\x4a02584e86fbb628bf2f84127e711c0711d01629f9c5946302a2f66c3f93da9de12a9f9eeacca31a5bb5225410ff45b9c42714a73d16820c78dcda7359281004 1681811891000000 1682416691000000 1745488691000000 1840096691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-10 \\x16242b6d3262adee347467501dd6197d486ab4f4a530395a8ae1d67770cc363aee95e2f3670739cc926a0f759f1ea51d5e6210eda598e200dde5b87ca9e8514e 1 0 \\x000000010000000000800003aa72251f206bc9a837fb2532fa183d3404597985f1287d685df08022a3722a47ee43252d286d0bef97110cf7b7ef88ea375e5da8f65390062de3eeff39d3bb8c748a654fc410c9c4f8ea59c55f7f08f8817cbd51b8bae40daab9188ada9a94042c10e426dd73168f8a9c2b2d70a10fac498a28098dc91dc22c645f968dc4d8c5010001 \\x02aff62327b7391fa39254c58628b447c5c6bf9ce1b03e5d9855b2d4d48ec91753598df46699f95a0042c359ffc2328afb54aafb0107197a0667525cd8b42f0a 1669117391000000 1669722191000000 1732794191000000 1827402191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-11 \\x1740d9d5780eb537bcfaacebca8c84c3632795f7604f90e9a981166fee6b3232ff7cc6feb83f885a51477362c8d625ce21eccfb67fbdc07f43bbd02156a38c0b 1 0 \\x0000000100000000008000039ed772ea61135dbcc623c8bf7b80e61a1db37d2d0657e1428be9e2b6baa7c65340a0e5a37f93020a36c0567c190169fe62cbebe2bd5d3ea77c229bd42f11b7c497c5a05dd0b8540818c15562faaf1ddba3fbd421edca69c739b7238cff905f0ae8428918fffa1b6870b6569d1ef38f124262d8464ffba19ea448e6bbe3f6bfb3010001 \\x8265f048bfc0f1ed7d2a1971629001b8abeb7455812ee652877a714082e99efc3e07b985372edcf696b409934af7f5fbb6c6d8b33cfe73e113685bee6b4b9d0f 1670326391000000 1670931191000000 1734003191000000 1828611191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-12 \\x1eb4b8919e5b1c06dc9038207b356b736e433ce04497a6e52101c9b5cf7a28b5e10de2d8ae0cd7cd8a8dbc0b0055a0fc8b1c04d0c962ec9e70d077ba3ab75d7e 1 0 \\x000000010000000000800003aa9decf8b8ae1ff41562f435565dcdfb752975c15899402630f9db0c3807b0a0eb345ae871d55afa2df05a950272005e6437e588541c259527a8e5c2d616924d6bb81dcd1a96b4de99dd515799155b3c5b809db2af14ff7cd15c1bb7ee0e7c5523a726f57ec398448155c5e285bfb9d0c08ebfddf21e260cc59f597e4f6089f9010001 \\x0e5b159442f8e8694afe7b014df4d46d493ab78aff1511aede7299b04b655b39748e205a9d2bf79e0868b4acf60f5d8cdde34effcf54db748ebc3674ccffbf02 1673348891000000 1673953691000000 1737025691000000 1831633691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-13 \\x1e38751abe71258a42dcc868c3b5a74326455af3f37774f559a6bc938865be9864dd098fb0fa40b3ecbbacc0df3ac9df2ee98f4ab832c6dd45ad7fba80c2e1c4 1 0 \\x000000010000000000800003af096d112d1439ef93c3a442ffa2217b5e3986dfc83a2895fc1590724102e95daf1702b874f34b1fe3f83e30adc9f04eca853c20257799572dd646fb3c1ee906dd1a3b8b94287c4adeaa6ff98fc6563ff0a8f22b5415686ab8e32f416a8341f9f50b5068ccc111ff584c0d3d4d8c27e78f9e5aa7c318e27b14c787a38ee14e2f010001 \\xb9f4d6b30bf2c7889e5674cfc224a29ec4c85b5ce673606ca06931699147aefb1610255d59f001607ea4848cee70d55a94af583818cc1a0c01e326a79fc2990d 1686647891000000 1687252691000000 1750324691000000 1844932691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-14 \\x1ef81269fe81cd735145388ea39df9f0e2599f2b7b143304b241c2c535ce09aa79e0428b189a1d895768abfd263c95312708e71e52dc73312f50e34d799f8e85 1 0 \\x000000010000000000800003bb152c8c2b1bfb317f847487c30650ef45a9ccb11c11c582ac6b7d538f405f6ca7bda6f44d29b8ee548c3e1a4935fee4ae010373e1ff518299baf06a4194604d65b37413ebcdeb7f32eb6875f1f3fb24fcaae8e33842c2d4e542ceea13da5aad2f105de28fcbc12a3ad4ac7380a63b594ba29018436aa105be3d41c08c24a843010001 \\xe4b98454db6990f700074d671aac7b79c4bd8be3eb53d6960a05bbd3a6383599f92c320c1022e8c609e872bc74a599a9e0ae7624e2a6336064778f2954051f06 1660654391000000 1661259191000000 1724331191000000 1818939191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-15 \\x21bce487dd92f020d99b04504a3ed2b23655fdc1229cdf42ddd5e676aeb732bac8c764a734d1f3857d2d48d70651b36c27bdf976173a6aa97a2677f75fc6b99e 1 0 \\x000000010000000000800003c98e8308f4d1ef9cb1af360c739502d637e0b562a4a4987c77af5e0f7ce6833a87443128c7ac47937e0bb6ce559f17235428418524c79d38ece6cccd37230904221a4ee9502963294a25651b4a5fe9797cf1c3b253b03f166e873b9d8a32795e4b25cc7a2c166bba1713f8161102ea2b9c023ef77170dab75157710e1903e815010001 \\x74dc291d538cda4aecf74166e1e307337df54f84ade20d384f6a3a564d488eeb2a0178f7b1acdd5e1d4879151280083d454d002aa62b9ac9e941fbfb0c8d4a0b 1684834391000000 1685439191000000 1748511191000000 1843119191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-16 \\x211c2315d72b6b0d8649ab97e9a83bfcc9c6bd3a4ea9b32c8849b0eac24fa2b20061904583fb8ccd61cb0cb94cd946b62e09abb21ec13f507b9284cc5f0c6730 1 0 \\x000000010000000000800003d4f0a0ecb031efbef03cf7bffb10b58f171b2111cc44c59afd7dcfd72749d55c7737531821713700b6f4eb55ebac072407dac37566554c80450b824eb6db51b54dcca68acce5ff1da915fc11d5a6359fdc1b77435b198aab37ec10fed3228e597105d6852b1f7ecd2efa3120ebe235fabd5213e8deee300a8618adff112f3949010001 \\x80864325642174a561bdb0b29a614d9fb8237eb78a0428e7b4469b4fcc5148bd0baa3680b7f8a648b15d551f1701760c9d72505affae9c19d23d9ae17c61d202 1681207391000000 1681812191000000 1744884191000000 1839492191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-17 \\x21508445fb9b6c8a44ba7f4d60fda6056f10d5f716f380fac748a769fdcbf10e3c9e228eab25c1c0892c63ffbcb96971284e4254152dc24c9bb0e5af1d47261c 1 0 \\x000000010000000000800003ea7bc561422547ee0e198488b21a16af83d8ea4814c620c0b3fdf4d7dd2829c1a183cc42ce75b468ac64f84e7e0d47c415d763e344878bcc120fd77d234953030c9596593a0233321bfec5fbdbae18161a531bbc1afc67b2ab15964f8ac27cfd8e15b3ea72390f5af6a09404b686539016c3056dcad2304c1a162cd74d9af377010001 \\x52f0525da37dd682e2fddf985b048cb825260183a65b1e438ce0870cd5bacac242e25f017d8006ce6eb11d83a016b589b80bb2d7dad46545c2448d8caeaa1f07 1680602891000000 1681207691000000 1744279691000000 1838887691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-18 \\x27bc02f74f6572f6347551d57f256608b368ee715273944d97004a220206b931adda32c569153ec7fcafc1dc735e6fc03d84b3053e3d4cf974d60e76d52e4147 1 0 \\x000000010000000000800003de9c926ea1d0cd97d91560462e70b43544d861e581c19c11af93f1576b52b631c10e38083dc008881228e37421b97ef2262f53968d829883fec77dd9bb0b2d17043fc17576a31938ee9be1a62ec8e5ed26ebfa289f06c2968e3850e5cae4b994b852645efabdcc06d661cfcbf02bdc89e9a332af75466d47e8121df3cf3e19c9010001 \\x0c233f3cb278225f4fc4177c988ded1e3da68a6288620ae82e117898df26fa6f00cd4f4c3e770e579800af4196f2ac33b4e002ecb74b32440e38110802fa2901 1675162391000000 1675767191000000 1738839191000000 1833447191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-19 \\x2b801dc3cc7b9aef37ed8018f27a0f4be4082c1cc4733b8be0fccc5ad970b1cbed889804a5447ff7d8ef0fe4bb67945dc053b63a01aa25124885012010dd85ea 1 0 \\x000000010000000000800003d13cd1ce5cb3ea84108e7cc0eb6603ed03cbe2b3c2488cdd7d627f6cc64b8c5b4602789505b7c76fabf2d098a10b4aa7a12836336f21311c4928be3e9e2a99f1e6a9c2f4cf64f45667d2b0efb472beaf9babe5c4cd6564a0044d0951a729dc23d4e6748d8ac30edae988460fc51189d468f5b4c2f02bbe052c09edec107f23ad010001 \\x8a6ca4412b4d60af1aadf7b2257c74db33ef558c8e8b904bb5ba09fe868bd6e282cc64474d22c90fdb653a448826ec6aa58a358ec58e7bd5aaadd3bec90ef209 1667908391000000 1668513191000000 1731585191000000 1826193191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-20 \\x2d5cbc24879e215780c5c09635761e53cee0087077176508b702c24057b5c951c2659b902c02dc4c983fb3af7fb9bc1e1f1abc1c825f18830f4639bc8127284d 1 0 \\x000000010000000000800003d1bf083000a65f16f33991558c33ba177748590a923f1b38f965e3a7d019a8c4eae79debef5e3ccbac4f3f73b77e853105f5d0e194f7cde8008dea141faa679dc14c26a891f9b9ddbdf05b6f8ab0d027280d1929f1a730718dd3a90b9a47d3548a0266b8f37065baf5e2f998cd8974abb7d9ed51f805416a03d0a5c4a4b97739010001 \\x1ca05fadf78a0a77fef5165765a1221daba1d0ca264bd51ed5d1722265c34505b4f7404a74503fd260591514b6ce3b6f474c39ea9e8aa0c4bb75ef6ba0d4f304 1663072391000000 1663677191000000 1726749191000000 1821357191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-21 \\x31e498319785cf2147a29478457389ac0f4041a95f43b2e569c75ccc266b1dbde9e2bd756143b349ad4ec18f5da58c3d1b5a8000d8f2ce83300d57cf8ee1018f 1 0 \\x000000010000000000800003bc671d712e0f44f516a02bf3a7e50a701ba8e0cf45bcdf21610d1fa04cc0568d46e45260deadd654c1765c187a96a60b819f9d25b9f06806ad4ef4b80ac1c8da0fbec38aaacc40554438225ded677de7d75ab642013c85e1fee52f78490c35d4996b63001eeac192eac478911b9557c454ebafc88e874bf45559cbd5666fad19010001 \\xc30bab704c3f0f3bc1985cc973b0bec7d398901e98cb51835a67565d82432dcd141e75b5255ae4a76ea888d23a63a1d703e6a1f6d3c4bf88f726258e198e710c 1673953391000000 1674558191000000 1737630191000000 1832238191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-22 \\x325c991f285ee455928263ee1a9d88cc8572969e07cb98863175b480ed6fd79fb946c6ccb3233eac6705d5d2958c6baf12d129cedf01ca6ad2e47cf903a1c3e0 1 0 \\x000000010000000000800003b0fdc47e16d5aa7a3315fadabd43be36f8f613d02849ad91761e1781d6a6505ab255bb49693e835c2c6799904184f8227544a0c3e2457d390fea8efee8c10b6d583405a698b28cd2134994c374221d213569a2d4d4fd2dc8a6c67e371c08d9b77d152c3008c1fbb4d732e69258333c364ddb97a854f0a4312df2ac43be605a0f010001 \\x4b794db37c70caaa0b5de22779e71aa09aa8e1fe17a352fcda8874731dcfff7109d0967154d574b5fcb76b47d4f39648e359b4f6396ec9088d115693e1af100c 1680602891000000 1681207691000000 1744279691000000 1838887691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-23 \\x358c25b541739b7ee791b89decc3a71554b1699a75c7ae837f3e33116e5a1db9cfbe880b2cbbbd0784d222092ad5ba3d78a83f3ba537d39c3b9802a42fb57725 1 0 \\x000000010000000000800003bb99aa919fd67241437b915cae4bf01c04633c085cc799d1654b555cf729e0a6b32d2363637fe5e1a3116752bac0a4260283e791b951b94efed79519dc1e68d84a90cc09959f01f44c992650049ef03c879c73563aff41afb52e8c5f0f60cadc453d3ea00257bb49cd992d0d5644b59ddecb323cbb99ee5e7bd06b1cd8c0af77010001 \\xaf7a5619b3d3ae860f0bf664e0a9213ccef741e8afa1ca6dd7815d3d0629de3a5de46ce7abd14b0327858225894c542109f6ee34bbbe508977fb5e13fdc0e50d 1670326391000000 1670931191000000 1734003191000000 1828611191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-24 \\x36142ed936070ade6c96c96c68e9fe560e304bcbaf9af826c33cb4a6da08a4deb4c39e00f57201c7ef6b75a2656d1108be9b1b7949ff448276330fbd69a9ee85 1 0 \\x000000010000000000800003b7824c8c47bca06f641795673152b7de3ef058bef3413e12db92531b179ad020428502d1c7ff6c6f1f5a66d60b81b29ec1f17f0302acd1c8412d27859666f114d75aa27185c6971871d2faa8c0a1c2224046a08e5a535b2f9c06ec69a561dc68546540380d054ee3df7e36c19a80f7de755c2c97e8341271296a28e1d8edf1bf010001 \\x7c463f4a869595abe5c03bdb30e671b4993b2004018074e3c755469a797c414289e8726aedd0623779a059e159241cc7bb25a3a6ad3bc74fe871bd311c3a5504 1689670391000000 1690275191000000 1753347191000000 1847955191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-25 \\x3754937e5d40e92c91deb6317e87909f4f7e1d512fc54fbbeda1f901b5482e6f56f3b3ae919ba03c6bd2bdacc3daaa8647b23cbdc29f83133d52651196f9ebfd 1 0 \\x000000010000000000800003e8fb38e1f092dac8bc83cd1d503d44b0e188a45e5442024ad1f35c71a72d8eebc36a5ed9a24b73bbbd76f150758169a9a3a65da4f262111ff9f8ad059049e32d4b1b2c5d40ad20b9e037edf7e4dffa26456a6852e8046510c65ce1569939ef1b04ed651b732bc040ca736a0e4bdc16ad89a6b82516b227ad12313f0674a67359010001 \\xcfbf721bc67d4c0332ed1ef953b3ea361b02aa95fb62232b595dec8b3c4909784a391a214d21b7be25cba31173fd0864f2fdb6f902565019957ad95690f4f304 1664281391000000 1664886191000000 1727958191000000 1822566191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-26 \\x39c8af747ec6e1d673d3862fab717596dbbf973356c5a2a4eefa548adec46713206d9618d63e23b22515a8be358f13f075737813ac2d2ce9082acfc7bacdb0ba 1 0 \\x000000010000000000800003bc94bc89c261662f1d788180f17561ecaf9e4e034a0ac4c4c148df059b5c039ac2bf0aab06743fa80642b0f5be4ad58a33b1b7d7912fd223f0f18d24307f6485c6bec7bddd748fc9d4ed251aba23628ee52f56b025b85deea530f233488a43afabc8f433b7690fd5a242219d703e31fe3be8c7280119f1f0383d531a6e99db85010001 \\x87959b80bbf835bfe6bc5685c556284089299b1e53c135648949af5e0b566a350de01570973f6fd229a7f429d95fc55fa803b17454f4192e4c3437d21008700c 1688461391000000 1689066191000000 1752138191000000 1846746191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-27 \\x3b94432b4629a8f2a5776c9ec59a6fedef6c9f8074abb536a3a94453c45295772939c9948ff715c46f70b0790d59b1157cd5c6bff323540cc80bd4ae4a92d458 1 0 \\x000000010000000000800003d45ca42539d2aaa2d27a6fd028428b5a7a971585af7eb04eea3a6c47374253bbdfdf9ef5c95229108cdf2c7edb59f76b794f725945da2647ccbe05d34481588fc03389ba500140b6d350b22e9733f23229860b7fde32740d57e2ba914ea78f521313ddbcfc40eb390551c7c2a145a5516c8fcceac53b4f5d126168bbbfad2dd1010001 \\x7652e8ed038bcf530f0b3dffcc28ceb33837143e553af6e7258d1464ddd4c9e8c79e96c8a075be4457a79d632bc7fe38f2fce2ee3bddf6271895c97724567701 1663676891000000 1664281691000000 1727353691000000 1821961691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-28 \\x3b188037202a4c6707ad46ba24627518215df4a036aa089c4acc038ee004f7f1dc20718f0ddb39afaeb2024a252cc9456f5441b3729ab7211b8b4661b42eecde 1 0 \\x000000010000000000800003cad84bf8e5c1e9066f5980ad695d1102d3980578032571da29e4a26f4aa01392fb5cd358b7ac7396da4a9fa541acf53a89aa7330e37ccffc2f1c3f9bef88d6fede1ff0136d0e980200fb71e6a5dbbac5de29eb9275aeb9de81a8d7163966e96cfa6cb93380badeede666de29b1084d93ed6b20ded04eef0817749210b8ecb481010001 \\x258607f29a381c7b75d7c7c8276326dc9073728ee1dbe9f75ff68b73a6b912f63d497668cebd97cc739a499744956484231ec2c579f809e6e00401125cbb6a0e 1664281391000000 1664886191000000 1727958191000000 1822566191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-29 \\x41047fe8bc032fb93ca3df4761e17503bcd3036d3a0643800d22b508189fdb45a71c1d1a0ad3ae43ad500f32485a8749fd8137acb9593a652858782a1bf4b01a 1 0 \\x000000010000000000800003a87243e20d063f5e2397be6710565064a157942e4c0ec58c101bba8b1d0922a1558dfe713e8afce4a35a376b0830ed2bf433cf972352ca8a0c9e1d9751bc822d039b00578eb44e0b705f85db64098d62b69db293d24ee7e65cdf4b0614332c225c616a4a72a9624c8bb8544557be82e6bcd8a271ca13ab318c268e4b1e6c0817010001 \\xa36111b27a0ba401f9347d9c292621eb5336504caca255b70309472f86df82482641aea3c850de714d5d52a5a6fd49dc7a6510e64007127b963bc50bd383410e 1691483891000000 1692088691000000 1755160691000000 1849768691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-30 \\x41e468d531773433a7be3a661cc4c4f27a79b8fb4e4fbd9b2875ee555206583d4f923b50958e94f99ebd403632f6e6414d0e18da99ecb2a87e96c5363e1193c4 1 0 \\x000000010000000000800003c0aac29658081c1c76fc64aa286598657567463f661e315a3cea989e3f4112a32a0754b039f67ad326490de4fe8af595686b08d43e05e0848c76c6a6e73b421d392b5ef1428542f47d5f648259fb36d7f722d159ee4e278ef9256f070a2ee2fa903b02b3c3abeb01f08130d33616fa0f37624352dc69f4baf61efe904ed08ae9010001 \\x193e151fe17cc8df9b92d7fd4d65c00b657ae24ebdd47ef8691afdaa6c23b9db6259be7455758194be3f1f4492274e2b9e6a533abe6c9876275fa73a28fd6705 1669117391000000 1669722191000000 1732794191000000 1827402191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-31 \\x42e435ab78b9b5df755556dfeafb1e200d1730bc6d1ef92539c57f1db4131773b8b15f88ff95b226dd688dde978f8a52ecdc5a1b553199f34448fad4cd76497a 1 0 \\x000000010000000000800003b50e1a78fd06c0746201ad686cb79f5f265298055f908b81d45d20622641106be8cfdc85d0cccacb246df92554923017412b4875fe07504813fb9fed60975406d8bc75ec6a936fb5963f8ab96ee0bde5693d06a41d2a816fa32edb9a9177c710977ca2035976677277ef674524d466a7ceacdc6ea69d14c23c29fd7b6a2dbe59010001 \\x562dbe3587d1b2b355867d8889f56c8d6af529551ccb9927177c24336c453df7c871e201eecb206a7684c945faba531efe2570bcf0fb3ddcc5cdf570989b2e03 1672139891000000 1672744691000000 1735816691000000 1830424691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-32 \\x4930683464f09f62bed52738cf07dc2e991324485db1fe7fc904e89860bbe5f832fb28de54bef3d001c3e3b6d936cf7c03616527a46b6280d2da30f7b0d3f368 1 0 \\x000000010000000000800003f050773df97675137118840e4ed61a0c6d46e1d32958cd6a205991510e9a5d70879ba3f45546484ef55c4ae683ecb29f7ee2c5915bcec32d97a827500e80a6468f899a7084c9af0c08d95331bd89aa46ad93a2cd3520ba36428a59876e98c84b28aa84b7c4fae0857718b7da365825ef52d65606b3391eefd34b3a6e18289645010001 \\xd279a988e1e6ee5915de667bc0b102864b0856a6a80c1d22954e6024706f7b186c597014d4f147da4da977f2d419f97b273c1ce0548fde7342255ae675db0009 1673348891000000 1673953691000000 1737025691000000 1831633691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-33 \\x4aa4957f682117d37ad000b8468512bfc6e386a52c1118a7c534ac1c49a1418b244c230189aba7bc17bf49fa3e21ceafb9e7b870c2aa0bf793962ba6b4bda2ee 1 0 \\x000000010000000000800003da414bf39aa329042d26b98f953b28d808ad5badae7f5c34e77584e61f5f56efe09256ad1d02d03443ddbb56f67e8420dc466e1a7f6c8deea9b93190eaa843aa84f196eae8194a816b0852c1e08f122558fd14939ac0f41837a52f350cc9ca922130299dde92013b9802279b3900583ae836e8f0fefacf9c4519f8a5f488db8d010001 \\xc59cb7d5085586cbbd3f5771d5ee800e180169aed2cbda203684162863e63a775a94d11bb9ef1caad3f31027d32e1f7178d70f3167b3cbe14ba2f0037573760e 1687252391000000 1687857191000000 1750929191000000 1845537191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-34 \\x4df485d8f7eecf81dd3930a172fd1747668af80721e8450670825733c1a62a813620d67551dc769aeafe76138d565e9851fffb3f49829455ac207410fd7885e0 1 0 \\x000000010000000000800003f058402ed5e1870a0c72b43b2dfea4fc3be64390b3dc90ad93cf8724e2475b55880fd379284af886e80e2452b74e39deb1089e1466e6b5387d1633d67685a7d78e411525e335a1f43c4592b4182330598fb3e6a95651be0a354defa2373c66ce166334d366b8b1c93c071e4a72de22fba41cc22a8f74bd2239f1099a20892a1f010001 \\xd641f586f3ddbd2d1939bee56b8421bc3c0b2041a9b1654ef50aeeef5fd7f61067a1716cdaaa2693c5692955d0ff4fe2b1392bd05a40e4e31dd4ec0ec68a3f07 1674557891000000 1675162691000000 1738234691000000 1832842691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-35 \\x4e18875e8217cf623e3f7d3fff66c37691c681c6b1e3b1756bcaaff3709e7c171b7d8a9dc5298dc91cda70c3b240276160a2c3a7db9af705b43a2ffdf8f9e8d2 1 0 \\x000000010000000000800003a6a9f515024256f55ff6fd29942b17bf77f610071ab754176197e73686ed15febbdc4103a6006443fbf9c3e439f92690142455f52fdb67d66abd16b7782c4bebba81e6c388cbf21d7004273d119808d89e9dbce169255bac23c3751ac71a1f62493ae1a9ea31479ec7a153b59c4b66912956d168a5fcc3e4a4571ff6f5dce23b010001 \\x611ff908373de791e21b636bbd2811877605421f4920d675f3a9fb6189209c8694fc0a8ae26663250770bedcfac443400d3c722c61a7aaa6cd4514ab93e6140a 1682416391000000 1683021191000000 1746093191000000 1840701191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-36 \\x4f68afba27fa67e6ee0cdbfa417f7d30c50711e098c6aa0337382f5b7921378725f9ea5d50af0f7fcc60fa76a23229978ed6391244f325ddfb18c402ea707204 1 0 \\x000000010000000000800003b9148c1d0d8c951be69954283efe92abfdcc7ab292349d2b4f7660fa047338c1f75650a9d958d6533c786f184c9a9c0a7cae8ece10c456dbc93a65b338c8a41cdfe9180942a9110027d4add89f5866b0c856b459aac68a78e0cabaf8e09e94435a487f6b2c2f5ac579c2898c6642f397a1914bf46cc5a9068c004e63f64e6983010001 \\xc02d2503c463fcb6f2292ab5cbc80e510bf6c4378ebb7ee383d563aa37de2a8ac9b67057780cb39b1b3c10e6c5e08de2f8583a1e77b72e023f9cfeb0a75bc00f 1672139891000000 1672744691000000 1735816691000000 1830424691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-37 \\x50b89f77605e94f33a7e3ed505ca5d4a13c68c3cef33da27b4a882a5f84f641b7877a77b0077dcc216a189ac3ed6c60b952547311d8416392784406319298072 1 0 \\x000000010000000000800003c5ccb0df7c1f46605d4d1ccbca407f8d3ca224b41908b5e6d48341f07aed81e5d381f0f46315996e8a2bf04bfb5a02be2ef248f33b6e755fd30771264e667371f0f48a056bc0526f7f64025669db90383497f55b1487840802d06bc7a310549f125d93e5c86bdeff15af6f7df53a85d84cb500341a299eedda9a08b5611a8f27010001 \\x94973a4dde7aed033682e223ced14bc7c9206c16c7511281ddb4bf7406d2137e840642a0a93995b4953e5e6b9dc5e1f6970be293a9964795c7c855d9467a250f 1685438891000000 1686043691000000 1749115691000000 1843723691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-38 \\x56887e85f3c0f20da12ee4d02e31f7c706f4357f796af077520dc61d7c8c8025c53446bfed2f605b6b185e7e0df179c8fdd9d4dbfc88835245783a9f263aa21e 1 0 \\x000000010000000000800003b217db6d90e5ac68deab73b45d6c784c5c64f1a41deea1e5a6a3a0f4efa836fc1de6cc9559d522592d226a03839dd58c188306f533f9295022a38d677070f0be3183070121c195a977ed89914114760aa28e18b8dca3dd509f611d5b834dcddcefda690114036cb4e9ac613aaba869ab483a4bb0a931438ce3c154d8de2f1243010001 \\x2117f51c05684c6c2d35aadc4d4c8d7f4a9dad3946e6eb5c011d86a68c863590dec0c6a5b2b11fb4d12d153b2d54fd0ab35b4ace5a8b75382811f1c747cbdd0e 1689065891000000 1689670691000000 1752742691000000 1847350691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-39 \\x58942b93cf0ea2e0fc471274be95179fb91f658d980f9e00ad699d4a2c473af6acf33b9fa1588177745f5db94dd17d3997fb2712898a67812263e3655e076ea2 1 0 \\x000000010000000000800003b903e532565c2c084202c3525bb5bb6789705185cf2e2c79e19b5a2b53b0e7c4175423c80ab3e38fa4e9e27b5c186ddd76e94ec6eb82ff4f98ea1c6a409d8a4c581cf6febf23d0ecb573d692d5f3abf2f74ae769c23ddb741537ca249ec78f34307b2d69b30ba7e79632075818e0de28a3f9fbd7264767a6a488307794be00b1010001 \\x3a4d1f813422d58a14ddc8431c93838e007c081b76008397129ba7ae79e811fe300cab51f2720e92a52dccd1fd7dfab5ec2e454ee6272ba4e343a0beb0e17809 1685438891000000 1686043691000000 1749115691000000 1843723691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-40 \\x5b946ebf5bb8550bfe0e7442fbba2fb651d980cf856ca4d297658ff9fb4a3dbc06101850324988e1f52c5e21f75b076bc60ecdcf67530e310826770de17e25c2 1 0 \\x000000010000000000800003b913c6e9349ebbc7d1047db2f1eb15cd50bfdcb5370d9816b06922c2b9beeba9775e30e6369184830f9dfb5d8b9c8852a03a5f341b3f31665a67a8a86a09690d4f11b683db6212fb080506175c6aa1286992daf3a238bc1f49c7882413b04eb75af971f599ce8833638bcd5e4ddb3a57099b52eab107d53bff6da9211378b1e5010001 \\x9c540b5786445d1c5a41b0b1fbd0db3858c9f0e4f52c4e6f6c36ca1bb397f9fd8ea93d46cca5085a68193491da4734e726b6de81d3fd6792f6e461995416d10d 1661863391000000 1662468191000000 1725540191000000 1820148191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-41 \\x5cc8c1cab751dd60ee040745482cb3635f858158f86aa69682a54b64c18b2bbd43b792dbd8aa08114eb89378325ef455ef6e387bcc627cd7f49140e7deb45a85 1 0 \\x000000010000000000800003e3c670f5786cf696d3b379ad25da23c1ae70248b013ebc848608ac14cd10f611c3c40d8bfc332417b99a13f8e11d6a3704eafba172a27d4584202a3065901c0ba628062f032e31034da0ea9d43b81373aa0d712eb811487e86ed39976c23230a51a820feed1b809c88dd72bdb4598d826f11a12c6be105ef8bdcce14df86dd93010001 \\x9d6e964d79d1c4733d9229d87abc7dce31d5a2e6a69f6b472ea0d86ab9971fab0842183ec27c3a10ce9c03d492a5927a12d42319a1215936c99c1b551015dc0e 1684834391000000 1685439191000000 1748511191000000 1843119191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-42 \\x5c584a452bbc40c54342f80663b4ce974c03f676e07f8fc920dd75cc70d1e6087e864f61a522b16c70068785268ece1033ee718da366873839f50d4833726f59 1 0 \\x000000010000000000800003ab7301eb4e807ce3981282d53e9f5df63763673570feabcf9fada8c3c907e0543aaf870661f8ed338fbde98aa73fa05132826b53f742e84239d16d93f8abce160c415326720fbd1557287620b791ec4cc1b880666eb4714cf4dc23f707acd5a7dc58aec65c0cad8d31d77d6d14fc9d1b86a2960737a0cfeb986c771ca508cf77010001 \\x488d0bf6d67735a6138511a2df27a4e65d9a3518adbd920a7e9faa1189a7b7ac8f946f90d4515422000439d0cc7cc8a04d96a8f74fdcd29191fcc95f32cccf0b 1668512891000000 1669117691000000 1732189691000000 1826797691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-43 \\x5e4466a54d9b1a2e60a3ba00f3269dbb5f1257220be1d1995d6c0a7890026137a36c251702c564507f2dfa4c5cf566f7261e5b7e664a98fe50079499c70c6611 1 0 \\x000000010000000000800003b69e042baa14f6e1ac30ae776a3816970af843e4b87f7fa9283d88540a7070c8c0394c16c3a99e6f002a39c1ef53160a26b5f907cd121cc2e8aba2a0b4e36a612dae6fc70030590f7cd071e76ae58d7bf2750d2a6f5aff4645e4d63adb8a9b05490f2ab45afa674ca6610cfdb26a4fe8b4cd5e0201ba769c83a3b7c69f5a754f010001 \\x8d60b8c5811a5279016bf54d15163f11b2e68ef74c32ed1144dc3414b8a3d4850b73be917c581683f60008831b7a515b9aee0bea0d65d914d46aed3c9734af0e 1683625391000000 1684230191000000 1747302191000000 1841910191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-44 \\x61e47c662bb861fe7bbb970b5379c1eb6bd77950f859045b1a1445f0df6e258470df58235defe12027d741edc27b58a8fedf3ae077c092b08c8867cf699f68a4 1 0 \\x000000010000000000800003de9e04cd8f8b1d9557656ae045dc8ca3dba25956b177fd364a8a11ec110055cd544f6784fa64f6e7868744916f349df3090bc4a5469a381dcbcf4763c5d4a10c70d72d07c3825aa111d5f06339223ce11fef65daabf8e1b206bc02cc0ac875b8c5c0d2185be434af891d50624679398860200ef5694e18b4ddea6fbf9a86a561010001 \\x6880f2dd3a851701942961e8a29bb2a5f8a470dd40cef28863789cdead2018110117ec13d18fdab14a966c6d5eec1dfaf5877f48c915036212f2b6c8f0154507 1664281391000000 1664886191000000 1727958191000000 1822566191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-45 \\x65e4cfcac1aa2a7522f0af644c2f1bfef4d476b1ba997cd5c5901229d57844ba9a88967573196cb98304608c9505f30f8267671cce09d84611446d361dbeca5d 1 0 \\x000000010000000000800003beb85b84ea8dc12db45620735dfe2480924b63ce54eee37eaa129d6ce846da09426a773d139f455e039814685b11c1786bdfdf0b3586ed35c91d220a280bbd28f4e8afbb7edd0286bc2175547fe3344e7cbb4106d8208134526d98eacf14da7ae87b18fd3784902f0ed2a5f6f6a4cf1768cc51b2497fdbd884a8663e304b2d7f010001 \\x954bdfa7ce63181a36acb4c5f75112d6dd757b8b5be28058ce117765040436aad65df8f755b3c02e0ab8c9bf95ceba1fc4a570146123c990be4a403e28282f0a 1689670391000000 1690275191000000 1753347191000000 1847955191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-46 \\x66105ae0574dc88c5d46a72b0feffdd907a78fee1a279a34ea4a20d25a4f532d1e59a4f69363535f9dd05e1f61ed5d26c9b1ec8f1b6bf0537c01d02d7bf7e07e 1 0 \\x000000010000000000800003b1cd73bf5aa4e92f50d2536ceb0467ebc0c5a0349ca1fe96867f28f7a57b910783c9385ab3f4fc5e2608702ecb2c3dabd54374dc606b91a7d4a084470bd9b0adfb4bf9db46f3cd7cc86a9bea57284041d494ec9aa63769043fd4806a46690721214e721d0ce6e8d2529fdbaad10875af11f13d0d9bc0e144e7faa667cffcbe07010001 \\xae5f3a91c4b976fdf825ca59c9eff4e7eeffb42854f89ba6f0707247d1755572426c5693aa7dd586dc04a61af179057e0b05963ebe6b8f41917f812b4f3e640d 1663072391000000 1663677191000000 1726749191000000 1821357191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-47 \\x661c556f32dd9ae43d45c72c0728e4d60929137974e50e885f551bfb9e3c3e0095d84dd91fb957636d036f285506e58bdd03f03d3118d34502557deea0c21669 1 0 \\x000000010000000000800003aefe84200bae8f69fe3bd3acc8f2957c684b8d1de56f33049d4947053d2f1f7905670e417027c7f804fecbf96c3fa579a48f7d00a16be979e0bf53b43d3cf1f2346bfe4fb51e9e8c5bbf4d0ce918098f2d2c953dffae9da5a3f235635a82b71f9c7889c5ee40dc2a03b9073a9423bd9eb84d2050d3487712e16fdd55f5b3ac75010001 \\x22c8d2a97ab11e98556536d40167765e0b14ecb43f22936032bba7eed2dc329feaca4cf1a24feebe64e645972b6061585a77f895357861c3fe09bf2f496e5009 1680602891000000 1681207691000000 1744279691000000 1838887691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-48 \\x6790ed924da42b121dcaf5c402e5cd2e06c29d94ca56f3ac17b33e03f4ef5a52f1a56f338f3f660749d928a0155a9fc88f78ed3019e54d600707ccdef9a1e57f 1 0 \\x000000010000000000800003c03785fb16745453ebe8f51185805f162ef9adc44ebcb28c174055a8e3f929f2ca4757a72f8818c920bf01503c119595d56c9337da87af864246bdeb3d0afda6bac3a5a8ffa4d90819bc6669e14d36b0ac6767f762675edbd1c62ab4e03c30f3e1d680cbc727bc310890fdb45e9256f90f6b01cd7f6355ebd7150024e009c911010001 \\x4043348e711025f764fa934dd574494c57523018f3566774e4b5ab33bcaead8faeee0c2ac6cca7dfed82bb98944ec7c45753e93a3ab816908927aac6c61aed08 1668512891000000 1669117691000000 1732189691000000 1826797691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-49 \\x6998192b3ae4c840292ede029cdf98584a96e3e567890dab5efa4eec5359296a6f69412090810b92bd2a26da1f08c05cef3c571df289e86877ae446fbfbf3f20 1 0 \\x000000010000000000800003d640d43f0c25254249b5eee9dd52cab739548c3ba4e96889a5ff1356ffbd4a20fe6c5d388ed5b507cff33946b2f9c2703d7e9e7f263a261959da4f7dad1c1655d9d990df1c2b416de3923d42652013246496febbe67f89548e6de5bc67082396adf5856c21722af7c3e45bacb4effc19cca058c832a3c10c8540bfcc4191eacf010001 \\x6888898ba8bab5d12a6a75278af5aab4c99cb3fb5eb7ad4e34cd1f1382d203966518c8aa2663d8bfa8ae4e45900a81730d20c98c872889c4244ca295fc6d5106 1687856891000000 1688461691000000 1751533691000000 1846141691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-50 \\x71d425a67a1ce2cb780ce95767226a27f5d41ddd0d2e4be13ddb66ca24ecf0c99cd0f55efcb2e5764a292d408f1ca4a4f05ecc555f0f693d478f808465a1270f 1 0 \\x000000010000000000800003a05e2fe5b53c851ef82f90fa631a5b58bedb574d70fb9137376dbef55a2049d1b3ab5404d2f36ef5a7100259070c5e55fbea3cd0aa8fd6d2331f41035da7827cde821908cae2b401924e200bc78f4f2df0a0378d09357c00e2d175b80aa9611be2d70f5b74d3255d1d61c6cf87bc3ab690b852dab00ffb66dbe78053ee573e23010001 \\x684e9280a200ada9d928e27bc6fdc44daa2bf749db319f835d47c72448537ef275ca14056cab9c7dc1088fa1ba351578422be80263554a068256b5fc506cc00a 1669721891000000 1670326691000000 1733398691000000 1828006691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-51 \\x7290a549a0048c28b93f262ea87b116d0dd54c007fffdaceb905003a8de8c8fa76a3e6deddcd08188f813d2f57352625ded57ebc395d07f9a0e64b385b5a2d45 1 0 \\x000000010000000000800003c9932bdf760c65e20249b480a6aeac4750c65bfd0a540ab570438208d8d5142008031bfa633fec20caad8764390aab35b59d5f6d0d8d57e3f60d29143b1fcd1d469329f5e3a1bc361d0a48875f3b39786b339f138588961aa7302057c557dd2ca10f13abcfb9a1a87a5505c87efe7f9abff9843e6dd109049b57ef4dff50f11d010001 \\xce3fa76cb88df206eb06682e64f022331bc3a8d528dfc62503633c6511ae897152d4e6fafbc1dd6d7098ce19298dc75baa497b765ce1ede878d730061d31d901 1679393891000000 1679998691000000 1743070691000000 1837678691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-52 \\x757ce694b3e56c9f40d622837f59b2b621c601dd92962e28fd9bf52c1345c9d18601bddd66aae890490dae1eca10c89e7b9f6615c52f8f8002dac6341fe0793f 1 0 \\x000000010000000000800003c7716450ebaa73caf76777346b29260c8ba976b65b572167aa39bc6ed3527ca926606d329f7ec2524909b0cbece2ba7c7e8faa4872cadff493ecfc21153dc043318dbde12681214e86a64564215bb170ce8441f21d3fef12c02a475412c9c149350651aa0aac45691ec8caefaab618f34b472ccc131115023cf158f9f6ea61ef010001 \\xcd751464f426bc6a7baa70dff7bd6399ca2c8d1d6bb25e0b2ff79cd89a7d2d4f922ae7e83501f793ae684076da3d80654b25830a5db9c9d8cab7025f88aa130e 1667303891000000 1667908691000000 1730980691000000 1825588691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-53 \\x77bc00edb0fe4dcd6b0c83b81a71264b589b37bb6262b9f69d66292fe636d6636757a3c47610391b1e60398eb9f1869f83afaed6c4a392b4749e8cb703633ff5 1 0 \\x000000010000000000800003bc53adc8f8f46e8ac55029037f746a1c423180f3daa5bfe1efd696c7707570d3b2a0969407436c79aa40b3e027a1c0cf00e01971362cffb6df6ffa82a378ed7a2b5cd2eacd7e43a5c933e1cb6d88fa4f0acb773b4cf037221fa25db4352a35fc042c68999ee6442da365778bd34d8b9f875fe70c14fd6f0ed52f9a335ee7066d010001 \\xec32b0f18de589a946ba3d76484f55723dffacf6ee765ab827a230c43d56cbc4aa2b3da791a9847ea46254face5f9fd2946ef0ef845ede011a103ef1205f650e 1687252391000000 1687857191000000 1750929191000000 1845537191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-54 \\x7788ab8d12381ac54888f054ae0bad4545b21052968b6e3a79e913aadf8f1abb6c21e05f8b64749922eba42754bb8543e25e17d700a73d9a589c675b258d5526 1 0 \\x000000010000000000800003a5d601b447af288afb60f0c1a0b3ed8d42c0a410587da2b04edf89453e572a7060dcf98f881826e7c9df746f3725aedc211986b1aee08145cd5fbc5f9a6d89a51b0d797e8f6dd0c5111da3cafd2355c70158f43ffc95b65b3c19807ad8dd0dbf7e7a6a0694acc02678d40a49888664e77eac0c91f02cd91ed4b127b1a6c4210f010001 \\xaf2a03475551d941b9012739e3704051402eba8c58bda7e93a47ef5ddb334880a414b1643f3fbf3c93a245f428e263ea41b4137e05b651a55fd0d57c304efd0f 1677580391000000 1678185191000000 1741257191000000 1835865191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-55 \\x7784efa07de5fd63dd2c0595d6c8f49111b42cedf473865e8f2c60b19309f134f28dd643b4b339ccf59c2ab5bfaf69b71535ef576883a3556db5340d03bd040c 1 0 \\x000000010000000000800003c13e9bf2601e45a8e185d17f0ca4968d31622a2c79c116d549b8fbcb9d4e8fc8ab68586cb97c880171239a72e12ac9c106cbaa554f3c6f72d32c072cd0d2d6db000c11bc939cc55220db6ff178dfb59c243bd1d9f4a76fb5f00ac9a66bdcaac9b67140e149919b52cb91c1926d1c5fe48138cccf83871c6223e14af80b0478d5010001 \\x505fff58b0b83f602dc47fe637cb082065f3bb9373ab1408bf42e3eac266c0464ff1c5be2defc4abe89f684cd07a21b5f2b206ed769ad1f4a236f16efaa2430a 1683625391000000 1684230191000000 1747302191000000 1841910191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-56 \\x78c8cb5fb9318f4ebd94861ed8dae1bfccc4344f4717661abb68fe8b2820ac6108222523b2e22b2c23d5328c1361f50bdb35598675f34ae165d2d81c162847f7 1 0 \\x000000010000000000800003c29c35d0a8e539bb809fbee6aa19b5050a801e2ed84f9d314a54dcf6df56dad6b56e8ecf3412485569c5fa274984ad61d9183d500aa68e3c381fe984571d2db488707fdabc935c3f3d640d9cb1f700bbeac6d5d02548b7a531f1bd52e21887d38766a4a27bbbaf7100b2cb04eaf46755e193e327bf04a9c53883ded11923de0f010001 \\xa78111b3060b139ce6a0d39e227c145787d887bda4d7b8a9513d2f095ebc33bdd3a9fa23e29e7a801480aef127211343b1d0fdf6e9bd827d78b2178832ee5b04 1680602891000000 1681207691000000 1744279691000000 1838887691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-57 \\x78a8063887ee3ff3a8690f10ac5f35d46f6f43a2c9ba6968243cdaf9aea60718d7bfc3c224533a7240d4d3c2bf15c6c73a692c1bcd7de826cbbdc60885c4e289 1 0 \\x000000010000000000800003aac4c23f5e6b1e6908e6be356bda9f25ba248dce2090231b74db805e2027633b9a853d990dd8864b0c600d8d12ae1e12a5494c039b80d5a3fc84bd6202b3ce1c48e912152c08cd3f2987ef356a7b7d040006cb18498be76d95dae88b536e66dd626623730b77a3f98162c3e0f9e4412776baecf2bf3e0c61833504637f742e63010001 \\xefce6a163d1c463f71410c9adb50c79a545f22f301ff7e35fdae1c6f22e1d2f1fe27a483152e111b2788830e64b116133ccf8b3e3255c55cca00fb09770c5706 1672744391000000 1673349191000000 1736421191000000 1831029191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-58 \\x78ec4ed0dbbdd3dceaf166b05cc4bbca41ab77926c3a99c9cce5cadb661a60c331610d5500a605377053aaa6c313c8d522a1798ac27dd5ea7787aaabff51a416 1 0 \\x000000010000000000800003999ed24a4fc1c7dc2f79a275021fef344b663d6796bbbde97c4a90414d824cd68baccf981d17dc1420c6f84b423bf39d5f9d486c4ec282b95a0b4e50fa5c65d52b78d687e74abef7f5e4fd51f5dd91f6d80a592f12fd1cff5b1de4ac2a51df1ec3ae2ce7cd37b0e9e8991bda7e3b5f442cb22c1b41afcb155237130d4694fae5010001 \\x10dafff72eb4e9dc010b69233cd85426e655bd1e2bf7f9750dc5e82e494535ff6ba8b07913af7fbe01fc1d1028685175b3c17f968e3f29fdbd1a3fcd9aeda200 1672139891000000 1672744691000000 1735816691000000 1830424691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-59 \\x784cd2caeb801c1169749d89deb9788f822f893012b938af3c2494ef627cba60d2d699994c221f27225f1461ec898bf27bcb214f402d36647f387bf7fad4547c 1 0 \\x000000010000000000800003cc466aeaa5c6aa7a5d9390974aa7c81cc670f31a4da0ae6512bbfc3715e364b2f7d36c9bb5b61ef07d4039b5e5745518b4a5e4eb524e7231dde228e6869f9876bc68f67e5ceda8fec2a9534cafba7ccf841345d66c0497e4453869b70b3f8558d9be4abdbd25833648509faa307f96c57a631ca1d3aaa5552e9a23bae367a09d010001 \\xcb6f0a437e74a7f296f911353253ba9c1141e68fff7ec081ce25cdbe43c60ebdd6b2d88be4fc101ae0bcf37962ed1ea74372b28c98df099f6093907ec65e4a01 1687856891000000 1688461691000000 1751533691000000 1846141691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-60 \\x791c5de2114606269fedbc9cb3f5c74fdbcdcc6e64b4845343ace071f9617d0c3b3ed75611571c96ee94c5ac52d4440c2c1062eeef5c5803f0f77271de460be8 1 0 \\x000000010000000000800003dae774316b153d7bc555b8ad6821fca4fb0af87596f5027af00190ac60cd13061d2fe54421e8e593d6edc59163ff3cdafdb29157283009f6a42a6703a259133fdcd7cb395754b7e45e470940444e29234bc1d476232a6538f15bd92bc3818eb4a795ab75167d6777e96896067ffc3eee37ed847028baa40991239de39dc2c3eb010001 \\x5a64d007608c624fb5ddc06da4f5d78769612415bb9f84ca4565c846e9267cead654a0b6f2cd8adc9203080bf475c257e68c8b12966ec3661ae5adbb5d6fe009 1690879391000000 1691484191000000 1754556191000000 1849164191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-61 \\x7cdcfeae262a20e81e2b37bd1bee6deb6ef312eb8c3e5b60413617738f1ad214cf1948889fb20866a3e2dd28168130fff226c86398da9514c86929353d58c49b 1 0 \\x000000010000000000800003b47ebab6702b79282afb5526ed789cc02939cfa421750acf7e18893c3a4685ce13b58b3955414ad62802c79077ecf4b942707fb0d8ef94df3f5ef5816f4cf860c91fed83836afc42468334d7d34da873f2099910b658425722c23875c7847317bb6cf0425214ee5171e885aee61e5052beebb4792b4714772b3c30e415652637010001 \\xee24568da4243b3e7d92dd6979e73dae371e378d99bb250a72e7fafc370d943ad696f4ac673c4afef9f56e6c491b39d2cca9d9fa67b4c42d34da0147bdd3450c 1684229891000000 1684834691000000 1747906691000000 1842514691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-62 \\x7c0c5fc8afa4885f3d9f1e5da8efddb50644e4a53f2acd09e3cdb157d431cbe02b1bf8ca976605f1ccd1d1e0e95f65cba1812ba8f16a37b4fc62002c54afa796 1 0 \\x000000010000000000800003e64e22fdfa3ef08a8549901605ac99113a793035b73975ec20680cbb0227b914f165ed27e3cca85be49afa2d07a0df4ece51d07b8e01821decf04b58b97bef4dc9e8476a74cb74cd5996c2c8650bafac5f8a3c35f528d7b85c0ad736442078d14d583d9b98064316acb60f8d89745dc227de3a1f401b3cf22cc59295b57d03af010001 \\xe7432051eb15bcd548933f4b6224cd461a2214bbdc28a660a7795fba7b98553d326dd5bac69479c15d742b26cc67ce9a78522491c56240332c022a3af6e91703 1690274891000000 1690879691000000 1753951691000000 1848559691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-63 \\x7e0c159a04b44f522abe8f90520de2fe9f3e6bb84a196553cb6ea168703f989c180b3f0b9d8e35aaf5ebb4262a4d9cf6293a3c8efb593765e6acde5735944694 1 0 \\x000000010000000000800003ed828563bb1a3d90163575362777c25ee5b8c8885312912caa99ebc15182e3f10f9c252386780f1c86af1a8e16ded1d4103cd79bcbf062bbbe5b5e35dc954f49e3e9d9922b6f2f7a2f279e135de119bfb8430921e67dc7df624b4589ac45cf791479135d0e24fae1261a79ed1e3ff6aa5aecbd22244d2fa58886f17d88568941010001 \\x620f1cc02ca417d9e697aa9239db3e3b1beba1651b3b51224fd0f3389d5d722e5020ac03f8a060ba61c04cb873cb418f7993772305ba8b68b711078c5ebf1e0a 1674557891000000 1675162691000000 1738234691000000 1832842691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-64 \\x7edca4caf9254bc6a5a1330dac9c52bda8341686a7a5fa64c4a894b59ee9419c93ef2f3fad9cefda5d4a57a44dee10a5ef079e9cec3c5ed90e8813d32c35dffb 1 0 \\x000000010000000000800003b9166644e2b9bf52046bf94b37831b1d62b15a81c71f29365c41a843986d524c730dbded0500bd59ad1fa8d90a33faf4d73367611348018f1ae06900d34be9a2d8a7a7c4b9975e6eae600a384f2147d8bb87a0bca4c98e7c8eace7f4c0ba1de8ebb9bdddf6df7e48e1994287d702a14547d67714b49f1ca7a8926ea27c2da59d010001 \\xd4025c87546b76aed896afd8219ac9bf13f120b85829bfd58806486675345056fb0976203de358e63383bcd80f336bb63d12295718e4743067f1a831a9d74303 1675766891000000 1676371691000000 1739443691000000 1834051691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-65 \\x82a03ed62ca743ead5b4f1ecac9e92524092a13c324abff3aeab209fa2c27b0d98ca6966a295bca2960f11efad8ebb1b776e4e011b5a345cebd3ae68ac77b707 1 0 \\x000000010000000000800003d707490020e4d7f75908e773c3b94a95e90b09a1a646915fe63eb62973691b1fd5006edc9648bbfafa9bbef34f84610dd50df6e01d4936c2f9a943d6cfd06ea1bc26b4a74f69b377fa3bfa4fb5fbb9e24b596d81f837cb16fa18ea08efad9629beb4bc1ac2f5045cde9a0eb329d9f53097d4cc78181557cf0ca08d2b27f12961010001 \\xd073cc0c478576f9f430fc9ca268f59b2e95a8eb54999f470a924c0af68b760324d3fc14404f9030b9097218a4bf80aef09f5cb4f1a0d805ecfc13588d9d5802 1661258891000000 1661863691000000 1724935691000000 1819543691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-66 \\x83e00d8a2edc4a8630e189a31f8e4d2c87a1efd7e15ed77b84a993ea00a867a2cca995da6bb4d228609d4aa7c1e9258f520da51217bf9b323e300c5333ac288d 1 0 \\x000000010000000000800003d2cd2dbe3e78cfcef0d7949564116afa48e543c86e6add3d31bfc3a05d0113d298dbf39b6229a71ff70c55584d8c3c38bb5402eaceb76010487725204d955038e9b4bfb4efed58d550dad3b61809ea9bb478b054870c7c3d32ca74608b8813d9f77b345ecb275284f69c1c4065479535a7e7ef00165a8efdd742ffa9390ba749010001 \\x736c46e6ea9712115f455fdfa2872bb57f96384decda3810b5821e28f624dc28a9667881e35054babc960e066e01c6c35556c9615e13b77775a5c922f3dcf103 1685438891000000 1686043691000000 1749115691000000 1843723691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-67 \\x830c3d8dae70765d8ffaad8bfb13c4557f4bb9c9f08c4cc7e77fe84201aed2329e635644450923910a6bf3c6b0cf2fba20917ddf77b947995e2822b23e1b09e8 1 0 \\x000000010000000000800003ca25b5201f4cc376970e45010299fb34ed55f880fd9221b27f718e7e5290ab1809a0e20c3f41e2f72473bb67751de37a41b852b7568dad558bf973e605a3c50dde02d257af139f815b15ade699c4377436a2c4dbb1f5ee8a26422715358339eb4cf59f2c4319d706b5ac20d60cb61e0c278951e2c17ecac1592572798e4ff7cf010001 \\x7c7f3efb7c6f50c3ab11993207e8c921425dfce927010fda1f6b02b732cca7d9901fc6cfd3f0083ecb49d25cbe1a3f807f3d73b84b433a0deb1fa004f9a4890f 1679393891000000 1679998691000000 1743070691000000 1837678691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-68 \\x8550276aeddb1e53f5b529308e076c638df139536cd02a0e1eda3aebc263c79597ade6cd77482c05f038b3c7138ca0364c6e8e83a9c86d31192835302eb00574 1 0 \\x000000010000000000800003b2cea5bbbd48cddc24455a284bb9bc231593544e596b1d804f42d501bd6cbd414036bb7fac439da6490f6ed28963b8fbcbef808eaaee652c40bd75fefac6a0ff7702d50965b20de18da4d85b88c3762e85eae5262136d85f4b664e5d38b0b76e9c2fd3001b980b9f284d9a5c93cc2187a5d5b7ebaf4e3d914edf4e20241d0ebd010001 \\xb7c8b12a64bdcb1217e8cdebdb10d33f7b77970b377e735019b6f5c21bd98773021b8283c7518bd82494ce1837069533be627f1ca72db4a220713a0fd5aaa50e 1686043391000000 1686648191000000 1749720191000000 1844328191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-69 \\x85a88fff0dc7a67a0ad19bba04152bdbecccd22eb1e73819ed4a7d0462f686a70efecc651eb182657f0a8475b8b78b70a678e8a074b1797baaa1483d8f54d25a 1 0 \\x000000010000000000800003f5b7b4b03ebe2ab0c37d324b5ede2967c46fa627a780018c71f3e7af5ee08891c7a5dc70a90bfeb30c7244aee7407dcdaaf8fa055b86de628065243c3f81c139e635d0251722ba96ab71fa3513ee8a95aa2267a98b5948d0ad0e927ae7d04bb89f8a3936279004579ce38257d26fe2da539595fb4478522583b85164de866e15010001 \\x3b25570fded382f83c6dc2fa094431772dfae031e1833c33e7d8490c152d28056ee562f6450c2eb6079b5b9eb9ded63a954d6eeaa9d738d4e37d1cf1a3a1c808 1681207391000000 1681812191000000 1744884191000000 1839492191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-70 \\x8c74b55bb6f50ef7130a2d2ac68980a1b2de324244fe1888a36374203956d5f1b42384877706e750b9cfdfb64cd0c3702259edbc90423c26f08f1185deb2eaa4 1 0 \\x000000010000000000800003e23e39d32ab6ca426beaafd086474a49a44c72e4e6a62a588a2c0a563c34e5d085bd2d21abc0968eb88927b6c1da4688ddea26c665874aab13c544d393d227bfd47d200d521ab938f2a388f4eed2897e6266ea0e2f8a1aee4ad1033bc2a3acc9b9277a30620dc0ff1dea836e91483a7f30e85c4636c2deef8808fb93ff3b485b010001 \\x675fe9a78a6772182acf0154bebcf963e93ea0cf7956bd59ccda82fc48716c5182424a2900b5477fa764dfb00608346cc9d2fcffe8eae2fb1afdb7d9442b0201 1683020891000000 1683625691000000 1746697691000000 1841305691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-71 \\x8eacfe085c73acb6b99ed17e45f1eade517025980ee7f15c1a8b7e1a7b1b1c9af9d034bf9ceb28b7124a483451b3231271ddd4b066c8c9754a3176e94009c49c 1 0 \\x000000010000000000800003b8c2c6dbc7a38f867d4ada6bc2eb4b042d3cc1f69e4cbe027c974ff36509e7c0f986d915018e082bce2ad02ad8e8afdb00f13e6958990e3dc30c5ae7ce3bc8445e3f200d3c56f7238b71924ed0774a8c8759a48047139d558aa7efd6d1c7308a9d2fdfd9d2faa6700e851475a533e17727f47e7eb039672112d1e1dbcfed83c7010001 \\x7c174d6f7994c42dca6b28242919dd85d449da4b09a9e526b1729bf6aa71d830b1114890c2f7f2481727f2c271043af40488e1d9b13b19d8b99e0d9e32f15205 1676975891000000 1677580691000000 1740652691000000 1835260691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-72 \\x91504cf08f29e2cd1410573dfe18bf52fecd170d1d4de37fc1788fe10c8864bcdbb69f747f98d1f027c461dbdd0b374042f2646121a52690c0181ed65d9b7489 1 0 \\x000000010000000000800003c732ddbe1d9b73918379dbd87cbfe931f0a1e1f401a596e37c36c8917129f5dc90a3bd39ab851225f716c57bf37b904c9c7c7c0a9c93781ff634067b8b4dd0ab3771b0aac9325a89d00b7f274e244b72e9402b4e2670ac985bdc3b59e0c5c3236d1132ea0de46fb284298f38ea268dc09da4f596cc12896df4d7e7ff41a26415010001 \\x7613acc577d5220ef313f60ebe8dfa42a7c4c2e8d6812d5189cd47465e23db76442d49f810923e4072cab83c05fc1fdc7762f118e4719f4050812a378153910d 1689670391000000 1690275191000000 1753347191000000 1847955191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-73 \\x9260051dc17c77a268540f0143cd3c1549190db7c489cb184d99dd4b6b632e10f99fadd5a4a36d346e0c92afcc21023e5eb97ed170f45002b1f88abe463ef217 1 0 \\x000000010000000000800003ceaeade4ca411fe472b97cdad85cb597f729d1151f3c82f95613627ae4227202e514128959dc3b11a6e54a463a7e9d2e153eb99de8a63c64a994c75099163bb569793090f451f8cc5aac9448008480825902ae9d43c1e7150c5a384b0ac38c1d8cd8403d2898b6772977ac7dc82de2be2535dbbc1216efe7552453a413bfeb27010001 \\x65eb6b92c8538f045144803b0cbdede517fa21ef793b00464c7af2f9306348b3d438c71dbab002f6fcdaecb78dbe95fb0b418cc6ba77fbb3daa3059bd9cc8302 1682416391000000 1683021191000000 1746093191000000 1840701191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-74 \\x9a44e2bd8191ecd44665b2cc545e0d40867c042cfd72a85e5c29bdee1488810e8d5e1575cbc88dc775a27d7fa3c8007dbb84f66aca9c4c4b10862b9f85ce4c50 1 0 \\x000000010000000000800003cc941a2613adb4f0cea3f88da93dfabea533a17eef91c0bc99499436be8752d632d657960f43fa0638c0aa776660450a4618a614788cfa1369970fee8ecf8c5b96ab1a4434a7973ea1173d597dbf68d97c6fa403872a6fb92dab8e0b248775f2ca5a9439cf9c2a7ba75661ab00b70b0517bcb911ac50c6a135ef47dfb6ec86e3010001 \\x455b856ded3a9088c04d5c8f739f23d988cdaf83f349de192108ef6c5512319923736d3254fa5819ceecd3ab08cad1355b6cc779db24faf97065636846926b03 1665490391000000 1666095191000000 1729167191000000 1823775191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-75 \\x9b7ce2264013c3a2a5625ab7747389008e9660783f3e7ce82108552afb34b98ea278ec7792459ef37e8c18ee405371967cde0996f4e6cc5251216d21869174cc 1 0 \\x000000010000000000800003cfab54aaebc296f9d20cd40ce0145c39dc0095108aa0c8ea87a7dba9a56d98989c55c837b9592ac346cc6bd2ea58243e4320faffe8b320a07e2b39fdc237964d9cdc8d5b1ee7aa6e22d6d579ec1f59cd1f88fdecc2dcc9a54ed44bde3cd1c216ac228b1773ad26b89d403408bbec9d06f375fb222a254941986f9c406f97a007010001 \\x6f070035a431a6a543dae055e0f16e8a8c15240df0d63f20626deb745a42e1cd70aaccb082e91f85fda019b0751830fc68cf2cb3efec7937e470f55d574a2501 1683020891000000 1683625691000000 1746697691000000 1841305691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-76 \\x9c14749c4cda29a1be3d00c0efe5f84d01c0c1858eed6a958344185e9906a0f698a359e658f7fea2ef730bf07eafbb850e9e94dcd62f4135cf3c51c32c0350ee 1 0 \\x000000010000000000800003bbff7ec53941b0020ed4eaf6dccd33f351c15362c3719aa535fa90e975548696e1e023e9a39f72710172aaa5bb0b62b8d08a5300dd692e84fefeba08f09dc14025350efc1ee0011fac4809ac933195153295c1c832a45f87a0e623e71ccbfdd88a6f577b4935fdbbe3a71f3fff0a442e2635504fe61132bee0817586ef32e077010001 \\x0af7a31fabf924d71fe695e4df403f411a1b8ff57c3cbe00e4d46a147a7ecefa7354bf3d75dc3b300140737126fb6dd470e98c536d1b3ea7e0af186b57935802 1667908391000000 1668513191000000 1731585191000000 1826193191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-77 \\x9de46ce3389fa91a2e9493c1006dc8e05db807df42dc806aaa639169ca7bdd4699019c03e30a19304878328cdaeef8536727b3658d635a4e93e8349824643e7f 1 0 \\x000000010000000000800003e9bc78a6013f483e1c8f4ebc8375f0ec46c4ea2875a41736c8fef125473546d1b62e973d145a8af6cec0949bb198f55c1581bb79cd1364c204bb82b2bab63c3a4faf0d8378c1d7447c84ae22822536dbc6eb2a531578b583dfc52c9e5333046032e50cdf1e9b6ba4d37e8e933452ab6ccd38fcea3b6d6441daee485742806151010001 \\xd8980c2d092e76f79a3a2fd1937f57cae06b3053dbabedca1a6ec62ffd25f53ef1a992870c0b2eb81b2c056d1ad46580cfa2d87f207bda5f80b94be93d15c50c 1690274891000000 1690879691000000 1753951691000000 1848559691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-78 \\x9de00556416b289e4cc9d36de44ea8d8e3fee7c253087fd2953c6f36ac1e8cfb028e6cb27edbce4896d7f2b406b642d60f67628e419d7ca6b49df29bf2360309 1 0 \\x000000010000000000800003c218bc90bff0182fbb26fbc843069daaf62a9a20766b3d78346c61b42fc72923f9567e5449e5f9f039a00920ffb0553ce4232975d096d88bf8ab2303c863ac13dc1a5554a9f9023ff06e9c83be0741d9f9fc732532019458ad3c1523fc9333cb9ff8e3a99a8f1a35972e224a2a789149e2a4a47a67cd04e6fc7b5d4aa243d949010001 \\x0e0a06382189ec923c8f269e9a4edbae6f46773a8bc799680b4b2baeccff527b6db3af10a1ecc4c698f2e1c41cfdc4ea2fb9a080e8d6e885e6266b05d98ead0c 1683625391000000 1684230191000000 1747302191000000 1841910191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-79 \\xa3047c6e6e9cf058c7de8134456c7f29d6c202c6661497e841a35ac6cb633f068aaf8bb10070dc986839f9e0761477be9464f5c05ee216961492a1ca069725bf 1 0 \\x000000010000000000800003b7320b5f24fb22fdf1ae2114e9eda962142afd33e9f179cc7510545c350013ffdc6066d305b4dd38668ef81aec99e968cf05ef6d5d368b8d604244e215c4d36db2dae98fda455da61b2d857aa4b0516cb81fd26141831d78bfd26e77894b930634b4a5f50bf32648a465a6d8a078aa39b441a12412d7639b55850025a09fe9a7010001 \\xce66dd5504fde7b2a593c31a21202c694fe53b051050b556ce6c9fa3bcef5550c923b5d7e6b2994c9dbf55809652db4b574d5ba64b45930bef1033d1afe4720f 1661258891000000 1661863691000000 1724935691000000 1819543691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-80 \\xa83017e1d8b9c6f1ab49cb532f908b64f5b85c4ee7c6083923106f7df954e0b552d2eed058387d74dd7c1932bbf845a1a6dbde98ea09ce020bba3877df58503e 1 0 \\x000000010000000000800003ab08ea563dd04b192045388c358bd3556b00bc69b8627d677c070b7c0edfb8c4117752d819a0e20be28f3868b032140a5f35ff63321ea5766555fd937bf9546348df2f2379ff78e126c7aa89035065fe98330de996b607254e7cb1246c69ab06252411fac98bb1d70b98e41bfa10c2e633a2fcff8f8c7ea4168038e824a64711010001 \\xbddd17ec216abaedc256c8f362998d32d5711ae7a0450292260109c949e32c2e0c3db9afca47494184d3b0a143146926622269206670c8f38a187287eeb0f402 1675162391000000 1675767191000000 1738839191000000 1833447191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-81 \\xaa48c6960d23141bcc320039cc19c1ff20a788aa1839f8885d3632d9735c4ae2ee1dba6ce3fb7fa87f91da2b0b5d00e4192e1f5d11a8c8ad68b05d0a7f3cdb02 1 0 \\x000000010000000000800003e97fdb8d4ffad6bf758e318ac3a7730a640c0acf13888fa91083836f9cfeb8fa8f1dfd513bc1db1fd4b256cdb9ace7c1a9efb4a05981572c1a096ebcb45ea45281affb5152a1cbd2425312141d316d4c1fdeab424c55820957c5d451549c710524b880fc33aa60a8a36580023b8655c566462de97e06e4fddd64506731559433010001 \\xe374af4ffc2f7c56551edd1d0e1feee929349da28af495cd84a10037e3eaf0ca82e103b287dc3c6bb071bcaefafe4ad18c9bacf91ce417835134f599704e7b03 1671535391000000 1672140191000000 1735212191000000 1829820191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-82 \\xaa1c74d215cf242570b24d53d8992500b5908c5fd5e9bd8a14e2e8ac69ac485643e4e03935ee28c85e7fd1745c3dd3c3e96b83db16be9118adcbb9c6d8bc3fa3 1 0 \\x000000010000000000800003c8faf690258ba830a16566f4288c28d74bc6b6297d174dc7a7343e7fa8f2f5ae37ca1d9035fff8a0495e54b6aa9e1bf72ce0608a68e9252bebc3c3d0260dab43a0ac6a79791a35504d677d5fe43755621766a1d3e9df4cbf89011f8761dade4bae0a61bbb3e47c8da903b503b287d8e7004a25836c66424f76685d2c8d0397f5010001 \\x22346e71d79b05b1899defa2e5d31f109870dcca418cc8ea43188b43fe35ea8061acbc6f17cddc13cf286c3841e3fc2b23127c3d6821c956178fb7f6402d9e0b 1679393891000000 1679998691000000 1743070691000000 1837678691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-83 \\xabfc9da7f8b8e80ef986bfa95ee9d2b3c34ba4b5c2248c17469c3bedf4c5b2f5729ec5173985ca7403f2c963b4f3508eea2cc206b36b8f93f47d8e2183b1d307 1 0 \\x000000010000000000800003c6f9820de137c42b4cc9d341f8976c773464fa827f1d8536c892c648c31f3c8d4577ac626724e75744078127545bb8a9e15380f8607421f7bd93c31618167368d4f1bba87939cc6a6ea9961770086429e9fa7e93e2cf812ddec191eaa42127645825fedb9719a62b851ae83e92fb6a6b2113cc25c351a065ff41bddd4227bfc1010001 \\xbbecf1f739eb9d68df6fd5a7d559c41a16bbcd85ed48693f3f5b9b2c9fb2e4ce5e93f0aae823b58bcaf442a09c04b588124c08e7fd2391d13e9ededd4658e005 1672139891000000 1672744691000000 1735816691000000 1830424691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-84 \\xacc83f0f48526f61f556471dbb5173a64d4b6b8537ae8c5b4eb095a77e77c5b2e7ad2dd24571151e2a7d483f4bf5d7038b2a6a4188cd6ec8d89b2e79d56bbd27 1 0 \\x000000010000000000800003ded772b4351f292051f4ad0a766a8e2dc4b7596babf21737a1567e519f2e14ca6c0e61980f73025a0dc30e66f648b5194bbf9ee1acc368e901797fcfe068a5223923f7b79f0caee423c12c44b3e5f845483c94e0ed3ee1cd46d11fcca8eff9299d76c95a85950dfe5f3585564e4a44512c2ea099d8851a9951f077a13c9604e5010001 \\x2c8008279b5d1388b2a177358299382f2384a489d6ad27303a6b2d7b975c60364c252ae0c90409e6868d6510a27a8ce4197fee6d0838072988726f7eff49da0a 1672744391000000 1673349191000000 1736421191000000 1831029191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-85 \\xada4b6b90cd2f76ed7ba81571e351d21880c278ab076813b72227f3733c8e28ebfb8f8003f108a0042a3c74bf8fb2710db882d463a819d00723d2d86dbc537bc 1 0 \\x000000010000000000800003e788d2758a3c3e4af3b0df588cbcd30ee64371c5bcfc7ea694424e7721267e79b1c8d725a8b6abea71acd92ce2158c47df7834bf5ddabf250a8277c2273ae31f7fdbc99912d42b8724ef8bbffa9e2117bf223cfca677c356e757e69c7d5c1f27b60d460e0ebb4af3dc8718ceae54fb561e95a165010e47cd15aadfe91d52588d010001 \\xcb82d082d1be081cb406ef565b8708552f7668f34727a6d93ce7163c6c03b1eb48a38bea436afccdb470f26227e32f2ba620295e89ff307332b507cceb078909 1686647891000000 1687252691000000 1750324691000000 1844932691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-86 \\xb1f8e00911924f049daec11119a8ef4c826c099c7b98831389d1ca94ec67a3a9deff26c410ac99863174b86a3e7661fa52a72b86ca2a91f0d3d99d4e5873c275 1 0 \\x000000010000000000800003e1e09a84dd3f6e19c3c8c559efd9d1ef815cf6086c0692f3059ea4d0dab848c0d092d95aeb941ecb74db8eeba14f015bea09eb124ab8bc881a826f7c6c92e8d4c51e79997d6d23fe39a53887d318f4e5c8c20220cf1c548c3f7c609c67248db08881a8e0700e26b5c8432697329f201db9afbc031962552344128c93d2e94e4f010001 \\x5e6aedb0781c74483e50ad146a5cbba9f11d87e5dee9ae68b946dd6a952ee73ca4d39dec128c563e0fd29f2f38ef16767a7d05caec06e1f014bf4825105b3502 1690879391000000 1691484191000000 1754556191000000 1849164191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-87 \\xb21c090e1478c59237fc1516e1db6771c292360395980237d3e68ce71f6141b1cc808fd93856c6ddf57ee3c2ca0ff450c15d239a66dc8bfec4b9434b3ef07636 1 0 \\x000000010000000000800003aff23cfc92ca0ff6d392f76db4b4c87fccece60bd358951fd7d7696fd71fdd7dee2ce81705f109f6fadce49d276c040dc41155dfa52824a74797639ca37ede9877c09d566ef0e18b22dbed02a110fa1222114da93e02f714cf2a0c4dacb348a3d61ecacd98a0e0240e31d7129d7c8d8e5e3af7add4f3fe6cf2bd00bbcb06c4b9010001 \\xbe6d41b2a6a40dc0c51503620718e3b9026772d360a98d69958a54e145f8b82ebab3dfcfd78e1bad29fed7396a5c7c8e523b192764aa818a662ef76652284003 1679393891000000 1679998691000000 1743070691000000 1837678691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-88 \\xb44c5587b18994ebf946fd3d0f8983f95f487a531eec487a6dc2f3b1ebe8b428f571385067fd8b1a36844fcbcf1946981d6868b16a035af7515e6e15a4fadcff 1 0 \\x0000000100000000008000039d66c0857d170bc5234d0a4bc319656c8b233d061325f380825e4a67240076970b315f336b20e1dc5aeb95ed36395a36c6f56b34bde452caf4d6f7528877afc8ba88e78b6cf0c6fdf78bce874c6f87470a4424fe7242d2a391d92dc8a2db7e49970022b9d165bf43a47331727b59f42d6c65ea0f2b4a2bf3f2c512afd4e856a9010001 \\xc709e7006d767b6bc59aab221df8c93513ee5154c0d7572d8a0734db28da6cb31cba09d61862ce42b0db84f6c0c6fdcacec47d6e816805e3e02f66ba6059ab05 1686647891000000 1687252691000000 1750324691000000 1844932691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-89 \\xb460ffedb4e0292c5e3ca46bcbf845397255457568b0580e22eb4b4a02bb1a8323678f0cf827869d53933e9eae123e0a86aa9470a937dc98d7ac3acaeba9b6bd 1 0 \\x000000010000000000800003d6b77182ab2a06262ada6b61deed60ca53a4da4dbf4c46b82b1f8dca0f4059d44b3bbd3c4b6fa0e69230b2d383a29b4c5bf7b3cbc1a34ea8c854a285a9f445d08b80e29ef63864857a63c8f9c3433b90e710077b9011f8096b8ad5df015fef45cefd09876266dbbdf73029e22031f6f81592bacf83ec59a82d37694d94721351010001 \\xe36e3c13b25a23c38d92dc1cd1aeab1ea56d2e0eba0f937c5ed03be308acd4de4e75aa83895e755d6c1fd035d9dbd8ccf7f43cf84658d8e62a5fa0cee510c100 1672139891000000 1672744691000000 1735816691000000 1830424691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-90 \\xb924f929af6b25f73bcf2e0b45d0a05611a46470464d4e35183286b30186f11f26000564b4d30ffd1e1c496c0b6bcfc1ed6d2c960bd66a84a1cb3740d197f8c8 1 0 \\x000000010000000000800003bd667c02b8bb8e97a9778e27f366a4accfae6a8a5050bbf5ca6608099b7e5ca1e4ce18719e333ee4b1fb5cf72410d68acf170702ccb16314d056da54980f227c67ed97d18ec18862502876b1b70252ba58e519c9b7aa71b1eafa49cffded0ad9ba0112253fcd0971e21de05f59dee59f5dc18a8850a564c9e7a2e5e0b6b11b75010001 \\x5f00e872abe73ae7efa119ba96cd640c47fbf4a5157f9697c0d8e6a9daf89c2a348bc5a7c7bcaeb8fd152fe582e87a5608c348e8b3a3310d48b2b6fed0932a0f 1664281391000000 1664886191000000 1727958191000000 1822566191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-91 \\xbbd4796152f5b5873aa1b69d41a0e27e908a61e0c7e75961c9901eb8018f0c6c3f5321c269f7daf87dbb02337bfcd50f297237bd274d7df754298307c1956d45 1 0 \\x000000010000000000800003c9a4b6c86410012cbf514b0ada68c17fd929e03ae0f7b8f7cf11a7c8f49350d34787f1b1ff0bd10c8f66768c0f7dd43f75ac771466e5bb47164383865f1e8abcf65dbaeae7bd980ecef7d88ce0ca0a2bb6d9714b7f57fb8767b32ab4ca12b606872e32c27b200a97f78735a9b1e1ac64572df8f0dc1bd1b8ac12e98d7495e285010001 \\x5a8941256008fb8ee52d36e5ba102dea645b5aa8c06218c292a640c7bd63e310bc575e76667707cfa926df2a9d2ccef67c49b17521c843f890f1cc343ce53905 1687252391000000 1687857191000000 1750929191000000 1845537191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-92 \\xc15cce2b11de1b0ab28eb2a678b1746b1b93f3b6ee9f27c6c48f7f12f3879f7c4c594d63eead869f2f97ca1b7038faf13a02429ced361d79c74c22970b1e6c03 1 0 \\x000000010000000000800003a9c8aa474bc6dd7d7af4da8c32306f8fa5e5ec3292b08b31a4fd51c894400bdbc1eb9482330cabc46df729f154a8025a6a46960c6d051a8628fb0d9c6530934eb405fb7a34253b2fca8039f9261f49199254bb4809cbf962fff27550f7bd2052eda69ea62a337317fc18d4c20ee8d1476105361f97858ef6cae829230954ca4f010001 \\xf1ca4e11f76001e65105f7d669b3abdc4128da3461a7aa4b70eb857a5ddf464819e963c158f05668974e8af2a62464a586bd6552aa93b875a907fe3cbf362809 1672744391000000 1673349191000000 1736421191000000 1831029191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-93 \\xc2843808057011c17f6224e905053b4c7e76156e8eafb35974faee502e0ae4e80921c5ea78395f5f40778b978dcdc7efc829add1873463f5beb286165e301c51 1 0 \\x000000010000000000800003aec017f16369487c15f8cc517111c2a5664abe95ce7c52adb079d4d8dc32ca86f09668506e464a284c8b6c600f5782133802cfb24481320c7458a779ae906614e4e2e1590bcf129af142c7631c9e910c6235ae215892575b50b24f0eccbf22c642a0aa37f8e6b6e17e244caaa8972ed19010d8eadb11e6102b13fc164ff9a90b010001 \\x5de4c7a76522f79bf1d72f22f2052ca0e2221ca80bbfccb0181e12b7ebacd4d40bb221ed94a7b6a4bdcd6efd61a768cf4562263430a8a5e53f85074aa4abc300 1664281391000000 1664886191000000 1727958191000000 1822566191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-94 \\xc5e4badbaa929ae81970f8d840eddce7fc60666e9c2bbdeb6ba2e3906f3f5df7b896f8f85eb48246f085a335873a67f9da33442898fa4d05b5a387ebe2fb1526 1 0 \\x000000010000000000800003c3ae34294b9272cc047b16580319fe805223450c8ffb49a9be0b866960804ac4de7fb2e7f324d4ff75b739347a074c2cce96f16c00d83ea6515fba5017aad6c08f5621a6c48c64b2f39b529cbc19779334c54f949d91fe23220e098de6964da2dcd73cd385bc8b14b33afd863d954d3c99b1a0092b25588a059142175df03255010001 \\x07dde920f8e4e09a23f1738dc5a8511cbc62c22996942575ea449f48f704217a67e4575c53e8779eb7dc4de38beaefbb795c8de9cf5b7b507f3d39118a55bb02 1692088391000000 1692693191000000 1755765191000000 1850373191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-95 \\xca6063bb6508ea4e3eaf2dc583ccc10d38a453d87c5810fa81ebf570a972938b40b957d82deb5057cf2237b9c8a0b390b60d5a28a0f33c9a6db3ba84676fa690 1 0 \\x000000010000000000800003cb4ba704d84446d26ff9a44beadfb727e1db688e30af6e2f4fc3f292d29514c5566d34b2e563abeb6bb08eaa5200bbd3c9974a8ba85f8aff4e65e73c7133468c3b9d89b6db6a1abda044ee7d94aacbd968eeb9a92f9e152f16ac5f4e60ffb955095dce8392080f2b45430d63e83c791d1b106f72534dfc8bfdbcfe5cc476dbf3010001 \\xa3a97acb0103c2bc178fd5262c70f3fac53cd15b026958c83d2500328cc1c5632f04e6f826a493aa0f6174440c8f29cdaac155a669b3eb1e606ff3d817522f05 1661258891000000 1661863691000000 1724935691000000 1819543691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-96 \\xcc5c5dc16f86751ff34a5e3f5631a94700cf0806221907a9035b4a18a5cace1f666bd36325e2f4974a38dc08319dd4b3399f2860f75c3db084fb598c202d1b62 1 0 \\x000000010000000000800003cdb7325b6d78c268fda8b75b1d40df9b561de7d09293cc740a9b9eadae697dad42eb9fb4f508c7f5b68d4f529c65261f5abf9e0c0046e94e5121fa03c806c710951a7e8054597097952898bdf23c6b4ef6d0bcd5d8b9c3c0ad018829c184d5ca8b33f11767500295e5a0a54540c32f403c66844f64982315884be39837bbce39010001 \\x2d656a172e7c7a49491bb517a852f3106b4c438e16c804242ae5b2bd84690bb3167cbab797ac8ece2a4cbcc54ef36a0447c89e777fab65c947bc7c7213a4ea0f 1687856891000000 1688461691000000 1751533691000000 1846141691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-97 \\xd01088033c5930d39962e667a0cc0f95feffbce4197013f1eaedb1368fb2d671626a962a22c93dc930dee809d03032252c01224c21c5de5fa0bd5c1c4880196d 1 0 \\x000000010000000000800003da29d8ced06923cc66237321e31baa18be4175cbc4fb57d3a73bc52eb6d3a087e78a0ee150121481f6703ace1f0ad7570f19775fd3e39ba98e5423e9638d015e62a031db86b3711ad56f2f01b9fd620f3bd98415329b9122702dc3c283f74e57513533719fd8f9d3bfdcdeacfa5e45f3ee498f670b2a8a23245b37fb983a4561010001 \\x2abf6edac96b0732329f5e0778a5455d38614719cdc903a58372979a4b722387a831d326b98016e45db629f053c7c2227864d1438b6aba02d4fd306cef83540b 1683625391000000 1684230191000000 1747302191000000 1841910191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-98 \\xd718f448c190e59742263f3458cafe53b6d5e7fd5ec19edf674f37ccbbfb3563ced34c10ed9df3561451c2a3b2d921dc7310390ceede6eeebe549dd495a98fe5 1 0 \\x000000010000000000800003b49a481b3c7647284bb0a816223af63c0060e23b5f6133c31e11c9776b7001e36c98fe023e34eaad50c14b13dbf303b63fa7ccf786a9edeeeee492e47285cb652891b3a60705ac5b31101d8fd2116b37db39af7d1eaa8eb074ecc20ef6ffbb1e8426f24c12a8c9ebc0e0443f863bf793adacee4d4af5e61446a2cdaff41f37e9010001 \\x3cac413855e2184e68bcb3a6a60cc01b992471844d0de13649a42da851693249bbe290eaa4ebc0a39973c64a9f0ab6b5345f85644a838f9cfa8a3636a5c68e0e 1665490391000000 1666095191000000 1729167191000000 1823775191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-99 \\xd8a4b0e62c1289969c8b3cf827ef614f68b8b123f33ec06e0b41495225c9bd6b891ba67d4d1aefd3854a57e60d1501a20fe9555425fb745df6f35404567acbdb 1 0 \\x000000010000000000800003c036620d7e4d9eb4cb5a433902af5952cc7fa6aca653fba60b993c637676aa9cfa5a872c337eb783e182b921011af968073ed2e008fcaa3746ae92b44a5e2a9fd60160a74175e868466f8b0c335f16db91694db0ed10c8a8971d2361be4da03727c8919357f861e295861c54e06b50de4260ffdf64690be40a41694803029145010001 \\x9fcd956a15b6cdcc59972e8de491707f07f6c3d4fa3bcfc5c91bd2ecfa5b700ad83d9a85e0977104679c383ca06c54eeda0baff8d3195707f2168ad496280802 1686647891000000 1687252691000000 1750324691000000 1844932691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-100 \\xdb4835d6f259bcf1868e2b733d942ee949d97195cae734c10045af22bec20bafc8606caf5bf707d1de7b980b9111d3935ba9a05e4ba93bb6314cb8a5494b9f08 1 0 \\x000000010000000000800003bd28222b3c106f011df72f07b0aa6af37919753516148c96782d88f99d38699c0c4cbf43076fcad36552be182bdc391b47882789afc4d40fe36772f8cf6bb23c8bddba1b66da9acd436c1e1b6d00872d594110649198a65d42f9787ad1a74cedad42220078c745acfb53d21758360dc0f28dc7ff29fb3e57a033babccb081c33010001 \\x490026b5f77a347adc1395b34cad75fab702e326a9e795663bbbf0de64c1ce1135968679cc09354dac926005a02bd53044f950ed08e6a7b53e10ee21b1afa303 1691483891000000 1692088691000000 1755160691000000 1849768691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-101 \\xe47ca7434e92efc8afb75fd894d178681d537c38bd336900f8896bae12cd812f1ea81c42eff9c8a2b7ae5d35b9ad1bac9e9c9c5e77bd98736e9139a35a78a05c 1 0 \\x0000000100000000008000039fc6070e945e53ec20b8814aac2eb97463543bf20be91cf5f2b8bcc28f6a622ddef679e58027cae20b9d9fd6cfb3ea9266b49b3ab61d6583762feea18f43d3f72b7bd4064cfc472df970b7f024bc47002f11eeb171f7b0ec323609929b9b6849ebc3f2767f2b4bec1f7f980a71a40e83d6fdeae415a7c164436e5cba17e7ba4d010001 \\x8372af217c848bc8a50828aad1358ad03d9561762facb8cc41f7a6df65c79149f7877b2886bf54b62d69fcb6083082bdd8ecb2147f44a184ef4864b9e615060e 1683020891000000 1683625691000000 1746697691000000 1841305691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-102 \\xed501c5e263b307f94b4b94cd216c00d33b1e0aa577e3a1c71771a06c30955c845e992a0b0701bb1c4a501ef1be8bd504c894011825a984b08b4b105671bc888 1 0 \\x000000010000000000800003aacade8ff4ae8b6826b72ce02a150d929dfd32494326f48f80768409de8df4c0733a177d1805c4d334c56ff25f4afae70084a8f141feedc1a935b445e034b38b78510f685805d31c01d2ea66e25b7b86414f2df343123f9d4eb7e9ff85482fce99de77678bdfa1148909cd3898b312bdd1418610e5ced6ad164bb9a9d47cb2fb010001 \\x74912a8160b248293d537e3a61c0f51547fdc491e00e99515ab00f1bdd675bb408e43388a6c9d12e9793963e2a19f3382b7d4f2564195068155df814f07e900a 1687856891000000 1688461691000000 1751533691000000 1846141691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-103 \\xf1b4ea4dd32d2e4366e7ae49842232e16dcb394602db741e8719e0f5ea9b6c78ed51e101c76e5f534202020ef246f5bc91585201d0425662d0fcb4cc331787ed 1 0 \\x000000010000000000800003d553cf15daf2c0e1eab5f84a29fc01c67210454bb0c4152588f16e474d4e9a47fc515960dc644a75ff38681f796ed3a8644e1b56c23046a76e8bccf450e822bca92f6752ed3c6b15956c881aa6d5ffedf52634f2381dcd828c96be678bcc8b9eb646b9d99bf498fe76db9e98b92f4bd2a910f71458702aeee5cef54151ab3f7d010001 \\x6cec59f3f1e5fdf7667db45b2156f0222781e83e11dc895aa952b3bfc7cdf335796bc18ebf8fe1957c20ab780f8959d2a0f07ed51507c767d2a0ee8dad76ad09 1667908391000000 1668513191000000 1731585191000000 1826193191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-104 \\xf588c7eef0bc18eae450719a2c9d0e8d8b04ba4be3ad073c98a248f1fb18b82adcd450e3a2d32c1873a6cf52e1435444367ee5926fcfe146a99eb3e7811ed6e9 1 0 \\x000000010000000000800003e5e9f2cfe7272041bc689f4aea2cb47e289ff96ad2280a1e8c5b9d86c836357765b7bf514a8fed3c8edaa4838676d2b6d047ed35ce9cb290a6f96bb99556c994c0cec0615766a719a825171222763ee538f3a39eeb0ccb0fd05353b41eda9a993a4a2cbe243aae0bebec10a0587a7b9efffd4aae28434f5789c607499ea5f09b010001 \\x3f643323fc6eaadfb31e6a28cff92ca5cb00a8475e1e48a576d8f8eacfb82288f45ec118948df31d2a64e80d001a935139c7b994fb42ad0d198cd2d7b0152409 1666094891000000 1666699691000000 1729771691000000 1824379691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-105 \\xf56419e46e941bbcc761deac4d581f1487d96b5537964785576c00e394267cc460e9eb182f0b7d257085c303341903586c7eb8ce00f7c38d3e1db6038cfe5d98 1 0 \\x000000010000000000800003af40e16209020359c6b457c5a9860a43c9a5376ffd5b1a62eab6ccdd2cf4189fbaeefcb7f9d100a9a17fe178c7f4e993e0ca216c9f13655e6d2d612a4172b64ac683f96dac9c8f443dce4eea8e04d68ed2dcb8291e302396621e4dc93e756647905fbcdf64406f6b27044884750b4db78283a01eda0a6dad0148bb283f43f3a5010001 \\x6715b640d105190898631d988a3dc994381c809c3949a7f91faff56a7f079f140411866208da2b6b25dcee60e57d1891943380f3b6efaf5880c73725aee39f01 1667303891000000 1667908691000000 1730980691000000 1825588691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-106 \\xf7c4f6c3e2f14d35fe0414d018cbdc4ae4792555ee3e9dba6267c3a1ceddd5fc5aee702933b865fcb280e20a8faace52cfc1372e749c8a98c82c5a5a7274ba74 1 0 \\x000000010000000000800003a6c41d40139eb075f6a5d4debaf1e6b8d14e7cc7ab67c657286bf4883eed98622bd3aef38186d8e5aa284b0cc72b9374262aa8b1bdf645d085d8a7c65dd92d436292b3e9113250723a4c5ef52b8b40628ccd8ca42dc0d7e3fd24abc20945e0ce587a04129575aa9da59de32531e8e6a1110a4d19df06f73931b02c009bb4870b010001 \\x6711f927d8294ec99d0a4b38faadfd9e3fd2c28477e0fd2bdd8d31b1dae029694f3b3337cd420aa18a08022f9c8c8c9e005801e37a8b40177c3e94fde70efc0e 1671535391000000 1672140191000000 1735212191000000 1829820191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-107 \\xfae4f524965f1fc529d2266866de5318448161e5428df0fb20a9030a2bde516beb9b2f66f9dd280503974041c3c6532ada292251186655b9c613909a0abe0c80 1 0 \\x000000010000000000800003e83eca1e48e41b3d486d40c5a15c63b35367739018cc40d9ca90a496fb58b83a212d5aae4373dc34d7b89c04b673f3ec40a33c8e2bd3d2ce8adab2af9343ceb3d3897463b4ba60a60c86795de1d863e237fdcdffe36d7ff68d9e03e5ed375a8a2371bdf7bd95320a11bb4807d4036ea91aac64fc871c002c515e2c57eeef05db010001 \\x1bc44642c47956bc43fd8725228ad4991cdac53601bb65c570a6229cc46a34d7260e5c48def843a4461df5b6da2da0d7313bd7c15886b3f5e46c401348c8cb0a 1681811891000000 1682416691000000 1745488691000000 1840096691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-108 \\xfa401fb1de9990500aad6e4629d7010151ea504022e986c1f3ac9a8e63b4c8b28bd21c10a203db47da5f5224c1ec55047e7d2e9838ed23a35190da0c844c1aee 1 0 \\x000000010000000000800003dfd0b3d1a5410a600f1aa909cbad5fa8e0190e29d07a486ad58988013373265d39028e26d30236671d39c8b31f24435295a3b05eb3492aaf37695a169380adf8a1dccf4b7d8a7bf9593a9c82905cda0bcb35e233e5dff11da3de1b4147c721be7086a72fe8a3f179537c7e667a5d2bdcdf4f26d0126dfc51436cdf8e751daddd010001 \\x7d0a6f1e958c70758997b6aee60ff784d3350ba2e50d40aa9ccf6a3e2a58a765ebebfe8b2d170351d53c89ee3b5b3e867bd86493dc156181abcc4b92aa8b0100 1688461391000000 1689066191000000 1752138191000000 1846746191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-109 \\xfb343fae93bcb676d49919fd4cae48ff4e403b6b3417fe87ecc9f65c0589cf83c21f1f0d0038b52ac522ef941e82a1a5f57a3f3c841172f9346f87008187054d 1 0 \\x000000010000000000800003d6667a0a39daf8152107f64e03c7b2a4c5589fd4d9d2f948ec6ca3419226e72a3dc3b095ffb58de0f7436a342623d83bce8b5a5482c9161455c4295e43fba5625698162107695a9dd775d97bf28a7dc453201046b84e268192ef511689241206306a9430ceb72b786f84fa4ffd67e68476fd8b1dc2f4a568e8dddc1b3952b009010001 \\xbaf7e7f999f737fb1352ac7a2d6167a7f4827faabc0b5748ea4fc98b581a7e05d120f2e278d9b8f2db0b7ffd0ed3492089f73aae5153d26e4da18b1e2a8f6304 1678789391000000 1679394191000000 1742466191000000 1837074191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-110 \\xfc78840055b4c0012264e0d655656076859346664fb6db247ef3c3b363604ea8a5f4404674236e7ea2309eff8519d68c3ea6f6f5797ba840fd5c6c962c666020 1 0 \\x000000010000000000800003d84a00f2e74fe61dda57a5d8c63dc8eb2c03badc80ff54c1213ec504219ffe5233a0a17ae440768abed981256992a2b331ed7e8288dc601364cf24b6a6887c5aa354d9b6f7ae3f0596bd0b74503d5ead19d1cfaf2244c889789ac154ee8830ec048cf664572f1aa014738a74da1444b120903c54634f28e5f1b3ef92f422c633010001 \\x94c1c9e98a4fd695d19cde7ee91a019b5930bef392cda5c92f72098583e77faba0c1a350ea143b674dfff59ece3fd832b0151550f39d61eb8f73e9e7f454c605 1662467891000000 1663072691000000 1726144691000000 1820752691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-111 \\xfc24132fcf95eaa71434fd53a02f108e09f560badc32cfcd6f33ca94c5b3436aa99b43001c85c1c15a63785b04ddfb1bd28961b4d9676466bbc5b0bf2bc5cacd 1 0 \\x000000010000000000800003ca54542717812c0c12479dac0ce96c81b43dc18da77364f9ce3e8fbe06ae5fd8244d64bacdaf7713fec4a655e5d358015e6f2071856a298f7b78e5b2e0caedbec05af795465c3ab1fc117d4536203dce907e3c0b4ee571014d7716a875801af51023b7fb9755c3349f9ec1632746d081168c7a0a1e48e076c896c59847ab6d27010001 \\x7d57072aaa266c3ad084df19bc7ee4b6b5ab3a83492dd3aec58127df9b01e11df053192f724f132f385473645e371e17036f0f82d945076d4d6e10025a05e10a 1679393891000000 1679998691000000 1743070691000000 1837678691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-112 \\x0529d4f01dab6023379afd72fdf74d9f95f57b863131402f58d703c1584525e5f0d34c6e699ed9baf05278432909049c72725d183117f1ac4c3fd1f69e41fb66 1 0 \\x000000010000000000800003c01401f9436c345a6962c9885b95fa76e5a2a979b0ffb8269d44a1a8f5038430292ea994b89c31e891ee4e73a85ef8839d70d81de53622bd8b31212ff42f89389dabf102a62b9007ed8c483b8e7ca1d294fc0caa289ea413a6324cbea862c6cb4fe3a79e9c45da5682fa7b1665193c3db30132ec0a00e4f24f599f8b5d042deb010001 \\xd99ac94d756417b61fc0dbdea58929082f1e232e0f9e119c56d16f2a8f34fd59c6211b57b9f5076ed0efd9ac4d12aa4b6175f35d581297d824aae2a7ba5d6004 1660654391000000 1661259191000000 1724331191000000 1818939191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-113 \\x052df830673dbdd63e116b343f8750f1d7406aabf9c29080ccc80b59e37b81533df43098831f40912a2d6e9b140c66ccbb08be3d427a663a70f18b4f0773432d 1 0 \\x000000010000000000800003b9f998139fc90c4fa478ee2f60261313d9a15cba743db8fbde16d13fae96538309f7c9356abfe06faf48d99806d5bb6484d953a3257b2e4606af01692a146bd5967d6cdae392e0ffb19f87ec33e7ed1217184d17f9caa2d3f12ed566558f4793edbc1645025a5db38b8b4b43065e4cc095064e100b7358422b4338afe8dec71b010001 \\x9d5a6a74d438a08d599edad6e970918903c10dc884727e7f9da9dca1bdc2d2b8054ac7ccdccdbdbf84848973f7138b905c02101f5b6c4fe8c1bcb970a156380e 1669117391000000 1669722191000000 1732794191000000 1827402191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-114 \\x08c99f1144734dd446e52ee5fcc647fe5d65ab9ff44caba0b636bf2d5caa633803765397d5892f3f840f77b550c6d47b48aa6d066818c98e2c88bc960af97055 1 0 \\x000000010000000000800003c34a28258723c9d33084a8ebc9d7862837a2f9b3fc1efa7b23c44e8ceeb0af5e4a226a04abf678cd8921a56f3bd76b9477f43885d40bcfe331862b6ee6cd98bfe2e4e4759af16f9c6e9a1405c2882aa5fd5d16588032e29afe5144554b4023f401dd9142340d71c38500175c8e8c098c81095117cd75b9f7926968919a3c5d8f010001 \\xecc86165cd82f92259ae1e518248c9df48928c4fee6b4e1c39d3f479dd707a2c850b22f41227b5b6e201edf0434730c741c228a13d9620a6d14a36191ee17c02 1666699391000000 1667304191000000 1730376191000000 1824984191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-115 \\x0cad974387d7c33c157c578b88d449382e132d782bfcdbb87b745d41724a77afb4ac46df7b8c9198d12d8a001b900e3e18945afefdc2e823347ff3313b29dd81 1 0 \\x000000010000000000800003ac3a699e98182a24c4abe02f7acf203a492d5e16d1610c121917a530bfe069f8a25869f0276dfd688c8da7b95eeaa63251fcce9f50a79df5fe68f61aa6da56ce955ad0425f7bfe9954ac5bf78728ed0684d55734669f7a95756c9b007b0143fdddc15049a283b55ae89f8c95e0219b464b3e4116069a9691e3239215d3fccdeb010001 \\x2faa865ffc15bf6282581a5474dbb6d73ea118236d7668e8cb636a0b33fee4d6822cc95987282701aed42d3b6e5d245b8999256b93565b25c6ca053940dca50e 1679393891000000 1679998691000000 1743070691000000 1837678691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-116 \\x0c39684fd401378548df189442e11c46cbaf094ec64ccb289d4291c4e088cec69cb3ecfe666d3386dc8360da901fd9ca77a6fb31f2ddb2b7e6fd31ab36c7a984 1 0 \\x000000010000000000800003ca8449e53933b0b267441fe9ebab41f19f111fa7ebe426b5d0a6616b76d6a420e4e43739875143ca85eb2111b4920d2e82d317936c60d0ed233cff520f93c1905e615fb08a03c7e1ad971f4f81f9aa7f0a83a4cd5ac4375551bbbc1498bc15eedda356e4a7468fda23412b27eea75d0c90364b9691e9e2b3d6e47669c5b7e68d010001 \\x0497a71f9aabbf4f7cd04be614ada7bdf475490328592a64710867703ec5276245aabccadbb9c3f3727a9c03c57f8b456b34d452baf8b14c8726e4383e048501 1690274891000000 1690879691000000 1753951691000000 1848559691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-117 \\x0d31d5c513882eea994aab690b8cd4dd0b9a85273048f91e4d84f66cfa6e89dd9d710e205a26242aa8213df7a304146c46d6e707f1fea4bfda6225c7a89c62b2 1 0 \\x000000010000000000800003dabb83eb2e2237959488659fd0593a9487d091da87454232b5c2f8c60d7cce83856007fffa37387d2075737f879773d9aaf8842f1592ec4b423533246f4548e7656fbab8f9b7bef6f7eed8f7beaa1a7995d68bc0d13a677b31c643af160bdb497b2c2a51b819cba7d73c097bd0a74df349067c2fa5d76be678e2cb5cf3b2bfed010001 \\x6bd93534bb028700a987feee7996f694556766794eb5a308cac0e60dc7f8dbfe603e71d04139ea3459984eeaf7ab70b3057bea81762d2e628d72c8f24967d503 1691483891000000 1692088691000000 1755160691000000 1849768691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-118 \\x0df53c0decca20a1919de17623428437c45b790485831e9932a8de4a5f7e47513b7f9cce22df2e38b468cac35b690f8eb55da7ed0f76d40dd5b0d82646684b60 1 0 \\x0000000100000000008000039d9439ce4d5b1ff02542b043947d2c7685e2cbbccc580da3de814252e01b53cd37753a873d0eaedbbb71dbb5162a2dc369b08ded0373f959245b3e0bfe6cdc431aeb818aaef633c212e5808d71a8974d5289a39c5812ad1c995a935c60eeebdb4998fee229cadb5ab6038d92c8dbb3d6ab208ab9cb55dbeaa79139d64a08cc9f010001 \\x7bbe25d7a10c66a6af02cfd495f5e6b1f9b076d9cf5c3101d496a064c89726c84c6b21aa231c92712dd40d0ca8adbb944ce02d2f0dacf3df41a9df0b5cf32908 1685438891000000 1686043691000000 1749115691000000 1843723691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-119 \\x0fc1763e867f95a334c2326ee7afd22c32891b498e9564daa0fd672007c7531320188facc5efbbaf8780db523ff43ba8cffc77d2a3a184a95edcd5405e6660f1 1 0 \\x000000010000000000800003fb0f5d0f6d89b682863246d84d2dcd7f4d10ffd6a37ea46e42a9689d01216a71d510e78533a97087eddc990503a8ef43360b183fe49d5105d27eee88e00b404c4e0b5b21338e42197309633dea76a25f47780979256585d7a6b2912feaa341e72a0bba91629860ff64f5e65319a1cf657dcb49ac666c7364f6d32b7141dd71bd010001 \\x0e4016cdd78961c1e0b623fad2c0840dcbe904b325dc5d896f68947ad652462cdbe49ed6c576118956e7369d27c608ebc186863d4719e44212332397ce657906 1685438891000000 1686043691000000 1749115691000000 1843723691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-120 \\x10e9ee6612f18d039397d41a38e8ded37a67bab0980d19539b81737af0b9ea53e75d252f472c15f9c2cd1e0b300d372c61302babea04955527c465874fd5fd15 1 0 \\x000000010000000000800003aab0e5e3a1958d9b85fffc3b4f0b1d0a107d94b14db9cd2ba00b77d49dec10fd511ab936160f0602b1e19411f6aff48cc7e355b113d8008fa3149d7ba0c659beb4ef9ffc26a480360bddbf5bd733bde27dc46f9132b44cf7c529ba19598bdeb2dc4d10b5c6b36608350e72758e803c73f11bd6834adffdf6161c4c770467fafb010001 \\x5d2acc62df8832ba8f93fd9c8b1ed1e03846969269f3be4cebcd7d0e0388e922c05ed5a1a59dba95f1884dbdfc3aba7c8e9d7427f42a940cb9d456093bc50d05 1660654391000000 1661259191000000 1724331191000000 1818939191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-121 \\x10a9f824bda7ab2a77a717a74dacade578fc65d582e634806ad2614f1fa2410462e5ba121c9a4e23908d9b6060248cc24e8b2ded991a7bd3bab916404f9e9b77 1 0 \\x000000010000000000800003ab25f04e058dac72c53e4f9347f271295c5708af37ead8ec744860992c64a006a195eeada4b771cfd43a051c94beda01e875a724720866886988976fae26a56ff73e07bd7df30fd414ae894857f348bd36dabd1d7b6555ff9b247afab2ba69349fff7329a6c96b9f3c5467b07c062aea02c5905cd0fc217ccde83c8a0cc6640b010001 \\xe04473b498eeb33e6642b5dc919a9c2698973d3efdb3e821dd397509a0b3e7ecbc7f41a62ef26f31ab6e224783b867deb6a8c14a0f161a32199e66d4dd00a20f 1692088391000000 1692693191000000 1755765191000000 1850373191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-122 \\x11a9fcb85464ac3f8bf3eae33cb84a446e11eadd35d06b3a96d137bf85d5123c470f2239ac4e95a7f922710945a183e9d20b7b2da1ddfeb50fcf29dde6abc860 1 0 \\x000000010000000000800003b70abfd8ba89ada1d39e7705a90b563ad341017d7d61ed841b4430ad809e9f049d7753d9eb44186306c400eef3b5afbb58e48f269f5ba631e6f1a01dfb067f0fcb895f7389ee3afd0fba7f6721da02f2c3069f652b1c967d0945a33460006b8f62feb1ee238798b672a20e0f7f81b089f89f53a5773da9a468516065ef76a981010001 \\x153d9fd4545fe67a22aec22a16433ece14f9bf6b31738110dd5a87f4c1fd919d86f3fae98876321ba1b2d0d8f2595acb3d4783b8965badfcafbb78868810ea0e 1679998391000000 1680603191000000 1743675191000000 1838283191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-123 \\x13a5658bbc131601ceea4a4947e98fd41160e01718f367cfd25158b464b233dbaa647c5e303653742ef4d1950a264a2957e8443f4f22b4eedf948812bab86bd5 1 0 \\x000000010000000000800003cccd6b90dd42519e1b5cd91e7198be5885d43e18addb219a69ea8eda054a4c35b814734cbf9e317165f0d60807b499e9bac8aec669f0073d2435d2b27773b26f47c017a6d5b9eb74d8a9b99fdbb9307c2accb4a5f5a3e9f7f4193a7ea7a826257ab1f7ef50cdf71dfe6c3ad6ecc696a051e253f219f369d65450c86c3769e43f010001 \\xc77ef5474a1e82ce1ec7d28c6e1af413c70a0c3fb95ba2704ce09ce6dd82957490078ce977799aa29298e6031404f7c8df0d4250ebe1fd5c4ae6fb026c213202 1682416391000000 1683021191000000 1746093191000000 1840701191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-124 \\x14b9c8f10b73e902fa8a6680d35ed464f48c218ce7b9d8bfae314daa4a0828781c8bc2e7dfaec720c535660cb38179ed83aa552d32424704b5fad44b231a3e54 1 0 \\x000000010000000000800003c218c317bf8c9e3ca78557cecceeb5bbc3478e804fc9843a2bbcbb7f729267d11fe17a55eb2522e07f6532e2ad2761742d0736f70a43013652d9135046aab11b6579734067aa04408a46f138de8e9ac2cb28eed91a2d2581f2a316c18332b0a6d408c42164d1d10f583f65b7e3c4cd486ca372b630cf7077d3cc68a9ab0431c7010001 \\xf30cedb49dda93f4c94e7a739d06c53768909b20b1fc7844b511a295412a1990fe3b2032e8964b36aabd4f65ae519781cffc1ba83d6362e48fa5f4fde7e19c06 1663072391000000 1663677191000000 1726749191000000 1821357191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-125 \\x1689e5a595459b56f5923a5d6281d224e1fbc325641af161a2ca3ef2aa196d2fc2130356e7f802df75cd40f98e9d26825368015f93e5f8bf618af46d94fd537d 1 0 \\x000000010000000000800003b473ece6ebee42b540b41ab8b058b974a36ce6e38f202782deed4b8bb4278916c5f6702d77f0e4a49e549ddd661e06edff262b0838f00b4d3fdae2097422da8d6c011c99cdab7ef26901754baa5621a45b6be88a2e36c358ab11e2a58371d9cf6c057c8ecca7abda1f09cc1e9621baa4ff5e4195ccff2d65283c0115f8f7ef27010001 \\x3ee8f722f6385bcbb915bd6a817f265b3269eb97e63284db93566ad70563271c69ccac7283e6a53c8af6830858958f42f04bdb0db71c554d76e0de496520be0c 1675766891000000 1676371691000000 1739443691000000 1834051691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-126 \\x17a18f6c7be461c2ec06b6c2fa10229bb1eba24e861fb9dffbd16fe54a6fffc6b81704c2bad035cff3209f6ba4bf092c1e8b8a8c1828593886cfa841e4ca1f85 1 0 \\x000000010000000000800003a89a538401d55918f1068ac804987d59ea02a237ba11c99b4d90888c997284f29539d4b89f48e4a06d918313e9d5d88d0ef3d7c78c3c8009a2371805c73defaa4304000488d67d315639acf6c056d1f6f6986f16cac1ddb984abfbb79474bd48af986f9e91ca80dee7e8b15307a45214e3108085d72f43b8a6ff9054f022bcf9010001 \\x26395857cf66867892c56650f728f5ed9eb3f2e6a2954345c5259cd6da99cbe862847c589c48eb603e7ca9ba361047a51dfccd987faa9fef351dc199ddd4a608 1678789391000000 1679394191000000 1742466191000000 1837074191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-127 \\x18ad22f917f47727221440b42357b39637d4248b0152c2a97bc2e1349b4cdac0ae3290147eb693ad8ebfff57bbdfd3b238854caa22e84a197ff1fe15a33ccf81 1 0 \\x000000010000000000800003a428fd1ce59412d1192aa77652ed58433f82f84deb36990c30e90f713559780afab23c0ef4e3781434da86c3dde192f325026bc4b06021967c84e26e928a3158f8c3b3e834b1fc2a027886d70d7dbeb92ad463d4662e6821f752c10be655f5fa229f9b99006a76a908144a11dfe3e654f4d22b6143452f3f8ce9e6016403218d010001 \\x80f1bc58aa18680d287004b234d7163f15e9f70083efab0efdc1ceb23bc32f90cec75aa274aa7b2561d5d3b5f766fa1fc42cdba72e27511aea873d846b82090f 1687252391000000 1687857191000000 1750929191000000 1845537191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-128 \\x19b56059696ab2e81e032f085fcaabbbb5bebef65f8d9b12588f33fd84627016f8c76a8cd172c045b70b63ac19d69ce2f3fe452e23068336ea818af699220172 1 0 \\x000000010000000000800003dfe32de6c5e41ae451f9c89587540ebcfb9043c38f802c25d48949f64a1062cb6be2b56f9c2e49cc18a5dc7d17aa570c5f08db760ea33a6d9b8eac9b023ae48754f7adeedd261e3d0a5aff4de5aee4349c229e939e0166187a6db6e0beb8cfc9e19160b6627cc63d1d64f716bb9b27a242ce282fc0d94fe7f5be2b8942a33365010001 \\x7f05c431f8f43d097a6230930a8388ca505486d4479920e16df13ad2227e32ded36ff45df577c3ed1fbfba329487dcf440bd3248f9a5cabb8da7ae62f1e61809 1676975891000000 1677580691000000 1740652691000000 1835260691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-129 \\x1f0984f1b12bf454d921f2c58a81a512abb1d4c8467a31a03cf9f810db91e20264c0c9f8ee3ec21c11eb9dcd99f4c035f0987dab5fc487a1040d4acfe8b27b68 1 0 \\x000000010000000000800003e0d4558a8af55e244dcffd69bb0ebe5f9bf54bc7b0623d9974d4dffe26995eba4f6abab8dbafb2c8f733a2df36834d052f8049f155909d8bdc4299eeb128c1263744e51928b363bf729baf8888154c0cf6eeff683ab05d7bb6c4e03c9a2c571da8449db8eb0ca0706680aff4d1f1dab5391c51090b09978ea4ec9e72b6fec8f9010001 \\x914ad7dc75781bb1efc38d7073f725c9b3b7bedc10fc30a21f67fc1b11c1d8719e6f8de1816427ffcd9055160579b3e782c80005d8e6b256fda51e475ab4110c 1673348891000000 1673953691000000 1737025691000000 1831633691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-130 \\x2021c7da73b593c6c4b67b3ce5ff4242caa12575f406f822def70040ad9cab004b6372c08416625f125cf7e19772a09b590135a208dcaaefb24c005c136a5e1d 1 0 \\x000000010000000000800003d93d8881e77a0ac5ce3733119d49072afc9e7fdba9dd9af743115fd8c074b435a641a6c866ae8d1a1d39ec837906caee47dd81b0cf46f4fbdd9c293b8426991f5d69e961da8f4c14cec91465f7eb3ef9e4f3612ed1c057ed3ca6f22672b44bde1f29e6b797262f99def728722a1dd7f4ba2b002937685e7f5fe9233a2e435ed5010001 \\x9e0354ea49dc411ecf061eafb44c6028357abc4cf5dfb62bc7c4eb2a99ab746b3893bc0268e85fe2b8ca5c63c3fd9c368c4899fd75e14843e7b905bfc40d300c 1688461391000000 1689066191000000 1752138191000000 1846746191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-131 \\x2219e4cb84b7f57ee9f49b5c9432a7ab58e4ab2c5750a7d9e3d7c5a414e38888e8912384692aec053cdabcfa041f7bf8e836243f3537c98ad7182264efd9f9ca 1 0 \\x000000010000000000800003cda70e6acae78afaf93286320ac438f8b9bd003183cac4ada98e42012dfacdf394743b9890e8c2d0646f873c8f599832144dc9d58c7159bfb1c25a8feb56f6a4cf7a34216a8aae3be04868b864772686c142961d71ce3a0de5ea6daa085894edc6aef33449f0a468640419c46f26ced9a28ab70f1854ae3abac42f00afc313f5010001 \\x069efa922a89f1a10380ba953310ee84e0883c38b906e88b6b231815f72fe1433a2df9cd0b1e3e7bef1e34e4e8a7b5c7795a872808becd98f79c4041a9f43c05 1690274891000000 1690879691000000 1753951691000000 1848559691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-132 \\x24c942aaed186aec299f1e3c108166a4ed8d75d319f4f3575ce993ab0d69dbec56ef01607cc28cba44d9912116d93e9c87bdd043e90fff5a2974f191f17b1622 1 0 \\x000000010000000000800003c3bf1e13caa6a1ee9b5f5637cc8c0a2ae9100615bc89b84dd9ab9decf2be53a04c8ab45499ef90c465155293ea06e9e5d73613d7ae708820097d96c4b67e6973a1a35d1b1dc9640471ab87e2c6556fed9596231243aef352d0bcd8216ae94b1a41ca5c251de768c42d237acff7fdbca16999b3ba9850a55fff177c7d4ab1c129010001 \\x6d7da543c8b2ef1e9e415243d1e966446e153dc53c83c71706b979fcfdb873487c7d1fc8eeecee6c622d40500d4ada4193f5c1d795553e45efb5d03c86dc9c0a 1669721891000000 1670326691000000 1733398691000000 1828006691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-133 \\x2a55fea44b3aa103cf7392e9fec8957b098fbd7b717ffce67095495969a6a1c97b17819de3159e11e15dcb28a9f70b950ff9c11827532654252b7663d4fa4802 1 0 \\x000000010000000000800003b05f40867c1b06dbe198a18d122e70af40a4e8ef123337be5cf0ad44782fe77de48f0e37e01532a53984be36528c28e704cd617b600e3f242819c0d72ba6c58147655775f4c82e43ffebdc5b4eb466f5655b49336b41b15e7b5b112d65bd1552229869f043ceae8d7c20fb2540b16352822ae764cf4cf4c4734d73829a5a7033010001 \\x5c8d63e80ad3790040118518e42eaf045eb8dbdee2ffb1b15553896e61c8dcd15c47022c1c0e0cacf8ade7e0b74a9693f5856e90315fcca22c760bdd7bde4608 1669721891000000 1670326691000000 1733398691000000 1828006691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-134 \\x2a216959726d894bf7bc79e3784aea06490da37c70b4f78a21f57e58993007d18f332f919e58a78cc742f4a44d94e77fa2d309c0a49809e50cdbdc263880b93b 1 0 \\x000000010000000000800003d2d2034a115d07de7fd4cc11d05fccf5664537d28a406a42b988e06b6bf7ddf6cb0fea47cf6c1900006893f52fb8a78c9bf58de6226a3bac89fb41ba2514dec33d0c3fcf47999240e371ae613549ed1e453df783cbaeddfc8875c8a572577fc45bb1df2cc5ae4cd713da7645f77a4c8e23b1d1ed454de879dc65c39130521e57010001 \\x129f0367f9cc400c0ad62447b124a5b40112086e19ca4103d3b020899a2ef02d8f1004e8d97ebdf6e63b94fff559fa4d5e93bb1b5649b5289cebe643e31d4600 1667303891000000 1667908691000000 1730980691000000 1825588691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-135 \\x2a8d718771a30696a554898e8d850c715a66b6248b7a02e62f395a88a15543f559804a5842919d5a494d949d0db052ac6a768c63cd7a3f8930e745f27f55320f 1 0 \\x000000010000000000800003cb944d507fbbf08ca13bb0f01beab93d03ea1e089651dc864466ed295941e47e7bbed48af0c743eec3033311fc321b215b0f957ebe900c9b724637f214bcaaf608d370e190d13574283adab442cee5056f10893b9a3b537f2829f7fb50d1e52df0fec9d9eaadecf579549fc6b1eec62a8704ab00a3d20a27ea561269499efeb7010001 \\x43019e2d907c97bef08845fd0328e0101a72c75feacdda9c481e29e91490b60c5042ceb8232b28dcfef5043fad3bc94af42a2a92903d1d1a62437a13267cfd01 1662467891000000 1663072691000000 1726144691000000 1820752691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-136 \\x2e25600461123c1cfa4fdb8189263c72a2ac12f2eb16d49f6296c31cd09f2cfc0f3cd215538dacf8e4f5427eea7a43f922979fe9132c1e75345071e4e69157c2 1 0 \\x000000010000000000800003ae5ac031b21490426cb922a5345bb85749df77a8815bc00372932cf94429fddb1f0a11a5861e58e124ffdf241424887e550d356c389dd3adecca9868d00f80c55240cb2b81164069e636befa9aa857a264526bf40adc08d7572f25f664e921b37bdd8c7b511bcea14b861b5346ab41bb5348caadf1b5f81da11716090eac3d09010001 \\xe84be438398305d47683cb9e8175610210e600d08c12d577c996caa6b590b5bc3e03aaaa447828ee63a1a5cd0d3b623b2be3d5e17ae967defae19fb4cbb8ae0b 1670326391000000 1670931191000000 1734003191000000 1828611191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-137 \\x2f95d996be6d12a678cc819d221798ac3500751c410211e406065f7e9f18724e54cddd4621e8b584dd29f8b6021bc7464fa663f94a8b40b765acd3f8bfec1739 1 0 \\x000000010000000000800003dab80a243ecfe199cc095d8fee8ff725f9984d25901d246debba3955583b355dc98e456c30e207d30c0915eeae58e406503abeb9a101c7d5e9198c69ab76a6e248d757fddc8eb8349009ab904243c6326c43611f331c48595a6e5f8c8ffe3eac6dce9a869b239368bbb566ee7098122b5cb762abc8b95c61114a63d539d1d423010001 \\x0e7729a0999329cfde4dce345c9b16845ce2996135afab7872ef9cd6387cab5e37d08d608b5561632b70cbd22881413b16ba1013f1d7ceeaa7bfe483c026880a 1676371391000000 1676976191000000 1740048191000000 1834656191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-138 \\x3a0d63f81370f6dac5e6dad70d6a13c90963d66a3decf11e321e0543abcf3d8a89dab5fed5116f12f9f726c1f494eb8f4d019b60ef6e404f06bfa4a4086e6fe4 1 0 \\x000000010000000000800003dd18c8c2b02c25bfd68b4283f68523f74cbaa236a0993bad93b00e3f6ee04a278f7708938fb9c34a0d5a86cf079c0fc140fef41ffc224ee55b0c784763f948ce69b46e910d096c27f6ab0028f081483f70e465bdd3d552867c6080b4e100a22b748e9701e6bd47abe29862e168fb7ad25c92d84f0965433ec8859871b5b4b5b1010001 \\x5cbed0c7d9fa21f45fd536b7d7c203b73d82f5ae0a8e858c2ff9c773072b71fed8f21e6b05000b3f9e9acd079b1ec4ed332360542eee5eac7c2adf2e2cde8803 1689065891000000 1689670691000000 1752742691000000 1847350691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-139 \\x3c9162afa58c8e7f6bf4cf5ca725bfaa84e9b521a4ae89972e02eb254b0c375733f18aab41d9bf18efe962db0b7445f4b1d872f0dc1f22d310f45f196979189a 1 0 \\x000000010000000000800003b2a377992033dbfb3280a1a2c59eadc3dceddd36b60f4b989fcd0a1c5f3eaea29c6f05d4dd74179bdc3432d2cad9b7a27b1d1add38ccca7f9f3e0c11c03cc218c7075760fc98417efcdbfb2277f90442ccae8ddd1921aa2b27436fd5ad73a83fefeac169e6745688d255457384c3cbb77e1333aa3dc0d3336ac3162390a32a2f010001 \\x41b3dbcae76301e7a0daf7ff7f12ccc079ee5c9820fa416b103149fe782c530b1d3ab9ea066e35a3f926df30abbe1a03b2fc24fb955fd3a9d163c94e64f37901 1671535391000000 1672140191000000 1735212191000000 1829820191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-140 \\x3f3d52ad22de39319475d12b3d1d6f20eed30365e6e6ce777d7fc606710548814a8da5e847fb980a66e487e5efe1a692f16285d1c8c619730b393c1d7060b93b 1 0 \\x000000010000000000800003cb10f7e17ab7f373b483ab416c8b7fc1315a6d9b5f6b6a95b558a62a65a4f0bb68ff4d0376846c0e3a9ff1203766a82ec722891e0cf3f60189a2613c4a98a9b22943b04d548be5e9c3ae40abf0f7238589d9745498997909867bf316bad703003085533b7afb206e507e72c2b317543b59ba189eaf66333798e6826a55127719010001 \\x73583ea8c9ed325a367d5b785b31bf5b8d860985797994e48691ed69e19dac67c78433d857721fba4fb8c0ef8c48ab106038b35bc18f4952ed50fb37a04ee10b 1667908391000000 1668513191000000 1731585191000000 1826193191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-141 \\x3fdd09aa582b5911087b9a8d25308b903333cf11fe4f90abf1e56b09c64e02aa1b8602bbc62c21205fc618713d3e0991212d8cd520b3b6312c847be52b36950f 1 0 \\x000000010000000000800003bf345f707b050a91d16464d0b37e1d09e48c2bd2b4d7231f8af319ee6fab4e6b123d46838e613faf9b98fb0656cde4abe5ae8b05be68bb52ca44715ae9f86bcb6e9d07ba51b7d0029a56ff27d8b24f7c8f261ae9a12aee5aa9d28e54886426c4f6698fe413dfde2084b42a812c46e9a50f9e72d9dac5d6a4462a2d61918802c3010001 \\x1049b859d2674848e3b0b124467ddf9513d50429dfbc5832fe3be798cd8f455f7d622d3efe3cf07f5e14e518cd4378e8151a1e7fffbf6cf3dd92f6eeb97af907 1670930891000000 1671535691000000 1734607691000000 1829215691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-142 \\x42f5b7ef277a7bb635a1126dcf8625c5a63b42cef69ca600412f1668151c866ac3df08100d0c6c816e1ae6324c83011ef7d7366b6b9b363ac153a81b7f12314a 1 0 \\x000000010000000000800003dca79965c168500248930a64256e0db74515c37bcefe703a090480ea95e7dcd74df5f039ad0f38131dde3626f247960f2017f1623657880b0a82a946adf5f07c2e5f29917a91a77bd3903c7b171040c3d14855daf90e6c697d769a6f3eaada296696ba9733ef847c906654bf60faea5f457d68d5f0f8a116f69ca23df55d7dd9010001 \\x31dcf5f9feedeaf58c7d4a22fba5aecb9ca47401ab37dc92bee2823dd3bc53c06569ae58fbe86e92422f9e1c2525bed00d01300264d318a979088fd5d9989007 1662467891000000 1663072691000000 1726144691000000 1820752691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-143 \\x4a09f9f0e093c73b27df39349df80718346d82f273c708f58bb2e82425ac05bd69f14eee58a030a3f4cf2409138d14d8d83703ca930dcaa70817900562ecd1f1 1 0 \\x000000010000000000800003b9f925e7dde41177172939a71a0f7fa1fa843426282de6e89a6165bfe476122513be6047bb6d7f185e3e3cb0fd35b47cbe744d0bc3ab3540848fdfca6ef721c1bea81207f49202340f29e4e6804fc486c1f535797f2c8570cb03f44feb87e2f221ded18a7924ecdb0375f03d17e57f973a2523ee5d4475a9368a9c01064a52bb010001 \\x6438b713e709ad055b8908c77aec4ed916ff00e88f3d2029b142bb3a46a783b163546e0e2f9af53a51f53def40da366e12a89b6359bd7d4d8b680f834c3b5703 1662467891000000 1663072691000000 1726144691000000 1820752691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-144 \\x4c35489c5dff235b9a83cf6bded3184c72debea4b4b8911217bdad490635a8cfac61d801c5d52d612482cd9d87bd5582f6dc79b516166890c389cc7b55b0fe99 1 0 \\x000000010000000000800003fc206b9216adcb82af387a7af71bf82cbd9f0777514eaa983ac3e37ffffcf9f49027bb31d5747625445bc80b182c6564282b2bbafcae514db901576d8561a576c4b4bdecf3a188be27c1bb5f3d2d772e16dcc8b2dbb3019b45f4193fd3bc5b11fc5d21500cd6a40584b3cb86491e2a95badfcb4c384a749da6b7732943919f79010001 \\x8ccb5009e771affc69b774be193943a196fbb2f32039c8bd47d911a90db17bfc3439409de7f4b863c27999172a2e926dca0011e8ec4c91122d25d8abcd268b0d 1686043391000000 1686648191000000 1749720191000000 1844328191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-145 \\x4da919566ee122cfe642642c94d3718cd38279af88cab3084303ce3de85fd26a0686927de3f5e7c35a5ba949ec091846c4a8fcfd98f5609e4028c5e8e5f45876 1 0 \\x000000010000000000800003b8fae78cfc7fd0f5663eb4a5d6c25bc99e4fbeb50cd3ff4871e559f979f1cfd34b0052664e99ed092abc17defbdc4d3d55223f093119fa372003973102c3542ea570f4d5ef08d42bc600099b66388de5c280f3cfcfef9d00cb4cd79b99085fde62c8f98aef5229769352d2a2e17ae5d3ea0100abf33b91a6335087cb74802355010001 \\xf8327e9b0090cc00227e34c98c66b05e971c0163bcc91c1c0af94712457450f3025a208f38710d930d3467baaf1b4fda2b7de47a0ed58d05fc23a605a6182f0a 1671535391000000 1672140191000000 1735212191000000 1829820191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-146 \\x4fcd6ce64815fe36a359d7f57823e905cac003685e82e87a96235828b2a0cdd6757856de196750eb6c8d048636db83e8141dee12e2d2c613f710770e2fd9653a 1 0 \\x000000010000000000800003d14a3a824d1eb317054bfa516694288fbb95a6d71c7450c46bd154786729a371897f5d6857b50206f243e1053164d97971f2d9f0f72c96e15f50b14ce1e84b4059a887bff78d2f38202635ea78ae4b6dc770ee16cb16fff5776e4638bb5e22300c0936fdd932427ace7e59d81382ae0f3b38f86b614353f98ead6d5e95a3d38f010001 \\x6019be47584383bbbd3e7bb8c1c8bd435f6af1001f36385dd2eaa0b8acc2695ffa2743afb754a312ea1d0b0fb4a7def5130674809c12b152b436004e31abbc04 1675766891000000 1676371691000000 1739443691000000 1834051691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-147 \\x5381f71cf32d5c6d3bb3bbb12ca529378a3c4ca39abbe3ffb4b4dedb4c87105111ee0690dd84ca8eab33a19e9a3207de5fb67881bbd728392248a71b3b62dcaf 1 0 \\x000000010000000000800003bcedd38aae8bab25b40c0a3d94e3ebc49499c09c1e331fff7918f81927f937c9666f46ac0cbc28239b39f410d351dade94a185661e7e793f0d30a08d3c4a28cc07be60a9d52c883631c66337181a8bb8fab0cb5fd8292694376e2fe7bdcfb7c3726bdbd6a18075c039925fdce762c69a4d6584444a7838352ddd8586cc667193010001 \\x40282791a0b1b190af3e6295db587e8a776eeebd7e1b1f1a39c49909fe0d293b59e71dbfb8bd0bab6649a903abf9798bbf7918af6ecf25e3b41bc4f7e8408c09 1690879391000000 1691484191000000 1754556191000000 1849164191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-148 \\x54bdafdc4f4fce836e2bbb2ada3cf9219ef1a70704bf526145709197f53198c29bb78874c2382c05fc5962d5314c779535a7608cbecfe781dde6f573c700dca2 1 0 \\x000000010000000000800003a43bb50e33fb2b6695b28c317d1b0f5d014cee6a6745546a144bf9d8cbf7a3ba0fcb6da9c9626ccbe6f16122011c45fa3592947e3e0fa5fd92e0bf9577be869530ffae81203f0249a00564f568cabf886e3ff014e8f0315cc67e24e208e1335b4bedbc5c249760ac18ebb97b7132d496e834a04f7ed382966c104668d7633d59010001 \\x5851ef0f63061701edec3bd8c4c2b0beb549943f9694a22eb36ff498cf11ae6f51df02c455ef67804d455366d11b548d2088fc379b54360af3c680cae5333506 1681811891000000 1682416691000000 1745488691000000 1840096691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-149 \\x55a9a9ca268d144e1a0c0c3672b9dab658190d9308ce667870b242a256d77b654e981f1e06e854f90e057871db82ccf48b35d1f7fece85e4ac162e3a6ea40e97 1 0 \\x00000001000000000080000392720933d3d7f30e642c697cf41f3af25789ebad75a8ec0cb53c936e46e2debea2bc9eb1fa594ed518cdb097684419d1a666864b8fcc4b98f48156cf415c1691971b785039eb45c669667d5b866f1020a37678e7c3f3572ef12adea19d82c7087eefb2cfb5f04612f14b79880ccf9f1f5967469b850cbc99519eadcaa8419dfd010001 \\xf1d62b9d09b06550255a15b394b6ebeaeb30c0b4b46614a2cf220c31633bd4f467d54f2bbf66768d07e2755ac14e4bd4b1147f3d10d9d2a141bd7858fedaea0a 1674557891000000 1675162691000000 1738234691000000 1832842691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-150 \\x565dac49ac3aa92933bc7d585fc3343b2adbef0bb66ebbee30354e617b33490fa46fb0ad1e1901a739594165785a56a58f18cfafcc3b9a80ae56479366a80af1 1 0 \\x000000010000000000800003b158809e34a667c0572e351e2e899279290b7c91789cd0dffc0866cc46be23c05b613da81b5e852f572182a201291798fa287edae8daa61da56cdc6893cbec43e787dad112d1d95fcd2295b8b41c158afc242dd9ac0212ee350eb66f85fc65ea7010c372a6ad2b726b6e158fa538485b615ca82ae3e35622e76b10ac93555921010001 \\xc04b697fc535dad151326342fff8c9f44798f39b61d45ce05cb6d6685e4ecdc6bf0a910dea945c591aea643f08043d10450e582ab675d21c184bdd20c0179403 1670930891000000 1671535691000000 1734607691000000 1829215691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-151 \\x5ad1254d9c7f16ab012de87cb2608eb7947edff7116d9c04ac29dd46f1e324bdd5757e2f0572cd44926fac368d14e31339034429b3de1331d563e891fefe5b20 1 0 \\x000000010000000000800003924f9a4516df621232c24dec05aa20569e175016651ee9a67fddbc42f6ff7efe22e5ee15231aef923fecb42c0ac1f41799c193afaeda3c7208063a44fe0257c7875516046eb925d4024efd54f2ed04283a6e71c15774c5bc61cd84bac811bca7c0a7abea0a805eec7d15f97439e6751d2ff4326b78a0145e0712bf3c53c29235010001 \\x495b04e6ac6087da42f5999da59cbb6238727a7db0d4b83f525f0fa2fcd91b81dffa6373d6ee22fbde74eb3dd6b45c338229c1d3d5c8d25f59e798b0e92d420a 1687856891000000 1688461691000000 1751533691000000 1846141691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-152 \\x5ad9842f9253c5103eedc6ad5cf0194666b5c2e51a055cc14f9e084b5ec8e3eddea25918916c3c8a78ec7a7d358bc668c6e3211a6eb4d5245c884f6ccdcde66d 1 0 \\x000000010000000000800003b404ae5de17d83a578a23480429d9174cac2178bb46315e30781b164783b070c91024dbad681bcb769fbc4abc873d25d9d4fe8ae9454f6bab3f70477f836c2588ac9e92a6ae942dba1795dda0babd031deee42ce1385ec28c7caebbe524b964f50112a00b71bb649d86399ce47b2e745309e691f6ff1ec032b2dd17d121ba813010001 \\x7f43c347ec8045b6715b128a3f5e55511797b9a152d85401e2fc0f533edad55066a208d0c6686262d9ff4d102bd0a59cd05559772d6e59835f79e22dd7c5e90e 1677580391000000 1678185191000000 1741257191000000 1835865191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-153 \\x5b3d2fc96ab02806ca25792efe810b0f05f1532805896dbff2ec5df185b4ea7993ab71836729143bc55628026c63f6cea3bc4780b730d61a1b5ae5eccc6fc762 1 0 \\x000000010000000000800003b7cd8f60103f54962c29802a1d029e3c4cff9582dfe350d8060654829a47319106a7b57d87aaba46ea9bc8e015cc0173d30cbfa2272d705fe758aa9c6d201f56f2e62157d38b9660fc44a7de85ba556838f1c24dca17733ba9af1479b3c164c75c7a696b6601f24e66165e0d369b4c7d5333fff7d4e84dbef66fb11b631129d7010001 \\xcf0069d2735dea035390b7051ecdc37e1a1becd0f1d7e962779a2ee1058850e601ef1cd6c95ee39f948471c724b5fbbfc0aad33914932b3abcfc7f3536da650f 1678789391000000 1679394191000000 1742466191000000 1837074191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-154 \\x5b41a6071a849322d8c98565047b826f53f0354b2a1b1dded749fe1c89f50e845470ea689bd9c31a0174d0992caedacaae6db03e20edcbc98a9f09499546dbf0 1 0 \\x000000010000000000800003fdf96f1538a307464b5b35d3123232fe3b6cb3d1687f64dc0f20a0492267c443ecce5f550c3ef33405f2c4853cef6f8114605e78d5ff682462b20dbd5e507f910d423f6374093c86467244d898e8f03e193519182ead334698c2065de6e037400d7beedb5d7fc566fea76e6f4237c6efaf6f05db0ee9140a909d38a0ff2916f5010001 \\x0d9d88939382e6aeb6b96d5cb39718f97d52c2b0b8f4cfc75546d9ca4f30b56e5a3d806a8c0c7f2acfe572c075cc22ffbfa06defa59f16abf090ff17a20eb408 1691483891000000 1692088691000000 1755160691000000 1849768691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-155 \\x5c890c2a38e698309a35c7f102503006c4ef6ecf43d3cb6fb1662594fd0bd28edc8b53df839f80a12cc48e9400a75e2db3a1e06280f1e60399c8820aec9ad178 1 0 \\x000000010000000000800003e33d1a17a3356e7d0e9c1ba481db4bde6d976eebea140d29c0890a7881fa786953a364e36dab9fd666d4f7da5f652a647de05ca9121d94658bccbebb2aca5531bbeec1c8859fee61cf470038fec68a3cef4d4eed7f6d1555a464e8fd0ce661313934ca3053683917a1933de30779c25c7497f2b987c58936460bcd4d0c70ab05010001 \\x9b151afe1695ef2cdbfbdd3762187bb97f433689fa0035d972e721b08237c7319fd7914b8d28de39b635fd2c624636e4e484c5ee835aa1e09e227a3a0a4e9f09 1674557891000000 1675162691000000 1738234691000000 1832842691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-156 \\x5c9d278b858419217baff6ce7444cb00881846eb1fe5c53c61f67c33641b111a8ca45dbd2ce340318b891661d4632ad0077e677ab74628f8a6c599a4cc261f1a 1 0 \\x000000010000000000800003bf1bda2eb2a5c4dca654c763d2e0fc3bc74feb8249fb70bafcd011f9dbed2e1f5004dc757d8b54faf279ce4da1d1bb8734df6b4f860a91a215d819f299486caa5c5023d4490dbc5d9b896e68dcbffccd076402d627b3613723ca40bf52c18aa494e52c0e9602352fd3b53805b7c576efc0ab95a20a4cbb337027bd3ae5cb2171010001 \\x15106f71b5ad789f1d13ea0185c93e0a296a258a7e702e883dddee8e9335b9ac69a3e3ed11ec0fa9a532c3e0aacf6491bf083b706b0db45db240cad2c1a8750b 1661863391000000 1662468191000000 1725540191000000 1820148191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-157 \\x62f9e9c4a69a2747d67cd33ec03bc0d7dbf57dc1e031eebd41c0485a0aa9fe9fb0a23ba6d0b9a6a08eb847ace15719f02eb116cc156c4ba15a9a0ca3f9eee30b 1 0 \\x000000010000000000800003c32c660d735ac2ea31dba592c3c331cdd8963c458d8d5d5bb24549d6083ec17b810f235af83c64d1d67bc91f7e510eafc7dc9fae7df84de1687c2ea9aa43856eb8d40af2d0c3e4c47cc1c65503148a97c1cb77d4bad80a664dec0a3bd9d154c0cd729e49075b079df4436832e77cb1650170092fd57cbc3bf49b6570b074aecb010001 \\xd031ff8ca0199a1da135fd386a3db4bb64ecbdce2b3857a6f2a4a7f3399fac0b48b462414dda97ccbe12cf3e2389d6972b443ba9b106d583b55b4115d2e9730a 1661258891000000 1661863691000000 1724935691000000 1819543691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-158 \\x635d9f0a19c2669ea8a6ca190e33e4efa409eb7e0f6dac1a2335c4a20a7c5ab228365447d151880ee869987a35781eae26ea05059569586225e5393e896eeee6 1 0 \\x000000010000000000800003c6de3442a03b66e1b80dc7a9f067eef38b1572eb209d7375e1292b7ccd70ee539dbdbbaa27f0b878ad416b93c20062a94e1fc31e4237c2fbbeab74053875eb50a3635376c1df99a3bd08c73fe965a0339f4ddc3f45c7698f1e049194f9c5117aa9373e642ae7e6129a7884a544925ef99e0cc342cc6246660d13630bff5fea49010001 \\x2976da0294ed53c0e3ee7f16a9cde36695344070a619c2d81aaf01044620a4213c68695bb6c380c23128c2c69cc0c5f0ef9731e60c51b12437ace2ce2d622008 1671535391000000 1672140191000000 1735212191000000 1829820191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-159 \\x6395d31d9355e437fc5d013ac1ac4f582247d1df5b0fd04ed9b107b49385296af31a10e6a718eade280da1958fc8797b8eb6bb996cecac125ba95edcf74fa226 1 0 \\x000000010000000000800003e4d78bd5c9d2f0ea6dbbaf72e0e3777a5cb0ffdb4d33824bc18e8068c900061648cdb18a397ee639bd522af5e9cc2f5ff4aff88adbe02a63ece5c3248ea7808c92c1fa3c9e251140b93d1a56af2b8d92f62a856a56a6d82ef0fb07c23afe82cdcd80fe12e8f422222db76d65aa6d95e2852eb9e1d4d8a251bbf91251677b2547010001 \\x8a52309854d379261c5517f87b0199f7383ce7e755b8cf9f8b5d58a4d58db1a09fc13a33008057ad9c1d746a2c052b2fe3bdcd8ea6551fb096a95048ebbd5603 1666094891000000 1666699691000000 1729771691000000 1824379691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-160 \\x6c3d20492d61e6fbb82598e22678a8bec658fd770c2a056424222e65d2937a0e537406f0c0ff5ab3b4e312ec719603574c8cd8688e5be1e3740df9286772137e 1 0 \\x000000010000000000800003bac1a4813a7264f04d5ca26617c92998eba0ce848a3680b7adb1665c5cdf11470ccaa000ed593c7a7dedc7032edc36ce1cce2d10f9cad059a428ef791c88e1010db1279b7767220a7e762ad5bc44b8bd21c53aa176f6b41cecaaaa8351efa5c9d375ae67af128f0c2987af3f836f6dc297ea1f60b56a656cd902f62daa2805d1010001 \\x99e637099c2a6e6b9535a3994472314669aaba90179bd00de15c8e8735376b78d0001e7cf7649078eb3fa4bbface1c74fbb8c951e37cabb65abfa86d13a4880f 1660654391000000 1661259191000000 1724331191000000 1818939191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-161 \\x7705cf74190718f34227039035db48a9f576af454241d5274591be218267d727c231cb7c6485dfd47034dfbf446f545e94d026674782bb4e9b18aaac7e2dd60b 1 0 \\x000000010000000000800003af2b8b3701bbc0202e625fa1aff7f9a6ce18c8fc91170efbaf8524ba60f3f5810afbd672e1d3562a4c6ae17ba41bfd7d37691938fc078b2e921f9d40c1c06e89de445d7368931dce3c523112e6c8a8bf34b1640ff32a84596fbe872d2d999fc847023b69a4408a902a51cb81c8127d73c918ab4a07ed48af3032fb7d601d7c49010001 \\xd3b008014c33ed945d36bc41250f4de0fb3d52ce0612eba07265f1d54eb5e74feae16d9119ed62b38c2f2c7e29c44efaeeb793c7c69089aaed042238e8af2507 1664885891000000 1665490691000000 1728562691000000 1823170691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-162 \\x77fd290dcd352492897ad78ff47f565b12bb0583886bca89ba60e55175b344ea5b73581993d9e40a6daaec548f2c4f287af2141002a93d412157e41cfd149d62 1 0 \\x000000010000000000800003af0d70a441d10d22d7186ca22d3945163825ebb317609a32b7571b6d5c211ebc524133f1701806ed14c74fdd6aa23209924201d525ea3d2199be34d9cb78ec1a523944ebbb493fb33417d7287419cf64598a7f79c2554cd988b5f16bcff0f0977eb17a49228d58cbdb7541871dae233d32ed38f3c28213100ba01c4f6078f1ad010001 \\x6ff1a15b46dda3493618f243c5120f58ba7527e11cadb8589753cf08d7194eaff2ba418c35d01ac15e337510cd2a67d8487e6f8c8925e500b9a93d07c9259604 1671535391000000 1672140191000000 1735212191000000 1829820191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-163 \\x79d193c884e625bfc3df8149935a48b1655aa6578e5bd815876f6b13e9f14d85d490c7e404d101a05a9625f446db1ee7b47f3941c7b77ec493e75aa7126cddda 1 0 \\x000000010000000000800003ccd28c03b86de9824ef0e136ae02664ed23d33ab67df62245fe2fbf960782c25934160c2aa505f611f532c811056dafba6902d4d2e85618079dcf21df68e3c1ce2be09087f1ce1590a0436c370584327e556152be9d81bfce86a6c37ef8fe052aa35dac2ef92b32b87e5be90c86e5328f33119481c17579029571f37fbc034b9010001 \\xc96c0a0e39915b754d853aeb62167245a9a9cc80b2a173238cddf31e914f3ec354559b30957a71b83c223f5413cc2f74a22197952596f028932a39b9ec4f0602 1661863391000000 1662468191000000 1725540191000000 1820148191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-164 \\x7cb58b92ee9ce615ff7e8c3bd2a751541c07343f1a04ed1f2cdc5aabc422496e194378ff7506b0cc81d1f57963332568198497577d8913e1b43a67cd7dd4e4b9 1 0 \\x000000010000000000800003c9ebc1068b6391a4527dcc7f54ba85870311303fe751a7cbf48bcdc41c8daa5d9ab9f2ee7961acf872a973ef1ad319767c362bbc3898c66ed2c24cccd9a6b0088a6e0267e1afc557d5a305c46ac4e522833818ddb797d36948928b73ec8003000febafa59406695d13e4af2b222f13aaabdf5434274caf7de02fec1511780855010001 \\x971365d13033028af8d19153743604c0c3b95815f7178bd534c41f1fbb63aebb5217b44ded08d36d1abb5ad405159ed6e9befbfe6eb315e793a5b1799cd78e0d 1683020891000000 1683625691000000 1746697691000000 1841305691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-165 \\x7d455d26cb27977c47ef757dee183102be01f501fb8e6a283573ebe50847958520c5c4eb3591a85e6b8cac744bb62d3e73805d48d3797f18eb13608658d7ccb8 1 0 \\x000000010000000000800003a1e33c583ad43069b2cf58850040a664c9c5de29f3504956bff6cbff6085768a1fce883466ec40a4362262c538a6f5adcf4ccdaefb9f456eb55491f5a05baf18f587828946f08a2b1f7a4d8c184529f3487229ff2d5fdba112779e5088c016ce48bb08a6634b34a667efafa9e181b6e368d528bd9adf9edafe30c9261fdff95f010001 \\x2ebf4861438afbf9d681dacb89a472f3042f3b8df3cc790fb1946eda2ba04c5e8be8153e38cbf9b8e8bdf095482836aee4f7dc6947395bcd3aa0251fccaf0e01 1669721891000000 1670326691000000 1733398691000000 1828006691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-166 \\x80410148420f0fac9ac282609ac65dbed7d00e8fc2504565b47b8dcba52d46502a18f1a2c7dd201ae2deb6c105d98501f3b2578ba74a3b8c70d78ede9988d834 1 0 \\x000000010000000000800003b16a449a9ee1e811cc5e4b6fcee8362f02b22ee7a2e2a9d572732f809fb1ca48668ee37ee38929d739bdee9754f716cb51ce52658e7da1bca2e5c03e03e7b0817d2198a9b76e191fc195220b6f313bdaee0b122ec85d1ec24a84a68aa62af6426175ce5584ea1f0501e98f87b6531c4f06389f065af7e3e7628e63aa37912e13010001 \\x28ae6492a16dcaf2c3360a6a55b9b2a577ea73832d7e9c10b19bd7a9945988fbef7346cab1b53311f971c35a2f60f0cfdf5ca0d57e5b67a66b5a049f1a3aa407 1686043391000000 1686648191000000 1749720191000000 1844328191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-167 \\x8f4dec09da68fcdde12e94db02cbea65f1bfd76e53e3f1e308ec9b3fdeec10f9dcff2d08306933ec7afbe1c46ff9a3d2469cc4ae2060c77c02af1398ee2305a4 1 0 \\x000000010000000000800003c49ff6b6a8cd51105ca63ecc32764ed930126a4b450f5c04e725486634a683f4c590cc2242932726fe636daeaa2179ac0f6ff6cbe24c258ba4c47b0006c6ae4ab2682f8410dbd1b68eb7a31a5c6c10e9316212aa66e88558c9b8dfab4d2f0de84a1a3c31354ab90cff67276e06d9ebaf7427b133f3ae4cbd089bea7fff30fc21010001 \\xca14b03cbbcd3a8b67fb1707328cf438834f84d2f60228896a4364db15f77b43c47843020a20e71568bce66e0b7fa3bc272749a5a82cd697e9a378b6478a120e 1684834391000000 1685439191000000 1748511191000000 1843119191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-168 \\x8f896170a7bdb7f12d01f8e6043fad08b658aa64e1f64f127e31751b29e63f7343512f5b2654f09f3fcc778cb8e8ee2b54da74be9e577cbc59fb3d5fc8f96a0c 1 0 \\x000000010000000000800003c666d3ef55eb57428e7217b27a5a75f021b4c12af80afaeed776a4fc9c413f397711e48324dd975e45501f383705788cda5abe770334f7edf9062a6a5e89f45e98762dc20952f0c8bc8ccc9dfb9b6adcab44711cff07cf95a575c7ca67c1be7e47b4925201833c2c97e4c1fd53790553794cb15eefd834ef0d9a523b613b2931010001 \\x1cb7d23a30b529fc667414e5a12d816384c9f2c471fae92387a8702afec2c10b66d158ba7a69972c72c8efb9251d57ac8787cf34337c7a04eff4e9ce9e682f0a 1678789391000000 1679394191000000 1742466191000000 1837074191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-169 \\x90b118e2e78f57816494ad0b01ceb3864b5d74e42f53fe947acf0c19bb20861adbc4279ce1969b2e52ce456908942720217539361f7682de6e4967a3792345d2 1 0 \\x000000010000000000800003c60bd639b69b9d274020751c0e8c4386f226b612105e7dc180a4d63f1bad118c9d9a8670d8e010894427842aa49989d5c1491703d42d0c98b654cc8d62923ffc43ba84a4327330cfccf0bd91022a9bdad04bd6108a34f02e5811d91ba824742c0b06b1d301bffc15cdf988b376a398c7273c0857e03f44309d283c5b874eab0d010001 \\x76586f57acd69d3587277521238b7b03e0708087ece2846ee6d821e3bd41291fd400eaf3ddb62767d659d59e0a496f44cb3a56d761f29acad62889fb8a51880f 1686647891000000 1687252691000000 1750324691000000 1844932691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-170 \\x91f1a602a16bddc14c8e44bfc06d01f57dc31b87a5cb23a27837015e84debbede15ec51cca6445f9cf852e247421c6c72106208a50919c94eaae9ffb5abee6fe 1 0 \\x000000010000000000800003ba9c132fc559e56dbf083db5d42edcd3ae3723aeb0f262bf47ec16e1b8e995fea4fcc955ee79e7ec6e590a37d32ea25fb4c20eb04017d88d388b904fb24a3aaf341e73ca42344a20fd1e535a941359438bfe653e568d2929ebd04970fd0aa1be92a3d2a7eb802d198d58b8140f84ec8fdcae50fee49003c240e054eab247aae5010001 \\x5c66c28981defcaa9e130ce92ba58146b933f8ef6e0f7e27625ed1f9dd5989a3da3552dc460766731675e27a99d4d5482ca031381027b2b5ea799d212bad9c0a 1690879391000000 1691484191000000 1754556191000000 1849164191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-171 \\x9595c6f432d311d105b5ebdd10ecdca2458073152418bdb125974df17cd7d58c318701f6518dccc3d7355f67076b03ecbc9e672753085846f5964331e40fd49f 1 0 \\x000000010000000000800003962a91d9c77b5cf3762632ecfc62a7cda4a445054ca848fdaa0d33dbf9dbc8a881b5a98fffb0692b374e47de14c5aaab22bf062bb918f12ee188f70d57b1abe38e8e540a7b78820ac7903e59ffc31b729cee09fd575aff725c37860b8756ab5f95cb777904972300462c51fc9b089c1e7010efa99f0fd4a4e3c59d51b22ba113010001 \\xce080ef5192ba2b706edd0bc6c5dfe5aa5b4ff03c4f91ae64776a2518122791a858e675478a29342c30bb253c41f9b168355a74c59e439d9416ab1cd40ffaf0a 1687252391000000 1687857191000000 1750929191000000 1845537191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-172 \\x9891700f16b5a7df884ad8a6d3633c8078ddb8e8c590eeb8ac75251b2816d66e9d2ce94cb3b975a8b74ef338543296fad7e9f4e3e7722833470d1acd0c79c7ee 1 0 \\x000000010000000000800003d6a6659fa9488da81d56b018b08a5252fabd626df127218b22461f2b0e59420d35f3a4ade3a050a83cffdef7833e0b615bfefa9faa19251c7960243ced5b5975472e5f1173f2d8f2748f437a946cc6d1a39efe0fc1398a55c6abd53d6e1ed244bdb105ffb8fe83b52db8bc00a5efe3c7abab916f87f1767e7f612d72c37400cb010001 \\x9958ccf5592b8e00534c5d26cc1c0c852d28061c13472d953fdd3e21b599cd6841b891f65a532e15a0d168e51c107b2d0e0e9a7acb720ef6fa898f226655520c 1686043391000000 1686648191000000 1749720191000000 1844328191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-173 \\x99adab36a536ec1ec2b9ad18ee67a3f22f57d0a29f55459c56e7a7f17bf0b615f4f5bdf277e5bfebb3ce116e33cbdbf23e224a63d87c3065ac7d91127abb2ff3 1 0 \\x000000010000000000800003e23f68f4405e45c7eb362cd19e5d936e473300feb85aa57247cab1d6dd33965aa7fc9426ce0ea4011ec7080fb7b33493490555af2447d4dfd830b84bbd27d5d1bcac3c19e461b8845601884e9e33fe9456abb3d4e94d4f9272da1dc34b8e95bc539750800cd6908e742dd6d51409729045cd9f47794f4a571237496b96326a65010001 \\x2eef294ae561a1573f834a30f8c3a4e6d51610182b3717d6374e840771186e1336986b3400d0d34cb89a279dcaccb97953ce4c8fd672a7544b8daa815e58c00d 1676371391000000 1676976191000000 1740048191000000 1834656191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-174 \\x9b615e211e525798eda6f8c1b499928a648d58ffa2cb1ed38124ff72f78d3f63c8e78c96edf8a74d215ae0f801c1c3e69b1e6cdd76b4d978319916668821a241 1 0 \\x000000010000000000800003ba4a2e02aabc27c94d4cfc8251a6151ebf6f2597dc66c3b9bbf3098af5aaed1d800b138e3e97dba1f606d83d1257c896a3b4fb457b17962f509198c44af68e72dc6ad7e5a70fba0320927a661750dd08d6d85f82362d95873594cb5c735d16af1a433592d7ebbbcd48e4340b2b7789725de766662535f2f85ee408cb8f25d857010001 \\xa69f57ff8f7e973649b96b57f80ea0568b49c3c92dba3a5d2d6b43f5d1d3f287b5baa31aaebc0905e57cf38ac83e6876f617467c3910aea69aea6e76bf208201 1675162391000000 1675767191000000 1738839191000000 1833447191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-175 \\x9cfd718e63d64cf6978aefd2e73803b0f76f0b36d59660bf53b546908eaa4b4f9051e7036197a0ae4e7604b645457daa99f764f7ce05f61318ecab1b60f35243 1 0 \\x000000010000000000800003c00753a32be85b87f95be73e569cfec6ef6b2def34f25115293addd09f7562220e08386d44bb7f6fed872379e1f7ab12835ca698d4676af7842cb4a67561a44e16541d43e9c2601e578271e1073588ac16163325ae99eb53e6531d577dd21bbe3debf3ef27aca951361a870e14e5ea70ddb0f82725a81faf71e8e8d76f02ca51010001 \\xf462d92e54316367ca03e980b5b19c8cdff4479d9e11a1f00cb234e7c677013ba4f433adfad78aca2a01d9aa62b953f0725c5a0dbe59f2b04e7fc1143a703d0b 1670326391000000 1670931191000000 1734003191000000 1828611191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-176 \\xa1d1c570005b9141151b094bd0b80eae94ededc37b3276a503f0153185d14bebab3c7de7ef33cb6d16a7f35485d867786fb17771f956420609100d9eb9192f86 1 0 \\x000000010000000000800003f40e44076b4dfe30af0e6df5f146ce3d456df9637af4053a37a4816484852d3901c4e5d57da8b8a4973524af08bb54ee66160cbdf9c7544695020612a7bed6b707cac5dfb449f6aee4848dcc1c776ae594d562abd1021156775442f8fe359b793aa41bb5c32e5e6840cf918bed35d201e86b208331287dcb4ed97f34f6055815010001 \\x6965519aec881578d7f5ab2495cf158b7494eb20543059021e286cdcd9120aa32761388ca3c6c14f85e73ca185e0eaab2e4051b6efd4557f79d1f57332d5670e 1684229891000000 1684834691000000 1747906691000000 1842514691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-177 \\xa3f561652003d5181d3fd24c4b5ec60a1c3b26b4fbaf366cef8de45065d5afe1213745a3657da76a023c1279d6403dfc08ac5237230c3375d36164255765ddb2 1 0 \\x000000010000000000800003f65e2fba32c4082b0083d351617a8492e2518ae5b1e7064c992b267a3315caac7571144c87171ac6987e756d5847e5af2f90e2285fc50361be0311c130469846d5fa6834c132c763f5f6b2f3891e61592af3963e1ddfa3c47a6e6c638decbe66ff47089f1a1a4e1335156def2b4b2f6cfc7f20dcb928c5feab7035b67bcf7da7010001 \\xcf326742898871401f83e42fc3ca487ee70014575a985b7d0a8fa7b5b8273960886952a558633dd826bc6636eabd92642104f000a1f88b1cdffc78b07b3cf20f 1670930891000000 1671535691000000 1734607691000000 1829215691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-178 \\xa66dabac98f733a3fbb775f63520cbb955daad4a6ef407b8104ff420d0c023d005409de59f9ce402714219c8619d8d53ce1a499b149d4789fc99c10940d68f44 1 0 \\x000000010000000000800003fb0655019f39be6fab714bf765d6f5d51fce91007ddbee6b7c9d911dbd8db6cbcf2c16b7696cc6b1a9a8817c94ae6fa12402b4ffa79659c6fcf5728c95725dd4908705884b12d8a8cfde9b5d54ecaaf2f1b70154933681601f727635ba29e198a24c7e4ec6f33e821fdb1c493f83f41b5398b7c5f82a600f48a1d2427362df95010001 \\xb7e2d6511804f93dc997e2d7ab36472a28255658d478066fa1b49407dfd2872dad73859dfae02b5d9575f234354ae254902ad1bf98aaeb5a07566aaf30d8fe06 1681207391000000 1681812191000000 1744884191000000 1839492191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-179 \\xa989f34d47f67d713bec787faede97a5d68c51555cc9b0ce2940f147e12ffdd483e2a5676f10dd896d67ab0b5441db1dd3458b47fcc15a4bfb3b5e6d8d1cb0e5 1 0 \\x000000010000000000800003df2aa17c0fa75bb529a6ff033cb5878d9c67f0fb5f6655193a352ca897145ebe8f5f15dbf56b9311be75bb5db8de72cfee32f0e449ea56b012f6a5ef1f1ad8780a13abdd0de6f03e7dd51ce97f1cb781d05b322642b76e4305a5783dbbda7abe3f5d3fdec58f055786dc292a4f3e206dd724f7884d758a830db5fdbdca268137010001 \\x2de376931ffdbcbce64be665453792b20dcebb6bb35342415b0e7aa605a6c01a0a2af2ab671e99158f93664a744f0156ce590aa1ae291a186fd55fdff37c3e00 1665490391000000 1666095191000000 1729167191000000 1823775191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-180 \\xaa952a461547aa9b7d5f21c7f6bd12e0d2f4cf376a97cfe7a5a48d6456ba0285ae005b611f03cf97b75c126cf29aaedd11a2e019ee43fd9440d83788bbacf0a9 1 0 \\x000000010000000000800003bd6fc26223f185d04e1dd189c11861c13c2245f76c7e255edcb7b5f1738c09d0fe869f6735b7cde7e38eeb9469a3e79ee586ee10394af42903230f944e2d22d346baa7be0cc152aed26503f722a7850125171af7b7c378b55e6e6ee43a63fc1703a08a4c6cf6aaa7c4f72e9546240265daaed8a5d435b008a4ffb75169582fbb010001 \\xd97f664cb929ff934f92bdd2004b89ceb1482c608d74e3aac22fb60e8adbd7ab250373a312230b4fcd1d7dcc842c06fcef4e656d63f216f53d5c3df2db102306 1669721891000000 1670326691000000 1733398691000000 1828006691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-181 \\xaa5dff3c7fea43314193e419d40dbb73b2488c08ae5031eb537da1549deab0eecc4214442c1cf3102e460bd4c67a253024afe68d9ce9582eca1d71542560afad 1 0 \\x000000010000000000800003f29356fbc6f37b4b46f912701167854269ad392ff05ef7180df08e8245234876183f8642d44ac6353078a7838bc79cb6255b66947f8ae4b80eb0458275bcd62f841302e169a79cf5fcaa32b29be1f6a26f5f79c7a80919fd2ca14a70bd8c0b0b1734fcb5d14f9d4ea323c9d8d4393e6ef3012c74fddacd204ce77c06d9eca921010001 \\xa795261494ae7d95167858e0db8eef3204e9db5e7f812016d07f4af7411e39fdbe8ff335fd16b4e40b0b7af26efb6af610cd0860efe947cd59fd9f5db5d30604 1673953391000000 1674558191000000 1737630191000000 1832238191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-182 \\xab85727d1d0b3720220256302b56adc6b4ae29d57a287eb30c52c260e79948a44baae7d5cbada7adb6b27298e335f1633c3314be4f1cf6c137fe414618b2d186 1 0 \\x000000010000000000800003bddbd14d55a2150ffb0c5fb825b9e5bf04d3192c63f815d7ff3455d86a8baa06633258979490545e646c4e38371a36bccb777733e835e59e743b59b7badb434885585f1af8d68c4c02dce6617f772730c0f6167162d8f2a3ce70cb23154f0a289f1661ef0ed4aa55d1aa7dd78a6b2072330b4e610d7b9d51b5c01c6140e41321010001 \\x35e9bf060f1491eb8da7ea7b49f75c5907527c936d0d6d8d84c66487c63eaafab050bfe71b85f7f12a4703a525f6c5a72f917e91d6300c3482b3ed3193738901 1672139891000000 1672744691000000 1735816691000000 1830424691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-183 \\xad75ae98ec473add3b80d70cb3dbae50fb40f7ef906f62261b2b935ad44c1f20240b2a02626762a08dd908b5e9e48a082cd080bdfb571addc8714353e8939230 1 0 \\x000000010000000000800003e08cc0affa6e1c70aebca45ddb4b4dbf3645961b1a031983c0d56fd82e44ad754644963949805ef4c05f018072bead9ed55f85b49c07212afeee27ccb74e8a4a279fed372c49d64039ba3e2a382548cfc4f1ef773c164e9d2e4e1a61c091c18e602f4bf095d673ad2d9d196782f1a6b00353c771d190ee67654a1fa25a7a200f010001 \\x70a1bfcc001b487debfe415ee72027412723ac91f9765bb8c6d63d08930aa86e7899519e035507f8b7f72cddc0fcad9d9de1d632313329f2a1cebcfb1631f804 1684229891000000 1684834691000000 1747906691000000 1842514691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-184 \\xb2fd9fc005e77d47c77884c30ea5a433aeed3eb0ea49e8ef4097a3567fd8aa40144fdab4be5988748ab90804d77f509df7b6e01aabd516092999cb40bedae7a7 1 0 \\x000000010000000000800003b9c54c9b218da7548374de746c34ad72f4df3720904f75abc1f31170e598b37cf648c4682f6ca34fdeda2425490d3e14499ef4a92050330434184a5c391961a6fba6b0deb7690556dd1f056514d504ced7ff0a37ef8e28185a08485849496348dbc8d43e44fa1fd506f892897fb68f40da4998fcebf39076eb8adfe2a24534cd010001 \\x49aa4dfede700458a8943115d1ea2b655d24e0f413174cb0ba6232e007d9d89b7dee1fd6cbca273cbfddbcbba6cec1eaf98ef4da66e15760d89e77e31eb20c03 1679998391000000 1680603191000000 1743675191000000 1838283191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-185 \\xb431715594c68fbca1669680c17b5146aff2eca7e171f33c51c6f34a421ee31c0cd93bbdafe44fcdea5c687ae6e66c7529fd59052d896781b6d599bd8f712b71 1 0 \\x000000010000000000800003ba69b705d4af808c92493db293839359d1be2b621e5fcb25cd216cbbc63d81efe818348390c57b205959f6ef7844dfd201c6a8f9cbe405417003e7025a1a228d726267fa40061d02e5fcf692aaf5b6fef95e57f052ae8d87fe207cace464d57cc8da34ec671ae32ead817444bccf7b537029802e41ffbfb20fc8765703270bf7010001 \\x9bddb463082f2b956e90cd49029a6c5125e6697673a7e89ec20d10bd3be1eac774340d34c065a3fc031e63cc8d5dbb25e10d78e439238596522c7022e083a604 1663676891000000 1664281691000000 1727353691000000 1821961691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-186 \\xb4419f3d640ab91dbb52d47b89dd2861f45f90eb45c4175f240dea82c5e382e03404fa9d5c47561223488fadb9f566b8ca719628fded3237e68a5f6804b69a8e 1 0 \\x000000010000000000800003bcb9159ff738e8cecb5558b2d7fabc6e121d3eefc7537e09d378899068a504a0bff07805cccc1aa3ca4a410402a39c4c6aff61564948950041f0891645c5d95c7936830b8be3dab9730a6752d6b83fcfc7f722bb63e9ba713f3dc59d48248ceaa449e888b5b15fead04b139a2008f8a9d1a3d9ac103f0d797ff585489146110b010001 \\xc034b8285461246652e6e55dca4be6bded7b2e84a919e27e08d4ce1097eb7010bf8679d234d010693939b3e675ef22fc915725a0b8b412a9b6319f6e00575c03 1663676891000000 1664281691000000 1727353691000000 1821961691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-187 \\xb54946403e95547e19b2c638a84196861ee16d2300d67451147ee31feeb39b4a817b99f98b00b26c6d59c5fceffbe02c12418bf669ac7768f407f9b06ea753e3 1 0 \\x000000010000000000800003c20b1032940a428bd5bb44f1751cf6cb92c0f478ab4e54a3ebfa8825b44cd5a2916a410ef75a8494643d096a84aee36a5df75cd58e1cc75ace7b62c348ad8f6cdba7769648432533dd4c51974fd604cf4ac5bb8d97746eda2d903c6b3ae64fcdcab76ace0de43ceee7b313513da4de7f6fde4f50a6f8ae6537221672491f2a8f010001 \\x1e2cdee2ad1e380ed8a42f5eda85f1a184277b0f5c835fee4ab804de0c736c99a74c387c137e27b0b5d6fbe9211500216db427f4b1651420e353379d6e321c0f 1683625391000000 1684230191000000 1747302191000000 1841910191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-188 \\xb585562ed03cb762f1f2e26490c76015232c968023585ef0c70d17520a5e7d448adc0fa5a3c20c6d302122813581b2ebba840d6111a1b7dc2dc62acd2363c4ec 1 0 \\x000000010000000000800003b5d6ddcd50005d16f73cd47732f5e4db334f3888a28e0c51fbbeaa20e060bd91f05be4f283e04e7d2c1ff0d6224bf10ec5ab3a82ec6e5ccd993e3d7d60ee71c2dca2dc46c412c696be9965f9798748e0b63e5a45f471ec8cd409deb31277fc17f68177d67c576d9753e7cb47d3fb6abc2d150ef695442520f2b92ee47253309f010001 \\x387a290a24c8a7e3125c6734c942cd580fdb4899de8e45e1053955218e570af581722ad55afed5f6472cfed9624a5b2d32ef1ee2fb195e0732d95381a7fdc90a 1664885891000000 1665490691000000 1728562691000000 1823170691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-189 \\xba61f5f5a64c28f40c65c2c8dee8591522e684a7eeda0fdea4239a6abc8336fa23005cdd6c2e3d3c8b58c8a98fd20e36bb4c01a3609ebd120eac4d8fa767b249 1 0 \\x000000010000000000800003e391591cc284ef127f125790977116b33793d4d76b5daf3907e3fa36a71bc15dc1b38b700c446c9cbbf71b095f27665d4ca537a12594fc33e24876984d230c22be17f9807ffcd3e31b7c1f17030f3443b9e924d896ec9bd95ae61c7954db75694bfb0a98a4e2869f04e182d0b4b1f1779f88b2697b090f9f9fe67910bf7ca847010001 \\xe24decd913dfcdc34faa8aea75b8702500c17e4c8940aed82a0723f044fa515ecd3f18711b0bca01fc0be78ddb70b4f1028c0d80f2e22fed77925c1009d8050c 1690274891000000 1690879691000000 1753951691000000 1848559691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-190 \\xbb71ce7f4fc17869cc04ac786f841104112e2ca6086dc8cecb321bcb46143e4c479ea8c1f57231a4a9bc00730ba2a1d8a79cc42c6a41bead83e67f20d7fb72bf 1 0 \\x000000010000000000800003c89c2feaad2e67315a4e69dd2fde16420ed763e2bd0c621eada086cf9e5a04bfe213efa075294e74992dcd8c56737fded3bb943ac757afcd7c884daeb0842a1832dcb4743fede7a35992046c1ff667de26c688fb5cb5d59fff9ab84a0f6f8e0c17741518162729b255b681e373c6f2ee3993a23e2a1414fbe43e0d0356f89e2f010001 \\x7452870cfc9f704a3dc1f72536430b655ca39db7ea6a48b32b1d2df42d55ba2e447f085b63e029b15390a19a4f038bc7d26c811c9dfa8bebde3e70fa48f2370a 1687856891000000 1688461691000000 1751533691000000 1846141691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-191 \\xbe755df21425b45942ab9748d6c247e7fd4c4361601962ee0ad6651c6eb222995ac08491951b367a5377512b4d4f18bc3a197a5b1e32d8d5b8872191e72d4c12 1 0 \\x000000010000000000800003b6d19e927a2fa9b3885854277094bfcb15a3f5e302a6ee9d137d09cb27b44a1097d99d8fd34b718f738b1273fd782e3fcadf2e6e98f20fc5480de78374dfac68ac6e2de39648a52c7417dda38a675180f54a5f4c3cd0963d44e20536a81382ce3d905f7f725d76640cf4342af6161578d065e38dc731325167ac674a9d305a07010001 \\x220f6132ef2ae2926699626a19d984a2a851a467e28d818435d7a03ad338210c9e2fe703f8255b69e328bfda25f950335547957c139bc7df0a9d0b42fdf91408 1669117391000000 1669722191000000 1732794191000000 1827402191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-192 \\xc275ce47693e0d15f76bcd49b438efd004b2c67b9db1467a913b6965a0f6912ad77c887151fa5f1863f636e65086c07de81e821a779a1094da22341ae0d364b8 1 0 \\x000000010000000000800003ed63a94a2fab13a4677f108fc44a83888984c05564e5ff21cff1fd58086ebda6cb64a61b39f9a0e0f654e1fd2fb39514a8ec56192f30fa6519b9492c9b5333df8f30038fb17faa5e5b05b98c167fe0235ffcc659ab4c4150b93f22b6b6c0157a1971d8a05960128865e0d1d7047738ec5dce2bed12e403a73ceccdb5efbff941010001 \\x127d530020f84405d73a219f6ee76874066296a381d138724df44b96e54a6209d40e6b46081a5b019474200cb61e067edf261fa01d91cdd7145249b6bdb10107 1691483891000000 1692088691000000 1755160691000000 1849768691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-193 \\xcc41420d8eeac12ea5d3eb47d2ae77b8cd6b1e53d22a11c46b62d5ce98c268b21802233df8cf2986535d148d87adb7f318a171043bc3ff716ffe1fb00586ef54 1 0 \\x000000010000000000800003d00c2acd9861c8a47282d29ab51a99d0491eb6794163dffd8506d133298d2b04d86464824afe6c1e47cafbcd2d8b5b41891b76808076340fa41bb35190fd2d13f930530d241f409cc91440881ffa12cca8b1024219ddf1b8dab4312f2ebf3ff16b924c0eea3e4eb5c61c5aa1154e430d7bafa5835f2a000388cbdc2fbbf77027010001 \\xb758ed5d378772dae55298029cff15c18f049062372db106084c8f5f2ccc43b8e5fa921d1aecc7b374dfdd56aa82691877781322f3235adeb7524c0ce2338604 1679998391000000 1680603191000000 1743675191000000 1838283191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-194 \\xcdb1a9956b174c0ecc956e38b789da9ae3fa5fd662bc7eae5bc278f7159f9547652de36490d74daa251788a51e6a666600d37537f1c99ae3cc6b2c5fd36959a0 1 0 \\x000000010000000000800003a132073ca66e119d4ac738e41abc170aae68182a7b10089566a36e8296183e25899dfd857141040f5079659b575a02760bee6cdb937a6257c3102ac9fc5c58e0d268450eb8846cd0713a535b0469ef6b5b1ce0ceea1c6f672c5dc9dacc2793c7d87f03e1b69b6cc70424af0eeb0262991712f7a014ce3badc6731c8c404c33db010001 \\xf8849042b207449eaede4dbba5c99e0ae43916ddbb2ca2593ab27a40f021951a911813f55456ac1d7520acb220f20c6c3113806d3e878cc9f926fa96d9823501 1685438891000000 1686043691000000 1749115691000000 1843723691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-195 \\xd56545f649cc28124bed508e4b180259ff22ef6146eefd3392bc4bc2ce18d408c307a2985e87c0c87ead4f33be88a4e6ec7af7f64c820699a1bb12e2c8ca4506 1 0 \\x000000010000000000800003bab0421e004ac92af55b6a9df8e201edb8bbaeda9bd8b50dfd917b82b0bea160b21777fdecd407350baae42a918c1877b2dffcdc600b765feefea9edcb779eb99c4cacd88026fd40e4a62fe0bd929f4611c17d430dc4ef5bbc3db773b1552a4b140f2fe020c15695070a591b5f779d31f248d9ad6d635af9d0cc35749fdd0b2f010001 \\x8da426227a220c548f0d1b37c8caa472f1a11b30970159fd11175f3572bf7fdb633d19ee7109fab0c6c7d26bd560c6af825f47e8219cca4a7ea730ceb52b4d0b 1685438891000000 1686043691000000 1749115691000000 1843723691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-196 \\xd545b6fc06b6570a2c43f094c48ba5811cd1b6dbd95ceacb71f5c9a0384cd662ddbffd50def614bfb87f83abaec2626095396ae6fdf9503501518cb23885f9df 1 0 \\x000000010000000000800003c36969dc8640cd0a074df7ca5ecd81da8d646ef78ca722282d1b2a30f31580751973d1f69328894034674bca16fcd46e9e25833cd993faa2715b9d954c84ae7d3fed77f60aad95b96a2f936f382cedf9c5a8d1b68d003a88df0d4a7dbdd3e2726599cfd9ef56d60730c0a13a67673b8faceebe4473419c45c9123742c595b6c1010001 \\xaf169671d4ca6989c60e10ab0906cf6d2a198d117c450e88f1135c51b3002152f26aff9165259ac4cf79c752662572db10d61798db6000d30def83af17d2c706 1689065891000000 1689670691000000 1752742691000000 1847350691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-197 \\xd51d29fe6ef462b364bdc735ee85e95e447c6529bce734bb5324fc3a1ebaabc4547a171a67b36a85a52413719804796ce13c3dccc3dd1ec9ac921083b53d1ccb 1 0 \\x000000010000000000800003adbeebd2437c55c72584c69f6bd3623f1dcc37e40ea2349aed7560daa60b8e8f1fc510c56a058dc0fa40f2bc55128cb16765a2808d4999cd2bb91c6681be875e869f002141957bf05f8b1fdf47929eaeac70c53293bc9fb6330213c0fbf043a061353b8ffb454f7b949b33f642249a71878910d14e219ddc59e21d0895c0cfd9010001 \\x240900ca2b4c46a3c2639d53e08dcf6e7c987e2c4e317883a54e1918943e82d97b4e4646a1e803c9c88db5a75d49c6f841a04902de39789118c6ad73a962680d 1662467891000000 1663072691000000 1726144691000000 1820752691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-198 \\xd7b1513f80bf50fd31046e5d652de072721a9a1cc7b0bdd99a372bbf3e361cb4e4ce11e19c837738ac1b6e62c3c2308ab067f1c8188d8c8abf2bd05f96689fd2 1 0 \\x000000010000000000800003bf9e884aa4ec601e1957ed68ee9fcc5f42f7f729a2443d491b17f61fc4ab20fa1d315ee7b80bb599b37e7b097aea882754a801a1c89d5c1561fbc6d5b534fbb26ef90cc8666f584eb02c001e761ff0928ae880697221727af8b23b8832e52c38681c0a2cabe5d31a3b5b594bf9b02171aba18197eefee3ca25612d0299806215010001 \\xbd0f7ff28e9c0a066fd446135f53e2b10a8e438d7da1e551959dcd55212a484d0aaecccac8490655a33f8770381dcbb9c361a2cee753d29ddbf03c043d344606 1661863391000000 1662468191000000 1725540191000000 1820148191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-199 \\xd855047eab65bc8580758dc2578c7ea22f1d5933697eb5338ad081c9c7d3dc703b601fbce10b2193aacc4618028e27cb2c6ada1cc3827ce84c991ad2eacf3386 1 0 \\x000000010000000000800003d5f11789cfbddf3fa0a35290931a6ea8bdbb84bfff1e4c7cd3c04bcb68e698640d6c984a4865d75ad2aaa64c58ddfbed502e2825af583ba9a0bdebbeec502eba064c4907480e1841ba88a947a5e0d199a6fa0cac859402d7e0404e1ee8c13994bda90c7e188da04d45e29a5dc396ad204f6dd16b0e7c3b6894a3b66124b542c7010001 \\xa56f481e5e8473efcff564ddef010dc942676c65177a788cf4b85a24e88a0736a087d0759b4aaf9fe435118fd39ba4d2662922672bc9ff9e76c877578eafd60c 1686043391000000 1686648191000000 1749720191000000 1844328191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-200 \\xda45854e29f8fcbf7dab361753a0806b8efbfe3b2270dd428df59b8a6a4a25d146f329c4c8a370dba3c4f01e4e94a2c9e31e358a0146ffee6e042951921b792a 1 0 \\x000000010000000000800003a9d1edfe44851c0d140a633b25075330e6f5cb199fcc60480d6e0f6cfa8e43ddf56310a6dcc9406c27d4b91ffa637191c3ac90daaa67e1403b186d06a8f9b3486f07b842bcca6888519004da26948865826c3e2a77456adaede30c28e60581e2cc9ef3c2072fc2f2448c5147c7a07bde5f260c7dcf9260ba28d8b810c4411911010001 \\x4f68c8f4d6c188a852e0b8264fb3d48ba46e733eb2996c33f953cbbb61c24f921caf318178f21e1fa1f4870889fa496e4700c4c971bcb30c0e0e3dac841e550d 1664885891000000 1665490691000000 1728562691000000 1823170691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-201 \\xdd21f27dbb5c2f6705dfe3a2364926e5121df5ab9950f882d74e139c8003c16db31737c01a4de60158f770c995482c00751b15397f0b0597ee47769a52bd729a 1 0 \\x0000000100000000008000039cf81f4e8fdb8e665f6c16491b6ba9c160dc5c13b2135802c3b8fc9298e3fa8a4ca1efccb7527cd5c1b985214590bf276266707f98811491b353f1b0197ab44facf330b8c14683e207c705d45eb0ddfa1be53049cefe5b90b3fcef7c27a0435923d2af94215a1c1a8c45a142a7bc4b4341b60ccb77906563c518b47c1fcb88a7010001 \\xe523b47734ddeeca7878bfb9bd77185fef13bd37a3b88e56baa1e845a891491ff3c62b19bfbd495f43657f8fd0df9e715dac2fa8b92e70621dd66185b9528b00 1688461391000000 1689066191000000 1752138191000000 1846746191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-202 \\xe1f14bd39ecd16f427b34f9393b5b92ce19b4d4aed431314b02331dda0a32a8dc4964f7d5e239b175c9d621e8d70f502339f2e132a71550917920f521563bc99 1 0 \\x0000000100000000008000039eeea9e1145378adb307edfa717e4c3d623453e179c5e1ed38219bc409620d2c807675c94397abfae3b98eb84f0d1b8f0095d409be747fde431e2c962f11c54dffa7d73edeee91ab630644d70e9d992a73c7651c53f881065190678228229665850610a57f941b1e5c18184dcd32542c6bb13b7e59c2c434d22c1d89064202bb010001 \\x8f6e0373b68f74dc85db6397223be974c51fc1e103f643a4d36f98de5834e1632beb5b9fde965033c36fce3c87552e225a0ce2974738e4b0959cf32d0dff090a 1674557891000000 1675162691000000 1738234691000000 1832842691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-203 \\xe3818fa4728392ba75fc97057d4b4381cb19ddc6b6adfe423ffd972bd33d6f8b6fab9e7ab6444ca167fb441cc54b7b3cf23e855995ad4054e723d57f0d632fec 1 0 \\x000000010000000000800003bced4fa5f6dbf714e108f5e4f502763dd87f5bbd6adfb472f2f598bf2a0346dee708e8984902fa060d74bf13dadcfadbd267bf5c5a58c866edc244fbe16dfcfd95b210e502b166f089438ff2055365706a792c17d517f6dc7a28609f95dfc459d0212ad9da5c332e443c654205f1299bf97ce97deeecc5b301cfec816637b4db010001 \\xeca8212aad4991ba30c39ad429c46c214bbcf426b246f1caeb98afad3de73b21ad96f5187b4de8ae54475b7f9370e0017b243eef878a1f199bf9fb3b02c3790c 1676371391000000 1676976191000000 1740048191000000 1834656191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-204 \\xe7a932b6de7ead6d793614e03f105363e7ae23be2d3446e0069ecbe9d91f01add4ced52684334c604a82a0a7cdbe371b93056d87300a0d82ed92c184f08fc5fc 1 0 \\x000000010000000000800003b92bdc4f8d4f8d90cb0fa704747f3fa25f0c192a3dd2675aba5ba9854111d25d6fd4bbb6ca1a51e8525b921d9d513ee53de3b664fcdb3eea19ed99aeb2e466fe083e6bcf2b0a19aea88b00d582a2668f0503adca881234c753b0a5e7d7a801d2f588297b3de1e986cee9d05c236b97cd5238345e4b99f348f0d80ea184984e2d010001 \\xa6789c3db41c03b5b64558389da4ceab391ddbe3d9d7524d2928acda019b1fe81ec4c841ce6e00b1c50460dda62cc5c1d6a23d8296418e9bbe3380333a212507 1666699391000000 1667304191000000 1730376191000000 1824984191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-205 \\xe829532e2d8187302eef667fd3638061b04673f6e049b003790430740a98d3983372ec29531b346a748ac3f7a9a144f59966123d2937f9a69e1330888040693c 1 0 \\x000000010000000000800003dc48eaf6626da25a45d2ea2eb714bbf516ac1047eb79ff3b128884a92e8fe2b7d41a6729a6c1cce31c53e1ab1897e25193144c2d5661796b3bdcc6964ec268727bf44829ba24bafde28cdec14b87211a0529bbbb5917ad9a33aba9ca3177d527a1d1f95499a06aeac8e1bf24928e3aa15411468c3ce8e79e9ce7f9a5b8ed8337010001 \\x840ff8d8473e77519826b3da7ad51093879e5e6d2469bd802d89ae714aec6a9a706d901a920f4f2ff1efa8b65d9f3c7483002e1c4802b716ac67c318df39ee06 1678184891000000 1678789691000000 1741861691000000 1836469691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-206 \\xecadaa68c74b434d74db0e94669f2f34e0b11bd2cf277ff7319258327c1882cf576fb33da322ee0faa30c4c7c9d2c5df5d6c587cbb8c34484fcbe8327a6eb339 1 0 \\x000000010000000000800003cfd9b2abc29fe19ed31326d2d1660ec43c5f22a0ad6cca8aa44ceac4e9791d181558dc82629d8e64f313d54feecfb191bf192c70cc6bcc3ca0949a0f3073ed3066c38e39cfa51e7204a23bbce54af7cefa596d3c45b7eff0115d46b3bfedbb0cf68e9576bbefa5a9a7f65ae61682dfa67192d6d6885e211a918b057a35f62443010001 \\xefc26a8a38f3f9ba65b54821ed37ba76771ec5b08bc416dc40c4ef2150cd4cb7ff67e830b7b9b076adcbb77cb298508922e6217146068e4ec42593e17179b205 1672744391000000 1673349191000000 1736421191000000 1831029191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-207 \\xedc963654d31c0fdd1a0162ec940fcb96ab64a162c173e629ee05602569d185dc6cf04db88f9a42c2aee0af779bc76aa648fc3995ac327059f348cb7b1db2190 1 0 \\x000000010000000000800003c67388e7273db86ffa2cac39d94eeb0bea0a699e200831cba2365502971ef9307b301aaaab647ab0d49f9fba9e30a19e4576b7eaebc542720cb1bae58df3d9606b4b079bedda9165cc3875872d48b89f1e04543263f7e47ee882a03d361537da38b962a0ba9da9fe5c2f29b0cde8945ecd926418df226f6d502a317ba24b66c7010001 \\x9d1feecd87fb3d47bc0ae6e99a667b3d67bca2a81151b15a64231b03ebad4e8440f2c62ae1bd88acccd6c26484a692acce41a9483036a971eed417d4eaf42905 1689065891000000 1689670691000000 1752742691000000 1847350691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-208 \\xedc92375a6522b202cfe67e688f3fd1a69095a582fe6f109901dbf2484a5a01b4094cbf480a58674fcae594e3e88791caa83def259bbb08db1b311af0e88a5ff 1 0 \\x000000010000000000800003e2848d6ee9fb4b9e31486d8c087d3c9357900db5690a2f7d1eb35fc663c5a2282d7b0e1c3273f56873abb3e0c4dc893aee31508daef905ce61ae699ad13f10bb31fb9a13eaa9a169595f8ad114b200e17046391d9c321d85e3cab8f51681c13f3718ecfb16860925b9b252999e5efcb3f3eeb5a2cb8f067a621d5a9efdd95d73010001 \\x437aac982e9084cd60a81d9378abc8b6449613b1e1da8ff2a64e1e1cec15d86722615f91e5f0b27c54680e1292fd3eef12ccfd5144284873cd0afd1a64265b07 1675766891000000 1676371691000000 1739443691000000 1834051691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-209 \\xf4e98dc3d9fe617ede89d858ecbc630d60ee2b4bf916b29b62dd7d27f15661d4f62d21a087513161b4bd01055f1a5e0d316c96e592d5ba75efe9c56f90d9c154 1 0 \\x0000000100000000008000039d68ed2a678ac481789f90a0d3f15b472fa41199bca4096bc8ba75c90cfcea7d56e394da4da851ddae3ffe5402592ffcbf64077dbb3a7ee3b0527307b8f414ae27f762f2d03fc5c54253c3d8f1d0079e3a4b90840e9778a147e4d77b48570b62fcd8bf5de2abe5f7af2324f78b1869b805f92baf9c1f5c290fb4ac7f10a80983010001 \\x0f86500341143de66568a2f3de57cded4f12821608d9b9ad60f88d146935fe33c0c5bb8d013884117c501d04b1481c86fe952fac3bfab699c92399c7dea77607 1663072391000000 1663677191000000 1726749191000000 1821357191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-210 \\xfc1157a732b6086a5bf2e1f3e37c41779c4b211ccef3c7120d0df0e81d6412774ae4060f43830f7d42d7e1332d305971d3ae6d3e60e790fec058d72ec811f463 1 0 \\x000000010000000000800003b722ac711d102dd5429c3b42777d6b2ac54c610b27d6fa4282e37dad99d36b4fbc189f60cebd05e07908fe5a3e2e35489f8dce06952ebbb7f97d45f8edde950476d88cfdd025b4069907502925cbff54c730ab90b3ad84e26a7c39e29c3af570dde0fa06f5e47d1c339ae2df9d7bb91bee274aff918fcdfa80d9ddcf891e4fa5010001 \\xbe8ca51a605e117b17bb60adf15f4c92ff84f9a1f19665046b7c31ffac908eb1593ef4f8f8a2a12b69f25167bd777728e97ec7224e204801a58bc0d04723f104 1679393891000000 1679998691000000 1743070691000000 1837678691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-211 \\xfea1403272c7116f72457b843afc27050db198460565b60589b8b4f76e9ebe7342bfbb6dabf503abd511563f96ca9a9a12acbf8b179ed16c40d7988b5c1f3362 1 0 \\x000000010000000000800003d4dffb806c246665174d22397435a87b8821b088bf7891d2e2d27be082fdb006a9a9715eb1e0ca120e94ec3884127eaa27eb9ad97934fa32d81e312d5632f3a23f18cd93026ab347397f0e42328d044f71acf53a6a07203271cbd7f1978597f7e7e83726a4a99978f9eb8098eefe5bb95608b2f25885bd954e5570c57588b649010001 \\x8645541a18e53b0c743ad2959c33de9878e3fd97398e7cd746b30b8231f36f9c192c5f146d3d17d8187c31ea088d5a9c3a751720bcc827a8017d8885155f5407 1681811891000000 1682416691000000 1745488691000000 1840096691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-212 \\x02daa97c6ad6a3522f6f0926dbe1e21dc2f4fe45d3e844bc0575ddfab8bebbfba8bda85d545542bfe6ce9bd88a006765ef70c2b0d81d36def3bd5c72eb4dd458 1 0 \\x000000010000000000800003a615500e9ee6bf3b6388c56cfb3563c10cd08a91421521aa7414113c07eedc2929146c8f57155e291d6da66414c249a9eb7e66fc362f29ca8c3157415f90d554827d9cd7eaf93e949d14b09504b47d228e4075726f1617533f38438cf9fa74661356786cd1b680b6fd93aaa037886601aac11bf161a8a30a37b12601510295af010001 \\x988c1c1bdb0fb7cb88982cb2238cd67132cea74727a6e7e85a341dba141a6031a7bf926c80e080e38d50ae869063a018debdca31de9d87b2f937e18842113f07 1676975891000000 1677580691000000 1740652691000000 1835260691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-213 \\x03aec6ee276a79aa91f8daa7df72f191c4186a0353ae4a7fab73b8e5788f16093f4a77ebba6b5d3bd8a514c78bb3bc3e1aa902a95f843c4a25f73bb22ae2313d 1 0 \\x000000010000000000800003d8c094ddba4231102525be86aa1a46310595c94fd5000f256531752b072606fe47829dad63359c071835166b82f5eb7c56ab480c38d21791e57f981dfd01858f41d7bfb0c74ee2664836d925301b3b154fda277693864e54920ba80c15c688b66be42b0c040d6ca4de1dcb3468250f26fe9a1a9d6911e0afcf8b933740d90a09010001 \\xcaa15759b8765bc925779be64abd36d414df2a30111a8df8c25f99f0238e128c6e929c360bdf0e1ddc8048cb5f0bafb3bf9dd78e273dd44f50cd9b6b5e5e1c0c 1684834391000000 1685439191000000 1748511191000000 1843119191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-214 \\x04e6d01f19e8f7a84699e1a9f803cac907a2fd2c236b77d934274316ad8f74bfb545b791c5f43057d57d29ebcffd5b08090e12220cda22e4cb35cc5fe9aa8384 1 0 \\x000000010000000000800003b9b1a17cb1c3697cb05a81104bf31e4e0851a3b3b24987ad862e899a591bb978c858ce7da51bea79f468d3e02f513e5df325da7a83d93cc3ab27506e586e8bdb00774cd9a12c939f4b9326c9509c49e37651eed90d3e08d237c180a8738fbb08b7dde809fd4484b15e845b2ade01d0587f5f8e0d7059d663c59d8db863de09a7010001 \\x5a8adf92030b996cb7f26ef351938a4928c18163622b181fb5cf7b132f4effea4d8c9395c355867c616a716814b0b015d6f4667ebe6d621f188d9dcd74b3220a 1666699391000000 1667304191000000 1730376191000000 1824984191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-215 \\x05ee6fdf6df59adb516da474eeb5fda6f3692a36fa10c6b49fa93331ee2a084af792a5f2e16d848c945f58816191bc22ed2b2aca51b8d969b001d418fe360ffb 1 0 \\x000000010000000000800003c28ddf748b677d0430498108038f784a6172aed3d05df3acb995abc737a37091db76242435c6452a26b736debc7cdba19fbdd3cc4718afefde9cbaedca249f70acd832714e9ef3fbfbdb5ac26af38d18997f04a0b90244269ac3a12a0359aff77975f6efb8b7afe8a3eeaed36e6d9417fdc3b26540052b6c05b8cf14865fcea9010001 \\x96d6603de47aa02e9b485a4617eb4e00dccda0a414db28ad16934efa29de7c74627bd8bc9a48f6b3add371f889b580b5d7ea286de6f0e53040ced0a5318c3001 1666094891000000 1666699691000000 1729771691000000 1824379691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-216 \\x05f672ac7d69c8c375a612267d98267cf17024adeff789019997df79dd8f7447aac8189f3e4d1088cf5036220cb22617c1198b3d8321c05c2bcc592d61402f15 1 0 \\x000000010000000000800003afb61c618e2fe7191fa07ad4721630369b84293764c7ace77e367f01de2688f148fe3d10d86d30bbfdb445d8ef0fd51ccab7190dc5b1210bcef9fe97533e4fa023dc039d0417a5f25f42b05bcfb02ef3fcfd4720e33952eea5961ab9b563ee5a714cd2fa6febe1c2d36428f2f362f6470614b9151d4a2d15a413d8a466fda9ed010001 \\x1d5f0671003c92f4689d076f1cad889e177a254841071497daceb4dd1bca2a081427ec7541e0bda80c55be230b9aa0829b50b8ccb9c37b8b9c6724d2866bec08 1660654391000000 1661259191000000 1724331191000000 1818939191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-217 \\x062ae73a70031b74a8988a8fe3dc04fe52ffa184e218a1e183cb6586cd2bf2c919b6bfd32cf48d1ee3d4d229b90c979f34d0726025f1d644e2caace9390e3b90 1 0 \\x000000010000000000800003b8252e347543e94f71dd03ded773f63fc5760e1e92bfe864a7ea8c281899c29509cf4bdae5a7d27829007debf37f4fd6ecb440b93912c5a57f03c9485c5cae68fbacf9f0e2b322b8eb39ad044194969a52f74e33025266649136f4889b867906c87c34b46ef2879b0c2ebd6a8dca132f2f3c36c0d2a9e93f994b334476ef80a3010001 \\x960fc4af57e7cde1a8e7f71854beaf8d7a5e48b513189fdedc8083e1e3f38c3a3504fcf09d413265279b44f38c5fa125a58707b89b6b2a47b31411525600590d 1667908391000000 1668513191000000 1731585191000000 1826193191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-218 \\x087af277c683cb0fc4510f34a93a1a193f075b8806f023e06fb365ee6113edf4ee25649ca08b5b89313b2b36d6133cb9875cd78334e9c692a16111d8f2ede049 1 0 \\x000000010000000000800003b648aa6a504cfeffe75c02466fc77281f55cf2c87bef240a98862bfc13508e5787a6b8453f199cf200586a1fbbe62f3d1d0de2a41c7cbc3916e3c257af2cfb7dda117b593f038811419cd184727e53b75694372294caa7b9841b0d8900aa0c1cf45dba47bbbeddc34c7f78c80749cd4304ee960802c2b2e2cd3a4892c415ba05010001 \\x093fb1ba23b45b2cc9753825ed3debe92afd3cc0ada50d9a079b5dbe8805434651764ac057af98836b877b4270f3c0357ffbff860cdae3ca0d33624811237b0c 1685438891000000 1686043691000000 1749115691000000 1843723691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-219 \\x0de257adf8afc26a65b0f9750390c918e0020f1b2f1e627d1f540555699a10e0c2c947552cbb4033a9ae1a858a6db7eea586a4a9a8cf0fbc3465bafdc6373046 1 0 \\x000000010000000000800003b707d729b0bea28541ea012fbefb0a57a97bc6e73c190d8c1e20d6a673dd9729b87220ea011326c0b27c7360f8288767a223a63319cbe87f494a28f5c8643945e7bef6c927379a568020a4b318cea5fe677b0428270f54870d0cef98979515ddcdf5a60ee29f3d46bb06eb007e7dcde18594d70e2cfbfc822bc36ce3bcaac27b010001 \\x9c47ac401f04632119447821f8a037a50bea2e501574576da4704479a0a402ee7510ee61edb175acd298b09b291e8e57692cf4f03a72e75307426d35a6c13203 1677580391000000 1678185191000000 1741257191000000 1835865191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-220 \\x0e7abd9f150fd897858b9221e3c9a8cdce8e8f61eace27475215caaf8b6dff34526783f6c78903d11ba4293f294662b6dfeba844de8fbcc39eed0d97256b2149 1 0 \\x00000001000000000080000396f4dcd8a9b72799127ccbb4e4bb77a19fb47c1dbb70516cf9adde4e9d99d008fea36327a8bb207932c49c33a0afb7a3d38d416bee1b8cf67cdd9d02a59e84839e2f2730d663e453e5a7a59cb9b9660adc0a48333ba47ec1a175fc8bbcebbc2ba83a3d2f1952ae13aa83442da1c356aeb39efa2caeb44b5d10a4d324d29347eb010001 \\xa7d17b7ff36caa465cfab9723ffe48ebd6cf2391ef5b067a559c70f05b76cc399c9b2c097781645b25c139c862fdf0b9df24c851752c0927c93ab00d67ef960f 1691483891000000 1692088691000000 1755160691000000 1849768691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-221 \\x10220b1f5a1bc8737a408d6f7185df0f6e2a9c210df9a248c219bdd0508395cb4366b3b6d5919b5152302623e0429bfc57e78a640b7ed9faf1b5726f11ec9f1c 1 0 \\x000000010000000000800003c1af848453c6f4ef97eca1af562f39d13facf0addd3fca1849a4bc36bb622b2834f0ab6cbf56b938d12affda63156777c521e4f9ad09f396cba99781460f8b7a31a62dcb2603aff7abad91a38a32f8412bc744d95bfbba0fc14ef267a0da7a069754f0e6e185f5738e0ba436e1ac3b58a191678b86f0d724d1b9935d6a550691010001 \\xe61aabb6f362a030ddf1537d9132d27546e055f2830578b97092d5207e9c33f3ea70561f2b1c049bef24fe98d07f0c6de0387003708bbed9a9f9cae3d5c3a809 1663072391000000 1663677191000000 1726749191000000 1821357191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-222 \\x11ca6b5bf71d52239743248774537c205b8b7359feed4fce6072853c3330c8b580fdb73bb0c9248e6f950afd9a4e98297222f22d75ebd6e2c29e859f53219437 1 0 \\x000000010000000000800003c71935df1cd8f675d6592d6a0190a5b6438a70069dba88e97b9134fab9c926e67e8cfc1a5524b2ae8077333121d997d333634f2d6ef56a99f340c47b3d694c1c7ff4ca102b4657978d804ece455d86ad39653aae01c6e07d4f8aa1c976aab8aeb5148ca5dcaa68cc47b57c45f673de4a57a670b30967135f88f6e41a95367bd5010001 \\x7a10d571ba2662db57d81110505e7281ea06a52d0f055ff12b4faa98208daa5917fbe907051bebd5ce730c84ac14a8c3a595e30ca37a54479181b82306359f05 1670930891000000 1671535691000000 1734607691000000 1829215691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-223 \\x139693a2a59dd24f6bfce8c48d93fdff53796d1815521ebb63a43719cc6e272991008250bccbfef351f21d1503e923d62e3645dafb8b73b6858508e3e0c9b53c 1 0 \\x000000010000000000800003af41071eab14cd4c742443eaf7a114638d5229f61b4e28e5401d8c6378fd19d065cbf3c39cc14fedda747bfec5c5b9273f05d00402f4a58db2a29c88964a7c8cb33711283006c3bf2e0790e21e340c859897935913959b0f8ea4b2f0b18ba2487c0e5e29a74a15ae7ef458ff93bf2eeff5fd8b3999514f70725f705bf584e1e5010001 \\x552e964fcb861a8c3e196b488293ef22c5e64ac54ce12f8a9d6e654484a1f36115c6854c354f9d05ef6f663b56fb2a9748f4942b0273bb79b7817fa140be2d00 1660654391000000 1661259191000000 1724331191000000 1818939191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-224 \\x13966c6f2ceacd3185b6a41906bfdb3e3195286ef261ae2e8ed460656a5d59787e699769b2528d5d090087366694c32a186109aadd3c45339637dd338ce33b71 1 0 \\x000000010000000000800003f087957edf94ec8420b7deb9add96a2fddd18e2cccf4c77d7ced6b0eb54ad22eb98c221a52b796091f9971ef02999ebf7130fc305737f84aeaf046c6c2615383f3cb81f7c5cd6d322df6c4e393c4592790fa4170ab8d05caaffc721f7dd5483ed62357674ba190da4e41b5393c60f6621106d127350a98d7ddfcf6cfe14b44e9010001 \\x9641c781802407bd4812719b880bb7acf28d8ba13700e0f042a9e7f2c4b451567f1f43256f8aa3eecfb44f4bbcbe3ef8c186dd9e4879a43d9691701cba798005 1684834391000000 1685439191000000 1748511191000000 1843119191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-225 \\x130a0c2f37c7395e784b882555c976e0c106a61920aa56c72ddfe4ad0fca942783b49d1aa67856db4bb9e9c43460e07fad4e84803dbd1f49f058f58fb1b2bfd7 1 0 \\x000000010000000000800003aa16efc11ecf67dd51262592ef848bbbb04d55ba6a4b1ebf8926f7b5c90d9723aff370537dd14218b813b17aaa6ab46187b651eb7c27f6a78d771967a250325d91c58d93be3dfceb1b18afa90d81198fb8309ddb051f4a9d3411efee60d55e7e616897805672ae996c44cc88bce144e33089733c2406efa50e6c2c33a2c4aa1d010001 \\xac025ff50e962b601a0983d8b714b6f566232edea6aa92db1b96a9a7bbdbf4d9e9b4d8ac958e16b5f38188b790b463dac08fe018591091f18c898abb8be0200d 1677580391000000 1678185191000000 1741257191000000 1835865191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-226 \\x161a2e8c4d4d35d65c7ed55d5af1de161f9b32a513dd910a4bd65d537650442e7eb86d92c293a93db05c791f12ca3f51928161eca099d1062cd784725cc10f2b 1 0 \\x000000010000000000800003c49666347d7dc4caf206fbf8ca09d970d604e369d84dbb30eaed6fc2a7461d64e5b1de935c8eda5b4c611d274da550d686b10755d5d023fbe04f2e23033898c1fb6be6083c3270b2ebbf25ac53714f2b436fbcce59670bc672490245a499bc1c031523780eec827baa527d02af7f87ce1ba07900f16b159f5a3e54fde1c1709f010001 \\xe22c424d6479e6ea9796679d298db9ab4c1ad5175889327b9531c2b9aed1cd8417781e14c455a7d6fabd9bf7d42246607c345be90e87502cfe55148c2ef9980c 1684229891000000 1684834691000000 1747906691000000 1842514691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-227 \\x1702c38ef33bd366109b7640fea484d5fff9378bf8b1b4f2ac6bc143a71634777db0c76dabbfe73c6538a7bac74683ce3d0cd8ff91322da508a3bcbe475bef35 1 0 \\x000000010000000000800003bd90dee07b4292720dd789173c8aad309ac1c2dd257ad4630abba7e33699a1de6d87fa4c020e0e26adfa6ef3561ce56425b71f2ddaafd3aacede18d3fcbf9f18a48de3f870a8c043b47d859652f0a9ec887ef1f62dd699ae8b3bb71778f47a7e174ebf45ff133f7334e01a1bb90f9500df1d16d330b38ba9e3a5fa5cf563f17f010001 \\x1cfeb2ca5df15250f4b83bb629ea5f115f52523436d885dea04b8a28cc2c9c101483c15758624cba179761cde5556f71adafb419bb7455a25a89374c5fa66900 1689065891000000 1689670691000000 1752742691000000 1847350691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-228 \\x18ca8be45fbbc576c9880d3100de4534594836f9837f0890a29de489154248553ed3dd2bebfd56179ef058d3eb210978fd9f557803d885d879052b4bb966a0f5 1 0 \\x000000010000000000800003cff7264ebf4fccc2672de8c6da89d05b4cb6402120990ef0ef1c52f4a90872fc2ceaf4e07b83576faf9d474249c897378a9c0bc88f8a5d7962135247b2eea0ec9cae82278278a0b3a5b80ef3bdb2b46ccaa9cfd9c621ad81a8e65d56159161534edf98805f8f0b0e2e1c1cc62fb6463c5b771ed930da3c0f20ce1897216f3a69010001 \\xc8b966b498d0595aa75acf7ab2209c80216a0d6af477ff91f2a6bd6d9c7ae9a07ad771a3ac23e2a4cf883bb0368d46e023c438225f4729dee6ea0a701ddc520d 1672139891000000 1672744691000000 1735816691000000 1830424691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-229 \\x1aca5062dfa1c5d40dd9c0f99e569cc4de2337b6a3f550cc58bc0540a599136a741ee1bfa62639dd08be32fe45fe1774f74a909e8c1da6dc59385f04dc46efff 1 0 \\x000000010000000000800003d2e8963f7e54c69b6df1092fa22706892a56d32a94f1415c48ff7dc9e32515987d25971cbce6599972659ca4a07109ae49e68c69dd26a50f041d33e49f0d8d24b574f86516c9f6e72ed92c530a951a1511c2e123c58b7eefbdb5dd448ce353c21f6a108a1f7539b4f9e882a3f9f27681255725c4b2cf86c7930f92e1d1922723010001 \\xc3bed17925941dde4369a9be99babe962c8ecf3d9edca4f69cd9e19d0414ada88c73fda5fa23248fc8238d0a725d5b2710a619a31f46601e3f5dfe3a89170606 1673348891000000 1673953691000000 1737025691000000 1831633691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-230 \\x24f2f8edcd42e069559e7ed78584f1d71b2be84fefa7ae26ba667736c9921a2f6f925bf92df5fe9da8707668ee31fa2179d8b54d525f982575b9459238f43c1c 1 0 \\x000000010000000000800003b20a3e784a8c41fbffc76233fe35b28b1960197942e229d2c120379e2d17a98ce0cd2824e7b78811dbb4867774750ff94e1c6850f7b01c73ceac97e2e5baed001a24ce064e7ad06d6a6f5985a9e50df25b877f7a1089ccf08dd1f0725499c54a2043575872558208f97c8407c196b921bada146eb0032ba6ec3755640dcd96f1010001 \\xdb6fd27fe1008f9471c3dec0f8f53f5c3edc3d68983d5a98cc88482be067e1caacf3840eb1a06ae2ae66c7aa166436f56714170c779afdfd04d2fbfbe0fb260f 1681811891000000 1682416691000000 1745488691000000 1840096691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-231 \\x278ef9ca11e07b4dfe9ecef86c4a6f56b3ee824957841de6440492ead520ef7a8392bf199797cfca8aa0e81e28ffb86fbb06e476f0a9de4cbe768adf03f1f892 1 0 \\x000000010000000000800003dfee2bbd5fc3e6a28ded434a0396dc4b44522fab1ee8038116f87c5c9b6727e91ee71139a471ce41ebdb8575d4d824613566081aaad2aa6d4a8b2c3b2813bd46d15ca153e41f67e5dd38335fbbea9bc1a7ad31997b199441b5c40cdb2eab2d7cc5727fb90de62485a69462ecc9056285417f0fb9dedf0d029d306a13b3d5c443010001 \\x8c73b2c6a55d4cf4055818685188c35a6dcf47f6baefca01bc455438c19106d31ee340866bf4cfd88a6709c1ec804256e67b68d33138f5e89973406873ef2608 1661863391000000 1662468191000000 1725540191000000 1820148191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-232 \\x2a62aab42a1fb09307064d55d62157604c739e19e0b6e9ab8af8d4c8958f42029003b9e70c9af1d94d53e63a0aaba33fc084bb04a892e82bc96544f865531630 1 0 \\x000000010000000000800003cc46f12224e1b26d96db7ee9d6deb95f49dbba253c110daf8127279e17a6045f3654865d084a097f94cc22361d1e295582f2293f9f9dc8cecbe33018c067024bea20a8757158a723f438923f963206c795fada0f1f8a174f5610978c9602bd8bf0646d6095504a8ed54b02d48aa75e0df21dc136e58ad1ff01b27037c06ac275010001 \\x334321018260e9a0791f6a64da0b93d5636a76e1d4fc6ac0a1eaad4d02422ffb2b6bd7aee45059445141cc925a8acf5454d9f450ff6c0cd55dc733e6e699ae09 1669117391000000 1669722191000000 1732794191000000 1827402191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-233 \\x2af6039a0e7f27012ffb1366cee755a7283827114c2c97891291d8f0c3dc2b84e1801194e85926073eca1e93114b74246c6d3e40a58f582dd5315454ce9b20cb 1 0 \\x000000010000000000800003c6857ce393e4b72608c040bbcef3975745da103b8acb447efd9e275fd6001c6842c046fa2a289102946239e41c000ac898e322c22598a98abe6fde5ea500370bc793c9172e482ffcc204afc145715de42ffd2b65a6ac8013c03b1ba5a6bcec95d5ada8e21768cbc1a2820cdded6020b572632bfe7220c0db291ea0d1da516e97010001 \\x055e5f953f975eb18517ee2650c1da25c746418d34183d7622152b7ca3e6dd345eba2f57368dd4d385c600273327c73dc10bc345f66712353e0f7fa5b7b8e80b 1664885891000000 1665490691000000 1728562691000000 1823170691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-234 \\x2abadb4c74737366caffb3da9d7a9c449d844474e727d06ddc023fb3e41abcf68113395ed259b0aeb253e90e0e3232b558535fa1e927d069c58cce09a87d9ad6 1 0 \\x000000010000000000800003bc19267ac43d27b2e47dd745cc41009e60fbbdea2daf4de5715b8740a192326c614b963872f6653d42c5da5dc28fb551992f71a4d0457cb10d1ef7cec86370e070cb0f32c8e2f03c9c6c8b2223ce7258972bfbee384d9e951e7e22bc1c7d8cf62d761c3ff198ffd7c387027cd78ff1af6e31ebb60a187b2ea913c3d402bd1193010001 \\xbd47f07ebd293e275e8a8054b1d58b6565a477fcd6ad135094bd2abf7413e8872a2b905fd185a60f027d472eca0f9650c240f3c9b65c0652576b72362ae52303 1687856891000000 1688461691000000 1751533691000000 1846141691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-235 \\x2c4e57569767675118af4cb51f59197faf8bba94161593ce182c1529c2225200aded9d608efd68cf57ccbc6681c0709ec7a1d2dc74003cbea63c1fa1d6ebf401 1 0 \\x000000010000000000800003b7d89a3244588ada5424f4691359cd858aa1622d0aeacc948d6938b2a05db1f7af7c10d1b1a9445d0081d802637c745c919160147c263fe925c2d442a0c262d4806c706b3b42e906a720bc2018b20b3500b31bf17713392b26fa35acb0da0ac8ee535994cb6d3a781030df894aa87cd4069fa94964bf45a3e4c88de9347a26e9010001 \\x38172ac2b0b38763c00a7de32f78c601752227431d2c0f508df8dc30bc4b4804b61c5f680a5d67e32a7a63e016c38493b0a46a257996ded9f5b3b6fadb1a690d 1674557891000000 1675162691000000 1738234691000000 1832842691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-236 \\x2f1af6f88a6cc1e8c5f2fea3cacc465c32cc769cf2a32c20d7746a3052050495b09496090c3610ab12c04777276d875bb7ac396dbfd3ede3702304ee0cc2b79b 1 0 \\x000000010000000000800003a3479ab1784bb193db20c8774c412df4b79bea5bbc5651db9573a66f38f25bd168a65213dec270bce4a4d101f3f758168f1b15d38e3223be3d80eaddaf3aa70a9745908d22209ceb311dd77fd84353c587b17c2972fa6c9192d5e8cddab46d448d08f7fadb56d2b8b762ca29c8dc6946177b117a74f7c05fd99ecc880bf479f9010001 \\x5f88e77e98f474f2785d001a005a6ee8bd1b7ce9f890a2aa0952ae5ce48106db5845a6bfc9bcc4e9aadd7f85d35c8700702a28b441e87e8a56108d63e8147b00 1672139891000000 1672744691000000 1735816691000000 1830424691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-237 \\x32aae91222e4f626b2dd6f9b7a32d5007a0214e4bee506dbece6e3382f2c690eb517f92e6699f005657f9759b88ada2ced52c88c08fa5781d1623b0ae4fffd04 1 0 \\x000000010000000000800003b777cac8397d80a0b71b66bcf8933bf8aba2a008c3effda4da24d24dba75b691f59706eb7ae6a030a3e0fdf1c56c99b1eda47c60445a27ae3517529d4025f6779913f28e4bfd77176e1c2efe4697ab946d0ddbc67ecd4c8c653cb5e82a198aaf8e29699346900855fdea5028a0fb1d87e22a0b54af5896c34c1499a37a0f9cd5010001 \\x56589311984eaf07445e2d08fe6cbfb963e451c4323f4df9060258b7956748c827a888defdd637aa9654609d93eb9b9c75044ffc96d0e0905a3f57df06054707 1665490391000000 1666095191000000 1729167191000000 1823775191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-238 \\x33ba049942a82b48a066acaa9d56e07ab23972f5eabcf720cf9f56263946f71a80cfe1157b3112ca12de21d26d5e46561990f3ddd546e41033128029a81559fc 1 0 \\x000000010000000000800003a48931209c971efa58017df57c87043b6dee06f69331a6af7388d73ec66ad94957d17f171233f3881d7fabd5b4fce259ef90d1e3d38a4076ed82caa6646682ea9f2eeac4fa5b9c77f66e02bb53cc4b36a240c63f468f8181dfce0af19cbcb974a9b388ec017156a121926b48e20c87ea44a95a1937ec747c1b9adaa702d1edf3010001 \\xb39405e6e62255bb2b4929f8c3c2ad645f262b96cea1a7bf3b160c1339d5c251768b69b48a6864b67b55d71a5f8805653aed913e5805a5f0b6721c0b63af6006 1687252391000000 1687857191000000 1750929191000000 1845537191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-239 \\x35820812f41363f4248221046ff48da031640db462a69db35cf70dc8786978955cfcaf19c6f3487aaa12800f653569125806ffb969a4349db971a7766c3a0117 1 0 \\x000000010000000000800003c5a5c20acd50b32da96e479d95d755765a42761314f249dc956f660fa035d35baab5386fa33ba956784b49510897f62abafb2d4dce6cc5c8769bc125e06629162415cbcbae518af027166e7e0685b5f3899803fa36673d649ca71077a33339e68532163490df0ddedf525d940877055bbc1715ed6562ebd5a1c15ee602aebbbf010001 \\x498c261d95d5263f6a3a846861e2de60e8cc21694ddd3662f238ff2c9d7d66ac3ca46fc115dcfb1025558c4d5c680a32ac4c04b45fb752ebbb5c5e11821f3b05 1670930891000000 1671535691000000 1734607691000000 1829215691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-240 \\x37023805e4d2c7882d76d9ddb9536674d3067fe3f77a2462950a6ad6607c76f51de4f9442729722f6a23b41b71824f60917d01f2df68ebb333360dd49ccd62b5 1 0 \\x000000010000000000800003b61cbd6dd32f03535a453d7625ac51bf6fcacc6f579fb69b32f530cd64e9e13fe27ac05da8441b0ca194892e48e9a4d1b433d0a5f055e53b59c933abc20de5b97769fd7ad9824696d5df741641db17f805245e8f42a24aaf9ac033ab25ad763451f689f42c32cfcceae7eab99eead3366937d9a3f33c9a491356cb83b747c77d010001 \\x137a105ce8bde36ad83eef902e5c470ddebf5e65d2a313fca9ec6cb410a87b11f19dce58acb102747f3eef4391472c583f75cf9d0a1783ef13c5e9348ba85202 1664281391000000 1664886191000000 1727958191000000 1822566191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-241 \\x395ea34609e05b76d523f29a740a0e5edd6e512b7ba9d45275322490d98647b58436c60c36bbca11387aa4d54f2fbd213973dac59ce1e1d215e004cb13393bb6 1 0 \\x000000010000000000800003cb74daf23524cd4f6cfff8f5dd8eb0892a0d705b919581740437a93209ed3b4d7ef4de661846e1425c5836193c57f8fd50fecf159a3da62cf6be367c52f9822d41b7f51674234e493d8f99703f0b88af83436264606d9fef44ac33e2c6c24f7743b9bc779f6843f658bb9a5673e55a0a50fa72bd1c7f243784711cba69df472d010001 \\x80726e45bc0e0e7c55e368a2a9c6e4c96d0dc8e683e19c8361a3ae9b21121907fbbe9c820a4f2612e7f0c5155d26a46444a7b8ed707e17d93012c2d798f86a06 1664885891000000 1665490691000000 1728562691000000 1823170691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-242 \\x3c62f2864e8ac12f6570d47d5b1cecb97ce40ef38bf1fb75f4509132b36ce5cba8ca2eeb0645dde434fee78f274e56e44e7adecbec9383cbcd53585e25fe8d14 1 0 \\x0000000100000000008000039ff335162167f0b9f3fb9127820a2f55dcba7e9b65c61bc033213b5726a9340f9211705a9a8a729d60db4e4ffd7deb96d1199735b325f244319803d8a1c5e290c7e5c7333cc7cdd1aaa3012ab13492fc82c97ef0136e1d207e4f342f944afb864bdf586c7a56a7efc6faf7d3e9749580e3b161f03290d618a1742c1bb6f6e371010001 \\x068d6e34370b40e0e19e02cd9c04aa4c31bf3af1afecb48368295c1bd084645f346f2b62073af10f7cf6bfb2fdeffc3e38634214555a0a4f315ea73f80f4ec08 1691483891000000 1692088691000000 1755160691000000 1849768691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-243 \\x3dc2d2806594de63bd4f88e6b47a7030231e5c31cad6fd439a3031049e425eef4a5c37500d0637b9dd4d184b0189859f3b2ff9f9b31314978a70d426b67a3926 1 0 \\x000000010000000000800003bf4e7453dcaedc3797cf031ff5c548ac5c5479171e9462a54ba76b0cf0f6a38ff83e82a8a614b5ea795329bab46d55b75c0e11af989e3391be7b5e0bf5c2340b395c0f6e72d6f0d08d4cb3163d6792db96a536c73aca0df8f26ff2ea38334ebf90be2d2b9ba0455a08c035d65d5c18bd081e6c1f2c4923262cdac39017668185010001 \\xe556aa46ba1fd0a7863c429bf8e237868c362183cc81e64e4937766448c742dc706669895f6cd8ff50f31f579f0b1746497cef981da7603ccfa38e6d95bb4e08 1667303891000000 1667908691000000 1730980691000000 1825588691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-244 \\x3d72ad903aff509f19bbacad1254a2608b247792220c64c28029c6ffc3d2e29ee4a8f135ab99ed46d0101bb69c5ee3ca44651e6e67ac27d7a1c22d80cf9d28b0 1 0 \\x00000001000000000080000395700b0051eb9e98aa1233be0c0373bd84ee9f22eab6121f8b943759d57115167d5059663189b2e1c73b44f1226fffeac92564aee9f9b4a4ca238d3eea33f116daea8b6a53f7beb0ce367b8ceafc83317469818a8a8ec15027d410291485e0f5488796e09bfaea2f5d74e36972254a8693bc312087e0cfb912826233c81198ef010001 \\x23f5a75e4c7fa00e147251689a4cd73537a4fc71294600275cc898986c68feb4ea349f2c22c69a6fad20349d1d58635922486115b9d26f92ed5f3bb6cb4f9003 1676975891000000 1677580691000000 1740652691000000 1835260691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-245 \\x40ba4854f2030bfcff2b7d5673a0694b7adece165983d8d7d7a8696a7af36f5ff34aaa2da19e7126aae8651877e1bb8e196b2f26e2c8c72a6152fe2ba0429801 1 0 \\x000000010000000000800003ef30bc6e7b2b7f61c613b17c8f1963b43ee69d0eaf95c5e8830206687d7372a76c4bd0fd6aad037d9a68625dc779b4dc22d7dc640324c7d3b4e89635374a7ee4dc148687982464603668765a7a6884082360d7973eca0e674da07d8048351434c9c4143204214981b8e60b52be1c3522c90e74895493ae4a81d0c23c0ac72b07010001 \\x84ce3d29c863f0bcd7e35edbe8f8b86bb317a21314a13e205a81cfba0e955d42cb6e997d2b69cfb7a2df7d9d6ea119da2440751bf0410272d5255faded72d00a 1679998391000000 1680603191000000 1743675191000000 1838283191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-246 \\x4112f75eda90cb7a53559ffe9789d4e6bb027567f9f975e07eb6135e8532c185eb17ad4a3490ec97b1c8e06ce8dbf419f585756aabc9d5a12a03400ef041a8e0 1 0 \\x000000010000000000800003dc0365f5aa5843c5b1a5a418a8bcd40c5f3e6c0542d945d6957665259c3512f5e60686baaffd2564495620d67412ad351e1649a8366b462f785da1a5c9d765033d3c22a8b415010ea2f2fa0125bb0f3aa690d9321ec0c4965e8064d58f9f92f408f22aca1f06a9fb13d010d453399dd70bfe394bfbb7a7b88c8f0ddd373a41a9010001 \\x75d83a29b475c867872332c6acefcdea2c59416db570736e38a474c63bcfe6e0639fb053fa1fac4ad7038695dacaf3664b09372fa403a7a2385c508835484503 1664885891000000 1665490691000000 1728562691000000 1823170691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-247 \\x498e0e9ac007b6de4e1b3efaea35dc72980978b6eef78ac4810cf7204d72b15b105882bff7a19f6e0432a073f2d14ec06ea03019464fc8620003b75e8771b9da 1 0 \\x000000010000000000800003d42b12079549933ad3c4166a22e4c5b31cb3dee2b52656c2687b591140bd03cf54587a0f0ee6c2dee0935ecf7b0914d1f586eeded9fb295d31db39c339dbf4454adefdd1acc0db0676e4e36074e9458eba63aa27cf50b384287bb557e1cd532f007ddb6024ea69d0701977d4ee0ad7d4ee355671dd08b5443875d8c90e4faf15010001 \\x3292a3000dad12d776bb17f961520fb9ca9426ce475092b5bf1bbe8b5d6e4ea05f12b8e14a6ac09943eb1f6d3edd20c0bf9128cc87ac34bb854bd819575a700d 1681811891000000 1682416691000000 1745488691000000 1840096691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-248 \\x4a5e521089587e476ceca043d85677ab7171004fbcb8ee20da1d822eec69dab75c76655af03686d3be1e03c01cc349b60ca041ef811881f46bff66d823c4951d 1 0 \\x000000010000000000800003d56114390663735ec59824eebf577bde8f46a9016a3a6a0b343b7c18fc3779f1ed9314ffcd0aedc5d142becda528c11d0276dd508aef6c54156b1344514598f7ee2fe21db2895c670652df0b896d6c5779de3f76fdd4782ff1acbe9af2c9d371c0492714104735ad66f95990536a689455c26fa0137dd766fc2f7cfe688faff5010001 \\xc5704311299242930ae6c7f0b76c4f132fdf93b97ccd1a3e742a4de21395a545e9c85ddb7632975e355b0d35f7d38dada068054d414cb4da2beccd4d15728801 1667303891000000 1667908691000000 1730980691000000 1825588691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-249 \\x4cc220dc8670173c150a160b44a590ea75c62e6129ff95cbfd7992319b51e5580923517a972d841ffb389515fe5c84c8a577de5ad696470d5a87a2c9e18e92de 1 0 \\x000000010000000000800003b945b5f71798bfbfcba4bd340f1883f248205f0007761a7515414f6319de1f4d5c6d9e2cd454399f262f215a14a0ec78147b015d25c0ce6bf239397a09b78318787d47bb8627d2630565cf60e59e27236780cdcba5268a1af900efb2501609be132de3803a5c1bb9995c5bf2f5e52d10b8c3c3760567e05a9512295cb7fe5ea3010001 \\x5cdf2e98e65323144f74c7c94523244767e82f6cddefb86cfb6f06e731b060bd5a6abe62501a456da7f8124c0b583b16fd97729a3d413ba4c183de31f19c380a 1664281391000000 1664886191000000 1727958191000000 1822566191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-250 \\x57363780adb3070867565597cf589d73c11100c57221fd82106fb25a22b457340c3d5f751c647338570f9b65485f694ef755b732b949988ec98c0de20d623647 1 0 \\x000000010000000000800003ae50465515062db42e10f5b19db895dec218b15cd748bae9b0981eb5e7843cbb490fbb0dc96c9e08545031c41661994ede8dd8dc98b453dcd8de9c50fe92b3ba912eeed10b3ed9c944dbbc64f1aabe9ea825da45f10f3e3c515f6b442125ff568574a36bba2eebc697fbbef2df9e10e33502145b245bdce9c0c5d466a9465a4f010001 \\x7682bee19f1acebdb14f83a10d26e2406c1161c50a3a01becaeabd99b61799a3f5d5587fb55b3e7a48b42d9dc77c21e436a15b2f5fcb7540e3fa2150d4135a0c 1684834391000000 1685439191000000 1748511191000000 1843119191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-251 \\x58bea50b6fae2880e7fb79ea9fd0eeb5a7b9a00671a2b1f625740297923ddd0d5883b35ad6e7fc5f7433f822b40010ce04d7dda6f8e9a549ab24dc843232ddd2 1 0 \\x000000010000000000800003d8209e0f81d5ca3e950f18dff90aa93e1ed9d23becf94eae719e26947c0c45337268a6997fc5ab98e90fbfe363fad8b2d7f5ad1ee9bf00b5df97b55b341426a83c513040e3bd6b038b66c5fd1336d09b0387097f79f7c49a3b25ee6324eb48ada039ef37f896cebb595ab46ca9abcde9276dc2e308eae4bbd4c9e069cc807e49010001 \\xfa4742921211aa15f7cd6a1e3dd5272604d10119514d3a0bbb481675b5eac789d2ccf353b6e71d0272d68fbc8933c97c171ab1d69eb6e44348d5318e9b970c06 1687252391000000 1687857191000000 1750929191000000 1845537191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-252 \\x5a0e937326835e9303b32a6fed859cb176e21124c203a397c33b255183c8fd99be34dfbe84fac8e1e6b317c87e9c93f96b086d5bd87e8138b847037ecad14ea9 1 0 \\x000000010000000000800003bf1b13b776c3360822e9841826dad84fa4a16c7791a724f0f94e23791e0df5d0a6c46df34c6ddf5acf2fd3e59b5e3d6c60a78081525f8f479ea3b77118b169212470e2c1f9e548f897cd554303ee814caeda0a73bbff16cb739c327172512b8a4f3518360e6b704cefdb4bb1bc1d69d9ca64662d6c0f5a5da3002d0b921c96ab010001 \\xaafcd77f6cc8ed4e1409e755fddbe2cdf6980462901b3d812c078e04f5f6faa9fda36275e4f21cf426d47de1a9c380c1652647b46b5eb53e01e0e7443c324a0b 1661863391000000 1662468191000000 1725540191000000 1820148191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-253 \\x5b1acfab57f60b007e5281bc9617d7c96009ee12108420c935f4555fde71653f2776ee352130bfbcb1740a67bb345bd8041aefc24425e7139881c20c65e23958 1 0 \\x000000010000000000800003c99e5ea4aec0a8338492150945ff0df1ee772f9b5247f982d796a4f0ce81cfb3542d2311394046d3eeb05849f659c50ef9cc6833d6d598529290a566585b13841d3f96b91147783d2054bb9eae9bb3424ffb7b4d99327e80f909ec386f6854c1e43968b4cd04754ff8b6c58384bf92663d4433e8c964d3d3e095598a099d4b69010001 \\xc102fc47bfd52db6b19b67db2341cadc136862ff2f397e0441f47591b322a9e309d872b91a3239ea43e58eb834c772c926b0401a27b95d75b89e184ceb442e04 1689670391000000 1690275191000000 1753347191000000 1847955191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-254 \\x5c529e8e80b60bcbb30a86a3dcbbd40cde5bd9a77104d469b622f0327e3389cca32ef33857727b3fab90727c49dd08d6beec6a209320c46ef1e00c3391886cd3 1 0 \\x000000010000000000800003c14ce4fe8df605a6e0eec8fd3f9f90e5296b9fa8f40afa5d41688410db9418bd2a333a688a8c498221ea5fd6754e6f9657ba05ba1db3c052b52609aeac3923d22d135509c62d39f70364d2c6b59dda8fc3d99eaf763a2c5e35c4a50e0ba22a71da2f7bb02857515ac453173169aa4b175b35b583c2688fb8933e6120bbb99363010001 \\x157b507d5f0dfb325a093abf671ef62ce0ab0addf76bab7c6ee637895b2a911b4a9306633f528b722b7b3f358618d0405d3f6bc2fda46b22b4488ead7dcea505 1684834391000000 1685439191000000 1748511191000000 1843119191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-255 \\x5e9e816efcdde370b92051d53453b28f30aa141012389de6a336c8a61a4fcd7055da301428cae1be0417515b7e3ad7338eb8beb6a9fff567d4174e59d7aee39d 1 0 \\x000000010000000000800003c77ec3dfb297b0dfc685986ec1dc69326f228ea823238c6cfbe491724707017740cb8aa69c1c5c1c252526f4627265b759d0d5b4ba1ddb8960a2149391ca2464c13524445212fa193b61412242f76a108517430941d4191b1877e37e6198539706102d95f4ec0bd4a507dcfe0aea402611a5036679407786c190523f0c690ead010001 \\xf63ad5a2f3b37fd9a68eea7a5468ee53a0ac1350e9137de698fc83d4d99234acabc9c4754ba52b664f2a15120f74228add8f7b44522273f827d33394969ffa08 1673348891000000 1673953691000000 1737025691000000 1831633691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-256 \\x616aac1e7e5846e347a02cc304cdce6552350423f9e58b74ff268568a760b2e51b9b55785fed2ed0316ee7ca6e6d8482bfaa4e9c8a26ca0a0888eceb4e163412 1 0 \\x000000010000000000800003af8c68be9b119c485566612ab75db59478155a3da2f2f7391c3ce54bd674ee3ee3d12eb77b88d4bdc8c0233e6b652b76e1172b2721ac7578f83987051151d7c5adf4cc1c7ebe06334c676e37e4e31cf7db44732f6e8e66114e129a9f420a7aeb468c00dffb694060e6c44073d6491f1053be56587e626746fe7f5a4008da757f010001 \\x6b66c8a5b7ad96f06fc7da6612d7af77ff50d0aedd7aab9b06ed84536acef5bf70ee8ba2c40fe85099d86b5daf6abb4413c49fdee18bc050ec5d33e4df550a0e 1668512891000000 1669117691000000 1732189691000000 1826797691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-257 \\x612ef4639f314a3a106df5ec310eea6d3d7ff127f0061b7021a67d8025f49eac1183fa5edb3efaa2be2ad252fca99ab93988271d5a49a2dc16192ecf043e013a 1 0 \\x000000010000000000800003f1497b329812a65882db234e4e9463ed535ff3a5f54b309db53e95a525daafd26144f7bc888580fae603aa815d49dc0f1deed42610db6dcf98a9bb38fe9acb3e5307791c5e35295eb6300e7fdf555ae958c0ae2338be2113c9197fea37c15526610caaf755a35946874cf2c2211ae10e109db61e062bb22d4bd14b744529cc2f010001 \\x68cd048639b284b0ae54aefed15b7eb07503c45887c5ca49c768df56365dff6b63410275b94fa673fe024a01759ac27a7e55d14453eb99434bb9744c74b1b004 1682416391000000 1683021191000000 1746093191000000 1840701191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-258 \\x6116db3337bfc1ff95ae9b48d00f69b65a67650a94e7bb9128a0de2703ec907b901e8baef026b82016f487141faaa9e9998ee181dc452af875f42f057e89873b 1 0 \\x000000010000000000800003f384dc75defcea71fbdb1d0de405f44f35ef1549eb3e44a21f76d2fab5e95a53c586f7035f6d5225c551f4504681eb85c2da661198c7190a0d3fdcd47e088cadca3cc3d093524cad19293fc8f797939cb32086bed7991f1081856aeac602a575c8c5c8b0c3f9e1f0d2c11fb716c93e990af8538c06c74953e2fadc997ff82a8d010001 \\x60899d15abfbacfc9974e512c7bd40e476b678864e0f16a84370226be5bd86d3083d6bfd2e4505b33dd59445690ba06945a4fd943998764c61ed1b6aa20f6306 1676975891000000 1677580691000000 1740652691000000 1835260691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-259 \\x644e0fee5950dff9d9ab3b923c1b125806dc65eb542125a551b0b80c36f389f762b807494f4f5d54be8a68ea2f7a1ca13397ed69e273695da03928ba9313931c 1 0 \\x000000010000000000800003afb3e71542c5907ae5da6d0103472b56f5eb0ccb19eff7a7e6c18bfef0be5701fd8e5bfa83f1977d8306199e5b351e2b33b57fc4d8e698e7678bcc50e695a1731cc1dd8be8a58f90bb8294b47e3b86bb5b4883e5030bc213ba5c45241152446e9352dc0a333016852e2501444b64c1911abe16dd51f46af8469e185db82e6f29010001 \\xdac98045a2c1144c08ed27503ba85a22b8d57022c60975d2b592b4a8457c2a3375986216bad708bbabf05b4b60d36315046ce151f689f021ad2f71d61f5a4801 1666094891000000 1666699691000000 1729771691000000 1824379691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-260 \\x65a28bca96c37384aeeb21dec4a81d3b50b4bdc26107e11860bc1903eeac95aeb77f1628b27ca728313f4a2ce7f6d70f0cf9ba10c4762010ccd1fbd4102476d7 1 0 \\x000000010000000000800003cb9f090c26e53fdd8aed7052cdb7bfdcde5981e5861e1b6325660d5b7302098a25dc14e6c6665648bbfb29e4bcb7c72db8030d713fb111b5fa674d40b41a7892217c9842015440c08cd7a11e635fff11e07fee94738548db056ed4db156e119a4d677eb3b22dd9013562cdc032e684f79fec53d36ef1e40f40351cd90261caab010001 \\x072d328a595202afd1da92c9860235a19b1df591fb62d787db067f767583e5c262407bf21d15911cf24ef031594f2f04ecb5b7da043c45e7819653114704f70c 1679998391000000 1680603191000000 1743675191000000 1838283191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-261 \\x692e314966dbf25e3aa7e1ff35f13f9786a4ccf4245cc1cb38b5aeb975a4b8495cbae902bb3c3da398437c3573bbdbd37bd8db929aee907b1c18194d9e427dcd 1 0 \\x000000010000000000800003ce09d7b4a580972e2a9613cdecf3e590dc6ae33462e5d8c4107a32ccd5c7d0362108800f8bbe427b7a497b26dd70bbd00974e6e421ee6f61af7935e337e06cdd1feb0a38aa219774c1cb7c3dd0b8abc129a0c4f6441722641dcec259ec6426a7c5d66b7a9ad111d52b9389733bebbe75d1448b45eff24cf6f500a9d5d4a507e3010001 \\x5e684bd267ea1f771c892c55558b11a0c44dd876176f62b7087c5b9cffc24b79dff54775fd139657cd2cc7fc52ed4dda43149cfafd6801f78c2179d747f90c01 1671535391000000 1672140191000000 1735212191000000 1829820191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-262 \\x6d8e07f5332e4e5fd5709cb5fae14a5f287b86cc03869fabbdaa9638084a3097477072b8044edadd7799b9b7d09fa7eea72d723582ac2306fd6587a8497a59fb 1 0 \\x000000010000000000800003f8c9cbabf97e9c226c627baf6d3a19e25c5d3011878230e988219b298128bb940e5c7a3424e2dbf0dd7fbaf1d244c04081991f5f206495b80d7544eb00e2c28dc30e1e3847f022247e0c6ae96797dbc507d04d09312fe00b2ab350ebf209450b2acc1699d1a9aaf944b8176a8b1cfc1883bb837dad96af137db5b327edfebb75010001 \\x8a1085cc52ba14c6cdc7fa81596e85bab9c343725a5afacc7d09de13eabee6773d763fc8ab43ab8b551775311d063f83d0e8a66691efa78ac617cd3005c0d30a 1663676891000000 1664281691000000 1727353691000000 1821961691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-263 \\x6dde217ee359f1aac8e3f967f1359b0ebf69a0e01906cd15b0285deba777f500441cc5fc6ae4cf2b33ce853747df67c2ad386b848f447ceafa47ee5ffa62220a 1 0 \\x000000010000000000800003c99ad5ea507ecea692c9c7b8057fb837ff316cf9da2997c048e0555c9906879f653e13734b2ad6680ed669b4bbf4394cb31e5a188ce1916021f1522c05a2cc77b42fd26428c260641f9d337fa53b091b2db49bef0d5f40368d9c3d8bb397217711788852adab0def20e6f12ae66b3b184cc4d136af830f755a5e4fd700ab3691010001 \\x02ca7938214d800305288bccad9ad1b2a174da9fd472216c0342cdcaf0dd50f2dba4a6f44a81fc42265c992a536c41ee025e383cb1c6e73f5025bf669daa280a 1666094891000000 1666699691000000 1729771691000000 1824379691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-264 \\x7076a760c39c790f05dc70cb98aa1b02bd924ac45ccf0b013bb7ea4764f050d15b4352aee988770685df4ecaaece365daf7ca2ebeaf0b047fd2f51d5729f06e3 1 0 \\x000000010000000000800003d44344ef76f1315a67d25e5e5ddb825bbc9a0ecb63bdc17d32ada0d4c44344f1559e18c62183adbbd683dd37027dcc9a22dd11a1012ed8ef8c99714c52e707133ed514fe90f02f773443d485a3c9dc08297e1403413cedde3daff975e8ff98249836c73293d900ae4c3d427377c5d059bdfd3528de022459cf8ef81f00656ed5010001 \\x67eaf8531ccabd417c55cb3c8eba8dde1cae1b0c6bb6d0dd8a9187bdaef5c62fea83dada24250cd6709e69e2e3f2c2c3ae0c2c5892de6cf52cf48100ba211d07 1688461391000000 1689066191000000 1752138191000000 1846746191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-265 \\x7416f11e9850af94c7d7cd3600f674b4c4ce994a4f35ca790bf4363163aec3dfbbde87dc732205cb3ccd1ce8d45b9fe2055cc3ff3b2536b6aac5b3177651840a 1 0 \\x000000010000000000800003d3dc49bbefc94483ccfa0ac542249e3f35ed28d9ca44d31ea3ea744b31ad1c26a7642cb0463c8ba1396bad0a609b95d7c4ff55d69817d79c5ab3db3e6efd8f0f5f69fd77ebc4d16c1a681ff8077ba36c76540b4c8b9acac59099bcc8abfd30f08a1d56ef6d7f3a67fffb07d068a490ab12d7936ce2089c6383293960d8493e47010001 \\x301a6db0762b302f7ceba5e3e783f78bca6a24f7ee019ec7ee9c6456d2ba24f6ff9861acc4e7096cbf612c7dd86ff1ae206caf5b5f036dff74edc6266f801306 1661863391000000 1662468191000000 1725540191000000 1820148191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-266 \\x7aae7bb32c154a320d8094b52edf9ff906638095e273592eb7068d71ef3d1b900b030eff349543efe6a10f551a8135e40083460839731c4450a8b13ee675f51a 1 0 \\x000000010000000000800003bf4941fb3819f0ca11295c91be01ca348eec9dbbc8d5a54b260657ba4dde14374a1b171b61b70b5cfc2a736c501a1879a4aaca54f3c1afc5a59626182f9bfde28080ff7ab2ddfc4eb22fa0acc6d866b6cb5f05080c1ef5a24a9423b093700a27e2ae7e62bf1e8906f5245d9a07928e9b8d302ded6b0214bb928eb2b14128d00f010001 \\x7b031abb676b21445cbfa79592be62c45153f08ba949009aac0b8475229a1be3340f7f13353277fbbbfe7ffc33ef08c1d1d4fdcdf88b3d6a0b682aca7c2b5603 1667908391000000 1668513191000000 1731585191000000 1826193191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-267 \\x7cbe16abf3ec28c9bfdd0d8e9f8324f61087842265e1685db83d7797ad6baa0c11ff59bb371fe7aeec863fe202bfaeae35e0c0d18fdbc7f1f0189cbe795a261b 1 0 \\x000000010000000000800003c994a0b370a796ed27329da7efbe1923ef6176ba63edfd5ca354e00fc142843723a19bd93e93c802ff9ab4dcff4e259a12aec88a350d40f81111f2b516a8405faa190f7df8fbcbe1d0add5d14e1fca0cf7ed09332a50557a7238064c30f735ec2df3d228633396753b27cc4d1031b8447e1946eff26849c58bc093f3921855d9010001 \\xaf8c69cf4ea6b045c4c9139fa44d3d3a1419a9e77f2bd906e43b834ebe615cfe29fa1ad521d074758ae615c20398670cf1058bf9560371f3dde40a15a5f1eb02 1675162391000000 1675767191000000 1738839191000000 1833447191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-268 \\x7d06602c12cecadfd8896a075267b20ad3fb5e60be7e18cdf2b7e68a021d0a4052a10cf1c2f394ed36c853e657ddb9693521b2fe287d2967008efd2410349df1 1 0 \\x000000010000000000800003be521cbe64f0a3c245b587a0d2426415f5a93d59771125471c338e8fb5b8e5771ebc77a426cbb58a2e378d9285c63c900a77f53d02fadc2d91390d32a38a854fbaa40fb58b8b500ce22ed6f231e5d1f2659092acedee805c078a85ea67da911c270c946d68c3cdf5633f02bbd7809f20915dc3958cfdb2def5ecdd63068b7d21010001 \\x3bb1ffd89620a7fc400f8efd5c9d3dfd26f066d67d8fcb16b80871df960124cd28dfe031b688f34b185e44aac28041c3dd01480fa71edca2ac6a973836c10a0c 1678184891000000 1678789691000000 1741861691000000 1836469691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-269 \\x7e3a48dcd8807691e88ddb8c6bdcaa51d0839ac8b79c6dd73208125f504ea7e9b523b0f78507d2e2e815561999a8cd194c8846f74dcf7138d4ef724a4d6484ef 1 0 \\x000000010000000000800003c11ce1b04058f3d63f5dde735239351cca10ff38ffa08d60268fa89f65ebdc149566dd8e0d5ea433347fddfba59e29b5346dee231c46175e15e4777ae08f4723cc688da726f23d7a4ef959850563aebe8b84224cf77e89d71814cd86e465f94bc371c054f4326ccfac2bcda97492c9dc8c395d4407cca8c99f3f6fb672793d07010001 \\x543182e8289de8f5899d22e4ae6933bbce5cbb34628408d064646b5c8b5af45599e3059e8144c4b51f06ba89edbb69cbb692df84c6d1d6a0f7ea31d9f7c40d04 1686647891000000 1687252691000000 1750324691000000 1844932691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-270 \\x800a99184a86b15592be12503e652558252028e0b8557975d4d5c2aca2663b20c9276c4ae29db2eb8738aa7ae9a46e5dac328b164ae6b04d6492a2859b1bb1f4 1 0 \\x000000010000000000800003b373eb8147f58a82cbce149c9b52c262a4c5e3c54e93ae0122a3d15da3251569d252056b0a3831240a2125c822b6df6467d01f6565a4b134f215b1b2778affb23a1b909e8ed920a157924f05d975cb07eb60c9d1a1f021522da91f86badeaabf4dd7991e9e5cfaf7957572dd443a8550a765bbf01a34a5e1b92d12d516101b35010001 \\x4d3ec4431ce729cc690c40ab9e33c344f6231b0eb8cfcb135545188914b18051626708b1a551895ced4ad62352a2773582330a891b1084b05aba30f1848c7f07 1669721891000000 1670326691000000 1733398691000000 1828006691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-271 \\x82f22da373f84c81ac5f22bf307f3829842385a6d75250a6388e88aa8fd2c6b6741c481143f3b133eee55f4b88d7b8ed360b348a7b3b089e4b13c0f5ef977d4b 1 0 \\x000000010000000000800003ebcc9fbdff1ce8ac3dbe53f2039a2da2cef31d8be5801accf520f33e49c6e6b3745a85f84160b718e648efd2056c9c4a7c3130a0ee39302d5f0a33fc9fec01fb2956766c5fb1027eb929450351effb86b3cac079c0578268f85ba99a1870b6cbe0ee736ea1f941f776f312c70957de6a2a39a52298c64bea13f76b6a1693987f010001 \\x4644d840de735e7f64e0d74bcb74e2185c0a4a404070fa476cd45e0feaf6643d603c3c94bd30c3b7efdae14d698d34347321f06d05043188e022df8f9ebcde05 1663072391000000 1663677191000000 1726749191000000 1821357191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-272 \\x87d6a9e616e3bb11b2405caa326c9a95d6dd36161be441f3948911a99d86807dd008d5964ee458c59e2cf09a48e7a77801bbe45d23573fd990fe37f8b4268bb4 1 0 \\x000000010000000000800003a26488757344393ac54ddf6fe8d18bfdb061e7c4c601c0f00eee1dc907ec9de5a0053e6e951ac8533c617f652ff4699b68b63980d557ae11884cb907c700eff2f48e035d04bbcd908c21f4e512936c4d5427e456b5dd05f1435c0af8960fcf103d4d93314de4e0ea12d735532e548c3e7ce1dc57c3d299dff2a82703ce7bae21010001 \\xdef1495008e8d3bd9980453e3b96fb52a001c1ed95077bc24ada04ba965879a3d9d97638ea530e989e9d39e6e655fa6701faf25c8f2dc90c459e7da146a15c02 1682416391000000 1683021191000000 1746093191000000 1840701191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-273 \\x8e7addd0c73bb53bc43761cebf41028aef30e59c632b7ff1ea1782a8765b6f5d9552063501841d57f137007ac0065b72d8ec07b513085c179c4e8b816d89bc07 1 0 \\x000000010000000000800003b93962cf8d04691a9986522a2c0c0a17be51788f5fbb054f13a682fc6ac2edff78def20807878d403b945aac6549596dbd7d515aa344cf2a4a11d766a06c84f891eaa604b743192db096c90b07e6db53c2f9d09f4caab3d682a7a0186846758febfc48043c61682dadfc6d730787069db00b1a33b1c94c51b8ef93067e027459010001 \\xd9f3ef0bc817362a2e6182850ca79cb959702e9a3f9daa02f2e03e8d8ecdb2d6f404549eb49a3cdec6edcafd8559ca2529bbf1c3ee483cd00aff52c2eee2cd01 1678184891000000 1678789691000000 1741861691000000 1836469691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-274 \\x8ebaa7aee466a8aa74fb791e3ad28aa00de271f532433be7801ba45a9e67added85792c99f8172ccb932bdf6a28a0a006cf82c16c688e7194479c8f3eac9a623 1 0 \\x000000010000000000800003b52109cc5c706f1a7a1adf2cc8d8f58a1fbc6304f511e85387853c7f1945ff52d6788e3f7727b53fa0ee290f9568c59740b6d0697a4d967982f73ab40303248601e38b909e1709cc7753859f268843e0df9b83f852fe6284afe9b8e6ee1bc693f14a2f6a650ec221018bd061dcd105ba7c7ce53a9586a1cd69bffe878e4c8437010001 \\x6183e60a1c783d8aa4af9f4e7dac7e6c9b49c60e5af1524cf7b10283a93cde27777b1a62535b50a8becbddbe6a5d6a2d97bac32d5ef3912d64d8ffa20a3fa303 1666094891000000 1666699691000000 1729771691000000 1824379691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-275 \\x9106bc2a678184cde8379090050bec43e67e92b3f5dd72081947e483a2ff3ed3761c8ea63af71caf1b7f9d4d8c9a668d7536248a1cd0c15322233addefde9023 1 0 \\x000000010000000000800003ae1d788a74a6da454ee8defa4b694dc8c1c8347f4da0d3dd783c066b811271f9e8bffbdfe0583d6986549bbb34ad79ea7d5cac776a8d3c951ad2ff241198c930f403649fa495a903517fd86350bd90bd65f4df4b5cf6f4e1793cfbcf92ac5c01c0f0343a1796d22fd08be23770aeef66c711171a1819f78c891c357f335df4f5010001 \\xf39d97e6f460d6389ec4ee20370d41a2a16205935438a3589cdc4a1a219b4eb774d3403ce7214def8a862c7cfe14408ee6f0a5d9dd3561146868ba496a7b6c0d 1684834391000000 1685439191000000 1748511191000000 1843119191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-276 \\x917aa1f6a2b54fcd2d3b76d1157855ae109b9b420969f3367e2441ee26d57897f26d96c3b30ab83c1481981ddced1ee1909e322afbec3525676553c7c1999d2a 1 0 \\x000000010000000000800003e14007414a432cf33088562ff8c538594345ac72aa9216219c60df66628040d09d4a407e0d8a059ca53cf2886a91f887cb0c54099092e143978883a23f3e86cae60b5c1d2d1578e5d5254f529fd38644546b0526b0337f298f4f8c6e978bb8592fa457e315c4381a3722e9560a5e239512a4ca0d0e796d9da6bbf6d57d6b4b5d010001 \\xcaffca46a3be1d1c42f8f99cbe727dfb0b6a9cbba5d9c63aecadd01b1ac2c9a1c0127b86f4172f06c829d78e965bdbe8e88ebfc08218c5acb95e9c332423fc0d 1677580391000000 1678185191000000 1741257191000000 1835865191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-277 \\x93a21b8c81bf27edff213d47bba825f83b0ad9d48e6d5646ab10a8a51e3cafe9cd161abde3bfce5db13aa62fafaf60b3d3efaafa16a6b9cb64ba54ec64fda138 1 0 \\x000000010000000000800003e60171c7317fd115566c278c409e0d1badc428f21596c0d786b5c04ae83923f5aff969c59fe729f8c17daa4de93149b615c60e9f29c4a40f4f7895c644f6c01add25e0f09ce573d5669c395efb8f2c7f94d61212a05e63d7beb49613da8e1f35da90872cb05b016ee5bfbb27a8f3aeb0aa3f7fb4951fc83b064ed95b1cf26e17010001 \\xe3829b62a032e545ebdda2b377c2ec3e772c016a583bd06cd371264ca8b112414ad03bee51cbaba1dd095a129481df6b07c238eb50a91dd2fe5e450841c2de0e 1672744391000000 1673349191000000 1736421191000000 1831029191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-278 \\x945ae37749f3a83370b7b196765fd358d2a9d3dbac8f99ce44b08b3a1a7042092a3b92681c1900611ddbc9b214ca1ea393a93220a3aa2622123af6c216537157 1 0 \\x000000010000000000800003dd28bf0036c4bd96d96eeff23a03e2a6777dc031c68467eb83481b57919e1f7faa5b23eaa785312ef92078e8dea9a5730c6ac164e0f7da9472e9b33a18ab8c37fa16b2a8e162a86911625a912b12570a68ffd670d66e54989a85de8648a9fd43743057d4a1d7288c08137361fee44246b05735aa126de4a0fdc7576df6e4f791010001 \\x571e4eb1be6985f406987f7e5225bf7064cc6540c4510dc40850abc6e949e1857b9706724d86580e80659770244d44eb0a54a5f86f79dee8e3676a17565e4105 1681207391000000 1681812191000000 1744884191000000 1839492191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-279 \\x97922c17177e0b022fa467e142f7dd798d9732cb58a7d3438cd43a1cb35d8eda0c1d3f4310231fbd04c160bf7f9a451ce9a03364350ffa343bb1d45e5bccd40b 1 0 \\x000000010000000000800003f278a2bfdbbff994ed9e057f3d7928a923b3d59a3385b1ddd065619ae18411a6db421d578388598064112209bda2d5d8ff589615d081a7de3dc088a3720dad6375328d61c5a6bad10d3d4ddc1f856c002aae04075aef22e310ab749a2c788860844ff9aa0bacad2a1a9cf0248bc10ff235d2a16db7190afe08c4ba18a3d24d59010001 \\xbb38981943263b810cf4cdc32f5b16e5a008279f837fda2848257629eccfcaf655920336891586a8de367100a126735de09c870a4f310a98996d0334dc5bd206 1663676891000000 1664281691000000 1727353691000000 1821961691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-280 \\x98f2b7a836b31f752176fc0ca1e3c651a462eca50aa02f7c8ee6ca9c109208415a2ee1f570dc49265276ac3238196488090c552a655c17af1010804346182a5e 1 0 \\x000000010000000000800003d67b8413e25fa9917cc73c604ef2f6bc9cbf4fd33dc45e245f39ec0998f521894dab5ea48a20de5b5f997be59307163485f30379ab37247ba5cf4dbcef4981aa99b31e33c1ad389e99ec29719c9accf1347abc05787153277554b19dfb74ba67ac0fe1c663958a7e1e8ce48a09b0920c9a69e872d5ef163e4db111f15a1169ad010001 \\x38c75a29f423c9303bab2af27400afc1927702549a4664bb25d8abc4f5b3e6589399fe19e092b96fc2f7ba7c62fa0696a275269878b69b5af7c4ecf056e3760f 1664885891000000 1665490691000000 1728562691000000 1823170691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-281 \\x981ea79d1d9c0ed6c849471735d56ea6ea271d3b391cd3072fc5e736e739777a5e27cbd2525b1c33d05c4c7d348e5b7b291bdc5eb1208511712fbe11cb11c903 1 0 \\x000000010000000000800003c8b0ede5177d4d92a40e1e3292776fe09fac4c1d375853e983be2aa19e80b51ebed0bbb99c7e185df40310bb1187d651475eea0e68ac416684b5a2f646fc9155e2a64c743d5d8aad433cac29b8432aa7121f649dd5b571758d4055a1fe04e88b32f7396983b37ec0cde9cccaac2aa6b2f156e3e566e6c286d2fac410895af089010001 \\x92fed2ec55cbe6e1c7612b1699458127267722c9f58593798e2ca3b7cc7085129c3fa5ad79afce16031932e48e6c8123a747095c789ee9709c2e40c5e6887902 1684229891000000 1684834691000000 1747906691000000 1842514691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-282 \\x9e5ec62bac7d2691994815c5ee1cf7494683805bc3ed915fc6100b640d8f335e7291c797d6189c4bc000a80655c53f715ceb7ffd0fe537f106c9b0e6b38ec9a5 1 0 \\x000000010000000000800003ae169b0cd8fa30783b092a687c4660dd438c9364241c028335253b3f1fa889409b7349fdfce2a9a4ec0ac7daead94603cfc79e7ce50d12e52d463aa7351cfc59e0220c32ef611d9257b8eb291aedc0bb43b404766df23ec19b25fec2636008a20038955e43e9562d5d4284a55c37a53bdcb40546158e0b10fbdd5ef0a6717bab010001 \\x9967d3d86a885b168f1909d3632faa58f171001eae30955a89e3db97faaf79f9c2474f8a9780fa8e8a698229266e80ad61a6391c2bd787ecd43f40cc8368350f 1676975891000000 1677580691000000 1740652691000000 1835260691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-283 \\xa07a21505d79b0b10ed9458458bdadc2a4012e93ae212fd6e9e11b05bfd6523cd4a354d51263b4173c50ac56fa50285bb02e63156120148de48199362bd977e9 1 0 \\x000000010000000000800003c62f034d4f65ffa4d0a56cfc8676bffb48dd0ebaa2571a927be1861ec58ec31dcc019358e2cecf580ba87b1e648d1d326bed62d64e563245fd5ee2125c709585c25663b81787ee99171a0150557fcc4d2ff47b260106ba470677d9cf50c5bb9a1893c41d0f0e6b161d1e4781bc9e95d231c8fdb934f05085b9feeb13a999cee1010001 \\xc78665a16220ec6e3cbf5fd1b9e8d1f9242745228b05262f05d91306dbb0ada8960e8d119e0ea3afe9159245b6dc18f4caa2c7532192dd7a41b0a9122078010f 1672744391000000 1673349191000000 1736421191000000 1831029191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-284 \\xa15279a5e013854945430a052818997591c1696f688861775b8cfd1cd0b07875c580011746958734c04b4c7d283bf1ee52388bd9e0451675ffef999715e05687 1 0 \\x000000010000000000800003aef64159c5fd3953279752f010f81b7499393a7b3a0016ea200d8529c6603d3e308b0c73273955759b57c1910951cdd55ede73af2cb6c85e973f29c68850c1345f5f1ee822793f8f7fdf0c0b042884d8d936ea120638ff3a153fd110b824504c7b822c7d8ab4b70b8271e4892304dfd6864f504d42bc5880fcecbd9b13210aa5010001 \\xe6bb9b2eda717200d74e46e4738b5e214623ad5fa74f88d451da784cbb39cbb61a7dbd8b1490f2cc3425a60e584d40f374a8532d3935eb09f3cf819a0072530a 1689670391000000 1690275191000000 1753347191000000 1847955191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-285 \\xa1a295e1a6aaae7471aebb46689d2e6d5de8fb25714fa0cd35c892c047e7c9ebbb7eb82678b278eddd58475aa62c63dc8276210d5f4519b7970bdb3181d75656 1 0 \\x000000010000000000800003ceb11a07c6cb67dc57754beafacac0ec9840bfbfc7c32942b1d1baa1d2ccc1d35030798812b2f96d41ad8e46c9f242d5ea0444582d0f9dacbd9724fd46afdee98de0c74bd4b6b1934a936d9e64506872431c69d79fae7802716dc82c526ab0518960ddbd3592bcb67a60bff792b22a631bcf28ed1cde30ac5fdcd8f03a8ab7d7010001 \\xbda8f7b5e80869ab781e121a74ed8e6b122d7dff9355eb0ca349223919c65ce57ef4879dfa8cf82a140ddb449f97919e11f58b1410020a18a43969dca8ef6a03 1673953391000000 1674558191000000 1737630191000000 1832238191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-286 \\xa402cfffbd72a593d76f4d55f374f97db6a29b8c00b8e06527fe153768268736194f35a8c7b2fff7b399774a11e55fbcd16411b6ef30f5c403a1c614a35199cd 1 0 \\x000000010000000000800003dddc536f4bf62c5f6cee99ba3bc61ba1a0d1ace5a92ca51d7af21f7976016ce945ddd273da9159a8b4b2ba0950941dfdf2b702bea09a22fe32e70a74a072ffdea95f3e2c538a78028f86700655eadde951c5e72ba823993051fb29b835d9ac51aad56efffbc2849f64b613a403babef47d73e76ae8ebf779a04de6f800cdf49f010001 \\xe341cb70485c7b0b069215c3971b9bb869e2b26b73ca99727773ef8e5743b13a7f94ed3a8572908e52cf9003fafa2cb4d7d28b71200533fc6b52e405aaeae804 1684229891000000 1684834691000000 1747906691000000 1842514691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-287 \\xa442874e00f74bf2705bed3dbc74832e9e20da64364c476b5804f91181b42361aa32bdc1ebc1cca997885781d71744cbc6bd825b0d2350fcbb55aec4b5c144b3 1 0 \\x000000010000000000800003d7f9bd30b07cb3eb3a5c803925a1daabf5a44cc174681085dff396474f86f096264d21feb6349930cb60db2ba05ace7edb94d359706321a97ffa8e712634bfa92ba838e9a2b6387c3d424bfd54668cbdf32b67d5a02eacda7fe6cab1fcac72bf09f3f7bb7c5832fbb66dc6583dec9572051a1dd880528e6cc0b45716c1c70857010001 \\x164f391c0bf46fdc6dc21ad9dd342bacb4245e3efd5cdb439ec26b90ac6309b65e895871cf61580ec00189de6ef6b21017203a6998e1e0f5e03f620bb7e73f0d 1667303891000000 1667908691000000 1730980691000000 1825588691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-288 \\xa57a914b350ea41af31dd08558c0ea1c987d6b1e7ce706d61ad70336cfc2df9a9c4ec21f804869d2f9e3de4b7195c78eaef6d393fab747e37619773b392c08fa 1 0 \\x000000010000000000800003b295035bae0a62e8973dc736fc13ace78df6a9e263aa89c541981387d28ca84635cbafefc0b1fc5c63fd2b9f58b02e9d456640f7d1a4b158ec11c2a87b3243248e338633451dc06afc0597e6e5a777f33b58d9b5c0c5b3eab5c0bc07bb3291f8d424b29b780118d732252429d6bf6655226e7711e8750088fcefa77752bce475010001 \\xf40452db1c87fd43ec91620d19d6e38002a2e31a03fb1d4da08bbb0b64dacf4b1848b7fa8e41e93c7ce55d603b056150e4aa7809af0129964e0cd0c0358af00e 1675162391000000 1675767191000000 1738839191000000 1833447191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-289 \\xa716eea6716aa8b222d0f4511d8e4023e3f596de3d39df4481c8a04b2e8a85c0ec1e15ccb3e6fa4e71dd6e80908ff8c00e1fd1aa1d408840fd5066d2885910cc 1 0 \\x000000010000000000800003d34efc0786c9f2a96c4e47b32b3d90a6df625277491b5ae82f38463592b1faf2a189e43675817cde707bc726cc63a147487b753df0e4e81fd744cb8cf10085f9683b2ee956bd7aad2d39c868ccb8fb363df04cbcdccce2606cd587e1b0e6df5acae6c8e6aeafc52ed5201c5662ad148f893d2749fca7fd56d893d1c1509adbe7010001 \\x67c7dfad405c3c8ddc5d15accf8dcf71e2061d58c08d4f7769516ccbc72fce98e1780cb0b5251c881314a7db9198cabc25ea3d33c7db0fb9b72a19810b04d50a 1692088391000000 1692693191000000 1755765191000000 1850373191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-290 \\xa82a6f5a9cd065d85041d48c9a5a5d9d980c9df96e722c96593759e94a883accc1e087d732b5820ac8ab964226ce9b3fc14b33db09d8722926e72b7372ea4cdc 1 0 \\x000000010000000000800003d2995a7369705f4a32fb9795e8eb1f6bdb43aeb1881647fbc08132183507e229ab37e9809ae313c9d04c0c4f8a9996caa9e0052b9c2b71e3e674b96cd4a2746518d14273cb1d4c4af7130502f58a79764923dfe96c1657fb3a56435477881d4afb6c2fd5ec1b107937c89fa7e74a46b0b1e6f6b551c29f2d7160288a076881bf010001 \\xe26dbbb82b94b699606b5126380c322672bada1f4788c89bae6310427747cc66820e184f7a772168407ed64cd34de7433c689e5eb74cdfd8f1faaceadf3e890a 1690274891000000 1690879691000000 1753951691000000 1848559691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-291 \\xa8ce74a2896ceccb7b93812ba2f2f1164a65e78de4501c60837c13fcc8b97b761ab4024a625e21251fe408d1e449efc5263b8f912f2d9be74982a27895fb82d2 1 0 \\x000000010000000000800003e823cccef46d7e6d1fe06e75afe7afb414bccd39f812b44ed22c403d56b567fcb6ef97b93cc480d7d4574add2a77c465b23d9b07a28f438f8df1456fcc4a50ed1ebbb40ce17b2fde553747a002c1e11591f976a67512071fe4eca175adae4da8caee1fd75efac7c0464975ba8dce04fb3561e44dfe5dda89c6f8a20d749ea22f010001 \\x8c65269a61adba56d6b3633ba7759bf3751927126c1db56463d0e69c60ad5aff36cf12ffe675e8fa3d8bef1ceb94941a3f06700ee0eca2bd208da4a48b262102 1692088391000000 1692693191000000 1755765191000000 1850373191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-292 \\xaa660e1b8a4a2c4b1746718a9bb447921929832879c8e9ee7ebfa4d85d4b9f901ac00ca5806dfc1a903e02411a8bce7a38346095fa2db350c0c2707920f4d2e5 1 0 \\x000000010000000000800003c171be8c5ac807db6d2e65451da1355c25ad78663b76a31babe7d30b5b8a9b04fc751953d932eb0284c33eeb75bbd7690c18ce29ff431b4f01aca56d3193893ca9aacf7bd4416572e50d700d813a7fd6596f941b1242d6cd5958910e4a3dcca172d62db06dce8201ad9b73a0f93b4bad3733898b15ba780a0de65414385d8a3f010001 \\x5c1456be4884cd1801b3b6bf319fc81773696e0a54af1bfeccd96c1559fe102c53dd2484de6bdee4998516f645b66f1bd971da997dc07963e446bf046eba9d0c 1688461391000000 1689066191000000 1752138191000000 1846746191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-293 \\xace22357d5310c9e281776b5155304850564bd7247cbf3f770c2a23cb2e62a459cca79fc52881b78b05f37a495ffc5c0519ca4101efbb27afbd81249bf21974f 1 0 \\x000000010000000000800003d708397e08c2780e8550b075864fa6769dd2e92e3df0feb1e1eb38597879d8212629ac45d81cb872e3ec0e13ee50dc5037010e9a63f860b99f8e0e90f4dfb128ae5d9178ba234663a8b0c1e2e86b86e26dd9c726ee4baac15ad3ef998de56dc425b2069061b667c53bdd5f9e107e39445077e7f9f1f04beaaf3b37b327322245010001 \\xa85ceb2ba6aba2a7da50f5bd8cb406e5561371a8bb7d85adcbe73c2a9e6f27d380e7fd03f8891fb0341726ec4ca3e364ba849d8c561126487e2e9acdcfc76101 1661258891000000 1661863691000000 1724935691000000 1819543691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-294 \\xac8ab4bfdd188b0e09daf2f283e721d8dc7368d71b3d0c673f65c84259463235bfc8bf74589f8cb9a241444abf5b3bc2891cc542f665a33996fd85e4a4eabefb 1 0 \\x000000010000000000800003c98d281b08c2ff017cb9b4e0322e750c9bfc824cad8cc170512e1f08520865d7e108bd7d96dcbfaee7733c6a812b70ee48f0577f175e7bf1b32879f8a4e9e6884e59bb85972da2a4ab5a0d1e3482ba0dcbf325321179193829217e4ae5073931eee1005fd93052fbc7f3227b812cd5eaaabc53729e5807aa994786383e9c27c9010001 \\x44079e7dc8f7f35054b9e5cf5fd5eb1e5ce1e9aa605b580850603de041041cc6b1e49ec3e0f3d1dad03a44ec3daec92480ad7bde4cf3fcf506e543d22fe5960b 1689065891000000 1689670691000000 1752742691000000 1847350691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-295 \\xb0d2271df886882c0bfe142f44bb4fbf16665f0335fad3bd9931c77044d982bbb0831c6633aa3e6dd654e863519660fe4deadc3704e5514d51851357e4bc1789 1 0 \\x000000010000000000800003abedebb7e3739fd0e03f608808321704cc535a428d8582e4df147575b402f5a6ebd01d8fd68e5a9b0ce02056e575b8083de7d4c7c92dc9d2f1f95ff3e41e74cc52a82c4ef852bb2c36dd1a2cc6c003f85a1c7ef311bfc29efbcba230935094108e9176dec8f34a68f0c31031b047662082f7b3104fb5e77d58ea200abc29cae3010001 \\x4203ed6d82a6efa9aef0fbe570bb1322a1111d68e0c956901925bf17259f01bffb288060e3d71dd7d98901282c060b9a1fbb905ad1bac62006e9eaca3952f500 1674557891000000 1675162691000000 1738234691000000 1832842691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-296 \\xb272e16eb8d2aa03ae20147b10e1ecd23b94e27e52cd83058aa4a11474bd4eccbf4bbdde7b384363512fd2d4dfb074d6f879a1a042bb499226d5787996ece6c3 1 0 \\x000000010000000000800003a41a0df981622c656f19e2dfa48f0ec55d455606d4796040f8d293791d0d9487451f0867babb229bee4fba5f316da0293f6ee3cbe6b1f6c2c18b7d137952fb2c197b3a8b686f293dfdda75f1a407a3cfd8c11ff0ee5fd79d287e652e4b5f62128d0df18f16a79a828cd6c210ce8024b7c522ed00c4f6a9269f97f0654ce4e6ed010001 \\xa48b723c5429e2910db49eea170f473ea58fbaacb14daa17391d01e4b0b24f95cf316ffcc50bc5c37e7be8a4c465062d933e261e6b0620fdb3db0577fea59a01 1682416391000000 1683021191000000 1746093191000000 1840701191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-297 \\xb59a7f26a0abd10cea8e8a4f2fdea518b19be61a8a50e8ed9cbe5338e1cb2fd0caf701abcba5fc773e904d35b93cf4fddc539098d0e9057452b8495b7debc472 1 0 \\x000000010000000000800003b489d99db449afefe42deea766bb526ef9ddbcf6045c8be4f1f55413805c1be8c8304b3e113d5c60794b7143c96d6b568079f65346a0bff96f894339cd40ffda2c38c663cbe95283993b78d6286d90fd905608557b0d31d82b5ab2f5c61f4175ba4306eebd2595377baf842a726a9ab315c7810aa2969560375923f5bf60222f010001 \\xed4fdf7ac214e10d288db8a21c91e901dcf3bc43e8157bd38e0766e1fbd8b2fe6cc1938b310cf79b3d0b5d200f9d3068a6d127d619132b0bca187f0c96512902 1690274891000000 1690879691000000 1753951691000000 1848559691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-298 \\xbcba86d3501b69f8cd8714ce71f2ce346bf8486dc3c70a16cd49f1f294952058421edb6f7483f8f17215f847043a30baed3ada1a1eeb51819f16f272c3c2c52e 1 0 \\x000000010000000000800003bc49c754789a1f2d16723e42234fd9b5b1146b405ef86c21169fc9122ee3add965385ee4c65dd91d91a354b021b8d4c6dde162eac50a9ce193a1009d3a1dad34d58054a1e02658e30dc3a120d20283cc6e3896532b595d306d14ba2a067feac44542e3dc10c8c19d730a876132d8ac9c18a0bea1c9806f78a0446d89070d5f25010001 \\xed81e9eee769e94e0d59acb5ad8d3ea541b9a7c4ff57d986c5ee0f47035158cadd8b6f50ac79c16eee04b1407fa820726d59b17f13a1a9353990219afee91406 1669721891000000 1670326691000000 1733398691000000 1828006691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-299 \\xbc9ae75a938fd1507ee07021b4ae462d0f3053144921f09f0346556fff681f07e8263c530e3a7a024b0fe248b1c69095a5d868eafeebd54cc716a3f0283944eb 1 0 \\x00000001000000000080000393783c59ed16c2963d2c221c92356033302e71befbd682a811de7dcaa987ead8a039c7a676dcaee89550da842f906dd2315cd7aeeaef7dce477d4afdabcf1546c16f4f6b1bf947bb7e7258014ea6ea2d16bee9be7917d0334acacb6ea8a345ccc5af4434404748cc15323de31735645b8e28c9a607c7c86b20e11a7a6fa482cd010001 \\xe4ca0bec0c2cc7da127d0a8cc3cbf7e7c92a27cd864d0c6d89dbe6764916ef512265ab253f5dd7e5a58e20e8bcbe0a7fcc5b47ef150432cada949d296c00ab04 1687856891000000 1688461691000000 1751533691000000 1846141691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-300 \\xbf666dddb6143575a62945f2cfc2fab21817991a35dfaa77317bee02e49e39ebc5b0e9c4dca6860456c090658b51c4f1fd2f8db4e2c4c62935064483ad92c04a 1 0 \\x0000000100000000008000039ef1b8229ed717f93e2c821814c0db23d2c694657a42fd22da8b7400c85b3d1a7867a7a0801d8652b7e579baac3770ca19ee1087b5cb092473ced80526f6dc92c388c44f30fcd512e5bc392b433c5a08c69bf2565409e337f06a200f57bcc1f732dc84a0cfc4a1b58d4e12c6c5cc0d1c41ddca15c8a494cfeda95d6e94b3d6b9010001 \\x49668c918690f0a986215cc3f12574c939eae32fe5c83d342baa7e6132b88bed736a613ec4bf4b19d8bbe88efc5f9bb08b0d314cea305fb2fe865fe7f9ac4f01 1688461391000000 1689066191000000 1752138191000000 1846746191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-301 \\xc0da144b1bcb03c8c0b0c681c85cd96203f895b172f0e3017cab12fc7a6feb2c3d420d25841e4533253440596d81955db0a58e5a7ebad019f5e3db282a2d819e 1 0 \\x000000010000000000800003cceb18d4200d73ec102e51bf2f9772cf32ed709f4dc5507757016926bdb5f34af4936e3a0aaf6ba05b72c33c0191c3fad7a8617730198d9446efb7feca903fd6d93eb716098621a5ddc6d5fe0170e7cf9c05115ca9a7a879df6a662a749b91ec8a324e35f19c3e757511570817abd896725e9b55a4529dc1c84608ea1e78cd8d010001 \\x047efef700fa2ff36bd3c2888b80e238165ab016b2d12e0f39bf5ebc3fd0447eb6e6cc43c0aa290acb4ac470ba036399a6fe92b8059b6346fd6b2cab73fe7a01 1666094891000000 1666699691000000 1729771691000000 1824379691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-302 \\xc36eab4ec26ec4a1456ca108a1ff3ec535f718892d0c0a4dbf75328205c061d6252ed1221e983a5f7fb16280fb4f995e22cd3410858b2b71e20a221b39f68c49 1 0 \\x000000010000000000800003e72cea64c3ee0542f55a94740bb4cd473ad0d00e2c0e56d7602b0703e8fabab5d63b5f760bf3382c2b2818013a82800aa4d236e9a97dd3003326c1c4fb4b4349a4a5da2c48c3613191385869638902f871b80f65fb2d7874f9230f7bdfb79aec2b6e52ba2c0c37c66b571834c6e88d7f1cb4607aa80308aa41d74877146b03a3010001 \\x95b74e6bb49570850669b898513815783278920319e4f8b594a7b293a256c7e4b29810555b79be289f25f59d5f296f04acabfdc54674070152ae700e8805c30d 1679393891000000 1679998691000000 1743070691000000 1837678691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-303 \\xc3864f745b46ad8158b37a0d6fcefc7319b7506d42ffcfb907da61ede7c1b76370dae9b74a6e4e554946198e65964405eb7c52400788ce64e1864974638ac41c 1 0 \\x000000010000000000800003d4cdf5b91f5d40d921fb96677c8f057dd9ae025341baf48ea69568b13ece6bf1f6565e175b40181debee3747f8a225825eecd6fa450d849ee2de869794d4067779dc846c13987cfbcbefeb73ee74717f48dad75c5bc5b27d7401b3e737aa6f3b0a1fb72f9c11f7a74353640cc29c2d532927e075a62d7345ae6477139deef65f010001 \\x4963ce99849b08ebbc2038600ed924dfc6d4e17563cd080967242fd7a8ef628c739323a749783b1a4f06aa1e04a0000dcbd6a8966cbb8aeb89898139f5645c00 1691483891000000 1692088691000000 1755160691000000 1849768691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-304 \\xc9c2cc67dc7b0966fc6ae0b3e69b572dbf552ee32b38d0e992d8bfd9c653fef9b56bbe2946e1fd0177b40bc9fe7a3e6e2e53ae621dc9fd4425386ff27eba30c6 1 0 \\x000000010000000000800003da807686bc90e8e03fce0f52c8e50108eea38dbaaa1559581697211ed5af4f3d4f69c52f03ab6a13cd91a32da5437031bc4f27895fef707c337d396c90088ed00aa2afa179136142f73f16e4b2fec989b3d9dffa07bbcc90ba459eeaa9799f0af5679236f5d002e93b0ccbb7e38436a8cbe4166c889ecbf5d8060d3527c788bf010001 \\x1c631c514272fc772011722987310faf8f77e45442849db7c1bada6d97c8c9b88187a9d765a9ed7ae50ac7848a84aed3e6720aa5f219f908dbfd2eb603e79d06 1682416391000000 1683021191000000 1746093191000000 1840701191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-305 \\xca3a6e122c0c4535defcac67eb2abf890c2cacc395eb673d062cffe703764f8221afc990ea446568d8bfee8cbb094fc668d23f617900e3fac717353d37a81c5f 1 0 \\x000000010000000000800003f3acb3da33c960a0ac4a8aa00e4b531ff880e5aeee69b319791a46911542e234e8207e02443327fe571701c69c3df34216835c340f5a0e24c7dc3d0e47658d908785e5bfa520e1c8c17b6673ca2ba1456d0d4867070ceb1d8f7042da0ce241159617e72fa0ac7492c1c88a57972cdea9ed9cb95ae7d989aecbe06b17b8f60961010001 \\x2d253b4e14a43672070c87011b133873d81f52c901e7b2e90c1bde2e369a12e505db9d66ed6d30e39c6d8a4b30e0b9ef42b622182547fab35a48eda10eac0600 1675766891000000 1676371691000000 1739443691000000 1834051691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-306 \\xca2a312db4d3bbaffa4e23d12b9a36aa69afb1365bbe29a6c3fc4adef4d39c22f3b1ca9135995b99bc7770c45cb35615e158d826c3f8269e7f707c509a4b57ab 1 0 \\x00000001000000000080000397fd93fd3db61ae2eb2ffaaee42b02e9e8a2c41f2b59ab15ba393778683f61d705e02a512f9d78f67f8d945832825c9f4452843e157b514335d68ae94fbba2318d706f2e188a214e04586211410ab7c5d2c80e68bd7a011711153d9030208eb3afb9c37573f5283039c302094a92fb73dd228359484ba653afe3a56c0392c89d010001 \\x2cf5aa3b9bb052d1cad41515f202d1797b0dd0124901aa6aad0c7af35d8356605a0a167fa2383b0be9301e1453b4977ae263e55da4ef673b290ba5ee92b2c709 1668512891000000 1669117691000000 1732189691000000 1826797691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-307 \\xcb6e42dda575a60d969d62c1c584d3d59a8ec6abdd1434089765c371fa90fd24987b29e8da85cd864edc96d6b39804d58e9b02cfb14478a0c906f499e8187f62 1 0 \\x000000010000000000800003d94411504f8b59879bc0f225e81f315af3fb07683a2d1a5166ed6d56fa07de7a30f9036a4278e976367dcdb51385bb68f8a1f4915571f1ade3cd3a2bae160b25c243273d78bc2ffb967e6ad43f5c4cabf6fe50d1292515eb2cc56772a5c48c8d6cfdbdde11ca7759798a22ba612545c4700a32288f7283043eb98e8132e14a1d010001 \\xbbc2e14d2608ce5fb04eaa14c755a047742065ba5dabe3a44b33016a4af59ef93658497328628b52254f7e46184e59107c2e3972f19b33d870dfa190a037ff0d 1673953391000000 1674558191000000 1737630191000000 1832238191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-308 \\xcc2262d9067a26d6f0c785afd0a2ea0062bd7ac6cc0b9851bee5cc12e9880baeeb8666e800fcda3dcd1de6ed7817cc21007f24a6a722471ed988c88e7295392f 1 0 \\x000000010000000000800003a7cd0d1220aaf571b8500169a8080945195bab0fecbabd840f04b454bc627e009c378f7424afd11471db411e4cb674f7b4e8377a68aabb7195d8d0253c8a6630dfd88c4d302fd4d6e1c322bd0674438245df56df4c1c38fbcd3b6beb5e320de45f5fc2d3eecf4153b80fe26a6333a9b0e3872ed8a3c39ca364283927122da449010001 \\x73d049d39ec7c7da599a386364caa8184db11dfb64571d834f1369ab1e65e5c471ec35195c9b90a57b66cfc13d6fc8213481a546684eeecbe756d08614647f0b 1664885891000000 1665490691000000 1728562691000000 1823170691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-309 \\xcf56e0be0b383502ebc7a6be1fcc428c3e1db528aa53de184c466d3042d331d546d3c33687b14729e7e9151675f1de94c8331d97008a9ec0f6b51cd20dd7f559 1 0 \\x000000010000000000800003badf9673e4e59e481baf9a688bca25fcfee28a7de11d9691ae9a8986ff5bf020ae40fc88b3125763a544eb6ce0f6e2d6eda56a51841b45fb8fc98e860571b9e6be077dee73447be7e482fb4366fefd1f91c2ea3f1ba8e203e307bac7fa1d002d44f24a9c645affd794652d4d079be98900a71a377c35d04272fcc897576c8c01010001 \\x71aab4d60a3fbed8b3e86bcba087799f0501f50086a8f6542be80c0e2a7c15bf1268aea9a87f40bda19d0f0a402c4cef1f6dfcd46780f6dcc94e96eafc785e07 1673953391000000 1674558191000000 1737630191000000 1832238191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-310 \\xcf0e82997f19e5211bbfe3f6972c2dd75adc1efd45474bdeb9aa0a732a42072476432d42bfb6971b5f8220d00b6ee60e9b9e8c5d388037876f4e192d0d4cb1e4 1 0 \\x000000010000000000800003c0693cd81d1502fc1d0f634fe6bf42dbe059dbbe525ee11cc572fd053aa903b7a765bb5cd595a01b49990fb8849537b7b11e0dd657e56fb61b7ed3f171f9079d8c9df547affbdc7bdd204f9080137c25a76247528e46674f8e2477bdc28ac6a2bc7005289bd560eae51e365665da6a9d7fa590fb6e293b674167f33281ace7bf010001 \\x3e33e2708416ee07e0318252f4641e44d46ebb82929858f6c001f0fe1c88f3a50cb6dfb7d3ed5e83874d363cc2ce89944074fe21afcdca5399273f806c2e0504 1684229891000000 1684834691000000 1747906691000000 1842514691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-311 \\xd4c2b503775383f6549eaf2e3890472136615e53bb19883cba66ea377f21ab9f0b86d3e6ba5882293c456a3661f5ac419d0c57388250feefd45afefa4877139e 1 0 \\x000000010000000000800003d744494fd0270d36ec693180482acabcb9bcc1deb42cdf6fcd604ac59aad678a58b10c2bcf650ecdcd8c99d8ede684738589c6c0a31c37a534b6074cca6055934dc30f6bdf6e032b02e21f9e37570ed8248d0d8126b714344f1ee3c49f73c18134eb2843d39453d0b287c76ac20300707533a678d80e9d704435d874ae4604ed010001 \\x8e7fd2c89da0332a6e8d11ccf5807a312f09066d1836666d2a0b666ea27e80f291de77c8b7be5de90e727ffbdaab976a3edd2522cdf968d9afdc301d6d6ebf0a 1665490391000000 1666095191000000 1729167191000000 1823775191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-312 \\xd57a990e9aa3e897fbf252ce1d3ce62d517ade720750d176a3e3d970ea057ed4de5ece4c31b226001647928777e33f8287506976474022ece89f24b9abb3278f 1 0 \\x000000010000000000800003c2211f6307f82b3acfc4de1343a75f379a143e04c722ff191f29a3342aceee2bbf806f3170760f6758da3acffe713d3511e627c5909dbe8eda9c40eda9dc531dd091295099b27b19684afdb79da4ae92ec57373e426046014cfa149f10e4b52de28f3f00deffc0db54ef3e8bc139ccbb2f89c148d896e1f8caeee5104a72e99d010001 \\x7eb5784cc7be72ad5461bc057c8dd4d4b115d32e40bbc4d8c953374b51163f231881bf3240988d964ca0d57d35b2017b13139b82e61b8e1473528bfcde512e07 1673348891000000 1673953691000000 1737025691000000 1831633691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-313 \\xd796acab848d0cc08ddc2c5eb0f7dff7ca049ec91b63db0137803df9f3c335a0559dcad4322bccca86d3283536aa58e103492c88498ae42ecc4a49444ced11c9 1 0 \\x000000010000000000800003a134b01c748053f7dde5c7da35222d465bd435dd430111ca6272fe056a5c4036039a075e278847fbb6b2941de3c6ed4e4af50885ddb563e6124cd9d7dc297fe95506b23fe7f9d45e989705ab3aa5424f30fd52c86792c78dab313614f05a39a61c35b125d4bc775c0420de17b6653f221fc922f4e4b593f6d1c1a5bf62844f11010001 \\x17bd172f097c66787f99f000df36c79bde983c7fb03a58a303c3f5ec62851681e57bc54f2f3e012af4a64acd2a6e3a39849766f740480736c775c7e531e5cb0d 1678789391000000 1679394191000000 1742466191000000 1837074191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-314 \\xd7b69c0ffaf22e7b6d52efc40e33c816bd4f58f27ba374e29c62aa4b3321ab099cf966d78e254670d8ee6c5b727d154c10569ab93f09cdfe78ef9cc08c31ae0a 1 0 \\x000000010000000000800003a463c18422ae6fdd2d43338095d73ddf3dffba956d651c4550653943bbfc576542ad12c54685ea36bcfcc2d9693cd7ed16fbc6836f2fa730ee0b478913c95c194953d831fbd425e9cd991f56f8bf22fc813d1f6fe5b6c1531944a3441ee4134a27b132143aa14b02888e89042e201c16d8aad7609ba6781e096a61e868d7332d010001 \\x5b5691c091b1d6d8e371c01d3caa01ed74da450601ecf3cf0d81f4e69584c4f969b7a97072bce8814698532a1e07f80dc010e30cb0b68a4c27fe0fea4626880e 1686043391000000 1686648191000000 1749720191000000 1844328191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-315 \\xe12ac94a1c83c337bf9ec86af8a306789b9141576730bac1384c2f73a6a299b816fc5fd7dc65ac5c30eb880ab8cdb60754b4f1d9c7096fc07cf6db2a0dc20d39 1 0 \\x000000010000000000800003c529abe9cb7ee0da995c5b09deaea8d14bae7ef0e1008a0d6ee81a2f1843ec4da3007812993d4438b1bfa66c8c6d863fe14fd8149f3f004a20a87c79849ada4d033967688490ef10414679c0703eb62e9e082bf5d15bccf69d6bb18c1449cb344691c611b7698303889e490d038b0e36da58f2da4247674e86e2318ae76064a3010001 \\x2f38bdf248fdd34d95286f3bc82451fbcc924b0dfab3b716f03343ad711de2e2bcc930288918ea0bfc3f8049dbe383c7195b58ccf24f889e039bdc342dc5ec07 1667908391000000 1668513191000000 1731585191000000 1826193191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-316 \\xed4e9d96306d576aafeceb7b074d0ffd40000e58a682f1e092cbe8d6b9e52aab5a6ae2b7a4b5c626733049f5d5ce3c7a66544f108203392130d61a38eab22ec2 1 0 \\x000000010000000000800003cc40ff877146b7fa88010f5142a26707539172e2085710ae9d01f9071818078fc9fdf2a8c0d922fd20d2fe10c0059a21af1db6ed2b8db21a3395e5de2af6e9fe813c1f85e21def4ab165605c20b2649da82e81c7caf1f04f36a3b49729873c6efa8425dee0a0b5cb83ca225490a98fec6a888a828d7deaedf07e3fb61d01330b010001 \\x26b1a43622aad3acd199c5118e5859c1ab8e7f140e12d2c6a1130aec8a9d5ab75b15085225ec63c2c8c5c41c59c259f86d786492fe93c70bd94d0313e1a20e00 1681207391000000 1681812191000000 1744884191000000 1839492191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-317 \\xee8a80a2d4dc5052934797e25d39852a8f1be7121bb63c19803b6dd8c4b6c86e3e1bf01cc7a277d42f42ac05cffb441a4deed0eacefc7b5920bdea6802f8871c 1 0 \\x000000010000000000800003a64ca2848cdf25c08119822df86e7de0d49caf40237e673ed8daf9fdf679cb66cb890a92ec89d8be72128e3cf7c9dd4563312de1e2c1d2816b5dacf986c13b6a7a82accdc939a6f46ece663142e63b748795e14911363f01be5a9ad4be4e2c3984313cf701faf7cb19d8fc005ec6b8c0bc2e3cc2daee081b75ee2a4c888ac37d010001 \\x76c5ead678b8587b1fbef36f8d4b6d2ced88f4500ff9e0a963103d9b5e56c27419bbf9f654ee57546c30bd6a80d7b99cbdd58f06dbf64634f80c6e97090a8602 1678789391000000 1679394191000000 1742466191000000 1837074191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-318 \\xf1a292327b0f1d49b074ab30f1e36e0902900f8e00da95f9efd8132f8d8fe475c7daf932deb6fc77c65d316d75ae3c8b06c857b2e992879ffd1551287217e0ff 1 0 \\x000000010000000000800003c3d8357e0ab82810c5beb82f48eb23ddd0c947e021bab73211069738f9438e6a9bf20c1f058566db3da6abedb03ef9df67957abd65baeb76608c154cd3448b6f76dd823e9ca171c3af7d3ff97c1f3833240965c36e5da22cc7d5c17e4e7cdc40e04094638081319a52d0843e12c227063aefd5921f10cbbb72b1bae92c78f815010001 \\x75dad6db88d51adfcbbb6414c8dd3fa261a7d4dc91d1e3705b311b561ea26db13354f073b7c30fadf7cbc6ee00add63c0d8f9aae426b696bed5dac7c91c63907 1676371391000000 1676976191000000 1740048191000000 1834656191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-319 \\xf2827a54fc5921feaec7f536bd5f1cd5b88977e69a5332f1196ee73b89718e95c555a59d7acbd25867ccac0e26d6ca6d0b6cdd45641d0b7127a074906da899cd 1 0 \\x000000010000000000800003d3fd3c433df22a5cb1d0bccb4be2085bde77ccd6dd4982063e19c1168cf1a7dd83fbe468d72e8c87fd43f6de9470b761d82772b1e286c8314a03bb5b171ff969394b0cf92699ca5afad6bee15574c0b182cea006c30c1336fbd2aa111bef7546e06e78cc2492d5e721566ba9110c81fdd0c56cd6b32d628786058d45c24cc977010001 \\x3b4a23a9a4f146fc86b08e47a561ee34247cd1cfe61dce8eefb8bb558475c343df0f57049b2c71c4ed63e9c71767a9590e0f7cb0b7e91fdfdc1ac18bd615e603 1689670391000000 1690275191000000 1753347191000000 1847955191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-320 \\xf2aa6593a33224974587a791895cb31bd915e57f734e51207ea3947aa533efda0b076fb082885335d4b53c319a118b8e632c610ef1de3ffc346d20cdff37e58c 1 0 \\x000000010000000000800003d583ef8de7b47350f07196ed5ddbf3f875391ea434f96f92c31dd3649a90fbc6fb1e3c8efcbd06932d22c71c4ff1e013cec0a55d24e42d3b7dcff7d876f53895b4f0ce8db91766b212021404cfd4986ae186a7e9593620d43d29f200fd552617f7a63ad8e3cb4791409df4970bfb7f39376660fa71af833ba5e8b6f1196404f5010001 \\x3fbdbe26a400906cdbfc87b2011acc189e6cacb8dfe16d44125b010eb5bf03c96c9aa98a8457b7688145d1ad719b5a1e2fd21a5a3a2036d8d78862f773748f07 1676975891000000 1677580691000000 1740652691000000 1835260691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-321 \\xf41e5cd54b75c7f631fba7ae7ee1d858f84e2baf4cafccd087de6cc823c7cc3282c84afa7b47fa8ca4979383e46e6e8952e313606fd4052bba765ef9d989a115 1 0 \\x000000010000000000800003b79abd65b88826ae8f4b71440979e82803acada73c2f85d21cf77279ad02562480594302a63dca8dd19f2fe816a87bea48f11c2a6c54e0781d4b6135f40ff30d8248c76afb9fc235aba70fdde7e049b3cfcfb0038bbf2ab380641bca9a5ca0e374d21435ece1d397696195667b15de843ac7cfa2bf82e3d4056bff796000056d010001 \\xad66616e5bbca916fb50f1b9ac0f25f5ea99830f0dac8b3dbf826008f1492d786d423b737d5110e0c275acf5e1b23bc7faa170c0f7a075ce0603238931191709 1672744391000000 1673349191000000 1736421191000000 1831029191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-322 \\xf74e102c628d37afa3dcd6b3b43dc745cecbda5b34bf7e7d09c9bf86896c61442afc97ad820a23681997af59f5315fa0de8e1a85279bee348c127fb2312c4d94 1 0 \\x000000010000000000800003d41c6fbf8d20e782021e50560dc7a71d050e7b35f78862edded3f3171e485d9cd8e55fc6cda82058deccb4063efe8b69a622450471832c9d53152cf0985f08dd2d0fb445dc63e41a4da0cc6fbf18bbb19d245638c9343e10f779212849b265f81e00e3e8b2bccfb7916d11ab98a9096200ee673a48ef88b56ee77fc28551abad010001 \\x720dbc5f81958e02ae220ec8624168ff89d050311a89e536a3b77f1cfd21b10395fa53cc5851b5a7317d3b3cf1489f6bc2420f849a1d7bd95d60d0a9d36be10a 1683020891000000 1683625691000000 1746697691000000 1841305691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-323 \\xf90ef309ff1371965c6833225ba03514e4ab0ed5c9169705eb99c32266aed15e1c3be0a68a564e6540b8701a01e19994d730e5746a8df976fa393161d7806a6c 1 0 \\x000000010000000000800003e5da6d9a0631e6a7bb89eb826e3168a3d9b0205c1e791bada272cac39a78571b37a6cd3895d6a473255859f299d957d3f98c6efb02ec5c0c67c97f2b20cb04974c00753a7ce63e584a0d7bd1e7ef878c6079b586320e5a3bb9b8866950a5818f3129843795d3a53bd83874583af41d321bb089ecd888516cef5e7190086ec14d010001 \\x5fd87d272c57f9f0a510f69da95fceab64e6e0a1691b94a925bdbcb030202653902ca94521d25ed6e12017a568d66f136d0e43804da91edcd7b6354066cdcd08 1665490391000000 1666095191000000 1729167191000000 1823775191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-324 \\xf9caa6ce92866e83b7657e686798b29cd205001e5f2550898ddc3c587d319014ee891d3761bbe4b682f1313c6a1dc17b23f838efdd02ae0ae4d85f54f4fee088 1 0 \\x000000010000000000800003ac3b0e3a0e24e24bc7bf1c7c311e24f210b57393658ea84f492ce888336f7cc113749c8002d569a633abd6d20c8035603f9c7eb175400e48624e60ff889c98546bc08fc9931bf2231cd06539770845cdf559055d4fe8b983648217cb0b33f599948c0802b7b299cce3796006f0a88bc286848c1a63bc3738bc8a81fa62956815010001 \\x0c16e6c096cf5d62cc301f517de4a4d6e154369e91a128a66751b8f9f0ec8677440d8e7d21547cd3e4e45aa4f89f2ae24e40e61d4a4527260163a08e9a0d630a 1682416391000000 1683021191000000 1746093191000000 1840701191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-325 \\xfaba55b33cd2ecf6c8a11b6c3997df9ed10c9fdff7003ade3cda30f9061d90cb408a3f7be74eaf1ed142af7768ca0ae8ccf32d50a72f72d2b1a7541d57dfad26 1 0 \\x000000010000000000800003be924b404dd2d3d932904ed1cbcb4eb80f05e7960b890f9cc9cfb25e9789dec036aceb888329afbba0e2ecd51be318acb0b9c13497cbee427ed254b09fa7d72534126b1d46a6afccffbf50be226eed6976b0bd21d4caad180b917bd4dd51b76b5fa993c2379ee48bb3cc695f55e699fa2cddc2b24c59a1bc5d0fc48a93f7f057010001 \\x829583fc99f3c6255614a226c4054038bfebb92e723094ff0dfabc521c2bc252168f5ace68afaec35035e8a9e44d286071bb5beaad7e6f5b9567b8bf1c2f170a 1663676891000000 1664281691000000 1727353691000000 1821961691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-326 \\xfd023e6133d6cd24a2683150fdd2c795ae0c676822c89f3e90c2018207f7983ab5ace051d1c3c50210c61c0e8a8467b495f252f6a00e5f6d7bd986bfe5ebe16c 1 0 \\x000000010000000000800003be5094acfed112f44f125bd48e0a45bcc996475ba7a73ee95dbef1980ca7eb6e88e511d1c8b704f663bcfb7597abf01a2801da2cc64dd2459611283f037a529523e8fecec00654393060716d36e4a563fdfff34cae35c373150ccd86b9ec1a64e970508012442ab3919719332557293c6fd25b2ed84f3a41b557bd51d989f989010001 \\xb8fccbe55c872bf875a182d128cdeee792dada7db536aa41522b1fc2306c61ce690900c26466c7e4b6bcc51c88598c34f41c06057d3f57d0bd9d943c52a9ed01 1680602891000000 1681207691000000 1744279691000000 1838887691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-327 \\x0033a420f59d6cf58f81acdfe0e11ce3a217761a6357d2eccd6e075505ab8c3d761656f86ba3d6f2da8089c3d4d92e4d1c0ec35df580dd6c9c53724b6c48c4b6 1 0 \\x000000010000000000800003b20c5f2d6f7d2bcb1aafbb7c8385c8eeb533bc5820de31bc026d7085b173bf61599a16750d2aa32f8b837be97fbe2438bde0bf59636f67faf7707419540e2544e6235d32836876f6366953ca8aa9e3a0a3f757ef17cb2a20a781114f26bfaf0c2da37538595d62633fd03e115ee87cd1396c8b838b71a7180100d7bc7ab7b529010001 \\x2fbf87209d443472300f8bba5895caee141ce2f73e5be674fa6d02a311f5489c1eadf353524c308330b6de4ffb0383a3ccfb5b40b5a3e580b4a444acd4f15706 1687252391000000 1687857191000000 1750929191000000 1845537191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-328 \\x01c378f744548a1d27224ac2e0b87bdf6cb956ccf6743a3a8ff04246f770ce4d6f6dbb629f84baa60b7a48ecb10bafa3527cf075b26072fc78b99537aec45502 1 0 \\x0000000100000000008000039eae3d3647ffa66968ca31c5c676bc3e1a893ec8d972ecd7d5ff1f2f6743064d7e78e8fc735591b34be6aa1703e3998a04f135b2c46d0ea8c850d60f584110291ad7f6c569ee428151e85eaf1bd834f8e192139d9111727cb72ba061b0821ce3bd4869b4e06d037c49015261c6277daec3f67f54cad32d5949080d1492268aa1010001 \\xdfb89a83217875d395549b39f0246972ce5de72849d7ba1fce75319c4d57f52dc29e3372728add3146bf98831f59921f6ba1dd4bf1aaaa240d4797aef0af390d 1675162391000000 1675767191000000 1738839191000000 1833447191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-329 \\x027b53cb69874335ea61cfea9eaeb2bb6bd00c9b92f74c09868ba94b75981c16e2cd17d27432b3c0aab226e3105c02dd8d2cff62caf7175db702951d562a1789 1 0 \\x000000010000000000800003c53d627cffccbf8360e1c26fe5b48f064e14eec3314873be77d4fafbc0ef7472eb405d73e1c74c4dc0286437540b77fd22e548afb0b9b2d4bed6ec827deb19e2c2d9cb24f189341125aee80b64ac98b49b3b79bddec463d803b0b88bc52de91b7c7e2697c6a9670de0579cc45db4c4ea945b561d1d0043c79b26b6441976a84b010001 \\x0aaae502d55b530dbd8b13ea9442d9e6fb2312ebf232ecf1a1b79404c65ca176cc025efd2b24a5e593d4405b938b7a37971024239157ee1c9ba3827b2e12e207 1689670391000000 1690275191000000 1753347191000000 1847955191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-330 \\x038f6916d43593c92a1959aadc8ec7f5f7db4a98034216f28b5f4e5f40fb15b289d290184e8b5913e1d07bf16dd20cf304a26ed24c278b79b4ec15b25e6a7e42 1 0 \\x0000000100000000008000039b54349f4189ea524e8550631e0f725e75fdfef28d48e82c7e2309ea23f8aa6c936ac60c92ba32f1c25b976a9a0d147f3b21ffc924a7d0edd0f965c21022d04a9deeadefa80c205c944569b99858886679810bd5b5046fdde126525bc5a5a920c94acaa22a920aef4e5c51bcf1d334a10cb7c834500e2f66c880c65792c7b8fb010001 \\x4c02a68a142488d5a8e0baa4d50f4f5ea7ced9b3075f9c176a8bb48c2144c4c6ec88f4da830e71e66afbf7531d3e9f814e8f84ac234d894c43acc19435d5b30e 1679998391000000 1680603191000000 1743675191000000 1838283191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-331 \\x0713ab0d0b886a879e937dacb252de763a966d723cd14a22e66bb866d59827710637178209438a3a44a79b3a6e85f1274edcb6e2fee8dfab0f08caee8d4dbfab 1 0 \\x000000010000000000800003c3c9f8f84841d3f83d5eed20de36fc25aef448218f06015f4bc5320a51769a8b8f5379f37a303e55177adf086fdd71e57895ca117c61ca1d99fea7bf5e755d7ebabbeec1258d58ba82a01bf5501482598117e6b50402d6470cd513c341b680a65626b4e79a157fe59b7851d8d7198b9f9aa016e3f13632968704b8312d13b617010001 \\x94f822a90f7e71119c12a79b1b5310704c547870a7453f23a0d4a234fe4d8571bb0b626dcc486e99b8e9aa7eb7e1ac6fe0036baa1e87d927017863da0b3e6a04 1668512891000000 1669117691000000 1732189691000000 1826797691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-332 \\x09576371337c0bd385192deaa1af612bd729be479ae010f31264f16b4823b29f2f3662d031e959d793b71bdd385b6d4677b78283f307cdaa2f57d19021985763 1 0 \\x000000010000000000800003e36003ffa6f516264c7b1cafa4cd9ec2475ef2ab78d106856d2c2b9b1967fbef9a47532c63532932582742ff8b83ada572e74a523f468481024499d6c0554f64a0c515a54bb3f372a0492e1e05de216f37b826885c50d4465fcd20ffb6ed755ca4eb4a9604cd2ad1814eb9204fa5c54619416d319e151f56c082803a441985e9010001 \\x40ad4345fc0be95303ad95d385dce04d6789b3e78badf7665c6d8ec069e9b2b71ae0fea39096d3fd0fd9a22627c7c1d9a9fb0a63420ebeec3892d39a6a49430f 1683020891000000 1683625691000000 1746697691000000 1841305691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-333 \\x0a7b602fec38921241d4276624a14ad574544b47c206bb15d8e9f8d48e19123c65a0d15d0532e5b73864918785a13530c2386a6f6a44d2b1bde140091ccbd0a8 1 0 \\x000000010000000000800003ad142bf5487a2f80b5c7b07cde35b5c8ed136ec02d99f6a2a695587330c0b27252e771d5e2c60e0225f6d3d0382d1dc5278b101f6546829725bd6d1576a316a9a93e952935c0f96618245c60c9bbc2cd34ba2a5575daa8a6ffee0cfa862344f939f1158b2de08a220f313c2c55bf50023cb3c90113c3a8d95aec6d59412839e3010001 \\x88dc308e1ff448335a1715c597db7b59f7f1eba04c386564af0b069d3f40dac4a1f1eb7978a41f1f428cb66d2cec130f034f09b9461c3264e3e7513f752d3801 1681207391000000 1681812191000000 1744884191000000 1839492191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-334 \\x0dbfd9650daa9727e1e0f8715ce00c886b76d30bb995d095a48a316de63867deec3093862582a30acab1c6c542f8c762385f59e4f28fa48122ab1f14cc27dbe6 1 0 \\x000000010000000000800003c7039e909fd4e309f3a9b5f8db0cef1b57ba96d433d68df88fa216ef27e24155d0629ff33a4a03bb9384c71e8766d0e192c14faffe9174b3a5f190d33750d685554a80ddb72563e4cddc27f62a89667b6968639f26fb0e6dfad23b83a5eda22e66828e111509af28a0c451aa6341eb970090101cadf2706238587ac7b3c8387d010001 \\x0c4950a77d7e9f25f3b7f827c74ac950a9f86f022d06a1fa9d47996cc12e3508cd5ea104616dd32cd3a95fcb34a861c63a74d6b7fb7ea124419ed496b74ec90d 1675766891000000 1676371691000000 1739443691000000 1834051691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-335 \\x100fd0818971e1571f022520020ec973e478a642d31417fa3c707df2c1bfbd5875a8249223fc8680118c690176d3013b30c05acab06935f16f287f7ef8a7c985 1 0 \\x000000010000000000800003e75f180a7cff9d52b57e89b7cc5d0a8438f7bf2c7ebb29d4d070aff34bb62d7c3d5bb9f4c84a65587ac20fd007fbf4d8ab0378eafb65dc6d0461701b4c44a854a9fea71311fb11446757d86a15abc4cbeb14ad871e126f0579724bca5ad339c26e1c5f27cf8761759035314fcd74b5ebab6537778cf12c95e8b64055b5fc58ad010001 \\xd577408c8b2b6e9ec2deec0fe1f81ae8163419dd9b7ac5ea9c41ecb76e220f265156bc9d43ef4c19c91ba2599797d4248c751190f8ee01d83313bdaf8147f506 1673953391000000 1674558191000000 1737630191000000 1832238191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-336 \\x12cb8c6c8946e30a7ed90535032573fc03fcf1529516234d5decc4b730af8b3ef1dd224843f37c67fe4167a0235a61109d6302a45c8ac71a44abcb42a11cfd39 1 0 \\x000000010000000000800003c3b08c8305b9097caae12608ca8077d333aff328257cf59527fd8129721b76b23b5a83101164d48fee5c0de73ea89efe929c7d5ec2cab20a934599a2b3555160a8710619eb1cbf952c3bdb51eb973711ae79d2ab5c8864922a08a6b5fb8198f19937fe184c94e4e8c0302398802a6eb7f9c6ecbf22b6e4f98b59dfd42ef3a3bd010001 \\xcb11f0b7165038b21079a08008e701f5e80017015216bc48309012b43681e44b8762547d01f9befad8546eb1892b2824966565f42d8f73c0d573198b37b48801 1669117391000000 1669722191000000 1732794191000000 1827402191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-337 \\x17b75a6e8e0e172065945b08ec2b76a3238cdba8f761b88a72f5df1b43d2d0cd6b7c934a417195dd5d44166bde3d360d67833879668715797e717f4a4a28edbe 1 0 \\x000000010000000000800003cacb68213b9fde6eb401882382ef46f432e4993073a2bd438054afc5f9ac9e4c6483b393d93d8edc60a81b13546f00aa541c866ab7eea6c1570c0a81219d715d0d27f8b0ee3729b0e185059a138e539ee96b6cb3dcb07655713f6c02a27434241822573849c65764600695fb894d675edb860ff20e8148873bb9a11ecd39b031010001 \\xbed6a5fdc8dc8c07ce937dedb8c976e2e9bf0f35c953bd4339ddc6677888e858b2d6969d577824ac37d2c476cbc855665e58c66eca9c9d6633400540b8a10604 1689065891000000 1689670691000000 1752742691000000 1847350691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-338 \\x180be5fed12d8e98aa3ae461efda4a10c359a470ce474c7a34914bb5f3fa8d39cd102181c34c2f2b0e1b780ba5fa11fa3dd316953182ab451fd6e601b7005209 1 0 \\x000000010000000000800003d7fdbd04812d4c5e8176a686e1a27eb42bc5129803597f099cfba20c244a12670b23983ca80fa6bf429a41da900262575d264742d7671766a690e247e3324ab25202dc31f8e9dd0eb869817cc66eb8e15198e0c54fdbb83112f4f9967c3958a3bac284693ab6fbfdfd68fc6434230e3e7952d2eedaf68f12641b7fcdea7c88f7010001 \\x30842ff119a5b7ee526afd2427260c8f6725f14745ae3d1190e8d8ebf416cb8a974248b21e67c5fc5ca4e1b8abd00bcda165cbb1f724e004ff384253fef41506 1664281391000000 1664886191000000 1727958191000000 1822566191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-339 \\x1f0b301f01009aef79798e220d06fc0a51dc11258714603b0d78b3de14f1b08c3ed2a04f67e3f29e8ccaaf10271565f3705e5a952280ffc69e11101c6d130016 1 0 \\x000000010000000000800003d0156e6319fc8acccdf8ee73cbbff1155beeca88e7ebb60099e7424ad8e424c4e8cd1309a06883e2f041a0013f6e5f3bf8eeedeaa8c59ea0b0d29f0ea6bffd55fa1c8786c7853ca0a4a50373d470604cf2701f33e9987feb38dea3db3bcb43fe4a392c9e0fc9513fd90a1a511e8acafa20dd2d8db273ce6238f0cd3f74f2817d010001 \\x79f51a60136406f3d9e158cfe2696a0d4fd26a985fccce0cfeb9eba7f9eb49bc79487a2e6c0146626b25749e8941e3e59485181aacdd5f63f6d41a3fb83a9509 1667303891000000 1667908691000000 1730980691000000 1825588691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-340 \\x25eb9b739d2e5c1fe441fecc6cb6a517c8ed6335b0458e541a4d3fc758320df8c04f5853d69600b2ddf015db07604245aef3c55e488d210946c67c81b5e60f83 1 0 \\x000000010000000000800003a20ba717704c6252e08f11338931a59415941c419c207e31b4f3e22728653538bfab3899188c5e8f688e075c4281f9c7b3bb87104b47161ffa8c3cbc73dff899ee2a4d67404d6bb9c9586dd397f664e23f7c7fe72ca44910d34178fc19e5237eb9d1e05256166a00ee62b8f564f163f8ce3dcc5a7afafd0c4d33fbf22d706c91010001 \\x1bd347de04837d36a929eacf15e261422b78f24801f22a2e3f58f145b4b5a6dc19a1b0e01783ff0a9cfee3a8d56445c41dce04a93205931dfac9c7662be1b900 1677580391000000 1678185191000000 1741257191000000 1835865191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-341 \\x267f90d51454b31fc84b55d3f491e30a1d07139620a551abb28584fb80744b7b0a8a1f826a9d20443716551c17150a8480b711908f451c678e512099f26f57a3 1 0 \\x000000010000000000800003e2f80550197f9e961aa71084f59484769208305847e095c7d75657629cb12ef78e37b430d9cabe23b7ce03cde50cafcdc6c6d93bc0045fcd0e61dd7733b9af01bad5fe8c26f90605b82938638ad6772628f3570ac4218490744778afa9c5d3899b9a12199a2095f4c62c517cc969637ff9a695deaa3d7770b315228dca21bb29010001 \\x1bbaa75060d978062b227e0265d00cebdbeaadacac9d7e8dcb1aaef32a72c55fdd5205e434d497816b6cc723a6f32df54757a663aa773a3f22c6ab328c920c06 1692088391000000 1692693191000000 1755765191000000 1850373191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-342 \\x26875904ca50da57d0fb2c4c879f324c6a78a1719115e3a74fd516a774eb78746d2dda95f956b305e39d2b5a12136f9c243b9449d06757e804a3b3f012ee48e7 1 0 \\x000000010000000000800003eb1943eb72dcf1b88e488dff9cd17b4f37b9c555ca494203ede59758056c0c74a7d093f64ab323700028455da492c48d0ecb6cfaf47c36fdc6b2539160f4d327c973b091144fd9f93a50f6ddc6e783bc6de80d0c3dfd5e98c1d95201ac9f586070537d35721824e040219dbd194e5b524eeb54fee0c8558941444c55bcb5dfc3010001 \\x7814c8a7278482962269f19e7c191592246220f6033e25ff85339c5bb2d6747ca087f390ebca1fc7ae9243d052ada7d2569cfffd661ae216df49e29261996309 1666699391000000 1667304191000000 1730376191000000 1824984191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-343 \\x290be7bf1a0a9580b5c10a2aceea2d5c79ed2e3c938ef854090d23f4639b87ead29b7e1b20527d233839a72ef9296df5b820d5568f8645b30eb0ce2501e4ba2e 1 0 \\x000000010000000000800003e4b57c7b3f60efda8b2c716676f3a15be7fe05dc3e3d0f264d738dd050c2390e256a2e06e1621a0cddaaea4d881cfcb17370289766edff1de56d37399df7231f3dd75624ca742fadec8d64b3dbad1064c1fe5d1d2be0128e3c17afaa9c4eaf0f1a1dd0eab1dc7ef0edb4aa16e36b73d5ad27c68dbc865616fa2c432f45a71755010001 \\x842ede164bd9a9a33fd5f696dccdb76306d4f9bd3fd6564d9a60bea2c37c1267bee9b956ef751721ceafb76d3547aef694671085164f50cfdd659f9192479200 1680602891000000 1681207691000000 1744279691000000 1838887691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-344 \\x2a4f4097bcc10f04a36dddf4dc6517f3cd648d9dd15c04adc7847370409254bb341c363ba0747b9b51e25123c5af9fde1ac5ede401a1a151adaa2a3d1eda223c 1 0 \\x000000010000000000800003e667d240627dad5e08231c38143b00b38c0932d62dc1282b1fec0c95ea5fe94a31f44c077e03f738c43565b5a6181912e7856acde0c18fe0d978d9d4a5d7101f0b4c6a2d56f3e4c900ce2a0935d9eec33a691bb86e5bbd25dc483955fb2f953b069e1ac2b9065448406b2869c6d2f81b1458c526b768e90257ad34f0a7d33f4b010001 \\xc8b198803b347a3ca5fded1da51559ebfcedf25b2ce9273a9c065ee830fafcc43050e684f8e8dcb991ab600842c2fe6f781a6717c31bd8133c96fa5f03fbd103 1690879391000000 1691484191000000 1754556191000000 1849164191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-345 \\x2c8f951cb4e4a69bb172ef803e8cfa646bb7b96c50667d077b871883562604c51cc19c0c658060b49100ee89be4e88f1fe388df6c46937cf81902b5c8978388a 1 0 \\x000000010000000000800003b8a579f44fa89c6f77f4c7766d500561d230fcbb39532d1af7005a5f1bd908fa9554b798d9e39d835c89c698d74d2c86929fc78339660084743de9ec3833592863d2dafea9732bd263b5f16eaf2d15beafcf4d3558919772a2d999a96a9aef2eb785e5e352e18b7d794fc5a427529430d6ed6f77bc0be442b75109bcf771b6d3010001 \\x58b215fea7aa8abe3ab32c52b329a4ebc7d3f93ee9e39240481bfde950827b0578a26408c9305e862da2eb2fed05983305883e251a034e314e73865fc30b050a 1678184891000000 1678789691000000 1741861691000000 1836469691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-346 \\x2f63ae9b564d8efac3071f18674ae99a9598634ee75a85d50d5f1bd7c4de8300f8b62f24f328d9f6f2c778bfbb91388df1a0c0db7e11772b418fb67cfbdde509 1 0 \\x000000010000000000800003c212f21130bd04e2e81e73ef58549736dee219f10158342c54b5c2eb112c81e0b2bb8faffb12dc29b974bb7b7a8078eb7936de57c048fe1caa5e8b0889e9462314d071ff6b18c0a35121dd26f9b9777047a3a327c44ee6be70d26a450c1c7d3e5eedb21cc1410b75d74c1d79b05a3b96ab7c4f6f17e12df019bb2a922ab3a949010001 \\x3664495fcb3b64b736bac16c46c21d806588c23d117e522e6e1ff6dcb522d779cd16de0487fabb9549a9e989581ce15cb4d49345412f24ae9f7e92b384ac940f 1681811891000000 1682416691000000 1745488691000000 1840096691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-347 \\x2fcff8083ba32e9b6c6929121d09a4121495441d790a69747424ed2a5ce7b1bbc74bd3dc8e7c259bbabf2ad5757652d3d749917acd0c2eb67c383e9e6b575f11 1 0 \\x000000010000000000800003a8e0241196d1ab332271b5a7308b4c019c7bce85375a235eb964ad5854e2ebdd39328497d926b4711977cc9763e792e01c3e4934a43a4df2c125e4dda2c779f6e61c814dc6a4a24ca3acab58a17803088c42d8df78a00423f2b3075001f8ea4b22fd744c941c66a79dbb44cb5500d8a1fb4ce2258a7bced1958e6e3dd8621d07010001 \\xf97ec3a95a062dc8b0f88bf160442157510b2feb401545c3ee9d71f2fa873e2f10792ac3fb88b9c7b17b54ed7d5c8f216f1aebe5de602d66ec4667e3fd3ac405 1672744391000000 1673349191000000 1736421191000000 1831029191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-348 \\x3f2bc4b5ac4304b82595022730500287b74785f79b72112f8c168ef32ce5ef6d3ef064d0db55db0c8327a95148f2c7144b3efa0d46f635e1e1a034cf6ba6f5b1 1 0 \\x000000010000000000800003c5c7b76efdb860a60d3688cdf8ea853aa0cdd6b11c8b1ce88a6b556b4a57e5f972d5a0f524413256ec50d08c34067d29363c1c05363227f14d0d644e22a2a36ddeca7e765189047332c7c8d8f02953810c65ef7c9addfefbb772f23cb162dd9480ecb7fa3b3477c9952b028921ab2414e1f7789c4675472618bf579d97583c6f010001 \\x610c46000fd5929624232a90774db30ace9967d98ef8fcbd18a65626d5ae5dba816b5ba5d729f02ec8982668be0bdad2e835e49d1585b9c65515a90849465d0a 1667303891000000 1667908691000000 1730980691000000 1825588691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-349 \\x424ff82ebb7e093fd70bb092c96949d949665da5e77a1ec407abc2d22f22db3671c45c95c91efb6c6911f01875f57c0b7b03a8a247fe7f43374d78b8d56315d7 1 0 \\x000000010000000000800003b9e571c85f6cd8305d606167521c167cf748d36553d163786e8692705fd4714bcf56ed5cb85e1497ad28142ed162d96a8d19cf7ecb3c1ef9e5da75b5957008745867b60d53e3caac84781215cf590e1fa1bc3a34568b2f3a87b323a82dcf9702213cfd7c4a4090888a4f800247bdba3e92a458e1767d3da94eab781a39f35137010001 \\xa438957e9c8044370cee62f2d2059a5979f141d33d2205561a9290f79eb83bd9ef7290a6ca2040234f74ac6c2422a1d1fa2a2efaada2e0144ea36ae6108a0e08 1666699391000000 1667304191000000 1730376191000000 1824984191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-350 \\x45dbadae186d4754b5d76e4dc9e38f64d972cce7d39f6b94324c5f3a0eee3024762a12efa7927f0e4b7e4d389cd4b7b809371b462a3967c720be8985e7e1ea50 1 0 \\x000000010000000000800003ea1368a7db0551eb980936d7925d7da05786b3be8634b2c697490ed132fd0138b755b1e238cb9379f5003a20aa3ea4770d7a936072b14c39deccbc2872c73e6eb11594a6a8f91ae72ac808fe58fd0e6d405c2d77bccbfd7d443594577c92b9b346bca004327556f4aea4ff0ae512bbf523f076d12125299f9761d59c3f40e2a9010001 \\x12c8b58bf7a90039bfb946c1c09b4947997e8178e1c6d6a0d8529216e216fa78a98b4971483bbed36cd558024b0f800ba57294ffbcc9a02670f0f8da5124fd02 1678184891000000 1678789691000000 1741861691000000 1836469691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-351 \\x46dffe067ab2d09bc795079c4ed3e2993fc9c801fc1c11453955363733ff833eded7ef0a60579ceeaa369c7fe56f2fc79881adb2e0c37b95fb1985e00078b393 1 0 \\x000000010000000000800003a37e44b0e53b1e664e3c3b68f72223b68913e55f829196c89e8f1934c7078b5853a6ee46b62ae69e690b6e095165450657706aa9542b26071f3e2eb3b8f253bf8a2f520ee3d878ab92d8c9d606040c8e650f1c5658439a4011209a685ad542655a7dd30fd721e312728fd923ad81aeb8799f983e8b8ad3a6c929e383aaf5df97010001 \\x3076fd8e8f3f17415e8ba5a2823fdc0b72a7d6de9ad44f699e76ba87544272dfc69325db49e84bd68868d9ff69df7976c798a6e88337f55011ff0464406a240e 1665490391000000 1666095191000000 1729167191000000 1823775191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-352 \\x4b0f50dad891be7819c845dd0fe39968199ec33ba3f63894a31803d2087baa62a8fe27774ce81287cf5071f44b20fbd9b369f2547ea474800df7ddef38f462d7 1 0 \\x000000010000000000800003a7cefed03efb28cc495050dcc6331e1a18e4c2c1eabe17abab8cf59634da9432da8a1da62a429c6972fdcbd4da993618f4e37753f0aa8adc4c0266e9a1fbed78dc17baeef6321375b8348315f0fff784d3cb247077aa2a0d5ab4f628a4d07aa4c0ab5fdc179187506e2fe08d8e2a7af59525baf332bada829cae71f0db81fe8b010001 \\x007ada93a99266fc2b252293cc664f971dd942ef909edade182e88a93157810a08fca2cbbad14d4dd2fb717bda454bc6b53d048c20738421ef7ecdf9799a0f03 1690879391000000 1691484191000000 1754556191000000 1849164191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-353 \\x4b5b8e0d97c8d215460627a213af5bff0324f98314219f4bce212477a196e522759cfe29540628259b74f03af6c0f5d48995aeacde0f31d7592d8bb6feb2ac52 1 0 \\x000000010000000000800003c110ecec617d7f0c0629a3a64b93f62b2185e283c59fe7d0ee9d86c12af0998e4cea2a04d86e8ba8ecbb2e5d85808ab3c201f799c74277cec5637b2836aa6c7d7113d48789aff49252e08c34d12f534840bff3e9e008451e7928845373051582c981cc0e507d9501476ba91cddfe339c0057ff105cdab1e9a1fd767de8e5bed9010001 \\x70198cdd888c711d171787b0da587c45d6a466e326bb7cf8d19ee47d4c448cccc9418a564a2d66551daf1c82cc029bf3a7c1e7944131cb84969de8f44f3e6408 1683625391000000 1684230191000000 1747302191000000 1841910191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-354 \\x4e673fd8b849ad17d3ffb3841385ce9347ad0c8c3b3a81ed59a523930fa1637e5bbc3933c0f10edfa77fb460ea00fce19243d424e3f4204bd94a5d7a14a1a49b 1 0 \\x000000010000000000800003c4e6878a5b108348e46e2b1ee2b2b28eef535c6b0ac1ae4caf0219d2b4e6ad63af1292ad5f168ba5e42c9ecd7b2c391b1245e3d1f577d419447ee85a4585b44eab90b108cd5b389a0340121592ae37f7f695cc646c9cac3d1c7475f48f0d333067c52b7771931cc9821bd5be097a8fea9d46529f4c2a8d912ef2e7bdd50b3ccf010001 \\xd9f90658f0c6079984d2194293cbc37899576240e2fd523273037c36187549dcdfa5f9028222aeb21215c981c63039fd4dad796412f301d28dc7445a782bd70c 1674557891000000 1675162691000000 1738234691000000 1832842691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-355 \\x535350aa8473635d3925490f41ee1b007b4b0b0162b7b4d88657823f0a4ec70ef6b018878635be771b8963c69c39efe96a55ad283a9865c5d549942d00a83c20 1 0 \\x000000010000000000800003b78eac36cec26d9a73ee3bd7a4702fe3bb9e03902e0d923153e7b6b85064eccdd942fb8f2ce4789ab0ce15f44d77f69c3e5e088fb615f2118716efb30f381a62d0a6da44965ceb2acae4934551aba05475e5bbb11e1a6e24f7802851ad3544eb95ac9e67bb42f0364461c4bdb9c77c4d1a9d8e43a543d3041f122293bde995cf010001 \\x6fc343ef4ac988479b81e7fbe2232372491e1619c5b8b03e1d80570460e843331dd53dce8e73bd00c79750130b82bf9125512be31264fe7559010cb75bf69807 1690879391000000 1691484191000000 1754556191000000 1849164191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-356 \\x54e35b62aa0d7a4b3d8395906ee66638cb45dbd05bb643cee6886641e372ba7bade0c9712d38f9f4b956658d36ff6aa22b8966bc6ee89fa8e53a3b600de4c6ec 1 0 \\x000000010000000000800003f33041b95c3398ed1042d2fcd410688b1cb91ef0291ec0f8032075ae56fa2854828511684c7cc81a603d869c03bdaac6f3e151a1a1842ff554aefa2518423e7a1e21be7b298895c4575edec842c53954f8aaef7e697eceef5a8d41b34e9d52cc70a2fac73b8ef8bfdbb9fec0152e09f4d587dda7d49facbd0fc5aa4038c63361010001 \\xc60eee10e6172af60ce973ba14a0597af06ff7c16e41306bef20c0ef3b16e050614954a201ee379e6acdc295c006fe8982531ab2804a50055464935a60ad7905 1676371391000000 1676976191000000 1740048191000000 1834656191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-357 \\x553ba824ee19de39b8fabe67b723bf7f5a30e6108b721bf4657882848565151419a9b7bc30a4055f880994951230f0e541528c5070b58499999b261dbd41b346 1 0 \\x000000010000000000800003b53fc2be4cec573ab504f38be5ff945998e9de53f47ee20f094e4da5cbf25ddea4b3a8d043a47d0ca9c0d0b6393218d86ac6db1f1c03656c6dad2a709b2fefd825b01a72f0a746e03bf9f2456d2956a37ead779504b58a956e59ae4ba17d62ba0d8f2e6a76ed4f95e9a5bf6b68e36896c50298b5496d7e366c76ae6f3ff5ce25010001 \\x99d85773b4a6564296d879964fb83c7fb6a15fa25529b1f5535c7dd9f005c1f719746a7cad5ad98ea7cce40730d84bd389dea1006947ce05084864ac77697506 1684229891000000 1684834691000000 1747906691000000 1842514691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-358 \\x565388069926d9e9d02e5097a30a37d907a63565a4b24264a2b8a1d326b81ba9d3626319f43d35de732868da7956f0bc4ae5c3671a126dee47cb8653c0b1da81 1 0 \\x000000010000000000800003e8a8b87ea6dcc1032716c46ddfc6ec2524d244daa841a0888a56e5d2c6246bdc965be2ac5554ef502d2602eae5698e6cb3b3dbf63c67592a13bc3c3bb0fd3ff0e16b2d3176db573837835548d56adc79e533dded4e33b015aae8894315227bc7b3fa8d1021319fd10c6e1b707dae03297df4a2f3a2bb91dafad3336dc2fc3357010001 \\x2d057a4c1f8b2bee696ee71d3c9779473bfd92b934185e004238ce6828eae7eb4c7180e3e6d626f09503da833464c6c1dd520fa199ca709d071eb8983f52420c 1671535391000000 1672140191000000 1735212191000000 1829820191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-359 \\x5ac70831c7ff7c5f1be87a2370b8d769b87e1111646921410759fb29a5fba31d9fe8c418bb292ab1311bd7f1e63e31558a6e5abd67217aba8e091f5af7fec7c3 1 0 \\x000000010000000000800003f07314a77e0fbf29052163e8159820c9bfce64af88f2247d8faf5497b5931ed8e0bd5b1e24171dcbbe59ccc6104e03265124b4f0941596392fb15e3ace1c33feb12a8ace6d8a122ddb4f5db791f7da070161bea96c2250ba19b8e520a08ef183f390746932568b0b8b1733252122a44eddf9ec5a82f5fa2a1a6bea18a53b1905010001 \\x715d1460a52cd12f39fc2f2cf85a162beabd87aedc2c9693247b68f0ea0640825485de47a8b42c6fe6cf51a87fe5156ee0de67fb201cfea5e247a594de63f403 1670326391000000 1670931191000000 1734003191000000 1828611191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-360 \\x5abb56aeb0438f4d7adc75f4d78c248a097aeae669222fb845525e2287870ecd90c11d76761fafdcd92c12bff154941e1bbabd7787f77eb1a41e48b2429ac9ee 1 0 \\x000000010000000000800003e72b0a94b2cd4613ad6a9b8665f5b49ec0fdddb9454c2fad4df741c42ef1ad3c3964e862d4527abab2d854bce9b960e4544d7a5061765a13ad0c913250bc4373061e83a55c7627b713caa6ee62d94f3a4af0e06335a6c980a423ec96aa06b45e07c9c16b7c787f33dadec85e06fcda65975710820d32dbcb147876e200026ec7010001 \\xc0e384df86ff878f330060add2c4c0a8624eae153639b1f84c19b1288221453a9998a4a699920241abeb042364ca63fd36aee4fdb91249babf27ddfc4788fb04 1670930891000000 1671535691000000 1734607691000000 1829215691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-361 \\x5abfa4929ebe9cfbe68f1430ff22af15412e02f490f7ba6102fa16b463f231614307f7bd4fb46fd4bd931c393c93fe2b0556685cff2a0513e723a457bfbc5fd5 1 0 \\x000000010000000000800003cb2dddcc5b5f18e828c92066656bcd828e6c33f44cfb899077a2f8400ecf70dbd4edd8929874452eb3667424488ed360b874459d947351d8378d747dfc4fe7be33442992351eed12d0025825c9e23eab4f70fe285adbf8f78956e96803576be63053fa19c68f93dd31a71a0bc2e8a76cc94d6e69213026f39042089d4dc43b09010001 \\x66c06406f50176f7f06678381783ddfec4f76189d1b09fc29e4284f5db644446c0c4a59cc0dcf5087fd207a49415c5029d2646005936eb66a396db6f0307e900 1683625391000000 1684230191000000 1747302191000000 1841910191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-362 \\x5cfbd103f812c409ccc69ab986b3b94bd275516439a0f23138ec8693fa6489d655394f422ea4d33be92a49c0b1ed7e6cb7ff159d0413e236180820bd21b6f6ba 1 0 \\x000000010000000000800003b27b130086f6032a49ae85a82f1215cb5182cb1f77e8ff886bc62a47abc11d70f76baaac84014ce44fcbc1b7894f8061ba2762e625fa28a204f3dfbbc5f453d8d6367705b2eeb5ec87272db9b6dea6e41338a1eefad8002e82babe41abe2d4c9b61d130cbec8eca0fe3e0d66344d602026cf6f27696192553aecb3fbaa3ca3bf010001 \\xd39ee33c232dcd269c81c49d860718ee4e1624dc616d836556dae11a05ba38cc2202651cf8be00d7b13ba22185acd5bdb00767dfe2f111d80248784d6bb5ce06 1668512891000000 1669117691000000 1732189691000000 1826797691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-363 \\x613f3093cc2b789060cd8dbafa5337d5f4b2fad2e0ea3daa7fee95c8177c7711b37164b38520332d87771770cd74424c5c47618082d1191bc6758603beff580b 1 0 \\x000000010000000000800003a58ed6fa49d6d594e7a44a0e2081b486e5e356ec15a141bc9b08b2c17882ad0e30c4276f113fae3c7f68537e17c1041d769dd64b7bce3b4bb39cf8bc3968ac8c0f6a95dd005f6804c46e4c173e35e31d2f5e5f8621dc0ba5a331500a0d680fc3c01ca6f4ed75b9435e8cc75cfe58c45cf6756f0f1cc762573d9080427ac6e0b3010001 \\x493d1d1ea084a6c72fc5d193d93d030ce4189f6779adf13083bc89c1a777c38fc85b6c18d6dc65eb99cdf5ceb99208fe77fef81e8a73bcbf092131a0c60a4a07 1670326391000000 1670931191000000 1734003191000000 1828611191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-364 \\x66d3d941363638738c599a3916f2a12b655fea631459481699aed0c3fd3c93830b09923a1f0e2e2c206f51f4758af9c4962f63b582068d43d695bcbe1ddd3a9d 1 0 \\x000000010000000000800003df21930aa6d52d10d7e5a53eb8d20e27126a320ae71d914effe5e2d3fefcc5309034bea3b6682746c154d89eb24904c702ec36443c48551afc4b19a7b6a959d74b1b4a08cf4235e85a438c7ff428f8d8a0d9db38afe5fb72aeeb200f627c4173a6bc80af81e7273bb0f52250766337efb4c80edef58e6c1bbb7dc8b3a48ff407010001 \\xb5b4ce5e8ac02218d72e64fa57fc67a2697e9e853498baa438575aaef4da84da7a4ee748ba3503663916d48c845978f89f845e433325ea04eae68f78c60dfd0c 1678184891000000 1678789691000000 1741861691000000 1836469691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-365 \\x67df1354f652de7313f78af1764d6a6e62266fb7621b236c943ffdaf7ccfbb36adfa412265d84af2aea6e7df1b82e438b4184fdcf8fc45da7c0c2c41bf91e932 1 0 \\x000000010000000000800003c9f1e3fe483d56c0d1b84eb4a4ebc118184dba01ef1b1e71621228c43f7b83eec1a1bcd5769e3345df880a15f95d32fab20621cdc6bdf5ba8ce17a628c27ba0c221129f7de7c16e6cf0cec7fa0dd87f6cf1270d52262124b07cd2c3a043655b43d3738f07d5e6b498e3a927facb0756aa34db2ff727c41147ff544e42f991d35010001 \\xad2097896777c9b503e666858f2c2e2b75d2196c85e918695e7676108c4fe67bc7d9233bcd2ed83561f22da7a4361c808c7eeea48a114c8534dd83fe5d95b300 1675766891000000 1676371691000000 1739443691000000 1834051691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-366 \\x6a8bae13453844d30bb9bd74f742cc4ea1a2d129deca6d60dc1b5810325573b8b8ad7de643bed60f73b376ac65bfd80bf146ad82fdd590ab39b88b4ba4471c36 1 0 \\x000000010000000000800003c8de41e406f6183395e65e73971fcb0e19c0f780e2b16912e67ebcd246668f0b3f5b5faad2ccd902486bb64f8fe5bdd453137925b1d6e70d3e8c364056a5dfa6dd36020ec4df886c971fb2e7fa19d35e25995b7f616aadde28a4e98110f53950c0082a5c76645cae2a650fe7dfad41385cdd9f434d9030f721dbbe38b650b717010001 \\x5302557b9a9040bda381487315715a98310e0115e733f1a73c89cc3414cdb44ff08aaf1967ed5410b64023c5fd9b573c4e9f06feeb2b250b821ecb82dbf3f700 1666699391000000 1667304191000000 1730376191000000 1824984191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-367 \\x6a5752d1761d96851c7bfd5bfb96f3b1fb1726a164bc18dd764801921ba36b6cb40d492697d13ec3dc4f37b65cc2ac6685f51203db4864262b6a43ca0b000c71 1 0 \\x000000010000000000800003d7d035e8ef657ee913a4b6e4d0d8c8c40f1d9e0f59fd1c902510a98c4a63e37b1a8f7e3723e7ff29554513fff108c08efeaf6c9199c60f7cde9435ffe835fd5404d030402f8a77aa199d4cb83c57aea19f8acfc94fa652889f54056009fb420a69f1b222cadffc3ece1d3dbd9367de512db50c52aeaa1e11361ea2110fc35e6d010001 \\x6e39409c91ef6cee0c9f2dfc314649a3df4e0c76af467a1e01533301fc6118e450fb580493e24bfc616543287a7bcbe7fc0985426664367114ed725401b5560f 1686043391000000 1686648191000000 1749720191000000 1844328191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-368 \\x72d72735127b556fda829d592461280b9647f566ff25c4479a81883da0cb58a9aaa1ec2a3cfe2b3a05e298c821b9ba0feb109b5a7f65206d0e000e57c05a005d 1 0 \\x000000010000000000800003f20e5712ee2f27d8e294881ea6897d3801b24b7e6927c49e1140fa65f89784c1f9775dc9c77c78789dec56ef5f6d9f1d219ae271d5f63c404784ab43294dfaa17eb89c42e56cc882100b1c0b8bfce28681ba94872be0f50528f89168b8c2299542a909ed1c4560c8c9ef40d3e2d58b8b27d375db49dee4e25fa013e7d7f037bf010001 \\x4df61efbda425e8bbf34b6e039c45c15e3c99683b673427a35323a8e56aed64f5ee1fe7797e2ceb748cd479b7f9e60201224db749d8e728be4973643c7227807 1661258891000000 1661863691000000 1724935691000000 1819543691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-369 \\x731320ffd290001d0d11bd4bc619d06bdb1e1b9f1234e524569d8a3e86a35366e05b4c73b678cb7430dffc68fdb401801a832a3bbd4b427cedca62bb2ab5a776 1 0 \\x000000010000000000800003d1ea7b5b7e6bd85db684d113516417074128041af5d6b76415abbd19c3b342d4260311957a4f4eb3c1e1d6b2627e3576d61d7c8334fdf9ebeb16b26fd5e7fae8495736b3e83a647bd03f0a548ab348da0576ac5d9e108d87246ebdc943f59a6707425a1d4cdaa29ce2f075fa4400dfbf33f17934a95c34f1db569870c600580d010001 \\x44a7130df4230dc8d85d80f2d62b0bccdb869c9d101bbee857fa5d5fa685650bf1b46cffc8d0d00d3d8d50c074f964fbd31507baf2808b0fa7c000acae79380d 1668512891000000 1669117691000000 1732189691000000 1826797691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-370 \\x7c7b1935692e91c2d717f7c5b83afaeb5421dd675129013e4d2d6b61009a773012d883c3c2a058ca20eb0f71502e301df21b9cb01aacf7a91310b642af6cbc01 1 0 \\x000000010000000000800003ae7a6c7fff9e7a903142456386ee2995b198667fd4a897d57b47212cf9cfeb0dc289763ba0cca23befa2668ca0fed3817c5dc06b80e03fdaacd8d8d17d669eacfb258e2d5cc4adb96b3b7085fe10d70e2faed2c9eb05653f51a03a4023e615ada6bd37ec546934ca763ed5382bfc4fbfa7e1bce4f9e4b451daa72b576ac48be5010001 \\x41150dec0200afcced8db104097424e470dfa87d4dab687bbfdf1831861dd8db0db86a4f60240b38b0fafa54f2bde4e8e1796e62d09ea7819d0e5a7f4e2f7504 1675766891000000 1676371691000000 1739443691000000 1834051691000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-371 \\x7cef16655e517b75edb25be5f4f062a72ac9d989cf91f37d1358df2697f81d3411f0105cc1de58dbcfe5e79cd49411fc1acfb25739b2b87a67edd15857337815 1 0 \\x000000010000000000800003c95aba29562c408250e8663e5f433c68bb45a8bdb5872a25402885f80ef67c774a451eab6b6a232cc9e32d4411f76bfb0fd493e2e565ec67cfe19940500abbc2e880da221328f9ee15eeef58be7e6818615e890fd3c57c1fe77cb1926ca6c2df14abdea1693ef43984a7bcb41257852b0035cc3d5b65aff37aed7ecb27d9e5db010001 \\xba4f9db321bab5caf66eed6a2e40969b44402c9744f0a878e035a29e9cf4699acb21fc4a5538029aef2aed5c921a422b7784376e1df247d4c8bed544649b8b03 1670930891000000 1671535691000000 1734607691000000 1829215691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-372 \\x850397ade6e9fcff71490da5d8866df6d2fc576d041b0fd689816700cd6b7741e1e22662cbf1cdbdef309b5fe0a550bdced2d0a83ba3b22c48f08a265ccf662d 1 0 \\x000000010000000000800003c2039d8648e7c52df5f82a1079473e0951e3aa13716e2e33b0b334cd8e3099ada1d57c1173422edf903da9de0a59e5ec3df04e04433ff35b4f8857267908d159332932b04d820cd2906ff6a04b3468bafb915ca5c1d1bb0ded89801999e1cf670b9fd5ee780d12c99b7c53927f9d90ace178381b1e77fb5410095d4977a5e47f010001 \\x3819cbc7a54437c767dc5c7c772b4c374ee468fd37703444c9ce0ec8cdad8342e22dfeb7124e3116504b3c484c5dc5cd2358d97e93cf21f313154cb8c545130c 1688461391000000 1689066191000000 1752138191000000 1846746191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-373 \\x86af23d1909c63d8764db577c789b866651f8b6f68d621a25085ea71f5f9a5760e864676b4d52b8695a52b2fefa0f8c1b2b8b8d275df9baedc0b8b5bdeed7f22 1 0 \\x000000010000000000800003ec587e5203ff83a6e2f0b16960634ac298344638837cce6566922a93191fa265ee3d7dbcc198244401bf5cbfa3adefea2098c02a835fb661ab5dc8c5bdaec3608f8c44ed79e56b918f605fe7d0dc888539c0247a4502dc24a0c076c456a44e05b7dddd0f1d269dc56744e3e9a8de8c9f8e7d48165fb1b72bcff6c97af9e0ce6b010001 \\xe3dba87bf9764b9d3439bd97dd9eb3ef62cc75802e75fbd5ee398ec55fc470d050a4c1f772ca76c6d47ee7f3d9aadec660648ad0a6bba91515173245ca6e6009 1678789391000000 1679394191000000 1742466191000000 1837074191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-374 \\x8ab7e1c031e9026111629e158929e94f9c80c8320486b6983c7fe381bcda9f170b4a5204debe0a5ad204e3a47a23231c1f798e5ae2cec9d2c2e5d5a33a6de21e 1 0 \\x000000010000000000800003edb714a18efa5f6888cd71e5d74a9970e3cebec1c8d067ba3b96d364763dd770784daa5ab2d12b58adccf9e7279aa78f4625de755bc547f0a762e25da020ac43f301496da88509f47d46d60300d135e3f7e48f092c14894faf43e1bdb3abe4dd4d9f14f297c588f79b502a218ac06edcc165826f06db1c0c4db9dc37ee7f79d1010001 \\x510cdde608d1e03278fc76f812d77e78102e5b76a8316bb128c6e07ce8e8893113c97b165956c885c9e2ac7fce23514396b54390b3d256c07c6aa5bc9c20fa05 1681207391000000 1681812191000000 1744884191000000 1839492191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-375 \\x8fdb20dc438da78618e10a51f2ab22336a7ba816d5cc14f285ef87a14cd122b1945bfa8f76dc08b2d71510db5379596c192c541f74acfe82c480f8d40a9bffb4 1 0 \\x000000010000000000800003be1017dcd116be39e5d5c96a7404d9c3937d95e141a161cb2f31e529bd3f1f5d1016344e932fd4b66c7d9ea9a19bde9a764c5a1991a1016ac3aee3685370f80aded3a226f0642bd110844da9e7efb4bf4c2aee8f7cf4c909c04fd8ed003942787ec8ee12c394f17f0ac6b38c75ac0dae4583d38b704d184b48777966ff2c2959010001 \\x36993fdf1e039ea58772e152a9341ea491bf802a235ca0bde2517eaebf95a4752ce3ebe6b30a021f6c5fe8372f0585cf15c4f79f3aa734e8b4ddbb776964ae03 1661258891000000 1661863691000000 1724935691000000 1819543691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-376 \\x900f5a899b6247f450573e83d11e43bcc2e3861c95887c4932d2d8a2f7701b362328af542e433959d770031b1249db5ba33706ccf90f3244aa553cbe7cfc4f03 1 0 \\x000000010000000000800003bd99ecd2028b5766ed08ac22952700513061117742b11ff5c0d153bb723c144bfd1ebe3bef36e9fa8d7326e6b1e8c5ee6d89a73b441f4ef478df8153a5d6d33930e777fa2f04e41475290022e31d48d5baff57e8fed73b3d0ba121d35ff4099dfe9512ef528514685028109ed3843c975f04ecec961ec0bc53f0d644c4d84b2d010001 \\x0e0494b69e5e9dbbf00c8c5a3d555805dbdb6134b50749f366df0252422b8da387a1304571089539d137d17de3191c4ac71eb0d12f2f318b5f762411da37e10d 1673953391000000 1674558191000000 1737630191000000 1832238191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-377 \\x9167057e80d1f128b67d471e9e5b6d37c42d5e97f8b00e1c4fe94ec158c87f37347ebe4457412a4e3aed066ba5796a6b9428cbb79b0b90dd1d521364169bfee4 1 0 \\x000000010000000000800003bdf6e2bd08c172ee2f2c1a7cfd8b346702e8233776dbe1d21cda17b4a7beb648a546c9d834e15d1b433399cf67b1d850c0e026bdb1df9d17da88cbb2605feb6e1ebbfeadc43be6147548f4bc0ffefa938fea03ca8a21fdc490d8e2e5119dc5077f22f0ed1065d34c9abc2f1db8a02a1157bc1f801f1aee8532316d7855623831010001 \\x02e15876d251c2274c3239459d5e4e032107e7a1f6259f1a19c5f1715d8555a994ad451ea14d89e41465a912d7f2be04677df6d73b250b9ef313817bd9cb680d 1690879391000000 1691484191000000 1754556191000000 1849164191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-378 \\x9313b6e98af9ef0d1fae88cfabe50bb445942d8769105ff885a7879be03c0a4ceb4ec0398082df68b93f023af03ca1aca1fe74c5409ba588da9c9b9832d670be 1 0 \\x000000010000000000800003a0a7b26f14ba593483643ae615e8c928241f32764e8676a7d5465d3c1815cfa5502b0182812ee9f3a5cf0e010fb8b018e0eedfd9b426088afc68e67bdd1955151b3a830904f35166f1db5ddbcfe18c13adfe39adda2ed33073924f273119588c4b24db195996b7d796d7d144069b24969fe5a63b1e1472be15e85f65477f65ff010001 \\x9a2389d0eec5faebe1c822cdfac13f57662c61f59a5c0018bc1e1825bd63f60a9b87f3f976915bc688341f5f80eace9583cfc2e37c15cb11e70695f4a91f8e0b 1661863391000000 1662468191000000 1725540191000000 1820148191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-379 \\x960323fb9dc369e3dd76ec552caba93b3052f1cc03499b3c4d4d0f0c40d1f02aaa899ac9815bc484d729ecc0b87428c63546ccb38ad2cceb44155e1a0fef66eb 1 0 \\x000000010000000000800003c18ea53c8e89e2c44c3646af7727047f5630f45efabd76744aa48938a5d5f784a9e1a2703cc6880e99655fcfffe848c9d9491a66242bd684a7a73dd8c715973b352588acfef3437c16506a6ea2d63d82561be655100d3020c5a08634190ea98e8cc82e3003ef341b8769e0ae228a5b374a06e6edc0d5e3962bf316a09cff35ed010001 \\x183d84999dd14eea2df3b4d549b0bc8fdb021437e9052471bed7ca006303cf5499ef70b08dfc4751e2bca89d50a329d6e048c2fc3125f7e9c110b738c7b59008 1683625391000000 1684230191000000 1747302191000000 1841910191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-380 \\x97c37a4f5e4ad8229834c5c353cae83070dd8307ac9aa79478083aaabf42e886e24f2f90b114a5d2082247912411e95c4dce795d7792056b64b013b6c8359dd0 1 0 \\x000000010000000000800003b7c8e0adfd43d853e0e6f774ea9becced3f9bf1ac7500b21982894aa98d114ec50ac303ddf8f916e56035fae57d12823a0eb9db08d247079c0c98d4d30a0c604f2cc2d90b38ab87f7074dc553db874785db066b958e5f03b86ce7386ac89d8b4da123db1428b0fd4674aef3be01e43416b1bd0ca151a0cab7af2d0c6ed69612f010001 \\x5594b8ffa84d467677b3ab7856ed2ed2bc266c2a72528a1c66875e88f05277cb03a91a09825da9c927f43e6af2c1d3fb1230fed34f7bfe38190cfb1abc378205 1669117391000000 1669722191000000 1732794191000000 1827402191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-381 \\x9857f315772e5438f7c87fa90d8df967dd56f3e483048c27a2903d38026c10968bbbb8426fc3271338a9de8d4c1fee53d010335165587f0550f82aec13cd4c0b 1 0 \\x000000010000000000800003c964770f0cb7efa7ee9ac804c98e7d04e4664eade5cd6e7d863e3de5fa25297a1491b2339319d55bc32af57d83edaa293885497c2738178599826808394db09c15948ba96000a564a0c3dec3827c7d4c7b5387c3093081f61b8b1d9d39c0d415379953def6e44d4e7ef2a6485fb6465c179de2c404d057127ad4d41b3c204d87010001 \\xaf5f91b231a73095cbb6b43fbc8096cd8e90322afec2f700e11ba5f1f1a5396a1791cae3c19b9744deede42889562327fcf191c8b2cc89a028ba2914de1f7906 1678789391000000 1679394191000000 1742466191000000 1837074191000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-382 \\x9913c22d604b33d5a81b52996f4b68b28d7c85ff7a88297b494c20662c08819ae88da3c5bc0b7b253dfcd1996828f5030e10638b85c29b38683b738c71f91ddb 1 0 \\x000000010000000000800003d346d99c44ba0da5007b54820a90a56433a294fd78a5591c7496a0e937cce3c825348d5fffd845d351893df669518035844cc8c77b5fa34035e9c6d5926608d6074e5f29d2e559ca9719345f4c9c6c09799489e943982dfe80e4ad7dbd501787afdc11454f56a5587c5750bb602183a01dea90b478f74a1be414c47197068be9010001 \\x613a3583e809c918fbf5115479afd8d14045356a51f1c3927a4e2c64e23f0dfd54d9eb2d4655a902331518f4b0ead223770d0bb3503cd26c0f1beace825eea06 1675162391000000 1675767191000000 1738839191000000 1833447191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-383 \\x9983005b3b0fef75f74ea1b4cd356dced0bb5b008274520b02a8b6d730123902665e4ad563255433abc842e68734e060c609fe44043468adb6fd02c10a4381df 1 0 \\x000000010000000000800003b299061d49ca1da4b5c6b8a0d73e292ca920b0f6b885fc25c865ebfa57cf435ecc4ff80170297686c0e33d686cb2cbe702d92b90196403e306e6ecb0c1732152cf8d26625b0dccd2af16a10e080c1f0978f6f2bbef18e05bc7e440773a3629e46d3774f3ccc39be7ed60745e9e350467a44321d2232b58b6cb1eca4c288f97b7010001 \\x4d7b5667b3797ecc8773d98b1b55079aa04f4d73f66963d3a1aeb3635f9112098023903052753fde3a5ea5f73e541bbe956e88ff082b1eb483da01387501f00f 1683020891000000 1683625691000000 1746697691000000 1841305691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-384 \\xa323e82a6efa801371262503e8d24eca4d22bd0caac6ddf90da9fce09311c2f681a568c2309afec0f1668f7646154c6c789b56bbe89056a0af9d74ff3fd3b764 1 0 \\x000000010000000000800003e706e9ee40f943050f486d15189af3705a373d535e2a6103b2b6e7aa496b9fc6a415213d6510a0c3c9b5bc8db0c8be339a3699a2669f700604bb6d0f8ab6f3df6cafe5d482c10fbccda999236571b5df6248b6503876d9e95b3f181cc03c58cc9cdaccc0a1bbe726ad984007a72bc89c48c39adf02fc2892e08739df22d82667010001 \\x9a95037025370451965dacfc4282ceffda676bb708acbe6501f9f1f547b33cc6367d93d47faf74e6204335458819e178c1e501674b8a5a025d749d8f817eb704 1681811891000000 1682416691000000 1745488691000000 1840096691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-385 \\xa4932d0c2f4d7fd1f8e98b6bcb235e4d6494b7dc2f087ce2a6667978ac9b8f56792a872c0f8c2b271c21f731d1dab3eaabcb6f8064e3f9aed702496404fdc3e3 1 0 \\x000000010000000000800003bd8f45ab7cb7132e67a6770607c110d82966cd0b64dfdb25fcd455e4b9905b3c2b5fb7990c4fded4491492ba6e6d7138e73c7d6ac027ae6d555e9dd10fe6c02e9f790dcdf04c6919944f05addfada4a7c310d4de270408e6992b09b3835aff271fcb853d969c65cb74c1ef863cf9c7471a30b93d0017b1634d6623252cb768b3010001 \\x654b4ea61f59367acc617332dd40adbeb90cdc96f03a43077b3cebe0323c64f34e087ae9c1d4444f6a592e2f1609298ec13937eb4d40e5e62641135a13b6ee07 1670930891000000 1671535691000000 1734607691000000 1829215691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-386 \\xa5574b5970f7346af27527804bda29628f18ea637ae098905c59ed98ccc9ac1d6d54c836f320de5e2fbc634583a8593ee99f574e7bb0c3dc67c3cbe39da7e2fa 1 0 \\x000000010000000000800003f037d10f082d8a58b27d6516fc770389f182274835e99a69c8caecee2d96ef498782a9c16150e028c3c503a0400475235af389b0d74929f4d1f96ae780f5dabb18d2beb3a99bca749e95b3ac097b47f98e47ec32d452d07956e68696bc42a9f2d1e497ade99d775f19f2a83e5601c9fab5218bf54324cfa611d35d2c9c7c6205010001 \\x3a58841966f2867fc0d8e029000fbc1ab0cd78028af35c045f981b648b4d88f9e766086b108a5c71f14bd3d6ec0c0e80d43ac3c2c281b4bb3ddb296114ab470e 1663072391000000 1663677191000000 1726749191000000 1821357191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-387 \\xa7879c0f982518b85aa8b7820ce1e721d493b5c9de4e7947a8828bb336b5dcecb8d97525d4a273c3a4c6b19f3ad57a3918e1810962af979b16984a05447acf3f 1 0 \\x000000010000000000800003aba0aaa4f2158fdb927f394d8175ee2e7e127053d057e9e3c4ac16caf624727971b796d23648e596d55cd016ec802c5653f9d23bfca42cfc1d30aabad761af1ad0056a17e01fc2732019ee01e4f64be47444a814c49c7d15759b9a0391c43a2353ca997849327afcb29b2be18245a799a3f27e60cf3b5c207d84f037d7f8fe25010001 \\x68ff10c1d1d9979d250a344c1f96cf0d0fb7f6e3ff559d2c75ccdfd3c91acba9e2d7dbb6176104de0091803c51454021bcd2aa4ca927eb53ba1ddb02681ad209 1676371391000000 1676976191000000 1740048191000000 1834656191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-388 \\xa7373a85ad017032c4b9ee0fa125e35f8928228ce4090221bafaa4df6c7855fd05cd11fe0de13b3fcbfab498e78b4a636b81b4b5e331cc79c2e598e04d735d05 1 0 \\x000000010000000000800003b8e116e3b340495e5160ce8f0cdcbf0325b0e81f054f7b427d6a8263ca2b2f21c850d9212154a7557dc0e046d2e1b1bec804f61406e25d297c2145b8f2a3a4e255fe35233ed7a28a3d2b989710e37270f2dde7bf2850d09caf6004c56bdf68f3efb9827572e3f4dcd2df2505967e4a6cb8fbf40751c42359e8a42684bda57a4f010001 \\xf4aef45a8c1a1006ead5d635201576fc3f896b5c247858f612b6638051bb60541fe65b6bb1b1d4db2c1afab26072a21649bf3abafb31c2bf8b1707f14601ed04 1663072391000000 1663677191000000 1726749191000000 1821357191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-389 \\xacef168665da9124232d9ace70808399a3ff3edace123701e07fd8d84a013f1e7d00f81f4c48b150b0e5dfd6a6761dabbd31f1533fc5d361825393d98f23e9d7 1 0 \\x000000010000000000800003c374f4254ba4c8c9328c64b8d4d19b4dbd6a7d20df3b3cd96d117abebb212b75930ffa920e7bac380ab60ffd0e1fab3c7d948ff2bbc56e774becf5f8135d913c981b48acf0ca437d9a6b76369f8ef067c7380e094d82b5f3126c38930102831116e679d58769298b970fa9a275d8826db28ae25e2beea1e1ab2589228d9ae445010001 \\x41d923ca68ed11ed7596bbb9376f13bb3584b6e846dd7e84af9a36fca88ae4bd067ae670a1fc3189bec014a4dbc553619bab7ac3e5fbd29cc1c06d3718f14109 1675162391000000 1675767191000000 1738839191000000 1833447191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-390 \\xad43d087295c33c021a6cb15e6f7214c3a3708a2befdbe5fe5e418a3b5a72972f4401dba4c19db61a320613c9345893d6d774a39d4ed9010a350d67177d8384a 1 0 \\x000000010000000000800003f6564ec085d459c17bf233dc48440ad647ef6ee6ee3a2b1e00684a525866bbc6c60d60b73d00af933a767b5a5acef6b6befc01a3ab6aaaed104a6f2134bec571f0a712e1c1ce07390695cb983f185f7736dbcf119c09da081c257955befca86c9199db7286ffa4c3cb80a35b449613542a20e2445d7ce11532515b9ef3c0a5cd010001 \\xd45bc9c67a1ccf989a208635ea43f56c397c1cddfa70d425bf0a30c089a406ccc8e07dc599ee2e37f6cd9cd84d8efc96e56d8ce6671c0fa848db202874a9db00 1666699391000000 1667304191000000 1730376191000000 1824984191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-391 \\xae5f86d951ab7d8cd40d48beebea5096b5931ec53b6feb858fdba1f3b4f6dcd5852b93f32c327aed32ad29a9cf38cdbdf4badce01cd1bde7e7f3914cf04a0b0a 1 0 \\x000000010000000000800003bcb39d968a32fdcb7cd99e8c57309b8cd3a4f093354c45070be1028e727a85a8855d7a75533e316cebb55b921ff24dc559f9a5fa3813d7df126916aedae0c8f26815bb5e5a00ff85b5e03fdd19f7dab0ab69e02e9f560994cbb21e582e0afed1ef4771372fe4710a6c42e53913d1943758297cb79ad27e12988cafdecd04a1a7010001 \\xae3d57500b3f0622e719bf158d94b99000c96c8034cb8ef41709588bff132fe051f08ca4127993e5230ff578d1bd975a8f49f12392a4e53861dd7dbc14134108 1660654391000000 1661259191000000 1724331191000000 1818939191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-392 \\xb0c7f37ea2899e1d010246d342470ca6ea00f59cb7b19d711c9b94a31127374a736bbe0e844ef5a78e1693f877447bd8d1da9542a138d04364ca6d440d074809 1 0 \\x00000001000000000080000398231dbd949deb73e1a46662ee8efee4191becc12aaffd099ca6376d8f24948b3e9e82151e97deeee4819a3db9a8b73fffbe1a35a7dbe07772935286f96e0702471293f7af3d06d1d146c991d8e5460f1f89c1032641d278a25b1d7c678728d77c8f48563cac8a165bc96b1b6dd9c6e2f2cb8c87f24f1fe7907af7e2b8746bf3010001 \\xc3cdc711a96ba9f0ab171684460ff3bb816ba250b738b74402b0f1512941ebbe33acaaaa31dc1b2d51bf298c356f6c50d74f3d67c1681bd81c824833211bb304 1669117391000000 1669722191000000 1732794191000000 1827402191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-393 \\xb27bb12ddb8b19c18103408754a72f8130cd198ceac1359565b4fe9fe8a03cfcda7cf771dbb502b89116273bc9fdfb10fa46837479868a0bcd62bf58c6724824 1 0 \\x000000010000000000800003b1069d30bb01464d3ffa28415ab70ede90f8829b707daac9c5c683c54af65de814be9d7d8c5f314bfbe01eb88c73b54a4dc39f1644de41e4e75b701f84a2cb20f6b5c6426afe2c348e07f46bed860f6ff2fa0f9e8575c25b4b25059e4525f80c52fa6c55e518dceedd776b2dc5a1102f3b33db4b5c4e849b784f72aa8a6aef71010001 \\x180c467759d2709d3b326399f1a03850b4f87e3f014b709399adc2ed9b0590585b964a8867e2181a07cd4bb7f8c559140d4e58d2bed7df2907fd9a06fb235e0d 1670326391000000 1670931191000000 1734003191000000 1828611191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-394 \\xb3f704c905f088be462d2941ee3475a5e1c8f38239407bed9c844f21f69e044380333410c91b33d7142a349671b50aef8b458b6f7c3583dba542a50d619b6b49 1 0 \\x000000010000000000800003a29ff9d73771273f9429617d785fcb7e59946df595ce1df1352308f4d41b76930f9876f81d7e95ff9e641d5963490989b6fdbcd814add8ff11187c6162668c1e10136d61f2801bd43f24268192d972e4f5f581a9db04e9d74f6efd069683d43d6c2e2530cbc538abd7b8ede7b49b7f906028d3c3dd6acc0287ad7e3a3bba0165010001 \\x9206a5d2b29288c96ad2a74fa3826b0ba977543ab2e859fc11ac7ba95a90315ae2a4c77e07445e0552e82344e8b4e1a22773c6c61bd5f957ce5597b08ea16604 1677580391000000 1678185191000000 1741257191000000 1835865191000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-395 \\xb6c7a8b73945487f74606af5479c699a68f8b494aa04b4411523f16db952f7f9d431b861aa21db3803df08949ccc21e4957e843ffbb580a2793c737fbf81c61f 1 0 \\x000000010000000000800003b838f44318ec9500e9bb1d7ef82de8c4d1c4738b2abba70d31db4f5d2ec084f44865653518b517ee35fb4c6b4b9d958f93d7b43f0cb7d03cbb2a399b41adcd83ed4a50afbe555463f90c4a36bd204074b8f7d7664776168994d537783cb37784866ee58eb6ac0dd08c22507e22b473832da46eb1b2940898722fda461b5441df010001 \\x38bbd4a982ca91bbb9b3922379d203886a23257f42bd7fe6e39c3ce3ef3979957391ce850f8c4d7dcca6827c2fe16e7973c95c1547926b137ad49d8e2889ba08 1677580391000000 1678185191000000 1741257191000000 1835865191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-396 \\xb72360c23c30d1675cfd2733c456b085aa3ee7d413963ca5167d0a0d7f88d429f8280078924d2693aee67ca92a79b015df67932f02b38cd76472b433675bc1f1 1 0 \\x000000010000000000800003a4a94872a5998a7c7b0aabdf0cebd04cf8ea4f587c0c62b89879d26c5249edbe01c31b97a078b34267fbdd4159e625157ffb88b2bca49ecf4e602094a165d87991d972000dc380149da434418c8402c240332d36c57c4b73d676071310c2c372faeba7dc764dea6b5fef87673bb61e6b9fec3db786975195c35853ac6b6be4f7010001 \\xe212ddb2178abb22674b21189167a80d1baa7bc53aff7edba505c5be10e5d5e8aa968de8c15e16837ebb3d1048ccb296e91c30070a583e213c27ddab95838701 1663676891000000 1664281691000000 1727353691000000 1821961691000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-397 \\xb907e763032218b2e698fa83db375db39956c1066baa738c38aa163bcba810b9bef809653d853f3da53cf781a74cd114034d4fbf1264fa1117619059ebab68a1 1 0 \\x000000010000000000800003e06b1e34e8c7ed979c2707177a4508285b55acc047bb239ac3ff6e5713dd4b9b16fb3baa9ffe42b892fdfdf2220acc29993ef53b073bb49c1695470fc2f2874a2eed4fb19c4353a92bc618cd0375cdb49b7bee179ab5ef123fe4f60bb7129c860ed7a860e647d7f065e4d5865e547375f5ca85e0ea9cf16a692a960ffb3bd083010001 \\x00f7630172f0420a23247851449f898a2db4603cbd3dc76eb1f9bd71f86636486cf4c9449c8c34904832af7fe79b24e49ad29f84c9c25440db1d7476a3a68e08 1678184891000000 1678789691000000 1741861691000000 1836469691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-398 \\xba1b4e165c853fb2a4fbb183ec288707e81375f05066c18ec7bb20d642653a5a00ac19ba999746e80c40b63673ef2ff62d27f4210fdcc8142e3ef884aa34b0ee 1 0 \\x000000010000000000800003b17e4b09e099e283d0588c87c92a56615a1962daa19b13ef81b02d0f02b1c2e8b49cf69f2fb59ab80030ce63d0c9a4cb30a2cb76b541248ad6452493edc97f48559f1484ca9f55adc38b0881f5451f091525da7a369a08575b83bb7770a730abeadd78f1648a81cd3029d5ba5f4ce439fbc6903877a0a738f00c48215fbec13d010001 \\x47594d074ce66e177609376b28dac9b59d5577e72fe0fdc37409f71352d633dfe76015c4168c4f99cc93c509b9f4ea7e4fd480cd297aa14b3edf60faf4a0910c 1680602891000000 1681207691000000 1744279691000000 1838887691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-399 \\xbc8bbb537fab46ea64a1a611b83d4812af91a24db1c12663525467bf364571de933b22274b57bbeff47bb7c5e1c1591e8f9237f209612510a7ec90b72ae4e9eb 1 0 \\x000000010000000000800003e3c1e714d0da6e417cdff3b564b74fa98e642486ba3efb4f37e927167f992297bf4289ed476be6b1acd48ef649c1932d0e356cc039aab5df6220f1a9fd8e4b2a8c23c91705da4e093cf030b8c49d33d10e3b471562e28caccfae70d71934cd53db9ae1f97bcf95c76e8caa373f9da6c45f66decd14084538f3d35e3d9b1f2257010001 \\xbcf2504040a448ce4ad69cefd6b3c2482578ed74c89160d44e8b2c873d2b8acf35d663e09e5758eddd4cecfa83eac034077bd8e40a1cbdc695860ce8fd875f0d 1662467891000000 1663072691000000 1726144691000000 1820752691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-400 \\xbc2344ec3ba1743dbe6e8ca56c005440ebaf2aa88507e874d67f9a7cfa510664a4870608cd272c11d5a0163a68ba60bd1f9011d4b019ae8125cc54e8faed6e10 1 0 \\x000000010000000000800003bf03f649e6774d14b563a5ab7aea1098341205a1cd48583e86d4c7fe16df65b082dad8770a4dd31c6c8e266bdeb22c504a476804f1c89573bc07ca29213de2b3c7e741056a57209b53bdad11809995907822561ab6084abea57c8a715b11a898fb22927075017a88b44987e0da8fa0d00efc3acee296914b047f01ae0e65567b010001 \\x1cd7c908f0a925c78ed97625b99ea43ab0c18ef375edfd2ccd6f2a4b6d59f60f505be03da04c8730bee8b070e9860a9d6062b720b2719d385acc2eae04271e04 1670326391000000 1670931191000000 1734003191000000 1828611191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-401 \\xbdefe769ab7a57f8d04e9eebfd8d1736bd12ca6ba2accc321b06f5968b578c4d48be49438994b1d028ec0ab09c4dd13733d9032a3b6bac20564ac8256d390151 1 0 \\x000000010000000000800003ab181870402060327c0b338934dbcaf02f7172e971b797e867ec292caad13b8a2c9ba67e047cf1c1ece0a992ac1432ac10942d09e063133b4b260761f431bce4839a9e4b3876e9586eaa9b9a35f1c05de721a37acf7b305c4b0ec31f7b4b03c32c0a5955aaec7df80a7d2367af241978ac4c136d7f99f15b73895d0060d01e85010001 \\xbf05ba847c888c9f83a2d2231684bb5d91579ee3d1e543628d80d774e071ec22933a4a11d412aec0d8c31b2d7e6a56c226f9379088aed256237bf224eb1a2203 1666699391000000 1667304191000000 1730376191000000 1824984191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-402 \\xc11f1c90eb4dc0a953cdca71a24dfc4f959a451c169529661a57b8341f4b6262ecb8a5205e739233f55f6d50f317c6fd1896ead46f30a451405e0f2a8a5f94e6 1 0 \\x000000010000000000800003e1e80646b706c83bdc75e438ddd4547ce2879065e42b6cd5dc5113e2248060a58fb916d72a6c1ab888475226931b900f4fe1c0c32d398efedb7965ade8cab3adb18efc05a170c1eba8ddd4ad498c7b1d9a002a08cef58f9dfc59e0ae65ae317d188704b754e316d1929258f4dff39adae6a79839340beee1740d3e2f15779b29010001 \\xd117e7899b6f22b40b6677b7161c8a55b54f169e559704c686ae4b0843003e1528722ee509c50c4c0721f923f02c8b07cc07a7189b8324031f1ee00101859603 1689670391000000 1690275191000000 1753347191000000 1847955191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-403 \\xc883996bec48272b9181ee565d4594eb933a72a5b34929b7aa59795c53a3f2615a326096d28bbc3a8b90cdc0dbb08a46035ae93a9de3c122ba65e69434756781 1 0 \\x0000000100000000008000039d7b9c57a1041208726644f0882bc9844a08e799558e6fb5443f1d5f81a350b2c82315fa33afd7a5aaa0381d2720d21350c95fbce989430befe9623fadd7a24b3cc1a473565cbd77508332e0e6ebca489a17fa8b4b6898ce8f65b5391df636d2255ea1c4f383190e99fe0ffb944e4920598660a1f45cb99b0b47cc3c9fd0756b010001 \\x66342233380ff5dc137a1ce6786d70e66d81b432f77d6dcba93529f8706586c227d813356881a79c74165ec482f7222b0f1f1045f3db9d9ba0d7efd3f223990c 1686043391000000 1686648191000000 1749720191000000 1844328191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-404 \\xc88f3dc6c90861bcc5895b18fe4a36c9c8eed0e6a958c928550b8a2b0f529b5ac81638177ea60c7946163cdf803406cd941822a7cc68f55b69f048eb316b1990 1 0 \\x000000010000000000800003f33c66c547fedca0ea2f9fadb18228fd93db5e51c9751650779f6a0751e57e1ee5a08419968bd902de1b2ce56206dd5845b52259f48b78bd16204683b0b4ad3961fe296f57e7263fd04c7eee1bcaa722dcd6e79617d0fa6890ad9495a4eb704108d4626582846ab5bfb7495cfb97d3a4819a223d83e0cd4cf3c51f6b8b561011010001 \\xf510a1c15ce07ebc7ab19dd130d958fcbd2d6f6f54e8e88e9a28b953d378219c9008e36ed61865b4ca5d650ac82987fe613e3101e431d5b9b48096271e9bad0f 1676371391000000 1676976191000000 1740048191000000 1834656191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-405 \\xc91f1b3f5625556d5e62818cd0317bda9cc2bd6b0746abece0b735df047a6b6a8291f8221a2ec665306b9076a27c04ff138a78f9f6836af550df100cc7d70718 1 0 \\x000000010000000000800003cff19de0a6f1a8b20c1fdd6706d3a65ea8d12e7200ca786ef2e0b8c78e80f3cee57b7af0f00e6b8f48117874228021e51aab288010f17fc468eac9f6af5034213156c0420ada07dd33c881ce40193f2d1475c0179de773893159ff735f408268473200a420ff6be7569fe9d71eba7ae4d9f89dcd407c076cfb8ec619401b68ef010001 \\x13b5c9f0da334db8c16d7aed97b0986a8cdf78b5afb22889ef162778f4abcaf155b2b906618135ada0b0f608ebccb2c00e1e628a3c87e895c49f9f6ad12e4f0f 1690274891000000 1690879691000000 1753951691000000 1848559691000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-406 \\xcccf8d9adcd937d20bdcca9b106ab68ad906fabddae48e07ee0eee991c66ff40213ae59cb6f7573c359cb520f38aba34292ee68864888229a1464bd98edddd7c 1 0 \\x000000010000000000800003d75e6e06f622cf8af0b1e0002229c7394610d91b97815059981fc1bfae623fbf1aa3128859e2a80e7b4ed581e1b03b13c54de8b2064dc85810114acdedaad016c375c21c53c428955aa3fcd4c9f124ebc527450fe3f56d85e53a3a8f53bc1308dc109f3d985ccf35125de9a1310386c37bec5f067f5e21c8cbb433198439c877010001 \\x0b7f14348e283e6ce69fb2c85da41790e76f76bcf02bbb458e976be94e8bb18e947e4fb0825feeda5541cc13d4c91df693c3dfcb216078adab30fd04c1602308 1660654391000000 1661259191000000 1724331191000000 1818939191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-407 \\xd037daa687edda0abb90eae586fda8b94547550be0e1f8dc63be8dac38c6fcde429dab767fa473e248ab1c119dddbc00959e2d48f41413a165d12b29f8496893 1 0 \\x000000010000000000800003c497045a08bda3d99de9e33b897a68c1d4143f816e38247c60799acd9574e8d59cd53bc0da23aac9c2b1902edc548ad084918b001cb668edf71d535f909c30d6cdcdce913f8a177d62ca456783e5185258c72813f2219456f1870f235d0286314ec3eadea5b064ebd0b95bba89f09fd28ad4829eb3bfe72d8f6fc5bf5407b86d010001 \\xe81d1fb4a24a43348f6d132af693873818e9d971675c7e64498848caf92ae8e389dccfd5861d8f7aa8094a8715c6a3531642313a450a9511de2ed5980e8b3602 1683020891000000 1683625691000000 1746697691000000 1841305691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-408 \\xd0376dc3472152a9782edb97693b3bd0255413da6cf85cd7bac0bbaebe7f548d6d8157a38a74a74dcf5012e3e20c6383348452f0fafa93c7d4c95f70dc7fedfc 1 0 \\x000000010000000000800003a87e15a89a5f001dec42a8e9305bee781d19d4ec1663c167d6c77fb6f7e20d4e53db22a767db2c980a768a3cd3fb3f36fa8247859360ada773d7775803734620926ff3d3a4aa5642d9247803bc1ceb5e252803b4b4204872593c5203e06504d0176739e0615bfc90518ccf0ce5ac351aa373fe868837f029daabd5899a3b5bb1010001 \\x1ae8ab3f5aa1400fd17708177fd9b37e26ac307fc9301b5eae58e60083e655e1cfc1fbe1b98ab3037cf2946ea0e897be1a607b6491faa80c4189f81dfae0620e 1662467891000000 1663072691000000 1726144691000000 1820752691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-409 \\xd893219315c66225db4a7653c851250f7eaf36b7369ec315abe89decc79b750248395327c9e2e0c15ad6b69161faa2f9da801c1a9177c5d82cf78d0e73abb95a 1 0 \\x000000010000000000800003df78919709a336a4ff1200cc9c1c883e703640a7ad666fc4e14a950dd22e5f9634f5369c3d30c44d144b5e5cf1d3a56386fcc054d0293ab7704b176f2e24eae93fbc7fb4390b9cc5fc20e2ef690cdae06a43ddbdb8bcdf0f21977ea9e724f9a787e3695d36689f09105630162eb9d05033c64f69b3156269247599a43575a95d010001 \\xa20461b709284391a635de8efb6d362761149c281c112c692ee239b837a86926be74d529ddd40b9f331e0a1cd020639ae4172f5ae6420effd1112ce64d97f702 1692088391000000 1692693191000000 1755765191000000 1850373191000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-410 \\xdd8b694bcd9810e381a24e05db6f37ab551aa50ee37c77acb706627eee9d5904e6ad63e762d12f8ee637ad7042dce6bab164fe4b84e8ca96974749c9c1e0fc60 1 0 \\x000000010000000000800003f4957ebb66143c8e8135bbe6ca65d071593cf2c54df3292f093c80c86e30923e3327e314b2d82ded21c4e3a82d4abddb84d3d90e2f69406fbe4d5f07185613177dd5708761579a79e3f310fb36bc46018bafb36821a2284859d12bde8097c74d41dd9f1d4ebb596f2aa7ba01ef98a595c25e5c314375ed110397e4a440387dff010001 \\x3e1e0cf9282f36c8b9231746425b54a62f8bc6ee508600ca52c7e33c82824f1da509624f2ffe550c4ac82bfe4f3aa228735c85480c6c090bb6bfe06bd5dbaa09 1680602891000000 1681207691000000 1744279691000000 1838887691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-411 \\xddff2d00e24404a145ba4a1e7200aa6e85b29d0c014f29f7e96b3b9129586c67e13a94bb64ea8bd86f40d287766803fd2508ec8402e8505bc99a1be7a4f0a0be 1 0 \\x000000010000000000800003ecfe371d067907d8cfa7732fcf15199b853dc314456f5982b242121c557394bf6686eb5b16e28af8db437075decc5f61ed5d00966dd5ddb3239542510664d94a3a2ae770bdc95b0df3a351e7be3b5b5bbeb4f75e95e3f6003d53aee0f98aac34bd04ef281be55cd58cdfc2b41eea144ae7e0326815833572b5f978c252d1ef1f010001 \\xdb0e46eb07bf0b1a93891d6cbeed2f8ce4e01239c999aad2f02c0c8eba190e3ad4aea594cd97232f5a646f35d5dddcc16d5517ae5d13464912eb5caac3e6d10b 1681207391000000 1681812191000000 1744884191000000 1839492191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-412 \\xe5ff22e8904969989c4bbafbe1210a8d3437d19e9a2b691a00f50fa22afbd778495408639390e9d7b5f69bf8025cd7746d6362c148db0ca6a4d8837bea583ed6 1 0 \\x000000010000000000800003e60553eab984644c521a0e21f8a35045eab3dfbe1b6bbd52adb4611a19493101d363257edeab3ef2d7c86f9a14a1f9fb6966021f750c149364f05fa7b4b25212ed91dbbe09879d63f54af5e512c2ae70feb34213702b8626e50bbbca0d9a64a03cca1bf0dacb418dc3b78bc947de87705f3abb52a9faae1b161e6f22562334b5010001 \\xd7ef13651b5819d11fa7f5ef68945bc4585c2bd1f2ab620e13281fab5718d435306452477883621d73018b8521eed64f683053774ee58e53c7be76a32f98cb04 1692088391000000 1692693191000000 1755765191000000 1850373191000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-413 \\xe62bb216d35d8f0206d37aaf87d2ee5ad114e6d69f2d60ba8b83b9cdbc892cd710a847b100f5bc982e7af41f5df50cfd1c5c6270b8b7940700ceae4136dfffed 1 0 \\x000000010000000000800003a58845a92351cc3004123cbc09c4eed68a70387638a81054ccdc2e8c054b5144be6e21e6c2985d2d42765b70203eae430700259192ad4974be790ce8015f40790ec86dc1a7d25d6130e7eb20206f5d419ed5a8b49852967aa9903c1dbb45b0c146e4fb61e8bf394ed40bf4a372f7252cb5899e2786567efd93142b5e9cc4b17d010001 \\xbdc9b4c1fd480a702ba36a6f9f00a6e39b9c632fcd2ef3dcfcc73533abc70d7dc91d924ace21898e2ebd867ad3773282832fc2157ec181e36bd9df3b9533a101 1666094891000000 1666699691000000 1729771691000000 1824379691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-414 \\xea97aafce26dbb55f1ef60be73ebf966f9563ecf3fbfa105dd1f90e379707fb9b269783abd5ebbdb24356d19957ac127eae379d4c506c4ec55491786fba62025 1 0 \\x0000000100000000008000039b28e17e2032959a65a786812b76cb148fa869c99c7b60debc92530fb3a73ca390add9a3a10d758f6aaabb13eec0c5bad6f1184f337fa7cfafec431a3979e5c7216a1cf188c0cd252e19175fbd5cd86fa62048858648de0fb9a07e8bcab4cc0dd3ac0e21114775c42cf5e8bbec059aa7cd9c49f93a2fb392fc7c7b75391dd5eb010001 \\x246152999f3a8b37014c807d163fac059e434b8e6e5cba1a1efa59392942b810c2bad099a153cabca0fc31e792dc14b04e681feba4b2f5dd61033428a4639806 1662467891000000 1663072691000000 1726144691000000 1820752691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-415 \\xef9fec7102e807be20cce7ea357f1f0a18b2308b2bc014faf29d88d485d62299b3d5aba2596d5e0b9674552671357d95d4e86736aae0a58b1eb0b9d586be9f86 1 0 \\x000000010000000000800003ccd4258d2cb4ea5c19b68d8b3eb31a3ff04f576cb9504dc28d01c3c057429d69d9af432c61e13d2ac474a532f666de532b1a2540d6853f76ac1f93e8d3ea2c31486e63e01bb4fcf6153a2c409cdc330277906262a077dec621cab95d3cc0d6468304c1c222b002ea654d6d8dd6f35d6594eded1e21776966f62b62f837124503010001 \\xf23253d1a2c3bdbf8ec86b8139d7902736b51da8bc7808f2e57462ce27e7f31bf1cc6e573bb71c8951e302ac57c2177154350919639e80c1ddc4f3b0e50f5e02 1668512891000000 1669117691000000 1732189691000000 1826797691000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-416 \\xf47b8507ffab797e99e23202d34832de2c60ab2e350a477362e8a99ddd3da1f7f960bf158e420331c1492b32ce58db170ec7e44d094d84304b6cec1089e0b7e0 1 0 \\x000000010000000000800003b192c5f5799c53d846f017b439a6ab723e2a701103c804d8ad34b4b17b5a9d408fac254cfe585b58cf13229d186bf1e3463dbf3a07dc319eb6c85e05280b4a1e3458ca5352451ca2133fb34b765f2c4aff9911a4912951c1c8bbe51287aeb387dadf5dcf5404574716cc1012b5910b1eeb8379948521567ec7e9baad98aaabdf010001 \\xe8efdbbdeae9d9b6658f9023395ac3ec942789ec86acfddce6983fe27fd35e31efa2ddff0bfdb614759b6ef04d2ecd85fc4032c2fb077eebbe517fd281b7b401 1665490391000000 1666095191000000 1729167191000000 1823775191000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-417 \\xf6dbc681ccb4cfbcdb289548b616e03574b9a89173c3fcaca55613b339d45efd38cd062606617ea42ec50fd3685bd5fc6fbfcbd335a5fabafa9eb9e2626a111d 1 0 \\x000000010000000000800003c6eb540dcc7bc3c796079403a16f3098c555a5d0f706bfcdf9461ffcf4fe131903fe56f9b52b13c9a9003fe41cf83a08964ebfc3eafb9feffedc77b2906d88ed6c23c5b8221e658a39a72b9b9b6673d251fe08affcc98163293803f14a3152314ea21b9b4371873aca5db182ccb3ab8e541c382aad75a1895aad36e208c8c5cf010001 \\x32f40cb70a9a7e32a7d762c10128896d9c91cf492a602591b8319a2a68d9c562d683a6e33f69202fe41f77a6f346695b52942fcafb473e511e6683f9bbe8360d 1663676891000000 1664281691000000 1727353691000000 1821961691000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-418 \\xf7dbcbce5c9357c7d9a325e3b443ef4f8b393e529533f838369992a1aafc73c9bd06f4305dd08bc152aff32fb9e04af2160a0cd8bbd9dc9c3446ff5dac60fc15 1 0 \\x000000010000000000800003b1022b9e1b649a38026f9cf7e6d1eca9aa5d0d6955e194ecde90270c33aec58d9483fae4da9aa803b7f16c98ee1378bf045f29c3741411105a8062c837fce66d64bdf31bf11bcd73b78c16bbb62e07936a0a0b081dd20c55ca2e55f2dc6289904901cfae62609cc0f605e64f5c5638609066d6d5ec662deb0e7ed279d2a3bac1010001 \\x758424068d2d435a981419bb2d74936f74acda41d8eb9fcfaaaa2b31a7c73f80366b53290549e2f88163d2159439dddc94e940451d45a236fe04795a9767a500 1673953391000000 1674558191000000 1737630191000000 1832238191000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-419 \\xf7935c548dc7a750a7907140a93745cb9189032f8611e2cc90c329065233d17ff6e0c6626d633ef2b8408cf1de3e801be2095e21d3d9749192abc41232f56fce 1 0 \\x000000010000000000800003cb48e4263c922d6f3b20d6dbbc3b969057fd3ae405fd008342489fdce774942b4562c84d773a86652567799260517f66d2ec8e244a87db132501a0604b9364d8dac1468cb93bec27d1d8b573a02ae5ab6b6eac3b7b80c344c565bce90bd3ba35c310c5288728ab1e636a28340feb8360f24b9c3f1abb77d18e2bf387b9f88e81010001 \\xa69601971a2f43b5d7d94d62e9869288058f5f06cd919913accf134c4e38550d70ac20b3e4dabe0b2ae18688a0d9d363c2cda09971567cc3f38bbabc10d2190b 1679998391000000 1680603191000000 1743675191000000 1838283191000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-420 \\xfc232fd7d93b86f2b10ccb755846a0826e87aa07b3ba3320f38531a4b4d1a36647b5941d7ee28f92e702703bd7c8182917f7d5e8ea11d885b2bb77d749d13e1c 1 0 \\x000000010000000000800003a47518dd33c853bafa7dd73930d269e564583894e1293da3510e864f8a5781f77cd97cf86e83fd069a075b7f8eee98bcaabf248849f4eda30e71436c6797c4e572eaf8d4a419a6d5bf633c8ba8aefafc6552e042f5209ff53821698dcf4e79b7ec26f024c043c2519b64fe01b6f09a83aa2f0e435c7749543137c218055fc397010001 \\xa6ca1bef7919d51cef95ec6ed1c8d632c7f584215fe9e732a754f6a44afefac65962fbe7862b430ba93d9fd403267c44f725c503b15b551dc8ba21d2a22a9e07 1686647891000000 1687252691000000 1750324691000000 1844932691000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-421 \\xfd53a73b1f6b166514f261ab1bf34205b3dd4eb09d298908c8a2533a2a7c17b95ac05a5248880beb320f750ff5cff924fc16854c899ca1eb46b0cddbf1241565 1 0 \\x000000010000000000800003ad80b109c083a34a46dca1adaef065d19772c60b97f2a6103c7e91a2d9e4b44ad9a67c7bc36bee0e24e99990d07877fbff108cb9ff15c09db7ca741e161bc98f1576299fca66e99c2a40c04f665e13fb75881d97bfcd56d409571cd0c494a0096b57c7d38a9ceb4227b4e2717778b4c0c52028c41fc5bf0530ba9769c744835d010001 \\x35743e7acff42cb33630acf99432e7022443d2b35cbd98ccaeb3de2324a3ae66fb9758b9ad421eaa44d86d6c8588be9220d4979adc287c01fad972ffec5cc305 1692088391000000 1692693191000000 1755765191000000 1850373191000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-422 \\xfd43fcbc0213639eb1e428d908ef50109c07ac2ee2267250a6f3c1ead86eed409c6e6f1ea0098009133f4228cfa4b7863f5b17b4f4ea17a622e94d1365f5aa9e 1 0 \\x000000010000000000800003cb1d30775ce7f72d69ca245974f3c697bcea5d20ea0e2c430e297df9d0949dd5618b16d41b9c58baaef86dde1433ff978b91aa904f38b8439f10415c1c2555287af351df0a73ed89246aa689c10e78a67475ee711f146ee5d983404a26632d9eb5ef25eaa3e1d922ca6d829ca0e591436da1c23be608a69df6a076cf58ca2c25010001 \\xce9225808070c6bd82e41c982367d83bd44d2d2db6f25997fcd17434d7cdb68daaeea594fdae546141186d8f3d110cbd6bfd31920c11b136ea34d86eb0ecd10f 1689065891000000 1689670691000000 1752742691000000 1847350691000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-423 \\xfdffcb590a5a97a7a9a91d2f0d0fbffbf70bd22e68d41400832b61ef48bb84de588f4127e3060b345f70894a22aa642c7c734b877f9bf1efb9d3b5f11817aa2e 1 0 \\x000000010000000000800003c5260414567cb921d5b43066f7e7543acd4235d353e185c343aaedf1f07c9158819e8d78f20c4a7330f00a977bba572b5b91018e855dd1e131c3a3cdfd018cb061bd7200c5f05a599e8aebac4ef621076373221bc67c85780f680b5137654ff70ec3b2b96e96ef3ab7ad53460e4cf4149917b8342fb615689e5d326a99e57d23010001 \\xb86d2aac9a390e37342105718aa8a9fdafa07bb4d843e738ad91c270645455984960a19c34b5e1560d91524ef9b094e07690074bf8556ca3f7b7081a2242020d 1676975891000000 1677580691000000 1740652691000000 1835260691000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-424 \\xfe4b93bfb297c92f113797fe1cfd5c3d1939dde60e5affef4b7d5dceb43b256e88a200cbe65ad377918cdeb8bcefd7f14a655441d3e3de65567a0346e9de9ae6 1 0 \\x000000010000000000800003bb22a13836abcdb6bd9718d4648c4359d962f523b11f890d873b48bf27f62499c7446befcb74dd14cf99dbcc9c73f5467fbd647e1b5bb0f22ddf3cf6993105e91f8451fa9dadcb87db2ef3b8d872d101046156639254a73d92f97f9d0589e5877ec5b1a6faffde708eecaaf38dc3b2f11cbeb8fa0c4d75b0d725f6129308a0db010001 \\x30c0a4fa984798e9285d59219b5f3d06fb092a7863b51d0d7556cb6c677d31188a3309bf444bcf205ffc3b977536fe7fa9ab9c28923dffc8de231c3212cb9a0d 1661258891000000 1661863691000000 1724935691000000 1819543691000000 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;
-1660655307000000 1495836830 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 1
-1660655315000000 1495836830 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 2
-1660655321000000 1495836830 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 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 1495836830 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 1 4 0 1660654407000000 1660654409000000 1660655307000000 1660655307000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x827f73b62cdbab20753edd20919233608f6e3d166b5dd5d1f63b7e9ea866fd183c6c4113576dd85e6f6b9a16d3852008d47007ad9981435d78d9375b35110ae2 \\xb1c3769807741baa5633b45396eadd4b3dc3f425ae23df88825775e2d97abfe290a4520e5ff36cf829b6ccba46e7685d7d8588d296457cba69c24e791feb6d01 \\x95b8b123aca8e5792f318eb8ad9827c0 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-2 1495836830 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 3 7 0 1660654415000000 1660654417000000 1660655315000000 1660655315000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\xe7c8a519ecdd88502897c79378308b3a8f2be183147fcc56fca83b622ce4f99ab34a46ea3b4b9b4b53892bf843a591fe57730c9cd883ee498da05376448e3508 \\xe3d5e9e0838608f21d5abca3fcda9d631d104ddb224d8035687f279da1dd5e1302f9634515f7b8efe78abee9b35a55f79cd67396053c43d236389d71c8656c07 \\x95b8b123aca8e5792f318eb8ad9827c0 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-3 1495836830 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 6 3 0 1660654421000000 1660654423000000 1660655321000000 1660655321000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x7d17d97ddede1070c10c51a33e9491e94302d74014620018f0f54bc991e493c0c33cf0d5c483444e6c5dc3c258246849d19cf15170774f361db56ae6fb724e97 \\x91824dc32aa51072b4a8f5a70c373ad43799aacce6e4d1b23850f5d30b98565e45536ca6eb43a4142febca57f7e6ff3ffe622e1b0b7c5e7ccbf3766f7a5e800b \\x95b8b123aca8e5792f318eb8ad9827c0 \\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;
-1660655307000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 1
-1660655315000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 2
-1660655321000000 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 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 \\x63b9d959e67e642c4aaf6a544319c636d53337e944cb7f3e4bc207453fa01e95 \\x7fa3cfa3804af9836d5a421e97b5daccfd0d0876a511d3df14881580f0b7c4259a8922fce44f7d7801fad4540645fe97c52bdb542971b9d4973655d8e83aa909 1675168991000000 1682426591000000 1684845791000000
-2 \\xf04f93e0462e5561211c2965203e125a50b66de698d59336db015a6a3ed4e5c5 \\xba376e2ba581dc09b7c980aec16a28154d50cbcc56b4c019b2a74f8c11e90d641df2cc2e465837a18dab7333340c2197b611767ab3b11941a3f836634f7ef900 1682426291000000 1689683891000000 1692103091000000
-3 \\x15f6a1c6e02150e2159af7c8b575dc669e2676345844fadc82640f8dcca448c9 \\x80701b6ca302d7dc016a070cde5f744138d0d7bb58c138f6ce5acc3c08300afc57d4ce4169b92a7fd2e1242a7fc8beef1971591d0286a9f9bb171445db64a806 1667911691000000 1675169291000000 1677588491000000
-4 \\x3c26105d9cb3541f8134cf8450ed4f6aa02572aa33d0b14b705c8edcaced4cc4 \\x7fd2984ad70d97c2d7b3b5ebe8d9355f8c941be321fec6f3709995cc8adb49c9b2903325f07bf4cdeaa676bb55669cf5cd43392ebc8f04d8aeedf89073441609 1689683591000000 1696941191000000 1699360391000000
-5 \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 \\x3e222dc7d5df2768e32c4067e9dc2e1c6edaf955299c10474b6ecb24c9b0ca33b2c6ec9637e330e03c6bce795f3ce5141eafb254d98de97596fa0a693913430d 1660654391000000 1667911991000000 1670331191000000
-\.
-
-
---
--- 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 \\x79a05e509493c6353a105eab8c9b86cce896d074b7dc6a0f2d79010091fd28d73dc820ec03f2f241665e1ac01352d49639c5e916edf9aa6b2d67d2087b95b80a
-\.
-
-
---
--- 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 223 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000003c6458d6197a3b350df6824bdb3b1d358fa3ead724322e1acf71f793d50140311cfbf8ec7baae06ed46dcdb93d71e4157784f0ef3e94625a578b44640885df88934fa3c8443fe12571a81c14e005bc5fb6907c54e7cfcbb4eb37e1601f7789743fa166e135fc829f3356155514a156fadbdcd9ffe6e7bd7ce0b5b0f6e559e03e 0 0
-3 120 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x0000000100000000aa0501d918459312ed65167a58bed3da4933ce3dce5270be16f554dd17dcaf408ab7aba64d66a29fdb92cc21db5e4635c977f2377ae266e50d554a696ff3444f2a8c8591f651963c6c990b92cbfb06a4e72d06dbdf3338870d9e940a7cce0d3a4c4845a167c1d519bb6dd33edb45e29202266f955cbbd90317e6da98dd3a6655 0 1000000
-6 160 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004fe6d6408cbb9584c96f73fa492e3e2ef719ae61f05d1d00859d061e511b33328a962711ebaf240b8bc8792028260edd48e031093cc9ad0e52e4eb46438c67eb503ad072e6ae94924a675f6114568451f3b8d52a7d81ff76730334043a227209d7f6264c6397b9ababcb6195603bd78e2dd157685ae09d7ec486d6d4e28ba0ee 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 \\xfd38aab6498ab407e72e315b66dafb54a004486b8c3eb26af14d44bc41ddd9b29af521a903d8769ea9fd4e78e92040fcdae20d59ab511f072042d4b801e8074a \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 \\x3d3b878b79a3901bb9796cc9b8f22330940a27aa6193c4d7d7056514a7a3f9cdb5f4d1673793dd148f3c16a1e6489310f01cade362fb399c9463e4c8ca520c02 4 0 1
-2 \\xff277d88cdce41d7419c86dd69fc4d59f458e6b63565ab491fb6496bcd34d5580c128bc9d43cd00c405e51ad3d60481e7374d0fac481ee7b3327973f55ea9e39 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 \\xcacd85b0eb5bd25e4daba952f6b018f0f976f76489d711f87195a487d4ed9f71c9e58d203f815a90225b001baf57fab0e008217599228a0737b132f6aa3c420f 3 0 0
-3 \\xde766b9c8f6e3fbb76d52eca9d02c34c4ec1dedbd0497985a4a71f78cf1eda097557909a21419508b4e147dd3a34dbe6b5c809378426db30747d4f78ba2a4aed \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 \\xc6296b43ab58c3e766f7e594f0a98c92c96123f365c311f3eab90ba27533484fe96a4cfdcaad46054ec83e8ddab7f6960791cf59e3fddd86c3939a5d0ad2d70b 5 98000000 0
-4 \\xe2aafbd5ed2506183218a98302c26081a18806ebc0599ecf30c2aa58fc60785677a7532167afbc6b72c18745f3f98bf4c6db14fce80bf996a0481ae35b51fc25 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 \\x923253f551c645da1957adc48501d91ed5962765f51264a0f13f821b2456fe04ade38def6051e847e3e784d2c9b356a8311088831c0c78b606be3965336a6806 1 99000000 2
-\.
-
-
---
--- 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 \\xe402b9dbd7cd0dcfaf09ce6d41994998add133204cced874e802d59ca95fc11234107c6d89e45819f626de5a6fbe4a5f9eea48f5292e49dbfae28232c03baf00 112 \\x00000001000001009f21160704a4be0f62ed9010d5c4fc843fcb97c59025bc89ee88c8b7cf83ab42f5229f745d3a6b964d96d5bd0b4dbf13768b0fc1744e6feca2fe58b6ed21f2e4c09960f14c8798c191bef5b75fc0ce3b1dae8ddf5d6ef56191283d18a6f3236ffde4deb6332588a8db33d1cb8b562400cee3588cd788e43b86f2cdd3fd30e8b6 \\xc913f1ad0a0cdffb7e60b1d7ee4b35ba6efcc545857e6ae14bdf79f1ea990f66af88da20c0f30c3bcb6bc7c45b6ec10f0be2691ac8c87e57714bf586a6df8844 \\x000000010000000142c0101c3adfd1ec100479f39b84b76c33244432963c9472df360bee6de904caaa3aa409dfd3892bff81f34e9a350e84425c42e95aa8d1e1d49e30d69af302cf91236229a17d709830b22cf0c7f4d86dd07912db930c107bf117cac30bdc8beefb13dd32dd5251631058713c958d378d91edec35de9340c9ec0cbd1e54dadb71 \\x0000000100010000
-2 1 1 \\x05a890a0c859cff76ec2649e57ed2dae935db8d3ec1fb9395c9f51a2ce9dd6240055de41649e8bff507cc33774d1bd9efc76313c021e6c55afa67123a678380f 406 \\x00000001000001008f78c8309667e5a9bcc6f4b4a6cfb38168e1cd584be94f0be14dca86ac25ad28bd126e62091ecedb80604e3378a7e97ae8a6d051b10b2e38664436ad906980ce64b9897bb8f94470d5df85ed6e830e91ce206804fb62d582718024a0c4ec279bd90b9df84f856e7050fff6df7e9bef0d4179dcb4b2f8a50564afda6ed08522d6 \\xa2d49455a81cca1292b911f7f57a967071e7ee3730fac7a78e5c797c489b9ccc64f35cfd93c0ce4e13748f494a086026c2f377e0f0546b09b634840e6c8715a3 \\x00000001000000013279295e5221fc44f08c4d8399a015e30dc471dfd5d8d2d22f8395e21f81319ea0447bc06ff2b5eb5631a5f4acf8de6064c561b6f25305945bb59b5e4e86e098020cda7160bea55e90d4bde9a674edbd0d513fa37af12bcaf0810845970d5dee3b2ed79980c14adb045c3b13ec67d36d89fe6437fd6c2ed39f59368f15a76e2b \\x0000000100010000
-3 1 2 \\x870b393c813bcf832d1b991a5890f7b825c1556477df2fe29164e679060b05ab2ddb906978a9ae72da225278d85ca1397b684c6abf2513542ae16da0a2e25205 391 \\x00000001000001003b41982cb0765a7ff5940f360e9b8a7f7a09da567510a1570d0f1c51bea59daf3479627cb668f9ac9924d3b62ec07b7d8c8e23717055a76de1b55c663598bc850ba5b0afdec07ea258733af6348fab8a24bb4e37daf2a5bfd35f566b4c087b6c23a190c654ce56140cd500869a1db155688976f37f21ea7169fb301cb3b815e9 \\x9cb76d8f39d12637947a86ca36c511521564c5e3db0ac08ac6cd8facda3c174dbab9899fbf29f899dbac82bf0413fd2f459e5123c33effe85c43aae5992c9aee \\x000000010000000151a893b929147188e41bc6ca88adaf460492d82fd67dab5afa6af326481978b0845519272bb45f5b7bcc2c62485d11973476475ae35da2354bea23ef02e616f51b7b9b9f77bb6755457e575cae36911de0a5a442204cee369ff307fe80639137750fee745dda7337eea6e32d5243b868a6e2fed216410f98ce3161ac63340661 \\x0000000100010000
-4 1 3 \\x546337f71299f4c0a527f5090a7ceb945d70b7375f1d906ac8a3c5edcdc06754115b7938c0e237851aeaa8aa046a2918389b45026a23b1039ed3353b8cf3380b 391 \\x00000001000001005807bf21e2f81bc1c97038653ae0e7c686819254386e378b99e6fb3bdcb599f19fa88af808592e41a39050c60e9cc793176e14e1fd1e84811175806028512df538b1a733d4e6b13065e310676f39f6eb827efe23222b2dc1217ec7866282bb4358488b581c401916448f4116b3eb4d417157c873f358d19491f6d6556fc34759 \\xc56d37e5b738effec9b15501eee8eb1f2b469de6db1e863520f94a94ada8c0364401b281361acc7461df98abe5df78e1ebfba1493164dcda1d00663bb99ce548 \\x00000001000000015b95645682fb3a88b97f6e0a9440e7535d3c2bc9395b41d94012675c239f611f6e6f3493620081c1b557463e5f6904fc6fdcb73cda05d48a6e1cf301440694c7c5a68f362a23455b40bf48ed9a26c03e569b77cfca41847f02773c643e45a1b28c5d4663adc913523aa49196957f560f7682d731649bd5cc6dd61965844d632a \\x0000000100010000
-5 1 4 \\xe06549802517c150824a459ccd88d8dc54bd3162bebc836c77bd6db553cb7fbba43559f947c6f9d565138c88f676fa0e55f66bae1f3aafe9a43065c62f4c7705 391 \\x00000001000001000c1b0627d9b52358f2c44892d197869d06e36b677234411e8a7c4fdd512912645617629defb4120817f3a7c7d15a50dade9d5de7d27b238b06e06b77a862483c6d08085ffabc15025ed3d09aa988dd59eead3967c7a2537e004fd9a892deb19292b63e70afa5c292da34715138d2e93fd92987b9f5ef18e1f93aae40803e248e \\x2bb3b2d4703aa775ded5564f5a5600e5fe646bb80832a86a0b69d732141aae8c3cfcbebe9233acad502842d5d81cefec542b16c4854beb92b2aec5561e1bacf9 \\x0000000100000001a065897c8b1e948b011879b475465b6b3cbaf6e2a90e4101760a21f4299458dbf0eaacf949fb4580387a19fdee0c57681918717258350fa40548c652a3b5ef9b4c509ad0d1f2d1ddc49b199a9a0d0d3ed921e59daf105204d892f8a88d55a8e808c8ad24b49fa80f676380aa9d6e50165482122b01504acecf1682c16dae25ea \\x0000000100010000
-6 1 5 \\x4deb04c0646e0634f6b81d6f749ed9df3cb9437eb7d308c0a90182fc27ac685786e34dcd40f0809de79fbf3fc8f1faa953de61a325cec3cd952725ab864eb605 391 \\x00000001000001000767b701f55ea8774a2f35b2e4e7123fa9da6dd348539c1487541fdc0d6b92379dacb76b3ff65380015248350eab44075d8316b2845b8b847631729a12decf4feea17f544d22e8249a844114190fcda01f4c64a915da64af0f1881447a4e265c1490e17c235be792f97dd928515eddae8885926f822ed645a9ee9fa26f221fc2 \\x63a1c866978314fc26a001551a28c26470476ca18275cb675f6cfc8613c1a2629ad27bf5464a216a097cd0d4cd8baddeb7e4212f4c0aad7bd8b3ea74017b2396 \\x000000010000000164f6fc20843978c1113499f5b6abb68789ea8db3f3db0c841c5e4466c112b0dcb4dd9f056891100343f43fc48166186a38bfa4c384ad1dba39c8b3f678e3e38fbc5e3975490af4e62c45599159eb8c6c99c7d3e12250266929c27739c4e91d7c4f7ea0e9286e811d6d88cfee4f66b3d8f66ff5a21fb7d3cc6ded7f96efb94fa7 \\x0000000100010000
-7 1 6 \\xe96a95a058052431b9da2250e403e25c343153743a5d5690b063cf366b146f2a26a3f834c27e22ac8966530c0f734dd256d359ed3652ca8fea6bb8858362cb09 391 \\x00000001000001002b0f1b6fa44c29da99e87ea089ef8f5a734659ba1a1a12e5cfbbf75bde460c5eee1ad30f0b8536cc5344f3764bbec066314296eebd15286699108c7c1cdd0987162b3764bfbabb0c158ed8fa6cc87fb6e6eea8e06532233f43211816f0d29340d6c5d2da45fb15758872c493d87c371612bb95747ccd162bb1e785112542a4a9 \\x9bc5189419284f77b866579ab4a17e0e75a819cecdbc3d59e4f4101587f4c213e42844b604d054ed9bbc8da9e69367655704764379c00a924d161aea729aada5 \\x00000001000000019c93ee8ce04d42a0d5a464a76af73e11aa962732946b57930e391dd800ee2b46cd18205021b35776350a8eedd6113943a995bcf74d482ac6f0c1ef2460158d63ee2bd21c84beefc3ca886400552d9d4702dc24c40c6771da967e23bba46db28753c82a29fab16d751d7c31e14e5b9d59583191b5539b8ce6e2218a4dc4f4d16d \\x0000000100010000
-8 1 7 \\x076297ebb1ccca68c832fc915f368524015c7613adb5d2642b8def4d9f201896dc1c949ad67e0e6b5b67050503816172566d1cdd0489eb8422a05fa1a33a4100 391 \\x0000000100000100161d419f0391db8f209883543baae9e3f756a2ab6b0001bc503e1f56dd0bb17402635a3207f46444b2c6966c2a95b6b580748cc2d00698e93d9a871451d9fc0758a9eb7a30b92d0109f4cdf4388d9ae97d8a97926f2eb97ab2f3bf6c7fa4a020ad1ab7d225d51778606b25f7a3a5bad55d2c0efe603f82bd4fd692f70b01fa18 \\xedd54d24b65accd89a886567bfe93148cac6fe872ec9995e62bd0503ec136d806e70d3eb23536fef3e605390b9aea89c52ab283eb231f19ff9349d19f4844f86 \\x0000000100000001805f88af3c9ce7c3b07394d6fa26a2052627af364f5776c175aea3617577d25f7be7be500376e8341cc5760f7ae78a8635253fe2cfe875fa5762d813fd940524fee0f34c561a8feb95a676aa5ad0dc3831852d6555581d13d7c7265dbf30411b21a2aa19be0b81e38b21933957a4e3e569a583db2645641326fde841acb5eba2 \\x0000000100010000
-9 1 8 \\xe346ec14d6906ade87160de209b76e166df2e96f912355e61c0251fab18f42f66b9dbf0fb11a0386940aba5f96d768aa12dbccfc11559971843d4400de21dc09 391 \\x000000010000010096247f81763279c418e20fa47369631a7630bf09f9d3f66c3eb1eba87458fe04df84846584b03de17732a832107e7216e49300d38a35e3895f3cb69b6ed220e93c303e25881cbd1bf3de751b53c0bcc8ad115da3d3b1d78a38913c923fb3125c5951f5698e49999e6e674eb59e7ea75e798eb3f121857aebee6bbddcab837c7f \\x15a2be866169c25307804235784aa0ccad226eab49bb33f3d18c520eac0e9a0273e1b92d2fb586d431467d2876cfffe917271a01eede4eb3ffe2b41bbdc8adb4 \\x00000001000000011ae1d824e6d2054760a65999ed3f465c85714f50382fab2995b053b23c5fe478ccef398c952b7a7786d5480403cb738ea2b1e036bb7b4b975ede525065b639e42947825ed95fa43c393bbb1e887f2eb7389dd19756cdf7f3b607491c398df17d952f25bdec80df76b458d6988bac015e61de876f1b04c2f64ae2d244464b9982 \\x0000000100010000
-10 1 9 \\x8946eb7874e5dab552487147a8e429f38f45bddbb29c76152cebf13860caf26f8d0521a0b7a115f3b2080b7f456880c04486f923b45e848cc95e89ebc84f7106 391 \\x00000001000001001ffebada36862e306cd2d1b27e78aeaa7bf01d5103981ea80072664b76f3a09e61792974721ef5cea129e658c825c4aba751b4b757874c3b55ff149d6639e908fe165d71504de0de62183c0f8efdbbb3ad73a016e54e7a7b8cde44c675e45bcca46e5ee1829f5b06e74afdd56ef80b1a82344086835f02e92cef3004127371dd \\x899af2cc7d8ce09afc1aab1ff41ef559b7bed92c4ac3d12ecaa3562c031c0c8d7277639b3a8d7a80dbeb99ea61f55c38b0138c1fac8c83a0de6181f176d7e654 \\x000000010000000102e969e416e4a58fdb09fb825d58960268196fd1bbe5b199d6ec32227b2de11831c9ad7df4d39bb2dbd4d10771f2dc6cef43ca05ca75cc09888f2ccf719618da660b733df545ec03d6618824a9fa71b7816a0fb884f838ceed8ad3c61aaa0467ca1a888667f418159fb499a8a0f08fe3b80cc9d016a83ed18b5ce20230796e20 \\x0000000100010000
-11 1 10 \\x2ccd0820789a271aefc1d9477d7416fd5c34ccf87fafa77894017c7a291f677409c7313728ddba580ebad8ffb2bf1dab08fe4727f13fc7df5e6b500906037b0e 14 \\x00000001000001000f8fdeaf46832c90e2c4d7425ad25b7f1e4d43fd3a64da22c960bcbece5f57766aa6e6367fc532154ec167b000079b165b8f7925d1995a82f20f62afb1ea6d1eb720c1c902a2f4a0e7bea1b8070f98ba25c9e0e24af2512830a4145072bc93604b19913c1b92e04408531920090395352f993511cb575891e518cb86a5bd2604 \\xf2c7dc03fa7f0f2eb94454782c132a5f9a2a2bb1d7d379b963e5a84fdf50a962a4c8968a9f93a2fe11215be5bed89a918c575c90b4e0d4cddd8f12a2584c0a75 \\x00000001000000013629ae6ff09b00ead536f397b4b91a45ff76a1abf155483645599556c72a48934bff51bcfa57385741e618e6f6e360a2c8cf2b2294defd0f2ae2f23d44bbe0538b91654096551ff24b5517b358a0dc7729e02bc8126e8423b39771f3d8cd27bd6bf9978779ee128db4e0e464f406959a32e83a8b4740d449445682f7a9c43e10 \\x0000000100010000
-12 1 11 \\x54de52db466fd102da328c2bdcc33674f7981ec13b1e338fedc6801ef26a80fd322f137f737d6b87e436113340855c81e0e327c5d781de5e2863ff9200dbe50d 14 \\x000000010000010062348923dd2cdde365ba670dd02741ed4dcd2528d3e33e178656bbadb3c3caf3d1f51dd8e817b0564d3a0b4131a56c4be903ab6628c103949e2ac2d3d2e6d2019f4df4b9b1118c990abb9e9146520ec58bbdef39da4b3e004c92f69af623bed013138693213f9b652457ecc9638fa1fecb511e3e88e4b1c78ed3b32504e3ae8e \\xed1f64daa2abc8df6aa49f0b01ecb538886c165997cd4699cbc88aee71da8d0899f3447f01e6be26a56ea0a9dcc3ac7f65762b1ee010307f06c570e754471ef4 \\x00000001000000017250b78411968cd41eaf57e13b372fcbc98da5d2223bea8c9549140c91ffc03b6ef6a6df551ddd091bbe8d586cd4f775cc87197b478c37dde438cc34f53b3c037382be5ed8abf8d9a406dcb5b95e4caeb086e55265fc988aa23f19a93e194024a4e046003b6e14c3cab424212699476a510a6c3e88d075cab76ef618c95d6113 \\x0000000100010000
-13 2 0 \\x81ab19396db2da61233aba52fbe4f874a6ae5edf4d4b1ec786f3cd6daba724f8f223687378356cee6be1bc932e2b3b813808f04608133d4adaecf5e56f49990d 112 \\x0000000100000100668c5832239c25eedc791578fc0ea60551519583670a8743a816e901b4a9ef45209b7e1c1ac9f30f5d649a4d00083561bce713f09f88bc5b9d24da314ee64aa6f33cbe4abeb1df02918b6f49109eb9e4d7704913edb35030e82bc2b3b85523c0f15954896dbc50697bff8c51aa4c6dad55d89927a79d0db25fe62f62a5470e0e \\xa008a15988ff96016c0d3a7dfe73e8e4c516d0de82e04e211f7c57874b65ecafa12c950629c59cdcfa227c3d99cfa456bec55ebec2cc7a623ba23d46b46d833c \\x00000001000000012a4f395a5b889130cd72797d07b9cb75fa0707499b14d65046c5ad73ceebad84b55df300a77fa924ed79c1c50c5dfafc98d57b0a4cf8c67a4319b29d500d20f1d18392e09b6d63e3e9de694b75a0399cf0b852a6ecd6bf1aa129da98f55b885b2ddb06a3d801513b58cfbd264156f11d4b758a961c4e56858b9821e4a65bb879 \\x0000000100010000
-14 2 1 \\xe7ce0c17ffef35332146878ccd724600c9e5a0d5135eaa0aa96e646462ef6056905471fd8c4718653a96e9e86e87d2eda66949083c667075b1d362def7829f03 391 \\x00000001000001007fcce77423126b57edc9e7578919f8c90f039de49ca8476123d65e8d950f224283391b533bf246544eb121606ab99ecec3436aa96c44f5fad04be88404cef191bd4d7daab296f38e12d1985e393c1f447cfce9a4571285861e175c30880346b25f9816cceb6129168df5e3321dfd7a72c713710423b682bb00da4298b6f767af \\x9be954ca3289f5229884552d4a6a5d8e967573e269b5dc280467c78e27f93a22c0f47157013fea261d3480c206782b8c9d772a1aacf25be01c3a1dc4b9689cc3 \\x000000010000000162ded98509ce4d132bd4e96488efd32ab61ece54db06f6100ff5ac43abc672c681ad5aa419b63643f6c2a6b8932249dacc21e465a520dff11a7a0aac06144cf0105f66be0bdc933267ab0bc028a4bd6e916d98cbf967cde09bcda97e585796a6fbf4e23afa7ead4812ed915fe8585534f449f3b9d19eb46472a73faf50aa5630 \\x0000000100010000
-15 2 2 \\x14479540fef14966442ca55927be73f2f305a63c8a26de6821d7aa4748ad514d17e47f068c1f593db9a7aaa652669efa78428efa04cb8a7eb487bb6836aedd0e 391 \\x00000001000001001fbe32ca53b9e742d0627762d9695c3783befb979fc6417ee7654776b4865d122f128b89b913fde75f8f8bc0ea28fc2e36586cdec4214d08bd0f9772967aba59ccde037df496591247601fc33b7fe4767f689e80d533625c75a965d41c4df8418c9b727c36c439a63a7d01c33b105b030636f32386b1fdceeabcca998592a6c1 \\x7c7d1b22a650f8e8cd35093b102c90382cb98bb4768c646d41268797a3644be6f4310b95a3d606d3121bda21a4965417e08813d23f15396a20ef6285ee126605 \\x0000000100000001500c0c8f8338db875cf23b835e7c5b8c270cfb805854a2e22a82d0bc6d6beea1a22b14b5f14dff428edcf611ab93c1a521cfcec228cea22e975bc3a2260896ad3611f3c2fc031f6315f2d723fbf941789f87e6f607983e03509d0bb61ed0353635008d74695f2673929e6c2582dbaa1ffeed0ccff6f2110fb501dda50bf1475e \\x0000000100010000
-16 2 3 \\x6a01309fdb9ab7136684caac44944dcce8ee9415457a9797acbd9a4c9b34e209d4a088766179066138064d99d30b454fc228b878bdd149555afb48473769f305 391 \\x000000010000010047e57f50164582d58a93fb0fe15223261b988c07b996765eba7897188cc01d1f6d47f58798e97a41321c75a869d97c74066f408fbf264fa1622907ce1def95fa9fea917ed1943896dd15a6ae31d04557cbbaef238b5da52daead81ad9a0e7258ee84ba9d010a3fe558c9b26a5f3cfdd3da69784879529fb192176a6f6c484e96 \\x68d67aa7dde875ee525aa0d9df1341ab21f2c54d2ca6a80b3614a96d28e6b69c45955e77ee61b06400d797785016435df7efa220c998cb6fe1a18bf97dc929dc \\x00000001000000016dc6d2b566002bb8aa68465ae2dd1223885fe9b6516ebb9be4e04788d8a3b1e04bc4e20b09ba112499fd9a1eb3d5cdbdd1ede8a4049d1d7378128e470dde6b68fbf7fc8f1d4e3e76542582e01e897be9871320642216edc8ed96280e8f12351f291e6db4ea0a8ea298dfd14dab2da7fda277487f56f48cb9a0bf1e5ac021f098 \\x0000000100010000
-17 2 4 \\x00ba8e2159ecc341fc22b28c4361a66622d70ab4f43425c7b558c1f4ba56e37f21e3ad9fcac536af795c8851527d5a0e6e8b3703489195b3b1e0312b77f3270e 391 \\x00000001000001000d8d3ee2285f70da7875563346ecf7e1a8bf1db5d04601384b46a904152a1c354cfb9c3b7919a8c7f7441e2319b65abce58301f75371ea3cbd4d7df69ae0b075b4b5acd251050333a17a5aab9e6ef697bf867852aa78a444d7ef2aeb0423858669304489db8167ea153d4f685243743066859582e82c1aadd267db383312143d \\x270410312ca48169e52feda95802f0b30b5447e61d32809adb98d00ed423872aa458c8894762f0e479e16b57b4122a9e171c08b565197a3b7e7a5b8a7031a5e8 \\x0000000100000001b599d8918c69a5a84e8c4c0c4b9ab5205acdeae43fee0edd5b079ef5e993d2c1ed340b3f3a45778a8e379f09327b01fcf4d65efe381d0673199283b34e2849e530b9d11dd653c18df186b22eb4cbc52dafd45e878c51d7264d12ea123aed58e78ca956d1706c6bb548f5d3e07ae410b6ee07dee1d98ad890110e50d5de14839c \\x0000000100010000
-18 2 5 \\x463419cc9edafab33850d0f50e2aeac8a456970ff290b3c396a5e3bd290e4c68d67f40bbd58a7fc5d087389060fa285d3a1dcb88db6bcd5b5eef2dbe4d0baa0e 391 \\x00000001000001002a078c896f1cf9fb56b37d2c335e3a4451a82ab32e8ac5e7dc053d2c77a811e3a5aa0786869c3d87cd201dde21550f93891285eac6d7afc35a656aca29741290dc563a62cf033517067458bc06ba2f03567f2d41be7fdb1db59a1009601970c7580bc1e0f85e2686cd5b7f3dd5eda145248c2333853b6e6f19cb821fa977e2a3 \\x9b8b226d341111743cb6e1bc6009c7f0a2b240ed9ba559ca0a90f811a6a9036bca04f5b21e5b6f6de5c00ef85ad7c58b9b600dadd404b1b8599b399730ac0379 \\x00000001000000015348fe92be4b88f847caf2d1fa957dbc9e6f7ad607936119889ba99ffe442ff469ff28b2bdd0802e694e8f6a7127447f5cf407564bd77c1bd2a434d34d54a07d1e0f596f2777330f2e458a8a68b201f5439ca8a9007dc525f94ee4c1db853a9ca79274f547daad4ad1a73eecb525ea53e475bc2f6d963d21e90d86a297c2c279 \\x0000000100010000
-19 2 6 \\x04448242b4fb1de22532de02bd5225c6a75f54e2c837dcda0238340d948f17451610c521f2cc65c41696bc0abba8a832bcf6ca02cfe8e47c29357f36a205e101 391 \\x0000000100000100558299930ac29eaaf8f74240197116692de7ded79d0fc98e2b77c591edcb0eb88209bb08582a4bc98b05db8056b948dc12a8413faf0f6428e639e53b766fe2033718c3da0a0a39b19e0c1e04a87f6e1369022c593025ad62e72af0f9c1405cc9e6203da72758467d2c462998d9181d29b917ef44bf6cf1db555c03917153ad2d \\xa29c756392c8e6b6cccae25b4ff36354cd47a216878318955052f092f7143a985a798424b8f5040f66b6ee6670be8be8e6cb7c3f096f3b2c6a4da6aa9603842e \\x000000010000000181d2f16a2c10de8452c52afcbd71d6fb72b76c4c2cf222353f3ab55efeafe8a0410cfea4f2b608b65902530cdb734c4d97149987b6bf379d26c5854afc467a3c94dbcc595365fd892ebfdf7307b37ad3cf9ed316befec4bc6bb6216d7d0a1db0236e53ff7533081379fcddb9b6e9c9b5c6b879cbcb387b9a1af1bb87f4f84d7b \\x0000000100010000
-20 2 7 \\x768819b14421ad3875af37b568806e41df13a50aa1667426ac776225054fd9c2c7ca77a6f7a345d7e0b950549a0d2d0e5ff92c013c1cd3338f75fe931c500003 391 \\x00000001000001001ecb7a80d6291497fae169818604f513dfc555e52870371c9d6cf4121b477cd6c3e57fc3c29011aee8ade17bd797cf7cc4d3e109af506074bd184c9239778a90b2d82efdc3075da9f1323be99f63a6932ff9bde4e673b09b5273426fd58389b962a2bdc6a29717281640f7a6108b0faf1e755eff1bf21eb977ba87377a2de237 \\x703eedaa1fbc74633222bb74b69aa5c6f440abb376e59028b141b372f61394e0c1ac831a179221ca8e3d9ff16ebec041c14125a7a2bcaa9ce6cf3771aeb08a97 \\x000000010000000180697e031849d32d6efcc5ffb32df36f7d802e53c093e7df11f46889c66b53aa245a9d4e8456d8d43941b90ff7f822bdba0cb06700a8ec77d9a13c94209d393feed4a4e77b48abe2dd364e17d546f27c2f432ad9b02d4c9d6e933246a1ceada65cf250c94a0af7b4441f6b73bae136ebae4f9005b8b39fff8f94603e6cfa500f \\x0000000100010000
-21 2 8 \\x8437b151e177d0e8b8799b3c435ed21417b319c37a956b522e8ce091d5c039b040a85cfb155113f9e0e40644191bad11fac9f78eb2fc0d4c022a9a8a82d32d07 391 \\x00000001000001006ead956a64416fa90aec894779df27dd7a597e1041b683d4c3b891ee2f756693d87fa7e2f1d6625edc39670a7112b6daec6f56b453e6424d35fd64fda383b481807bafd45cd2c4cabd15209103d84cb21552e0aecbbf3459964b8007dd5aee624ac6506302d6d37f4e2a7e35a8567a4f755c0e357a21d77710e5c66f60c35e7b \\x02515fa637f7c9d0bec291db5e2c424299e1a83370b5a176077b0e59d3fc1bc66eaf70215ce0436af4e3d117665e509f267f96786e188c03d46976f67ee2a242 \\x000000010000000121d2bf9cefcaa4d282c77c9c50e73069376f5b289c2ca19ef76b96fb65a61dc90d072b7f639f637bf4f917fa107f557eb43cabb3eebe7130bf49a3a0b04dbb60220fc4f89beab82534a1d242755827f4e42d3a511caae108320291f4b7dc57643c4751a5630772c1080a0d246c6d96062efd02982125a49befe8b9a714401a1a \\x0000000100010000
-22 2 9 \\x6c53fc358752db9dec6bbe1ab3eb37cf6d77adbbd6664598b106e0c8947a97b33f1d777cc01bafab3bc8d8aaf980ed23325edb4e127c446a776b2f86a6ecc307 14 \\x000000010000010084dbb56f101ced499a749b32bf996f32de828f3b1204fa1635bf92635cd90b4b6d2fc3d7cd9fe0f29cee56dd72da93c3c3967fc1421dab6d2dcaa6b508fe75263620018905919533c67c3f73275b0c908c16dca022417ab384193ab0a0792b4d0de5c667d58ccb1c762c0e8f9dc04f14173bfd89b408da7cb87c681dd3e86408 \\xd4caeae3d6e4fce3a54b77470de8c8495c8d104c8c0fadc12437e51d2e6d789952640dd27478260fd778f1905e852602716be14432d9c35492c6c1ce176044e9 \\x00000001000000016a505b01358ed4e3c0a3f65719bc9bcbb2d1b7f58bf0e6f700b9b57375e0f87e5f0e5fce77cad70a6b31d298f09d311f6b1fa1cf3427ed8caa7562ad2903629a4e5d5f0047dd3c91711aefb5b2e3435770b4d27afa9b07654c1b15af54a2cb1c048da9e361d68a2739465c003b0c2f1998a6ce5498a1d26ade453027643a29d8 \\x0000000100010000
-23 2 10 \\x19243634389b3c02a007bb673d4fec863952cb891a3131b63bf67c87e360bf70d871c698b5725abc91b4d098490485b73c2df76112f436efa4edbef96b952409 14 \\x0000000100000100069cf583a4aefe4ab60c4aff78a98624ee1a21af90f62192de7af7b60f098c92439a00a99a09bacaa93fcfc55e0001b8e3fbb96e9e412948145d4481387720757dc42a25343e85cee9483981b280b19502851621ab5552ad7640b56cce5a52ff766a916d219b12c13c72234854a636570cb398191df58e5cfadde8ebcdebdcc3 \\xf80a1da16cd863ec881bd62b89965a4a85438ebe9ba52afac69efa274edd46249f96b9e77a14ea18d15bc4a3a9befc5021eb9e9fe559db16119650a382cf2380 \\x0000000100000001653d16784680a15974aa76b76231d8355fd45ecc03de56ca4c72210f2de4f825cfdb5a1969ae5d4c00bcf13036b09ab35861364d1e082c0488dfd998c6237a0e358e3fc940f41677d0deeef216a6e89cda997cfceaef761850840dc186235387ca338fa544dce45809748198112be9f0a80dbb5a0420a27d546ce5ad69310b7a \\x0000000100010000
-24 2 11 \\xd8b7b10328fc0edf2f9bd9b7ef58780312db24cdde735b540d26ed406dc6a8a5f43527d413f5a6cb090311e1e69c020e09149ff642f029c2927067531c14ea0a 14 \\x00000001000001003f2d62314c593e6473de76c6c1ded0c646e722c0836c8b9b3b1eef54ffa0d723554695f6d13c59a9f9d823b27ecf8fcb8b91adb9685d86e09aa3b101c25d9d07ccbab27e0215cb1f49d8af80c7d8f4c433af02c2feb49549b2e46ce3a61618642b193519560e91c011ba6e26ed29af960d170abfe8d86cfd187ed5890f1daa27 \\xf0c16456ee503411833f5fd1dd0e2ba9d552f2cf5d5387d0de765154d6cb0281e9c7bdd484193df15c38acf00d239d458b079cf45591d1a1e78e4f9dce69a865 \\x00000001000000016574fb78754c27300b55e75993c286712fd59c17f30331a048f27dadf5a0667ac676a2a12f27f0cd9c2fc5a27fa753d243219fe4de845f711f240f0ade6e52ec9c18b55e6f3c613c29d0e4493262dff9a296fcc33811510dd24130702b9f100a4288d4af51903e1fa7d3b374f6abb8c9f75b66e2a311eeea8e7d771d02b4eeaf \\x0000000100010000
-25 3 0 \\x5ea9e4003e273e13939a52dd4d7f86443ba1f83668a6c859b2036b411d868fd3378c78217d799d257b6b08d854b4a4356b71a6492abe196b7e6d3170ea62b202 160 \\x00000001000001000305dc42345cfedf740cd932e1a476152480903ccefcccf71424b0c5d14a964cf1bf770dc1388c4551c68d7c2386d8b6b0a99167716f7b0225fc03346842edf3ed70991933d5debcc78ff71e7621de8a3cc590df2a182b5dcc74ae24a05c2a018463d5434c9c0c6a3f30133b49e7abcc041d211888d06cae34f4fb0cc6a03b87 \\xd890e8df8ccd6b5da3e811a07f0ae5e374aa544f2f6a81882c1421e710f6f113321dbcec4b182a3f4f69285282eb6e4a14d5412d466464a40866f0f00b3de052 \\x00000001000000014d9e418249622f394dded3faa04656d77f82c1a90390cf1b67634310cacc0face343d663ef28d39655dec9c599483135bffe6629ef33f92868b34b2271688429bc4ccfd516f1d3b4f741a92f9d4a92d6543d9bda2d94adf844b57b72e005a50cf129cbbbb7492d5da8e8ce86dba852984ea59ee1af523276d8a3e0769dd44f58 \\x0000000100010000
-26 3 1 \\x7a7df3412fb0df007bb0f997fe9769131ffd5bda6c34fe5926236fd8187760ba2a730d4806b6dd4971a1ee09552085c11227ba0f349eb796dfb8ce2507b38908 391 \\x00000001000001006211507db9e1a2ee33ba68fb45a0791431123fb743a01ed3e56707a9649c191e2902406afb0e0c82af1210dc1b03794d3e6cc27c1f034d355178e9125ecfe2b8204e203a951f275b44825383d9197d750aedcd43bfa2984ae13bd97426a7e5f7f896d00a332440082b652b2cde24131002b40134a52efecd9542ddd1d874b718 \\x0fd420243ef39a6febfa4b53d73607feb3ab8e3d6f368904ba44e03e11c47b419b9cfe09fc3e0d7a15d831bbb2766ed84f1fc88ee434e1835278f34a7a4798ec \\x00000001000000016fd85012522493dc9e1068fe3e527bdfa721b23e71fd2b605442c0aaa680c9fb763ee18393f9e993600d615ca353fd3323ecbb236651587a824802ec185d2ada8c37e96bebb82c006a43471aa573c6d62a2215a9ed87e2a0c5951cdc99256c17ad49aae9d0946f854be4516442906aec2bc73afebf2399071aaf03ef981a0ae4 \\x0000000100010000
-27 3 2 \\x78cb32bccd131012864b0c75349091c6a0f8c41504054cd2a9ae76f3cf7df6a617710bab0efe8a0edc38277af3dc46bb8f8ecc6d217c4b75a2f3bfe6f94d8d0d 391 \\x00000001000001001b6ae710ec680148fcbe1010929c9f4b1592b037f91d248a9523b5492732b17afac06d2711ce2ef0881b50d639df01f54f344e64150e1cb60be86e60844a06efcd0a51fe85618411c7bbeaa709e7547114493bfd3be434a497343ad10d062652c16f79f4e007fa56359707c0511cf4de873498ec231f104ca253d69db6f52b00 \\x75fb5fb77e3669350d886612660f53fd9039845ba6616e880cebf8e6645e2f027fff5a3c3708dad96b043ab52a664004c38a944fdd6c83452d877a045a70fcec \\x0000000100000001111000a69c7c99174735240126f0cd54394d8d03e0ef90bf360c74b6c37b036e150db088920c91a904228bf42b5452f4ecd8090c088d597493e48ac6c77ba7dc96a290e58b48981cb41646a9486c09c10494799469461c2844f8122c00bcce4382989723695bf74f81ef5513cb7c0b939cd4fdd338fdb6d1820d40afcf1276ae \\x0000000100010000
-28 3 3 \\x240169afc27fe77dd648c1497ee6ee74cdb8ef8ada8adbb7333c874e03f18e4a54121a5508b6e424097b7eaa3f1dcdc86300725d013f5e17d9d2aab55bc3e900 391 \\x00000001000001005a403731851c44b4c326f28cbd06cca744a2675a69e50ce825a0cc682322640905e1575da4c95ac7945396b0d2878cd32d2ca5ae5569bce4c6cf8ca4bf5b110c8cbbad2c95b46c3661177a087501ea2085ea80feeb11d357097b4260e80f933de139314b68e89f649d00bcc0974c5dc316fed9ded2ba7b91b948053237ef55c5 \\x4e33e8905b22b35d4d955ef6a75ea66276a2d7bfdd40c97b6f9b0fabfe8ad116aaa4aabe902b4ca854f03c906f4b01bcc4af90bc35c7ffdc45d5782809f82635 \\x00000001000000019ba7999398dcc90f7bb7885f46ba1c32c6929c5de3bb57239e3928971d9b8a72a741f02e47f658b39080bf38eeba6634aaf2f1105ad83853ad84faf58153e342b40b7da500917a0b37d6c8d10e16da5e032909081d82ad2f8fef1eb4449b0c28e490e9104cabea2abe85e6f4274ed898c7e12ff1fd186f2793c7a5db2c9c40ba \\x0000000100010000
-29 3 4 \\xa6462d7b53c4ca3de5575a715dbd72e3fb1c6bffd2816cbde673d8196759824f2831539d2a0a90841436f840684d192cea62a638e6c33b869d814d91dc12b806 391 \\x00000001000001000d80872923e42fc905511cad24d9e45555dacbca8255e0804024eeb0608bee43324ff7b0d7f6a1c7277596c6f86f294198c9b1dc2c58638d64ce3c0b0593e2a313c54a99809de5626abef11797cf1caad53f732bd344ebf3114d937a009b0aa724c6e8e2352a10a2da4a1d6f196fea48fd2b36771dc4855fc1447fb88b08b3c8 \\xced8af3270f8b2e5aa75b0a797b6b86e4ebb4fb227830eb8c7560130f88fffd4b7632357eb957f8972b669278a1772f603ecb9d1f73baa712d94094d9863334c \\x000000010000000155184754bfc803880c82fc53ec01cb7f1d53dce679f0e97bd9cc84035d238aba3077247945a1dabe63189abbfd7307f2c072fbd2a1ba406f6264d49776f31072eed065d8c6a0d1a7765971226c4abfd8e39d3084e795c63123845ded78b9431821717594447cddad471b6a1002e281ca986e945c4d6b0bbea0424828bd6da024 \\x0000000100010000
-30 3 5 \\x867683ca1243bfebdd7568b093c5fad8cac552f5d6adeac6ad814b7313eb884714a90399b828871d07d1922a4683d0c253ad2d2221be625ac88af7474890be05 391 \\x0000000100000100074a445a86253315949759403103a2e424e34a2c345aa6d72e3c9d2cb0a59db55c30a243cea7bdf6a319a547c68360d8b9dc954360fb24163e8e6fe6a161218039034e0bf0c8df6c0caf73ab8722176bd47900d8f11c879a213d1797dbe8ca1b99c5cb8d3349e8cba294dc59124981ce62e5826d1e6095c5e6ffbed37a2e5b02 \\x48ef2bea5e16882690707275bb58acc8bc5d85aeeef1cd6f57721bc168f4df5f0cae4d10963792373fb805c7872dbcc833b7cd9d0ab8c842f6fad703880b5c51 \\x00000001000000017fccba3fd8fb7fc5182965d1ba6961e083b6de6ae0e1763942c3b193bbbc96221d2679f79253090a634848412f73aaadb124245ff5e77bbea6ee790b2ee8b1f85d8f11c7d11fbe8176f4d7812f029b64b200b5b02f8023955e4d0c0022f9ffe187c5b721669378ede659e7fef3eba2ada7a73c23ce376a46b45bd7f9afba120d \\x0000000100010000
-31 3 6 \\x9a9f05db53cff3407f19489d590d6fd3a12ed1a32c2177e061b001d48dff275f8bcaf730a28807f81b5440397401739a0e33197871f3139bf8ba2d6b15e2f80a 391 \\x00000001000001008ee9575fca7cd44d37ccdbcdb999afcf433ebdda5759c4ff003a4d86c6ca287dc29c9b2c1d80cc43d5332b1db936f30362437a25c39882712b7c3fa3e5c66f597a8d4f21c092d797f8aba17d1b80c281f2142e2d377a829be08772f8b632c12b1aabbf89bf12ebd842a67cf3ce50534ce8e1e8025342f38c007cb96734985a73 \\x72cea15484b9d830ae02bb36358cdedff8f21d7232e3fb0104563d2558988829e816439e5c3e121e0ae53c418ad4de381f11266e41fd70403f6bacf279215e04 \\x000000010000000134a21d56e893df01f6c343e957e748ea4453c4e002ce23eedc3476a4823190bf794721bb17431d2127db685ca49ea9fd0b1267006fab9fa73744e01bb1b5f8e2813bb0461bad8d732325dbd16ac84cdc13393e5e03f108983b26c8098726d7a9a523e1a1f07665cc6b462ce8f448a967d88d97d0a0ae4e41e4a502167e94518c \\x0000000100010000
-32 3 7 \\x6586ea591805d2437bc1224a1a2c777755f9c83d58a9bc8622a5da927f7d5ed127f1691d2002c96477b8a3bd2b20fc47bf268791b4996daed2afc2e8eaa4890c 391 \\x0000000100000100668292a07637d9a24a35b7cea13dbcdf32055146972accb7bd0633dc2aeb37594f3b06517b26fb138abf74a05d430f1dd75105bdc7ff8cf960cbb9edff6cfe9414f1016af9eda297b65da1fd2608c7006bd2052f7160f324c11811e1c21c001fadaac0bf74226fe06bbca42502ec5800853414a3000e1088f55575c4d6b10169 \\x875b651644e461c7404c8a6f2456079d8341ff5bb8e0a10ddc2e96439e6935b8ab4058574284c62815b00008ffe6da8bc6c75de769077e667c69ccdcb784dcde \\x00000001000000016fb4c8f4683d57d6c854fd788b05a386b6d2d46720cf317732b55c327fa2ba879e6240e4092c04a4fd25056c153eb80531266f342d382da917b1128d491fbeff83cf42f73b9f19e6ce67cc216c40243517154b7a2331f9850662f3d77e9b4023aedd0ffd6521b60bc7fb5e814291f6e1d3f8e4f15de3f491c0c1e21818b45e77 \\x0000000100010000
-33 3 8 \\x5e27cb67baa325e53bb918a43f98db11d52505bb531cca691b34d8dd1a80d8a386524edd2e940f980a3771fc3b0ac58e9a0b4a29d9a9cc290bd106603d3c8b02 391 \\x0000000100000100307cdbc1e5f3a9d6d8073dc87dd147cd0acac4b4698ba8c8a6c94706c86c5074329fed0992cbb42664eb9fadb7f562c3835bacfabf78b162d7e2e3f2b864a6b048f6d519df24924de581cd9d1b9b9b5778c33a6d4f921bf66488e58bd315088560cee24ae785dcd3e3ebc2f72f911b9211a1540a251ce6bdf110d6a97b286268 \\x983772a70d47067263f891672ca035fa9820b2b4064fed3a39ad53c12dfd6df399e9d82db0cc238c966f37f997c72f350bd5daeae173e18feb9865b3c715d304 \\x000000010000000178b14792a55bd6949020955a629553118836954053ccbff2977aebcd584d4a3fa455a85d43cbe806809e7f4b137ead76efe8e0b3a7e835106c3a25e8f995c0e17fa8165c557bb0892ee795196bffed7a89dbcf38383a06746f9c8802f361c784fb382f73bf837c862b20840d008f61ef2f8bdb2cd340ab7ab7f3de8d9c5896fe \\x0000000100010000
-34 3 9 \\x784ec625a24e7438c46d22869c2cabcdc31eb2bc5d0fb3423e5c58ee04934b0e2edd1fe1cccba814f2a2573c8529b5b8df35ea5d2b1f4e0dd097b8520afd4d04 14 \\x000000010000010071572fc2e726d9295eb49137c82a13dc12c08cd038101122d8a14a3841bbce45768ae5526951afb3e4681f90a2e769df22ea3ae95cd95cf011fefc529d2c44e156741b053d29a598d05a0a89eccd1901739570cad71de53983eef7b85a2ecbec84353decc65714cf02a9976bc5e874a8ca8cd1439a3501a7c30683021e4f5d24 \\x831e29ce6e6c439d9db7c8807b14ed47af0bca0167fce972f968f1605760928eb0632215c941ce286aa10bfbb427e9ca13098b2e1839254583fe4aea3bf138e8 \\x0000000100000001b5ce7321288881f83c44bdf03da5207558f19f3d3bab0773105fc506ac5b89bfcbd249eb3cf40e95b004790253ed25401c1bab71f328c66d70dc313137aa20608e478c88eca100c4389b689a8dd8f7f7942f487980a28664bb500a9e583ad8db5fbd4b2077b9896e476fff66480d6591f07554de62687bcd5d9255adf0282344 \\x0000000100010000
-35 3 10 \\x4c3fb70222cf876276727c87392a446453c3c9f04828aeeb1d268a18b8fa89dc57b4b29fb360f515d49ee0fbc413847f331a7db75138aeda4cf6788d3da1030b 14 \\x00000001000001004d8707fe7c683cf5f65dc197f94eb50f7a5451c1ce6b9954ab29e7aff87d70e364f09d19bd57c302bc7212b4f6142374d39c147a7233bf5f944e840967cca4a9c33fd7c1042b87895e6e66a689041c0c4f8d5dba1c8922a96b030b1c8cdd958bdcbcb66b699c907146353890982a0b3a3eafe634d88a2d35116bebaafdad5a32 \\x62935e4aba2d3dfca83219f69335b7078778cb5afc30f216f51e82a1f83a96e4d79a8bec8547c7c0ceb740f0707215b7655803f9d8de379f3fd695d1b77b8aa9 \\x00000001000000011a30ebc7ef9aad1ec274c5f9515108f4328c2af3cac8e0fa9f14abba22cc551753f5c15b4d8b0d6c75b338618e05d61685b0e90107b02f4027b2e9495c09188aeeace480f7ef86f90010eceb8d793d1761b656f1b04af16a4c8a654cb405d408dd4f74690815936cbbacba8bcc506506ae7678b465757f0f0f26bfb32b0b3999 \\x0000000100010000
-36 3 11 \\xac6ee2a6b44be729ea8c6589f494b4481b808794e10eedf45da96c9cb8d57006f7153e9753c2b902dae0b80e746e3904dcb9ef7807ea9dacc76d7ebb09c67705 14 \\x00000001000001009389916f58dc99df4054cf6b6f31705d3d489de101203ace005283471e0a67a1e36d22eccb69d3a0c7c7c7b1e3066e51c69328bb7c5b2fa5f65d0ed509a7fdb1abc177660f1ab059b511cb2d3b55aaec04ea24fd02b7d1f4b23626e9ef6bd41a7d825edc70ca5d7e5547ea3c2e1709ea9938050f8d29eccb7a6110ba0b6ee177 \\x71add7f49d0696502622f7d9cfc74bbe629d680d313ccad659a323e597bddcd03d638ad6c3e87804fb031cf844b98b6c53ccb5b981fd580f1a1a0ed3ea0e5476 \\x00000001000000017bcb38bdce4bc257bd4f9ec68b2d71b2f0ad80ef6d403ce7d84784f42fd3c71a9e1f0014ece7babc967ec0097084baf95ca8bfbb3862c5771afa56c43075b98b648ae983e3a9cd1f5b6df942045d4761534869b48312c67f1633bebabe6274bcd94064d47d34c75091187c679b6a26d63aa99e0a25dfe1917fe26bc55ea7a1fb \\x0000000100010000
-37 4 0 \\x032fb82bb77bb08d9fc51d2797d1eb8631a1b2bb780263f662e080e411d62265b214f490c0e5ef48f09718ff6e4b7f9e3694669a6acf196efba03c4cb18bba09 406 \\x000000010000010064bec6514c8d6031a814ca278d7145118576d0686a421bf306a05bfe592268b3bf64b0939a93be491377291d03b89509147f1255c314a27295c260c61634d3b7a051857b73df656dfe545461035acb94ac7ed91e11b4db7fb86c8d81f0bdd6e7744da727884875ee5341deeb4cc206a42b931cb29557d8211d7134da587d79d2 \\x9277c58b3cc5b4b60399c7a61f96a6819c3364777d3f065103dc61135b567555c7268b5eeb3ac0ca44c21ef87086e18cf8003d688939610b311a6f48cdd3f481 \\x00000001000000010df4dfe8fa87d35debf87bfaf6ff1e0912e59a1da1b4e3487c97c1cc4e9a03c900bf1a5c75dd47767f517ba04a942c26309041630ade58fa71a52df6677650aef545bdb6ea7a29e138b3e0d9aa0f3e4b5aad5e9303a86a29bf4161e943d238a6ab786f322e6afb8c5fe3944d6b670ab2e37ed8ef747bd49f4314fdbd8ecc4e33 \\x0000000100010000
-38 4 1 \\x37ffab308d3e706c6f829be7edb978003a1be3fb2a5d4b048a28af61f60cf6e525465f4183028e15f0f7f04b0c0788f290a77bb742bc6b33863f273a8c60f102 391 \\x0000000100000100b28b2b89e303ff35ff497953722b8f220179e52f988071918024fccf2ed036637e5e731d3616a913f98e81bec3e4b0a8780ed0c7a022d8206805a02e6c407c5ef8e28d0b7f78079278a0a9fd11fa00af678ac769484048f90eb065c8ad37af115d18fb169645ac1bbe9d932105ebc4014944142d1d5179b674f0a235b38df359 \\x4b8a71ff6345bcdd6066462ebe30685589f5f406e86179b2962ef949134c5f3de9db8a9893d0432a394e0f2d7faf35f4cf61773b55af310080fa4cc0f07a6c60 \\x000000010000000115b274dee45d02b822ebb14222d6a71fba0a0483892d1cf34263cb60f14fb5a478fc9dc0b2ca163742021ac56f8eacb4d0660a0d2a7d31d78e88cdbd824a05c0fa9315e193f9c92684222cb2c7b7eaac102c8eba85ac3e1fd9c67128e87c90ffb514d0e0c383d4b9dec701ea09011736589a18f4a5bb5b58d262d8f1e5cd40e7 \\x0000000100010000
-39 4 2 \\x9b78b9b333518ee5519e2f21aa890a90f5c4f23a7bcda4de2ed0d755dff449b194477fadb08c9ecb6b191a603284d31c1d581bbc8e8e31aa5d821894ad09260a 391 \\x00000001000001000c613c83b76fa8ba10665fd6b946342748aa9eb17831299bb4ae7acc8030b2719c96027eb165c18cd6fe5e0c25982ccb0a61ad4f734b9c9dca0702355cbdd13048d2855aeefb501cb81d62a24b148e3636d6177622cb2e03c92232365578c6a6a6a1bd9e8126f057d78dffb6069ea76d0f689dd1dd8afc4acca8c88e0fd6de70 \\xdc9415d838a7faa5b35092498c4c9a9a8dd87f3013457c3a4e198ac5f94fc0858c9e86ba0ab98ead81123360713d624a845bfe397acd7f08083e251b3b1dce8b \\x0000000100000001af584fdee0a1d57f2f6331fac4bc92af3868c2c4bc80a2bb17f45c6da51cf636024b800031048b5df4dcf6ea36fe134c23fe0e27e9aae555a65294c8764c6fb0eb9d6ac46c352e27afa6f8551090c8eefaaf07d9273a6d8f76c80244e13da7a9873c7458fd9d5851214c03d894ef05d0d09e7b339d679262ddf2b7f32191691c \\x0000000100010000
-40 4 3 \\xaf3ab2f172b707aa5ea66741affcf8db3ec3ed55f810bbcf9fbf7b0f67a4cd5fe5d28bb28e92bed43326512fa4bc11992caab8ce8db0d522bf5597296368f006 391 \\x00000001000001008f82a5a1a97950b0a6f9b769ec618e935fa8421a8551c2be44312e863275905ed47f8e0f0c2856ac9453c694027dbbbc713e14cb91d883fa8438f28517d1fa25043621fa8e98271489147bcb960f91414a67bc82b85a409ef39274b38110db75cd6647ec01ff930e7fde444d3d4200995b0ccd9a6c76057d9e8e6a340f43f718 \\x7b34f2efcb43caa3a5dd8767265d23a4ffe975c2cdcf9c05b65c0354def640acbc100dc23ab2d52a1798670313619ac58f65d25d82546dd3e86ccd4dfe4b0d72 \\x0000000100000001a2b6d154f29a3a31d9982128b0b1a1ade994e26801cab262ec28d45c6f92c4c8eb8174848e83e876adef01438529094c2d1ef74ac01362d7d2adefe008d7a4f3a15cc2efeac3baed36cb91a59fc5981dbec361ade8fa0233c0592a1fac5d41cafc94f2f4aa5b6266fa8e6f54ca8cfd91d425f167868b61277f7def246aaa5cf4 \\x0000000100010000
-41 4 4 \\xc580cb9f9cfcaed699bd84a6773be04957f933342b0a923185944b2cb84c3c8943460932234b4b8cd285af052e950fa86206dc83de1ff3c85070ed58ebc7200d 391 \\x00000001000001003817cceb6bb2d0f01c0e8f51a2d2969e521b6ded88683bc8806884a806bf78a5081b6791498c8827102d039b555f2f3df460fdd966ba89fdf03071c6317db1110cff34e844bfd3c9f71269f364e59288d4dd2f01fec118238da638fe32c5e912dfb88d3f699ab20b71953a2e6e25fd06bb116ed59a2180312a3209de54809da0 \\x6cf8951f7581c93f510c3bdb434589383efac3a853363f20f3cf3e256676b0d67b48b2dbaa2d428697aac1d6f095f9850e4e925d69b43eda9b14f39d78c4faea \\x00000001000000019307ab036cd14c377298c0bfab6edbcad3533e249a0015a884b6a7583e3ec67e1ba54261c754650d2680913d4d9ce5685fa13512e1336ba8c253c7c165227dac7992c6854684605faac3eb96004a347eaeee0f518d73ba878a5df052b33e9c0f0531dd1f0375000249da381248a935bd370b865de9d2f120663dcec0267af923 \\x0000000100010000
-42 4 5 \\xd3a533406d09d116cb420eddf6a0bb4a08fdbe1e7606b4f54ab722849b2eb9d7e38087a11ff551c03176cbcde7155785d43ca1129e6a83eaaca43dbab7d97709 391 \\x0000000100000100c7c244579c5bc7cea384ede40dbf2601b38fbc5dfae6e25ae74da6aa35448d80bcc546219bed6af3b739296f5eb485a84078316bccf0715b0a3e72955d56a25af16c555b3a396509ae8fcfec8c201628ed781648553408c8ae5c7e5d5a0bbbd2d36fb78c39ec0074008c03d3e6dbf234a9c2887568a212f7944b8e1cb6fc94 \\x23c65b63641b5b3d4aefea3ccece9270911c55e300123f3e1f2c35eb1916988ace490134a9f7cae8aa8d42ad862aef4a31fd4e2ebe1a3573bf392295d5bbe0bf \\x00000001000000018400c158aba40cf19a9bf020499e72044a167ca19cfe7c59abc859d280d7922cb1559ce2a63e87691a0584409bb98e7ec332d2b2d84f39842334e4ccc369e996b14c32ad2c23b6059dd63269c29d7d6facbdd6c189497f60e0a8fd3a153439be5790780fe707dfb936dc9a88b81618b67814a99efbadf90ce1d2b9338bd87af6 \\x0000000100010000
-43 4 6 \\x69c3c617fbbec3c6f658183d5aac19b803c08db9d6bd3f93b512c9875b752aa6ebebc1cf74455195095a81b970f6d43dea87d34f92a05fc3c956c1f4f1782902 391 \\x000000010000010041c0f850773daa09ced46fbe15b637852fabe3161b56502bfd1ce44e9fc16a651777a9b56e73eb1d7d4fd1720fbe64e21a07a91c6bc1a075f930acda62b770902e94eb56e576e27addb73b0ff2803f2075a1b88fca90f2c3bc47be7ac816a3d591812365035c69bd94097996172a14cbc05d8cacb3bc16ff9e0b099e16dcb55e \\x80d3b170168783497c1a0aa8bf3269014ce7a4ec72213db3d8aa1eee868b91c60ee62cc7d831bcbdeaaa63731380a4be091dd51b2ca2b4b34cebecabd0e3c00c \\x0000000100000001a2cf3b5c57466b6d20d92a2fdd557c79a95dcc50ff4677091cd922eff00bb4cf4fe88083fe7593356882f181edf8e57934087f47d087c4a1b2d8b1a6fb47d825b49a0f10f89973a10d2c4f970335375cfea751d59c8ffb07eca6a266f1e1c1e7a613cc89c3b57bbf56e81373a2ecaf3f9da4c75594ed9b73f60f3d2f536c3c44 \\x0000000100010000
-44 4 7 \\x9a0394f7ee9ae72c62f772df215724130d4cab4e8226e39af1c6a95b1257916c09e45475053a01e44779ac2d6c3becf801906e48ccc161e5e5cbb51391f38006 391 \\x00000001000001001196dc07e8a389bfdf76ad2e2d87d16d01b4a7513278af6f9a637d5ec68638e468fd2109e0f644ff935506aa3421d3e56ecdd89c43aaa269838fd3b5ade3301dc9d90d3c979d19e87d88e12a7a1e12f71bce39c3a886b49b56656b7775479c47cc2f5bfa01be41e2b73c75a1f446b39129aa45963a16c054d14cac31039ff8cb \\x747e30143d3b4df61068e9adf24278f82574b68a7d69f8cff8a98ff277412b32a4c2d9c86eeef36775fc1ace1611a0aaf0132d442735158e2bf58e9f5e7c022b \\x0000000100000001849aed2f95a904d6685aab01e0840e470858d40e2c988cffa3b5ab889c556c2021a1c046f3484660f4f6886b8e46165a94b8a16ccdfc8816399f66d08d5f06edad438407561e139ae47b4938da7e232dddf4b485653d9e1789f8b27f216a02b719a9f0ea1cd8c39aa38889933126ba3a6710f793715179b200f1b7ef8564d0ca \\x0000000100010000
-45 4 8 \\x352525209ee4ff4d9c0af793ba3d9344eea0f0cd60e92dfdc1124ed65a8d2249badf11ee9991134023343b304ed515b73a9605bf04ab8c6b4088b0352a884c08 391 \\x000000010000010080ec20487887b006661cb62a2d7f9f3509958d68a735561829ddca4f7a90d234456bf64e97cdd0526f91754330466eefad2592d897fca2b56d6e1041893456c5a2f200537c7aeae78a51d08a95cc90891823aad76ab7285bd144eadca63edc8fa69a19dc064fae41c0e5ce77f71a831283e202bc6eaee0652d0c2ed6fc4d728a \\x4bc210b44ec290462c2b79715dd16d0b1327db634fa0672213502ec8f44b06230f2ef78a4252d421a990adcafaec938790666732806682747480ae5bb68ba824 \\x0000000100000001a9b5b05f9db51b6d88f3623cf2e018c24fef6b43ae84fdca67604f41ba288f4a8ac452903b04b574516fd678191b40697075a5dfed7ff64eae1260c0b1f79e67f329e3385cb27dc1dcd42d41313a7f4bd600445196cd59e5fa79accd6d8a18cc73d3b3c66c51bc9dc0a1bb64e53d547d5189506ef0414eb56dcea5cce6cc5065 \\x0000000100010000
-46 4 9 \\xe6d6cda7de0afb05552e4f6b4faf4d6d0e7a412ca56e5aea52d86b3da591eb6fdd09d6d501e1115e0d529acf40eeab19aabb1a8774ef83f961aef6eadeb6700d 14 \\x0000000100000100a4a5944d7510c770092effa948acb3e2adc6c2385cc366f077945358f17d97c5ba286cb62e2258d82cd9d65f20ea21942ed0ce2ad1d9fc4ea89f1967d243230c96a11988304c0530a09dcc28d9f6d56b4d9849220b0a83c1bbcf15b8a71e1ecd7a4155dec5b936cb2b0abb9b814190b176d6222b2a11882c4e4ea745c4df2cce \\xfc4e145563ed3c5e4648add0f3c99b2532ef8859f97e73eac7297313e612af244f634e54667fa30cef28acd042f973a28fa86f6d4f9fd50ca100f1cf1a3fd46d \\x000000010000000146689e64c6a5fef8764ba5fcf323dd17f047069cc4635b6df654416aefb54173f4be3a1651829b9116a23ff31ec3dc553f9288a1b83134cbc142ef019b87fab324f586f04ac7b41b09eb0713008ff4f10ea0fbe062be34f07200778ede41ff191d09063c30a5e12cb521cff983aa8baded3c57cf2dcd9013e21a24df3071bc3a \\x0000000100010000
-47 4 10 \\x50787da13def68f1f83996ac9c279322840c6be3d8b84050e1f454e28607dc82050279bda938cdd8379667ee09b9ab820e9c7b9dffa426ea9a67c1951f4a8102 14 \\x0000000100000100b71a07a4f6a9ee9fa6fdc52eb1698e3040d6dd79028b8870fb0f47592c7ba83218bdec2e3aa7777c6a33c1de24bb5dcad3ac3376858478713ea4a5322fd6a4404e91ee9dacdf81594c59b5be0ce0ee6c74e9fbb12eed89cf5cd83c694a72e619f950258038e4c18c6b08e0f5a55856233935f37c27bbc55aec0864cef3baad69 \\xe347093ff361fd9482f8d518050700215fdd2d5a6380628e42c9e3542b80e91f5d7ffe0075570fe1cb0ca7b5ddfdbdf74eac47bae950da72374387f920e6ffe2 \\x00000001000000018f53d05004b6871aa1cc65afc5043793c7f9032effe08cbda2bf35dbe5caceefccc00f1b7b94559cbc23cb1b6cf9c41434a255466468be7fcc57a871f30314b3230de0c7e55b56b13976e63be5c8ef26bfb8396407fa3fc3966032c9962f7032881530f47201efc004bbf8cfa46e50dfdfed5fede8646c58a3f450f2d6b8ae51 \\x0000000100010000
-48 4 11 \\xebd6ca0842b84469b5a248a93f84bccff376e55e3d89083c5fef7d6321145280e27bbb727d6f4cc71a9ec2e77fa8c2903606aacbe7322c4718f345fd55b3250f 14 \\x0000000100000100b07cdf535ae68f86b00225e9ce0161e9292870c5102f6095e10155f70e2f912dc54a8e931a25005db7df99372e265f6fe346fd9c45810afd5ad96ae3f826a0171a9472e89755ef5435fcd7c0ad8ac8185546208d7a798e61ce537fbb33dd8d96c9583f9424bffcee4d183658c236eedd80246a9e7c57a1f95db4e6a1ec6520e1 \\x856859c405fdacaec101d710f285e9cc1b9641677f0db0620d97c5c41502956986a92eda4dd1811424048db7ec8f47edc1e3594bba893086685e30a9a4d2aa6a \\x000000010000000137ce92594268e068836fcb90b5caf9f1ed09894c53afe63e2f76a14e775cdf4d1388e7d0b1c9140b61e63eacb2489a4329b6ce4b5c3f8134d23ac36f1c6dd0228e4b39ffb3fd8a6cbec29d0b7352542b0857c0b2d2551e1a488567bda16ebbfb7731bdfc274d67fdde011c5a4eba5be03edd272dc6b66f587722829fea456c15 \\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 \\x88c8ae90ede4fb76af563c92954f80155b443adce2d11528b6e0b06387b0a87e \\x6d3d1944399ed2bdc7f985b86052d37015bb73409efe9e7dcb7b99959cdbe5dece309f620f0fa4cf8c77e077b621509f063abb0c28c091a69fda5d051a3933b4
-2 2 \\x6e08daaab3b3af6e38b20bc41e83c7c957a732a785179a0acfce76c7367cb607 \\x2f2ac1efd024804570cca5fe7392efb48407dcfb707b51f407b8871d4468df041e0e7c806c980bc09aa05567212d27a2aa04d25018565def68ff1e7c3753a67f
-3 3 \\x5bd5e1bee16de0844b8219b35af03b80dc313600b817a647aa25611d0e77b76c \\x0332acb1b1221f132ec859898c877132b7aeed1e1dc0db7d74692cbba43249352b1de01402ead8c66db7e372724ee50c48f6cf2785e64530e0503ce6fade7276
-4 4 \\xec7f949a594a49bf11fd93c7a4dd00e4cc18ccf6e374bf3f0ee41e1d9d3acc19 \\x85f78f13a1dae065db1d608e8b5553fa3e1702add68881d766f5fddb1c27f354d10afd7aa5c850358d835e1048a9f9ffa64cc3f7fc8171cf83aef892f2ddb791
-\.
-
-
---
--- 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 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 2 \\xaad0153dc4c5564044400275fdb0aac96057cead28d38bf64547513633a5bb399a675e4a5e264237a957ad4fea72d2bb76df84ba3890b7be73edd4794b8a9108 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, max_age, expiration_date, gc_date) FROM stdin;
-1 \\xbd20ea3db4647abd447b0d7fb5bf8e0c95b325f95db574fee43b43bd04aa0db7 0 1000000 0 0 120 1663073604000000 1881406407000000
-4 \\x1e8dcda2f5de0323c2fdcbfa5278e19a43f8c4d31090403a818572a2397e6240 0 1000000 0 0 120 1663073613000000 1881406415000000
-\.
-
-
---
--- 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 \\xbd20ea3db4647abd447b0d7fb5bf8e0c95b325f95db574fee43b43bd04aa0db7 1 10 0 \\x17e36f9902fada59cccccf07172878ae75a41daa3537c439b45b8c4ed129fb57 exchange-account-1 1660654404000000
-4 \\x1e8dcda2f5de0323c2fdcbfa5278e19a43f8c4d31090403a818572a2397e6240 2 18 0 \\x7b4b32ec2d7f43a6b45ee01806ab31368d50c45c7c6d1783b0d7c0ac26368540 exchange-account-1 1660654413000000
-\.
-
-
---
--- 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 \\x5a7f7510bbe60fed8b164e472e56f7138f4393cd8b0314043957bba941c204adc3d2f22e320d07afcc9b86afcc7d5b83ac7b896a543d1ce0cce31dfa9b708029
-1 \\x80f609ae4874d0d1d27d34722303eff525dd6b1667832027a8a4ddb441cbc401c48e91b7b7a313c58a253f6715bad938e0628c83f2d1810d08724cf28c492028
-1 \\xe7bda2ec636b9f9f175caa40872fe13f69280877c67888c990c39340c9258b0f295ff6f41e5e29d1a39c799b7e222e1b7cfeb81c5044efb1483a14c5ae7c5f6c
-1 \\xff5ffca6ec51dfe1a76075a3188510f720514b43b82e2510cf5626f999bfa0f146428aa965bad5edb0f7c471b7bb7827ca432af4718de6998ef0c7dc9783c89a
-1 \\x323e5a1163f5210e82ddd56a30f34c56f4e133723c6938e7ce8b1136ee1faae41ae1e8b655e768e07ea10e6ebc56b4cf911956ed73d144b78463f05f7cd86d51
-1 \\xa5012e03825ba9ddc9fed44e5dfca1f9c98d9a06b14641cb219b403306352dfe0c60b29b24ab55f0f103d7a795bddaef1900ea471244c4db410fe860ff2dd3cb
-1 \\x67baee369bb152ab80b17ea8543be2e148e7d7da63c0b3e8c8a0907d1b3555a67373c736ed5f66f99fd2b0c8eb3ac856b430aa6eef3f79a925c722ac39667f3e
-1 \\xd707f6ee0f47d6d533206ed994325363aa329646b5d0314987a06b33fdb4b9db3fcf0a76436e7e5d497d2df51b55083e7aec98e2d1c4c5e18da4d647f8318e88
-1 \\x565d8d5f41b66f7d60016511badbef3dc33dfe9c7e1a7bc20c87daadc41824be61b485a5d9d4a27de5cde5648249d0ff67cde5ce1731ba3bcb600fd5eb76b801
-1 \\x0a5c6e2558c383f3008bcb27970867e46f7c62aa1f90ef7f923f8204dddaaa35fe8eb20c141a57869c5b895b5ffad1bbdb19e6cabda4e96339d3a98b3230d8c2
-1 \\xf39dd6d991e8b39c9f0a6d8705a8ad0068c74ec1446e96ae708ee4c876f16ba793a42ab12b5a736147019011f1f8bf95cd439c04293481223bf822a89b010ee0
-1 \\xa598329649094e0a89155d72b42e1a7225767b140d8452f4327f06ab8af8872ac77ec2e1ba90be2fb14e19c90fbaa8b5fd7df2bcbe904598e17c09cde0d8952f
-4 \\x3676e14bec87012a1ef4e7bad8bcefc96b18a8d75b24b191ab4a793fdef2b983b43b206f02ed469c190138f12f269f4f23057d3ce97a2865f2e7de2e857752c6
-4 \\xeb6c7cae835471016a55bffb10b979b266463a2e6e9d8f63377de64880abf86a935c61450c9fd38aaf768410bd676905ac595f02a9d947d8d7ac404cdbae3b7a
-4 \\xff9c671a71a07cbd1e2984cbba160990ae40a528f9a1d7475331c1b97f5b0af21e1cd4066c0ced0597ff262ff1e6538bf4775b9f41c77dd7db4d637a6473b1ac
-4 \\x9c2a64e2f36d05b45411e9f1c628acfe6ef6f9cde87d6156f17b1b114de078b92634bd8335b8473eff8a3906be636057e2ad5310af4da96dd0a501061875859f
-4 \\xc49d10e052c2ed9cc54d1f247e6cb78868d1fab7d6278fb936d5cd98121f7b1c1198e2a6ab5c80ca14bffe3fd2e2010b32b02ae2e6a3c29b10ddf7e849de0566
-4 \\x601a139fda0ba3142c9a11f5f64ba0dce8289c5f45c0f4257ba39a15f686f548419be0c127ec9406f935ad79e083e675286ebe68b94134014f79cc4a1ec050fe
-4 \\x2c8a770832c20541567958681a6a3cd011c92051bdd9da77f61282c75f0c9843f67a49c0532aef0ad51da657bcd85b9e4364b6b6c4f107b1766cb891bbcd8080
-4 \\x7a8f3c7eddca9e1670eea57756074c4d8545502962f7f7dc03bc88960ea501569a91de7a46db636c75aa3994fc5045e154ef6b1e571ff51eab511afa9dbf3e71
-4 \\xaec98a1be95e02769e9486472b3729e2a5771d377c5494419dba889998b5a7504501ece18729d899d0955d425bb94f20dbd45ab418d840760fb1ede87a02c689
-4 \\xa487effe9d926e718d4e6aeba52e1c46e83f21c90c12b0edb0660ceac9e7e66fdd2db3cfc8c3282874be992ef9a4cc67665e72963de3f98eb3b98601587bb6fd
-4 \\xb649b38d797bab334d46f1700fbca9f5d09eb0f38dbdd878ff24f7c50fdaab393cbc1924d772cfe821ba0ade949fc628721a2be43c767d83aff049c61d76ab70
-4 \\x2db46c560e35c1c2c092ad315f25004ff300428d2a7862827feb5eb4f3762d8ceb5ec3b88eb2f6df35beba8aa78cc841f73940d6201cd85734099f1faa814b54
-4 \\xb2ac27e5ccf0922d378f7b2e4ae8affb4adceb68d2f297a9cec9b55dec2b28e3944f06cdf6513eeb9b8e91e944cadbe062951efd3a96958e0871d1f3272255fa
-4 \\x9cde06ac1cd335d8f31e740989e9a0ffe544c651144d12b4f3a63cc14a0f19e003e2719fc9bc8692970e72ffb95320c6c78e3467b228fdf57fcd950a1c7a7d60
-\.
-
-
---
--- 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 \\x5a7f7510bbe60fed8b164e472e56f7138f4393cd8b0314043957bba941c204adc3d2f22e320d07afcc9b86afcc7d5b83ac7b896a543d1ce0cce31dfa9b708029 223 \\x000000010000000173e2e47ba1765f5afecf031ae1843b780738092f271e2711337422dcfe6d3429d7102542a2c2e2d0b403ae9b94db8d42e5b87cf754e834d38dd19ca3f669ec25cce7e7f2ee3c2b5a5757944ad3a937445fae3c11b7f5f2961c3a5a9ccefbb3bf8dc4e8dfd06c556cc5ed0ccbc63aa050e23a2e2a4a66006ddcfcc50ed405807a 1 \\x25d56c5441bc6090c8a75072eebe7cd72f2342ffc0e5a5f710227412b6554d0327afc97e2354025684a22eaf9aebfa303348006e9734a7810b45abd263d16a06 1660654407000000 8 5000000
-2 \\x80f609ae4874d0d1d27d34722303eff525dd6b1667832027a8a4ddb441cbc401c48e91b7b7a313c58a253f6715bad938e0628c83f2d1810d08724cf28c492028 406 \\x00000001000000015682be45a1f768fd28864610ff01cf6e8a3f1cfc7c35a70a75bf0a42d6c69a2c514101deaf6e799ca14ff35b67abb5ecaf5a1135d6aa9d1a6879fbe0319c925c95867c7c3c0ae8c594d17257948d2263a8b8273e6b42a7e6dec237a276b7613702d5260b43743b8652f83204eaf8a7c0bcdbff6039b18bbb6ac69e8999304a1b 1 \\x85e2fa242fe5d0a52964d0b1265d3e350287f617e167ce1f52ff1db84f6266641623751e52dbe2e79dd5705ac2a4017bdbb9d767101e6956928c86fdff21e20a 1660654407000000 1 2000000
-3 \\xe7bda2ec636b9f9f175caa40872fe13f69280877c67888c990c39340c9258b0f295ff6f41e5e29d1a39c799b7e222e1b7cfeb81c5044efb1483a14c5ae7c5f6c 391 \\x0000000100000001392a68efea0993517362a487b7289b3ad490c4b5365185418de89fdcca85bfabca5425361ba1c6d2727eea1c7d1246e1e74b19166add04a5f3961d4f939df5a37a0e6be9fd7205e73243c3ed74b7931a16c5901ffb20e41f9e7db70511e7c74c59df976425529697fcc4b94c9fc5195e9484911dbfb42552c39d6bc3f799299f 1 \\x9a799fc0a9d9cf25830796b7a27fbad36fe741ec6b564002df2ef077292d06746968b1e15252ccfbcfda6c8cf07e6e21e4e87d0fdecee311869e557849ac370c 1660654407000000 0 11000000
-4 \\xff5ffca6ec51dfe1a76075a3188510f720514b43b82e2510cf5626f999bfa0f146428aa965bad5edb0f7c471b7bb7827ca432af4718de6998ef0c7dc9783c89a 391 \\x0000000100000001ad7430052962936295df39f347bb5f1f0f3ef7f2ba959fde84349b7eeb794523e39473b90acb7028e9626e42b52f92614a183509b64b644ae1d5bbaa411c7b60da3e999a2b050a96d75cdade7eab3777aa3e41310ebc0ded4ff2484dfe2d2c1f75592b4b9e5e24d1ac1baae9f0791d0af8ccb4b2d1541b77739412c7ea866c79 1 \\xbb88a328f4943a10a8a91f7fe11b0a645af2a80d5ccf6e2c11c926d55e5af0dff8f12b47599220be993a9ca8b422a3bcb04f919bf8458fe0626696ffcd9e9b04 1660654407000000 0 11000000
-5 \\x323e5a1163f5210e82ddd56a30f34c56f4e133723c6938e7ce8b1136ee1faae41ae1e8b655e768e07ea10e6ebc56b4cf911956ed73d144b78463f05f7cd86d51 391 \\x000000010000000178df6b54310183dfe498ed9f99491762de8bb55dfa0058849f26e73b2cc06d83da95db0afdfba8914911f465bbe8ebb4ffbc464b20b5315fa191ae568fb6d1216781b65d41387f49660bff5b4e2e16d0bd39314fedd3aa690c743bed34dd9c32c76320d61630ccc857e52ffe5a18506b6adf99613bc1884dbdc8345520e8161c 1 \\x000c4f6015ea62b1965aa84a00faaff59e6179db6668576cb7771ca88f8a5f6b296baa3869f3063d8226c805de697b7f7c907d9d5534c67883b896e0932de30f 1660654407000000 0 11000000
-6 \\xa5012e03825ba9ddc9fed44e5dfca1f9c98d9a06b14641cb219b403306352dfe0c60b29b24ab55f0f103d7a795bddaef1900ea471244c4db410fe860ff2dd3cb 391 \\x00000001000000013f352fea094dbcd6a5ace4c3532e622ae70e3b8dfeb0eb4296ca4dfa2758ace17a2218e8964b2c85e0caaaad9bc1ebf9f811798677953387237ec3a241b3277e63d685b681b224a454238c636972f24674c496ce58e8460abbce3c883ff0fb2c5c65028f2184948ca6b4a048e8b98f799be0d64ebee18e2bc1b35880c41f567c 1 \\xc7de62604637338a96c513262e6ba0191e215b4c2987e6dda05015b212f6f21c363be160121cf99c248771a5b0674e2ccaede0998c3a710b8fec0bba63800b00 1660654407000000 0 11000000
-7 \\x67baee369bb152ab80b17ea8543be2e148e7d7da63c0b3e8c8a0907d1b3555a67373c736ed5f66f99fd2b0c8eb3ac856b430aa6eef3f79a925c722ac39667f3e 391 \\x000000010000000164fdeabaa4b1ddee6329bc2f7a5d8112e00bad65fb4cec99719fe64c32657826cf7aea326f3c1e0dcb12207b8399501bd51af5ba7ea1ce99e1bd9ed23fb29722675a90fcd86f8a6c6583d29a0f1dd9e860d591574f1ecb585ec5723ad91e3a61e8c2bb61ede6071049910119e3f032cb8d95c9e58cfda4cc34f64497b49caae9 1 \\xaddfc54a41566a16441d05f4773fae88a821ff0956d3d88718b46ecc191a673db552615220a9ca6e6b36488b713e3350c555fcec39c19861903f320b7a0c760f 1660654407000000 0 11000000
-8 \\xd707f6ee0f47d6d533206ed994325363aa329646b5d0314987a06b33fdb4b9db3fcf0a76436e7e5d497d2df51b55083e7aec98e2d1c4c5e18da4d647f8318e88 391 \\x0000000100000001697ab9c35228b744451f028f0a875c84a0e6806405bfdc44bfb9b1caec69e802aa3ed8049453123106bafd31eb46a52ad019adad6281bdb517f01a18e33a97b86a096c35570f2a865c8dce848b0087b7627547a57548310bc20489dc103f293c0544a6660102e5e7d21cdb21df2b1ce92fe6f10dd545691bd02d096484b88056 1 \\x3d172ce330becdf46df5e7f1a5b2fe64463059a803bc13287fc32f8f8346ffb1d957968d8038e927a9c5eee09dda875598428cbdf91e0535dfea86c69fc21d06 1660654407000000 0 11000000
-9 \\x565d8d5f41b66f7d60016511badbef3dc33dfe9c7e1a7bc20c87daadc41824be61b485a5d9d4a27de5cde5648249d0ff67cde5ce1731ba3bcb600fd5eb76b801 391 \\x00000001000000017c5d02515be2f7ba0cb399eb24383a1af3c5355ca4a87304cb97c7eb6bb5edb92ce9d1cd4abbf08f74428df90fdf93fec6afedf55d7ed75f10915e02eb8f9b7b4f91482ac48cd3ed92a87abb74cd9977643c2d549a3f6d80cb0f761a4e1bd7dd1ed53d23f104b4c855fbf1ee0496cc8cdbabb0c87552c31d9b14be084d5cd28a 1 \\xafee72b45bca47c7284899030ab91c08a6a25c903272097c8624a94f891a447e72b49ad7275c83c35e9ec59cc53bcd9eb1a9c61fc0fdccb71ad696f78a1c0e0a 1660654407000000 0 11000000
-10 \\x0a5c6e2558c383f3008bcb27970867e46f7c62aa1f90ef7f923f8204dddaaa35fe8eb20c141a57869c5b895b5ffad1bbdb19e6cabda4e96339d3a98b3230d8c2 391 \\x000000010000000180ca7e6471deee5a29d3f584391c9464e9983f8a427be6e751cf68b44b20f9e16976a8a574abc60e92595569900bb8ddbc00b8cf2c56601d22eac71fb9b7a0492e7c03d995febc9ef24ed67ab1c229f2abb69b9e1a2ef3dd0c2d17742b2f06cbb86e702b3279cd478547d47eb1f65a3afb91b135f30064d260b013ec6605e3c4 1 \\x5787221eb37494da38a20762066e8728d985f5b1e6576a3526532614148579a03513eab70281264e306ad17f912fa911ec471c8f7be901a084222d8b37c04806 1660654407000000 0 11000000
-11 \\xf39dd6d991e8b39c9f0a6d8705a8ad0068c74ec1446e96ae708ee4c876f16ba793a42ab12b5a736147019011f1f8bf95cd439c04293481223bf822a89b010ee0 14 \\x00000001000000018f078a1a5aafd378ae7286eeb771e0fc50ccdaf20d0c384d54c0bf2811706eb9bf4113cbcf3bc608ff1745c299b882daa92023bd9ee3d51ee7fa7f2ce0087bf291cc2b800d5688ece9f8ce29824002ba6985c18da7198eae5c1844599887af17b8a6a54bf30a24ca8a868a65104b4a47f1a9806ce8b3c01cefdb4806151afa65 1 \\x67e1da6d3f248f96d4ef573c08291adc9c56eb14c7926e878de6920ae12edc445f9980214922a4076e2ae009cfa012e1f55ca0faa8845d4ede3a3d8bd92a5207 1660654407000000 0 2000000
-12 \\xa598329649094e0a89155d72b42e1a7225767b140d8452f4327f06ab8af8872ac77ec2e1ba90be2fb14e19c90fbaa8b5fd7df2bcbe904598e17c09cde0d8952f 14 \\x00000001000000017e78e78e9ee649380d854ba408db9c722fbb9e381d66701124a087949543733e6e627ebd6527d2380685ca7cd9fc57710a0ba37bd810d206b8cd11edc2d0bfafe83590412c4daf16a1fc9f50c356e61f5d11fde7188c32cf180657ca8ce47d48a72e0755b7708047fb7204c0964dd3648368471a8f243f2cb43daf91b013dfa6 1 \\xfccfb712fddffc8c467df0bae8f2e6bd93e1294ea8263a03a4f422a86ac65cbe8806b89e8dee72e9ed519dc8a82ea6d25c2f195ffca8025e9f6f371ed7515302 1660654407000000 0 2000000
-13 \\x3676e14bec87012a1ef4e7bad8bcefc96b18a8d75b24b191ab4a793fdef2b983b43b206f02ed469c190138f12f269f4f23057d3ce97a2865f2e7de2e857752c6 120 \\x0000000100000001143c70ac85e3eb02390a9854ba20cac82241d7bb51bd278e670a5b1a8ca1fd77f3f601f757d1bf1de789de851d505522eadb19844e631483dc075fb955d8c1ac470015d08d9e8089e20acf8cc711efe9c407d7992bd3cc9edfa893230a904a36d22de0cfda77ea7425491c7a9d4fc4d23636bb9c122dc82a25cb9da92b860adb 4 \\xde7b52fd7f928c1e68f51dcd4b840da0579a86551385c3e7e0c68c58db91b7d0148322f2ddc0dab9189ab1ee7292142f877ee738a346aa5cf36d8e227d4ee60a 1660654414000000 10 1000000
-14 \\xeb6c7cae835471016a55bffb10b979b266463a2e6e9d8f63377de64880abf86a935c61450c9fd38aaf768410bd676905ac595f02a9d947d8d7ac404cdbae3b7a 160 \\x000000010000000111ebeaec4dd9631db3d837747ce1d95159a44f38920fcb1786d9305b4f2d42191f18f08630957b4590ee74d09fb1ca31128944a736fe4db465ae273c30ea18f9beda7f6ec17cf5ec692862bda4c71b31113cdfb57f9920a4a03c8e84ebda852d6801f02d3b2fd3cee2aefeaac136faacd269702083de6526e1e72ea7146307f5 4 \\x3f8bd80ea53917360cc01c38051849f7233277aa03f6383c98626eb1aa9f750a719f12c8a1a75827f8b3e45ef112526aa4db29d455c195acbcc19f65de397100 1660654415000000 5 1000000
-15 \\xff9c671a71a07cbd1e2984cbba160990ae40a528f9a1d7475331c1b97f5b0af21e1cd4066c0ced0597ff262ff1e6538bf4775b9f41c77dd7db4d637a6473b1ac 112 \\x000000010000000180eb3e3211a2f409d0eea5a104726c00548fa81071cba8cfcabf91a00f3eb4e538fd237c387bcbb3eb2ce21adf08619ac4b1b0fa063fc8da2a5036f30468184df0177e3382313af02a60763a8419f5420091ed66ef8431c8b4984b5841120b63f9f66c85bde0c4a2d43222ae95cee0440781f56c805db7c6cf1b86fd5270ab99 4 \\x8efd976f50fdabd0cac4d02d9d24c78febc17f30a852da55eb99d6ed923491c68c669442c3608e40baac8cb454c1a89c03390767a84e1769848f64a5995b8206 1660654415000000 2 3000000
-16 \\x9c2a64e2f36d05b45411e9f1c628acfe6ef6f9cde87d6156f17b1b114de078b92634bd8335b8473eff8a3906be636057e2ad5310af4da96dd0a501061875859f 391 \\x0000000100000001064b027d6bbb24ff79e8642e59b58c69b5ce032b33395ef7ec6b2bbc4daec5921f772da78cca7395e3e51f06428010b58fa7dedfbde66277abe889b37869958581f86cd550f1dd784ccb779d6d9123c233a57033b8294fa4b915ceda569ee2562939b58f38cd44918fd097eb891f2c3aaf798c8ba1c86313691cf035c8533af5 4 \\xc4ffb42f0782a463a9561b3b936f71e654510684597eec0e8780df7a71442d4b08491241ac1dcb457f7f8b33a73a284fe497b87dce44d528e96f72bcef318c0a 1660654415000000 0 11000000
-17 \\xc49d10e052c2ed9cc54d1f247e6cb78868d1fab7d6278fb936d5cd98121f7b1c1198e2a6ab5c80ca14bffe3fd2e2010b32b02ae2e6a3c29b10ddf7e849de0566 391 \\x00000001000000013dca500bd18c8347e1ccef9bbc1e18302555fa08d191dbd3c31379d76dcb266f401828ccbb9f62b34efbb739e688c8c705e96caeb70792b129229a786164c4d7bf05e2438112e3d26f628236525e00facf3e02bcb77e4fb537ec9460c2cf4080cb0de4baf57a9cfb74755be141dd58ace45a0a5a286e6823e9c072d2bc044466 4 \\xc9662cb45e29745a13be6dcd7415ba69fd38fbfa988c3ae2715cb78e6fd0e4710c6a420b94578010cdb2cb1dff8696c461382cfcf8753c6302966062fef2c102 1660654415000000 0 11000000
-18 \\x601a139fda0ba3142c9a11f5f64ba0dce8289c5f45c0f4257ba39a15f686f548419be0c127ec9406f935ad79e083e675286ebe68b94134014f79cc4a1ec050fe 391 \\x000000010000000110892ac724c2571c41370e1ef4d899eae6f9f349c8cdde0ebc1518a33880c3eae80ab6558b0bfba83560c5aa75ea6c0d1a181e0286f5cf60c1a6799c0a8b820a7297d0d2a85ebb3e8f8ae04d7bfceb18af885182f634b566d90d91f44e0d9ad366b3a047b4167baea5a3339d55331e9cc06ca91c3832c6233a63974b2a0fa6ad 4 \\xf434a820cd9b5472d8d9b82a2221a98c089e92c74ab833416abbbec1832495bbcf5d672c1321e226bace72851b24feca97775e40ba4b5bc79f3ac76b8404950f 1660654415000000 0 11000000
-19 \\x2c8a770832c20541567958681a6a3cd011c92051bdd9da77f61282c75f0c9843f67a49c0532aef0ad51da657bcd85b9e4364b6b6c4f107b1766cb891bbcd8080 391 \\x0000000100000001b9ae9ddc3b7182abdc4579d88510c51656dcb36ea7d140a787d0a058269d014a8805abcb439b955c026a4fa05600a463ceb7892c16b0fa5e31111e45026a2849337b729635a2b819bc958a8988681aa0ce6640d5952984527ce7ad8e116cfa9777d0496ec163052f2b95c44be1b54988d39d069ca7fa11a0458a13efff5d1f66 4 \\xcfc529423f5065cb823c78b4693b701bc2fee7ceba1a643e79d61273e83a5a778b0c3706f6208c3b70ad6834625f69589dbb03437f279d9f75a85518996b0e00 1660654415000000 0 11000000
-20 \\x7a8f3c7eddca9e1670eea57756074c4d8545502962f7f7dc03bc88960ea501569a91de7a46db636c75aa3994fc5045e154ef6b1e571ff51eab511afa9dbf3e71 391 \\x00000001000000010c6cfe76138e41205d56b6c7905679f2d2dea3d940039ee9032d40a26af23e004a183d936db8083de5e3560db17d0f29373c28403c15a7218ac08d69926367dba7e29929851171c2586306fb3d4fba490001e920b9e568a69dad9c7337c599d68480766f111b5c2fd6baf3a9fed3f7c181b6735bdaf159b84d74502ac7b87567 4 \\x62f211442cda8966755e6c5007aafc5f2227846f277e873c0cc29c8cd582e318cd4b2e1290864b6c3c1e5f42bab42eeea658454dde001c35a3941d6a7548500b 1660654415000000 0 11000000
-21 \\xaec98a1be95e02769e9486472b3729e2a5771d377c5494419dba889998b5a7504501ece18729d899d0955d425bb94f20dbd45ab418d840760fb1ede87a02c689 391 \\x000000010000000162f0e890d19d5d0369a2bc727528cf26f7669a8b6fd418e2c9a671847489090778e31ebc182a91dc1ab96411c960567aa006a22f5584b2a40919d8b4b31419c1262a59aab5f7e554954e160e9637603e8516630b156bb44de0458b46900d484b784fd4d7a91a44d8ec53f58a066a134e7fc1cdabd6cefcede7d79c16e235af88 4 \\xfebb1d4bf9dfe4b9fd7bb5e8053101b9287fe9096f72c55ee82fc74bf51a75da50c0458e42f0f23da35ea05c10fdd1da2b4e7a69ffa7cead14346b2863f08601 1660654415000000 0 11000000
-22 \\xa487effe9d926e718d4e6aeba52e1c46e83f21c90c12b0edb0660ceac9e7e66fdd2db3cfc8c3282874be992ef9a4cc67665e72963de3f98eb3b98601587bb6fd 391 \\x000000010000000123f6ad84672c424ec8a0c22883c4833c29be1bf80ca9517226d5d04551a974d7b2a6558c9f0d7fc26fc986279611bc0392d56259b96543e5aefc6f6a206d2fd38a37f76976a83ea4776270d7097f51c434549f0923a63403fafeb5ff5e060e23cd1f4820eb16d58b5d3e1b9b4d624aec3a3276101f327d6b8bbfedfcd64f470a 4 \\x3b959bcce96d034de9ba5a6cef7886c1b01f349c3518e0938bc9a0b099063a8e69c297189a2595d487c9ac8ac53a069fe502b8abec01b98c0c4f9a5a5382390b 1660654415000000 0 11000000
-23 \\xb649b38d797bab334d46f1700fbca9f5d09eb0f38dbdd878ff24f7c50fdaab393cbc1924d772cfe821ba0ade949fc628721a2be43c767d83aff049c61d76ab70 391 \\x00000001000000016a0e094627ed5ed7441070147eb828995fe74fa3d5eb3e259ebd08b68dc7fe5de57eac03d616eb7914816283848197c1f44d6be719d2df86010c11a1c57ca9fcde0bfa278fe23a7b0125fb850f72143bafa0c81d0853f22b75a396c2c0693e5d26bb319ca186bb47bdfb22adbb9aa3230422644fafec42a2bdc44e51aae7ed2d 4 \\xf60f7038069dc4fc60d851335ee65a685835c5269c8f469673762dc917071c33ae29b5679ca1b3d0e1a029d8b4328f3c64b0c4664f196bfcaee408dcb561b200 1660654415000000 0 11000000
-24 \\x2db46c560e35c1c2c092ad315f25004ff300428d2a7862827feb5eb4f3762d8ceb5ec3b88eb2f6df35beba8aa78cc841f73940d6201cd85734099f1faa814b54 14 \\x00000001000000011446ed6c532b2f13de97478b2c17b55c460c410afa4380a24dd42ee6381b06949b7fa0b675c602cb1d2cb79d8d6f1f1692e2891fd1edf11d12d09f712dc99c5cd0fbdc4f2d69f32d01cc966d00b0b4a96a3e13a636894d23cc7a8a4318072f0977d7e1c617912b38c79e65c74c1a136bb95735efcd96cb7c21b8259ec251489f 4 \\x85cc4cf8c1be3e111b8566dab26018cf391799614f1147a3bc056f8d89e028f3db8e13199cde031635f5f1d8821efa6ac2d9fc038379225d886a0d91f04cc907 1660654415000000 0 2000000
-25 \\xb2ac27e5ccf0922d378f7b2e4ae8affb4adceb68d2f297a9cec9b55dec2b28e3944f06cdf6513eeb9b8e91e944cadbe062951efd3a96958e0871d1f3272255fa 14 \\x00000001000000015d78ae132da796f583a8607ed39798135678b9e422fbf47412f1fb96e2a72f2eb0d25daff19443e1ef815bd0e241e19124f2ac1991621cc0d1e2cf20dce612727a18c9a004aeb13a5b04dba841b75af6a10d486b2c0f43b021c80f4065bd8011b3c1a6d4b0a76e8abc1c4667dc5dfe705012a9756f2c0dc9691a26f9b2eb9e7f 4 \\x1500f178ef359ecf2c8f617309c6e1ce51c16b6074f231f7b7d28e3ea8c2d15b1afb9d51dbfc1f94cb3e6e8d955e2a7c7d24b94c721d9a9ad92cc6b5cd602c00 1660654415000000 0 2000000
-26 \\x9cde06ac1cd335d8f31e740989e9a0ffe544c651144d12b4f3a63cc14a0f19e003e2719fc9bc8692970e72ffb95320c6c78e3467b228fdf57fcd950a1c7a7d60 14 \\x00000001000000013ced93af7f555c6dc1cf8f9b138441c7535f2bd08988bb2908870ddd609768a75a0ca1dcab03be33d8b12339b806ce6934489f18d77699d6b544ecad46c993ac3af60e71c45a4bd11db7ebc0b8b1bfcef6a0e34bff517ee52fefedfbc39eb41f0dae82d9c4ee673a752e1c37b452ea7825730260baedf81478563c8d3ec0106f 4 \\x8224e0d7d8374882ba9bf3309b36eb42b7a6981bae811d644edffb7c3712269b59d0353508901f64a68de6d16ef470bca2bb5132dd145486957aca057692cb03 1660654415000000 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/DE471160?receiver-name=Exchange+Company \\xc5cd9ff99335ed5c6ff491c840bcee93c232b8296713b7b76c22fb00bf0881fc9ed108c7438428fc78d1ba7ac95ce2378b33063a4b808e1a24184008eec4610b t 1660654398000000
-\.
-
-
---
--- 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 \\x3847cd25aa2def0d9c1863c388d1578231deee0f2149b873953b63e9c2b3eb0f272ea762e7da0ff897a1fd88604cf68e0aace0b5607838bfd628d7b3a585b900
-\.
-
-
---
--- 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) FROM stdin;
-1 \\x17e36f9902fada59cccccf07172878ae75a41daa3537c439b45b8c4ed129fb57 payto://iban/SANDBOXX/DE236345?receiver-name=Name+unknown
-3 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43
-5 \\x7b4b32ec2d7f43a6b45ee01806ab31368d50c45c7c6d1783b0d7c0ac26368540 payto://iban/SANDBOXX/DE209794?receiver-name=Name+unknown
-\.
-
-
---
--- 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 \\xa2de7d3db3c3095c9c37f0b4cdb56614a64c8ed5235a1032d4bc94ab0eca424b31c52a5fcf29bd18d1d9b9a2bc88166531db9ce649435fb809547d7b001d9058 \\x95b8b123aca8e5792f318eb8ad9827c0 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.228-00RA4YMF2S8VT \\x7b22616d6f756e74223a22544553544b55444f533a34222c2273756d6d617279223a2268656c6c6f20776f726c64222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303635353330377d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303635353330377d2c2270726f6475637473223a5b5d2c22685f77697265223a224d4246375446444b5243344e533731515932544356444236324a4b345333504e344444313043504d514a4141503350413839354b33483941425a374a4b463852543743564b384e5748304236414345564b4b4b344a47545a5130344e385a425630304553305030222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232382d3030524134594d463253385654222c2274696d657374616d70223a7b22745f73223a313636303635343430377d2c227061795f646561646c696e65223a7b22745f73223a313636303635383030377d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22334e5642474d573853564d4b4134425342435839485a323356374b425852305a5a30324a5756584243524836524e59534d353747227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22433346585142384a56425144514e364b56514a543650434648465151314a5833464a4d335848394643584d364545344a46594747222c226e6f6e6365223a22354a3841434238414b5a4158395943383350413741464439424d464b333357504d3954423647483656324457444732534e445030227d \\x827f73b62cdbab20753edd20919233608f6e3d166b5dd5d1f63b7e9ea866fd183c6c4113576dd85e6f6b9a16d3852008d47007ad9981435d78d9375b35110ae2 1660654407000000 1660658007000000 1660655307000000 t f taler://fulfillment-success/thx \\x30cf1250df17f685a9c3e6fe6ebb6667
-2 1 2022.228-02W1HWVRBJ67J \\x7b22616d6f756e74223a22544553544b55444f533a37222c2273756d6d617279223a226f7264657220746861742077696c6c20626520726566756e646564222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303635353331357d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303635353331357d2c2270726f6475637473223a5b5d2c22685f77697265223a224d4246375446444b5243344e533731515932544356444236324a4b345333504e344444313043504d514a4141503350413839354b33483941425a374a4b463852543743564b384e5748304236414345564b4b4b344a47545a5130344e385a425630304553305030222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232382d3032573148575652424a36374a222c2274696d657374616d70223a7b22745f73223a313636303635343431357d2c227061795f646561646c696e65223a7b22745f73223a313636303635383031357d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22334e5642474d573853564d4b4134425342435839485a323356374b425852305a5a30324a5756584243524836524e59534d353747227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22433346585142384a56425144514e364b56514a543650434648465151314a5833464a4d335848394643584d364545344a46594747222c226e6f6e6365223a22595233594a363846534b4d43444145544734524d4b53424146465a48534139454247463434343752425858324446473241395847227d \\xe7c8a519ecdd88502897c79378308b3a8f2be183147fcc56fca83b622ce4f99ab34a46ea3b4b9b4b53892bf843a591fe57730c9cd883ee498da05376448e3508 1660654415000000 1660658015000000 1660655315000000 t f taler://fulfillment-success/thx \\x63dc236aaf25b6d15e8912baf51b6316
-3 1 2022.228-01W1EHNFQM5T6 \\x7b22616d6f756e74223a22544553544b55444f533a33222c2273756d6d617279223a227061796d656e7420616674657220726566756e64222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f746878222c22726566756e645f646561646c696e65223a7b22745f73223a313636303635353332317d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303635353332317d2c2270726f6475637473223a5b5d2c22685f77697265223a224d4246375446444b5243344e533731515932544356444236324a4b345333504e344444313043504d514a4141503350413839354b33483941425a374a4b463852543743564b384e5748304236414345564b4b4b344a47545a5130344e385a425630304553305030222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232382d3031573145484e46514d355436222c2274696d657374616d70223a7b22745f73223a313636303635343432317d2c227061795f646561646c696e65223a7b22745f73223a313636303635383032317d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a22334e5642474d573853564d4b4134425342435839485a323356374b425852305a5a30324a5756584243524836524e59534d353747227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22433346585142384a56425144514e364b56514a543650434648465151314a5833464a4d335848394643584d364545344a46594747222c226e6f6e6365223a22303150544434544441334e32504434305833593433414e57414b395633585050514542464847585a335436574b46455932534e47227d \\x7d17d97ddede1070c10c51a33e9491e94302d74014620018f0f54bc991e493c0c33cf0d5c483444e6c5dc3c258246849d19cf15170774f361db56ae6fb724e97 1660654421000000 1660658021000000 1660655321000000 t f taler://fulfillment-success/thx \\x70025150ce5a02fc1454f6c7d63812cc
-\.
-
-
---
--- 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 1660654409000000 \\x2dabf8597c744b25c53956be0a58a67853eba9e3d03c7a473a594f609eaee337 http://localhost:8081/ 4 0 0 2000000 0 4000000 0 7000000 5 \\x9c632360d0c900fb2d148afada5dd65cb2d0002d0e0d32d970ebbac05b163bf06f79c0e68f75a813f012e00cc00096f32cf420a9fc05ceb076dddcb5a2899104 1
-2 2 1660654417000000 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 http://localhost:8081/ 7 0 0 1000000 0 1000000 0 7000000 5 \\x0594eed06b2991af84673626b6eed133274bc63fc370c5f5145d3d732319b2d94328af0a90b45fbc787db69cea4d51a692e9a2c2b8ca81a610a2082d4ec1e70d 1
-3 3 1660654423000000 \\x218ffcd2cc9b2ff4c35ce5eb12500cb091ad85e091ff642d13c0b94169d848f3 http://localhost:8081/ 3 0 0 1000000 0 1000000 0 7000000 5 \\xe881e2b2cb12b6d6539f51aad37e39c247a2288bd24d26efea90c013058353327aacb578a138011a70390518d22cdb06099cf5e6648af4628396eb5206505d08 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 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\x63b9d959e67e642c4aaf6a544319c636d53337e944cb7f3e4bc207453fa01e95 1675168991000000 1682426591000000 1684845791000000 \\x7fa3cfa3804af9836d5a421e97b5daccfd0d0876a511d3df14881580f0b7c4259a8922fce44f7d7801fad4540645fe97c52bdb542971b9d4973655d8e83aa909
-2 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\xf04f93e0462e5561211c2965203e125a50b66de698d59336db015a6a3ed4e5c5 1682426291000000 1689683891000000 1692103091000000 \\xba376e2ba581dc09b7c980aec16a28154d50cbcc56b4c019b2a74f8c11e90d641df2cc2e465837a18dab7333340c2197b611767ab3b11941a3f836634f7ef900
-3 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\x15f6a1c6e02150e2159af7c8b575dc669e2676345844fadc82640f8dcca448c9 1667911691000000 1675169291000000 1677588491000000 \\x80701b6ca302d7dc016a070cde5f744138d0d7bb58c138f6ce5acc3c08300afc57d4ce4169b92a7fd2e1242a7fc8beef1971591d0286a9f9bb171445db64a806
-4 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\x3c26105d9cb3541f8134cf8450ed4f6aa02572aa33d0b14b705c8edcaced4cc4 1689683591000000 1696941191000000 1699360391000000 \\x7fd2984ad70d97c2d7b3b5ebe8d9355f8c941be321fec6f3709995cc8adb49c9b2903325f07bf4cdeaa676bb55669cf5cd43392ebc8f04d8aeedf89073441609
-5 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\xfe2916caf605ab248662840c40d412468fc0c6bc087a1059df017a5df7e02c51 1660654391000000 1667911991000000 1670331191000000 \\x3e222dc7d5df2768e32c4067e9dc2e1c6edaf955299c10474b6ecb24c9b0ca33b2c6ec9637e330e03c6bce795f3ce5141eafb254d98de97596fa0a693913430d
-\.
-
-
---
--- 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 \\x1d76b85388cee93511795b3a98fc43d9e6bee01ff8052e6fab66226c57d9a14f \\x21e4a5e9d5d17432fa0b1f7a02f8047c7634c1053d6aa1f6456ac134caa8bbf3da7776a78f85636af980472afd166b4edad654979a89d92c49a4ba992a7e3571 1640995200000000 1672531200000000 0 7000000 0 1000000 0 1000000 \\x3847cd25aa2def0d9c1863c388d1578231deee0f2149b873953b63e9c2b3eb0f272ea762e7da0ff897a1fd88604cf68e0aace0b5607838bfd628d7b3a585b900
-\.
-
-
---
--- 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 \\x60dfdbad12daeedbd4d3dde5a3598f8bef70cba37ca83ec52f67686738927fa1 \\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;
-\\xe7d4c77080e998b482881f1f8380f68457cdd351b89eb864c1059f18c32935c6 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 1660654409000000 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 \\x3b877908c67cb5398a360a1197ecded3210e800402f4c15583f5cf837c90d4ff42bca70a5ac2444b30a25cfbf9d46f90219f374ee33964c19420fcb57b610a06 5
-\.
-
-
---
--- 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 1660654418000000 \\xcc0700e2c32290c2f4603707c44ed0d0344afdefd394e144bbefd390ecb676a9 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', 16, 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', 16, 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', 19, 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 6096a3fc2..bbce37cdc 100755
--- a/src/auditor/generate-auditor-basedb.sh
+++ b/src/auditor/generate-auditor-basedb.sh
@@ -1,268 +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
-cp $MASTER_PRIV_FILE ${BASEDB}.mpriv
-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 5f4b79de8..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/DE870149?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'30820122300d06092a864886f70d01010105000382010f003082010a0282010100a4a9e52adeba192df6809f7adc620e754aaab0ef0b05842700d2717c5e9af2c601c1ef7e05443d29b67d3349e7478e82b78b8b0970e79527534995d68b07f5d3166d7760b5be51bf9f5a3659ab67abf39464f70c1af41563f4a55c902c5803428d4a0f0877920576819ccfbdf3d605df2527673cea047ee364b9765ec5cf1b5dc24b4f36d780b13f2c6e473244033034a12415adef30eb16766b6934afb201d62f36d744cfda17d064f032440d1dce80f7cdeea0a55fd18c5bfbdeccfbe7a33945efd0474d099b63890fa1eeb9a9bc3302faa68c132aec65ddaaa6b37ca1143395c8f6fb77b3da387340a4c240cb3429f46ad72da1d7ce731f25037fc35ca7ef0203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(2,X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100be7178d24a364d245042b506b0fa20235fc6a60e8ade08a398a48c913cbc363d720e93c50aec87f8c2ece115f1cba04a1ee05eca1398949eb1a39752417cda2ed40c7bab13273b4acf87c1a506be43cb25d32f89a90d8c13ede4ccd0fe3fc5e35ef8b71a56f19fb5dd1b923cbcc7092e87623c58231a9e2ab0f182c5910fdc1f65b199cf40c4eb44d9b5ad6e2861213caf9a24627303b06f9b7c1348ce6e702b51e7f857a9eb0ce92796472fdf709a593e89dc708c99aff798be88142084e17778e526d16cc970dfbf14ae7659ab65ca0c7dc0401925ffccafeaa874c80fd40b1a34eecadf7fe2472b18cd1463679da24cb030b72d46a30bc38db12addab6ff70203010001',1);
-INSERT INTO EbicsSubscriberPublicKeys VALUES(3,X'30820122300d06092a864886f70d01010105000382010f003082010a02820101008b29e458ca4646f8ba282f02f3dc56b6c72fe3393163bfe09e2efec42663c3219b9340eadb5a05c1bd10f44fb919116071fc7b9b05e23dee9615c10264b93b92a0b2be68f96ed79fa83120ee64728ed1b17661f799c0ce5e7f1651bd2a4280aacbf19641d6de9b03c546614172880e6ae6885e4f355a16b92037126b537f1a65056e6835bfc8f7d9c52de01e495df6da99219d1d5d5d0cb7d81a5f409069b408d4b3b0809ded3dc0a46a2324161923b82fd19d4bf48cefdb345b8667e8782fb5a115ee2bbe487a9d952f563daf443f89a78b64cbaeb4a5d9c91d3c8714f71c5a42896315a84c13ab82b5053d9089a57d96ef4f9b35f5a508693a267287723de50203010001',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,'DE870149','SANDBOXX','Exchange Company','DE886824','SANDBOXX','Name unknown','Q718MWCCRPNXXQNQ32500MHJAAA5J1EHTCVPBQHY0HF7JH7ASN7G','8','TESTKUDOS',1660654502171,'FUSDWTH3',NULL,'CRDT',4,1);
-INSERT INTO BankAccountTransactions VALUES(2,'DE870149','SANDBOXX','Exchange Company','DE886824','SANDBOXX','Name unknown','Q718MWCCRPNXXQNQ32500MHJAAA5J1EHTCVPBQHY0HF7JH7ASN7G','8','TESTKUDOS',1660654502171,'FUSDWTH3',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,'DE081474','SANDBOXX','bank','bank',0,1,NULL);
-INSERT INTO BankAccounts VALUES(2,'DE694256','SANDBOXX','fortytwo','fortytwo',0,1,NULL);
-INSERT INTO BankAccounts VALUES(3,'DE741644','SANDBOXX','fortythree','fortythree',0,1,NULL);
-INSERT INTO BankAccounts VALUES(4,'DE870149','SANDBOXX','exchange','exchange',0,1,1);
-INSERT INTO BankAccounts VALUES(5,'DE485313','SANDBOXX','tor','tor',0,1,NULL);
-INSERT INTO BankAccounts VALUES(6,'DE432396','SANDBOXX','gnunet','gnunet',0,1,NULL);
-INSERT INTO BankAccounts VALUES(7,'DE891665','SANDBOXX','tutorial','tutorial',0,1,NULL);
-INSERT INTO BankAccounts VALUES(8,'DE096500','SANDBOXX','survey','survey',0,1,NULL);
-INSERT INTO BankAccounts VALUES(9,'DE886824','SANDBOXX','testuser-wacpnqi4','testuser-wacpnqi4',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'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100b90b48af5ebfce532d9f813b2b6ae0dea5572cb197afcec7492ca52f79bd91ad05474599a0490106f4c719e335fbaebca58ab40ffe7011afd15d03e2fc24ee830bc5e1d7be4c68f211dde06d2a1748f68c8b4543beba692188d0c196a0f5c3fe494626c553b606aff6a4df6ba16f6a59d246530afa11fa560556a35b7cb61f5e0ccf879a1ee1ffae158ad8ae176dd50bf96be8ef7e2a921a6f82de5abd8adcf80300f7040cb47fb9430917dca10bfb3ef303207b9abd4550b319443b63598fff648ce0068e2d1ecf1132ecb05a296a460a6f48046fab2e3c24846f46477a9acc48f316763360585d74537ab0b42f6df9ad110e45b286aa34ff527e765c7bbc8d02030100010282010066933bba83125e243bb124a9111b5105faaf8545f8e8eafe0bb124ec5956dd6f04f30a40ebda2c2897fdda7ada0ce743099d06cdaae4a2d94c7c7c501227c2d37fee34902c9c1cbcbb6cbc20a7697af7b8d6e71173a3cfed57f328ad0012dc8f943cbff738bd399dc76283bb1d252ed615bb080398b5e88850b34320ced402346626194d10b9cf81c3732916ef368337d67fb5693d0fee271da96e00eed7563e8b1f8cff9f9c0fe112b3c10e5135d48ba8fd32ce822522fb1c6be3b02e9f3882a836f60c87c9e35956cf98e236e8e8192574f9b2721a9199eb921c711b13f80d9949ce2ed785ed8d6a4acfed57ec89eb26b1cdd0aa41264954bcc017f55c4a3d02818100da189fa2f105cc8f44a7d17fdc08885b92f00d5a97eac1431f6269017e0856d8588f43ff2016cbe8ccd02cb2afd4825db3d057083a60d7b8ff86332d0d370b83729f7b2fa5380e83305344439cdfb162ee16459fd1616e88d2ec4f0e519bdebe77fc1e87853c8496b5cada46371e5336a4038a97b599eaf824d17bbf811a9fa302818100d934214be331ae84b297f2d608821c4bfc96ca78fbeaaed553beb57165f46ef4778452a948d879bf9a1afc62b0032e256282ad4b49bac1269783b43aaa46db421b88a6f9f9bf2428d3b25eef992a69e2d6cbb8c07ea7c1093051c747cfd6a311c290c0aadf2dfcf2a7472771a7f602d38c6cca147d2d1f398194b6e2fcc0360f02818100b52ba948a8e141596e15de31516e011fd902f284e417cded5d5fd98cb4ce669e178b035826a6e9427d091d685e29b115f7ae44edffd8bcbae000f1f825b729284b8a71c155852881101ecb61432a8b677c12224a2d9bbb3f8bbf63b8a8504c0b7b0e83a9de23349d216cde3f5fc0202e0eb72664fa255f0c3d418b83bcd289f302818100994d61f2ddf842e505e8994cd7d47d84645349b4fa9939acf7deb2d1c6d42f3bfcdf3838a361a70cc50826fac0a07e0184f616b9fce00353e9bcdb884c86965aa27460e62e8fea45a6a54ebc6daeb1ed990d50e90c7bfa9331b7869ff8e1d556c3acc74fd315f262920e769891a3e17aceb23a2f1beaad0f39966d3ee88601a102818014a4c8130050706c306ffe0662802da69abf74565ff7bb995cf396408676a2961b59c57855003f2c5a716cbe2f5f0f51ac6b7d98fe8800263f10d0ac05b4aae5f431e7ff35864c2f0bdb865afbd2b97e6e52b37b69971b80356de8bc6195cfe2c7bf81e1928591055f57b52a0e68c7c9ffdf173b5e4d7ce9c92907f1d683bfe1',X'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100bbb8083d5bc7b335b882460f24e08dba598b5b080eec08a14202179854fcdd3d59297b459ec0036da07ca843666d90e316066d0d8450f40acfd701bb5b19a3bea6d84bc2e22609683fe54781b08a445f758d1396395dc657ff8489f5897dc84a29f7453f4b7954661d25afd9f48e48f65fd9d5f1cbfee4500b5070b54c7242bd1d34c83457d5f2efc14e1cf08a0313a25447f253fbd8e0fa3bacd360361b11a5fde945be1c2b48b5e3e6a4228f8237d0ea17cf201745de97ab95223fd5f971f7dcacdb55b39a97ac8795825ed7c3df2a432051d7f2519fa30e74e111d18de3555748945af0517f670d7062f3595e5bf7e40b10dd3bded51be661172cd0de895102030100010282010100a9f7fc1df298633fe50cafface5d3476e2d5375b988747591bb7613de0d6044ca40ad73f367a8da0198c459ea183db88824cd73941f13ac6ff61a283cdfced3297478971afead8e1b7d91661eb43869d1886e09148e80bcb69e4cc35b2845d7229856701e488bb4eaa5d91583c0309356b9c860725ba6967c096d9368f3d7606d018c697de8ed4f08186ad61f2c67fb860f4ae7a1e636ded10ee9b9e54ad0d1b794737086a8ac44b156d01f5ba39c37c307816894580e41a05485add4fcbf27cbc2f78839ba4c5841e9b2319536bb94518393a148a9bf6fc8fa4a970d89f86f8868cf90185a3376b5c954694975ccf1b3b9a88f8cf2df70047c16b063b85e74102818100eae6b184daf9d882ee202bee8a3efd2faaa5e02c6cf3b88dafe4855121028c57ec8daba1c23048874fa76eb5b9fcbc61099b34d74ff2445b0580ad63487a30f87040bfce96f1e495172565d762b8258a7ee9077b2a6d69cf7e507c22827abb15a62e98b3fd34db13e36f5147381c5854dd8dc1a379f3e8bb6985041bc071006d02818100cc946e84ab5f2247978fd32f970d3a280aebac1ad61f8d70fc61e70d0711a51b3cb636e7a0497427a272d7bebff3f7d4a3426f72a48735b023f4ab5e1a5b3ad125b8b92b76499c7fbca552b666b7e84837c5cd479f13e20fa7f36a6a75a4378e1945bf547830d3d223268dc177c233b6951fbe0848510544b1618f05823305f502818069c39d4238662e3a25858ec244b4bfc2ea8eed349389d91ad28b8e0b4d559c632a3b4f7ff1b353b4b904a63064a18b2015f72fff921b7ef38cb2b75ef08f33e568857ed741d7801830e7c1c70cc7e4ff4acd1975375134471c94988fe137e96c81fa90fed98f26e4f98e718623997f9c1675712e6e06884f79df4e4e4083a0b10281805644b16618ae01529742fb1732674d82dd380c5734bc1174f7b8812a2934f39eccb739e7eadb8eb3b7f91da93e60aebd682af7bc2c4d2802a2e6e5ecc4c87bc0fe5b2b1a7cc305cf87c95f5bb36d11f282325322449ea9d1584d792e7375504807b835ba7504820e36ec67129261be54dc058aa90b75bef6fca5db1dc38da89102818100b3544d9b75a591f3c17f64af68e3729e0af2845650dce57cd0b3caadc02cf1068175d324f7071248fc61bd4ff11a09b852e60ee8278a299145dd9174deb3d518d77ce33c4210a24b9e3635c84393749945eafb1891423d04ce7fd79e1ca3ea2ab064799db2ae247278be1f8ae446c1ddb1d195b7ccc908aca63b8164ab118b93',X'308204bc020100300d06092a864886f70d0101010500048204a6308204a20201000282010100945c696418cef506cb1b337a7cb8a997521edd0cb61106f22d49cd1082cd50e583dbe7978fb125854c0ab0162a4950eca4468092de9797766fdf3903cfd7bfb8c2f9c871134ae50b004dc7ceded9c55f9f80341e970c6b94f675a65340233a4db515a245609dfecb45a7be51e171046af9d9211bd8931c6e131a4674d62d875d3de3e34d7b442eff7e38c94a7f3f0458f5e95d3ba285ebe55a68c16ee8a6682efa3311b7672ed20bad2aae53d5aea8a95d35bd77cd98a6c640664b790006c43cb9a1cd590b3fb85fab76137ff51116e30ee6f93cda4d51c89cf6634c3f4416c53886c3cf18f423b62b6f18c312d96735972caff261c632bdfeab04a3069b6b810203010001028201006867c02318f24bacc432184012954183a3dee460959fd5eb87c36ff43698965d6e35cafcf5ba0c5589f5db853daceaae1dcd1f9e3bd72257ced2a024f69735eca8096fed634e49713c7d80272cdcc3f14f25c187e57470211c701ee4673663495c2e254bfd7a325c8a6049a705a7ab1c3d4777ed48b3fe45d85b9d498b8feeb9b503bd39380de6c18b29eff5dbd8042e7b34975c88b088e24fd2964b8493d5b2f3ff41930355f0d6b205814a7487e07959a75c56d332edd36423f12b7efb47311582541ac0e5428f3ac0d79e2944e90223ca37a9e2450f723768a621b44c7a3612159802886b2f09401877784c7d4cd986284e8ccdb3b7cc39b51e69cb21800102818100c6a1ab81d9b6101e8e16fdae848e251f2e0c281a6220be99130126aaa4aa70bf8105214fc3f92f2eab4438d20b2dabc72465832408a94a8225c1489a81ff586d8e795d878b985c3f2ca929c2692d27972e2dd8a47cd57152943c8fbdc8849f96735e781161a13135a32aa20e388854d0ebb662a3adea31aa5c267f2bed205cc102818100bf35dc560f32bd692a26b50200bded5ae932244b36ff5871d7a6fb72e5e4491ac82a4faff28ebc539985e6f6db68d8ff3508f20005b6a5fd38aaaa6a6a18f8bab73d57cf9b18b57db7dc933e463351e1fcced2987cd31f13d089594b43a595cf01d7057d80b7a9b23a313d04d9a9f70bb5440224effb69bde0f1e4749aaefec10281805745d3706332de543e8415842753b935c0eab0781f2359fb31e17096cb70e3c710ae2b5bbbb471a9a4b07df2b3dca63c025ee3c6e253579c65704e312ceaff746b8421b71b7b9f1456d020bbfdb04c53dd83614bac59afc7e3bfd43c43ad19dd65e55d05ee0a7fef9c387029a5672934fe4c0d7cf33e12025328caf986df90410281806c7fdf9b65dc60e67fe89ee5980e2dd55c65fb7a42a6fa44ff1ddda901125cf93983e8dbea435c5203d79b8b904d1a75165f11133a2abe5dc5fdf1dd987ebb05185d52aa97539a08d07ff57d6cd04a327605d632790243ac36b4f95a5ff461e1a9259e13ed2a4abcbb909d13577fbe938234291354a9d102d1d5f0d0c9c56b01028180226e274bd80e46b86096963ec109ac840b816c2edb9029f7669928f3ee4bfffbf94c395cddb79d4c10cbfe8946942d1ec3e7d8443482e16ff8e3b3ae4f5700370dc4075fe5650b1d8f072f7ab7117cad10c15fbe2f498446f5fbd6c6fea52c0cab51df8bbbab252d4b1a5706ba64fd454b55dba138b8fe72ad1475e1a098201b');
-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('FEED88A2C88B413E516B04F5F96BFDAC','HTD',1,1,'+lULrxHx8EM2+5WBcUsC5UKOHRNGWYyaavfsldfzqrsEu5pbc5I0Qm16k2UoF5phtPqCR3wpqsLa8EmvmGt1dh4zxgK0NjSVMe81LengMn0iTAZW3yw9MNczjMQKCiPoj2fSXcF+8JwjEs5uJ+mJACuCIprd+l3BeJFPJa+282Vu9L70nCMEpQbEVRuWp9qZPPtVYlzeSfYrkBw+YQV0Mou4VjtnqKRK1PsaozKne0H0YoAwvcyW2gACeMxxm/EtgmkpD8vFPJprjDqaxKjnBVpIMtaXNaseyKyWrXWZrh+v7cVbg8kMO/55GupjkCH77BuCxpyHjJswamr+fQFrBkQjBdl1aXNmsZOqT56q/S9Y0+UzfSZvcgrTMZteqLxy8/OV1/MlRcCjaujP16N8Ts80s6BfUk8+xeEPR2IAWmSaRoH5lmRsq4Q0Jrwd5XzuQZMhglWYNvx1hAb2qpAvqLhXJqEZdfebDDpkWonHHJho8+u+vG3wWNM+TytHd9COlMMg0c7uhHWNYyecaZY594m639araBAoCWswU2caKJOG6QkuahIA76tmdi4YHMP+F8Jhp6kyzI8uz+JTu0ZH5QS7Ux5NPulaZJcs3wAE8Tw9QSgTAy9XtCAi+pZ7xKc2fsYanewz3mXEWc9q431AMlrhiWBe5/n0uQDYVP7e1xK04de9vi92qgOutJfmOeeK75E4Cxt7+an6hGG6/7Fozg==',X'651b91713eb2c8b16ed87c1b73f4b41120316f79d869448946e56ac92197091ad9ce93cd937d467976c4877282d88a5c7c49a499f991815ac515f28beab95e5f4321d1f308877234341f2cb70573b27aea890537528a0b16211684dc46984ab6066057ee9d095061ae39837425048b9733f36775ef19d9f7a47f957070c8647abd5cf9068c8feadf4faed034a6b1b27ddf9d8d02d88f24ae657b382201c660a60e76214d33910de6e6e7a19d570bc5601562189c2047b8142b0dd2380d99b45cbf4ab9163de97f5632da0dc253e7307ad6b77312450015b9a92cbac2bd9536d5658a00937a52f3f2f4196e5b67e1d74a13e4e6341ec8c4ea2fd56318c86127c8',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('D5E84951AD8947B6076BF491AD7A60FD','C52',1,1,'1Qn48Yqk5dvP4G1L8Rm6dGrOJLTxHIQKz5zgE5tgPTjHDtb9HxUSCEInavRUz2oA6GADYClLMi0ybg3A7zh3lMvUYfcq2i/cs5UXKtS4r1DJY0/ZFx4+c7YuVpY/pWtHJjKANA9RIatCUjezKpr9UXBLsiCiNySOAqcpPejrdCxaWNgHPDSCVAGF28+dzaWCdPnCbjmpzqJOA2H6k+75Eoq58fdv49CR38Y2Kb+6+ogG6tZ+W92+TJRk9vApKExXXAvVrJ4cV9dmDl/FR2ktyN+6VDcEN/LOBZnAhPczwee/fWIQiRGEEjLtDEr5Rbc0ahbhwJjghRhpd2kSzmfsea22GwhOTtW0PpCpKc42rW8x/WNscdureoDuY/0d/8NCx4YJZKl33kf7JvJPc0JEdPH6qz9ZMilPKyTnrwLuHGyq8VypLs+nC3Y4SHQ5ca89wEDWMybVQOFid7F9jAT5XAUjMuxmexPDQ2R3anBiVdNhGjmg2uTrbi7BoWSLpGd0S4cRRA2QlDNkfo9kfsohDoB0lSumkYylhPjjB/eLC/2Ry72Hdey+ccNNbtCo8wmKIuXjWmDM56pIPBVamsZRg4cVb30+GzD073wVy/xO2rrB9d83ZpXh2A3SRjvfMVnao5n49qhW9LnNHI/a5zpEr1hp2BwNMLOZdY1mYSgU0RvjBnIeaUXgUoxbN4zAfyC6GQ/qxDBrszjYmhJWT6QOLPeT+z+i78HaIksxrdrPdBxS5YJ59RbiqUgrsoHUtoU9qTHzV5yMnrNpKmprXyjB8gVBq0HR4vrO9MISQjl3Q9NGtyfQQvlX2tPJo/tHNLobkGIBhOlVOnJUM362yqt62blsDTJWwM1IzWTDzrpiHFs=',X'48b80882b4873a8e4593ea773a2fa6f7c34d946d472bee899473dcd9a6f61d18b282d80051bd8a98096bbc6d9d1747e9ac3130902e5a370996c847d2a1d4362a94d845a4d3995b945fe2b47c3593b6887285d2bf887abbbcadb5f07dc94c528c4b04df114ab578bb4e030ab6dd4d0353f4423e0f8797a7a3e74086b544d72d5575bf283d7e7e44f89d389ed6fe07796f08ce22c98ffe9eb2136ed9d5c63c7efedcf327f280d2cb00be3ff749c942136a4b864f7120814ce2930a1ec6a40d9348e0aee94c41a52b7a79c70651170f1be25af6aebdd7864cc2bc873fe4b1a5580b4e1baa745880b356deeb6679ff8e5362d6ee4d34125a3d10158204f5b66dfaa3',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('43E9BB847B21630015D8EBAF8F0AF8C0','C52',1,1,'BShgrMQ08kmU1ahHDv+V7R1HUymtXR5QZO/bsIKbLaWPsnU2C5uZg5HzYwzlsc0jo0aX2z3ZcSkx/WS+o1g8tJxqYGx0sWD2g+CqCHydHMrtz8H+18AVf7MLSVc4r9Y8eN99RW+gpamS3GriLjzENAzVxxUuk64QJjVrzb/LWg0IicDjvINrCJCIw5B7NvVkh48hHMUbCb9ElqUKPfVhVdqgVX4ZigxO/viuX54pS8XyNbb6gg13LRToA28pEXglRaUoaTvdbb6zWP4RaWOdihUvniZxtLH44BzU64i98zd6EAapMEqiVtkdXHRoJx8tIc0hUVJL4xVw8wiagrj+jEl2SK1yb/k+H1L6VC/5pI3ucgsF2FgeMF1FREYoTCNMVHW4T+Uw2xrxQ1bzCRTP7v46Sxk7WiW4cWHQidWpJWtyXU4/d3s3dH9L7vEAGzOg1r03ouH7yfWa6J+OerUzltQUkmIzaJTsZjvZLyQvmmRg7zGtryxczRimon0wHrRcVPaLbJ7PZyCE4TErh7DK2ry8TVf50a9BsNOz6lNzpORAjoEBBDnyeHj2REhgnD/vvTMQcBshKNuobBFmWJj9XLJJZfqTj4St74NPe2YafGlZgyXev/+yUH/8Y7/xfXCciWYtKPrh+ESdHclZi+YX5F4QHClFF3fIGYpTIz0I9XGaU7L2optzz+OX2jY70SSZd/oNlihWhyR/2uG2ZFmICvTBSoT+m/1fUvsl5OWVczAM41C7T322s57Z5j0hWE99oudZOOvlgXopPkI1kjmByQn0shKXj1253PEcKpFetd2ALyKoj5bdAGN9AsMHXuSUbYOPP7BdazJqBUJXO3R+tiol8UtdKR8DxdbaJdE1HKQ=',X'17ed7ca1cead3a5fd64f3784189b29eac55c034165ddac13644ff300d2a77f3d6a6f6017915fece8dd5e64edab98986f2420d8e31c5869542228914e2c6bbb3c664bb4d37508cac486a263b8e25ba37f49f88c340abe6da23a9e76e09b2fb4a92719647c9e3e1a2834afe79728f6fd913ed1074d0ad58de69fe9f1ed28984f40278f6d98a6eb9575c86725a1f1984b65e963c2a7d3bc7371e54e0ce535058b5fa0faff5f4ac12785b0da989f7fcab1fde3fe7a2c3fe01bff2e0bd985886f26e8a28a8a06d4658646122b88fc56ad5ba5164788e4c7b08be3feeb8fd16c541bc7c06ce167efe409dc971f791d871799beee9041ad325fd4fd491540c8f238f465',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('93AAC411169DB4D4E5FD307D9F4FAD8A','C52',1,1,'kM2aQiEiHwK5zdRxiXbE9+GgeZ30J+1j+/TEdx7Q1myTA0TCW2sy4d2m0c/ouaPncJht9bA+O5Fi8QSKJy7Lbed81LFy9LJ8mbgZzk4KRnGQLcT5HUhCq+TDWNYApqsdohCloX4Obf34zDUSjAMPNcgp+ULGLBgo8pMS6accm+uKYQRsGLV/BGmuFEeFxPgD5bhd6+oaY0KN6TNWbWlAUhULAI4LC5LA+VReApzWd7f7+QUxqRorzFhQKAuh7ouuM7tX9xBOi+iaNrUeoXzsAE25uP/ZETraRRhIg+KxJvdWthPG5zDU5jvgLefNwlIaj6CSogdXdLk8cc4Re7nYseTUtPoGufZXd3EW7TvthUPMso/IStOnG/7s8LxTmWGu1jOxCeH8+6VXpOCm39fAKr6PddMCZY5CXqPEPwgQxgOlwLdV1v0Cb3z1hvfMuPsg7wjfsHeWlcAhRcGJXz2ahPvQRpITF8Gdc9/F2nonKCUYeKCXTrT+aGMAafgR7rYVpxxPD4P6LRfO4t+38WvXxL5b5WkAujELo1n2b0jV6MQRNa1ZdWVLzly2Rr/TgctiBi5t+0/YBKbpNFdDA/2V6hsZjutSeSnpCehWaamWX/EQIDNeFHfE188h2PUBNv9vs7aIjDAwXzGNALSkwpXHmMngcrx2TW2gDngtm0RnNMG+Mkl3bJBIwnlIhaekSA/bngsHMiplp15cpucZ3m5T85pblqmN8Tz519sDjzsc/5Tk9G82iuteSMFM+7jFQVxNVillvy87ZiN+Jn4xctQZUhP8KJDv3AyNoorMQfGidNe1OxAlddTf2zD6VHTeX1pN4cwpvya8Yit99JzpMGSos+Yqb5vdwyA7LEOdU4+DscU=',X'68d35ef90204df17f9b31a976d9983bada36443be790c94b080ac2f21defc078a5ee63d5474dff0c46602cb045325b5d19edc46f41e88fb62715b0969410b664c0fd2e94e72b3792b73170d6ab8cf69d83184bcb8518d59940030363cbf2325d907cc71fc607dff3421577a4f464e47a0b4c31d97a47bb75cd77faee2380d933e2c02deed1345dd37546c636665bb9b074689a6077d1d581b9348a8cc2bf3ffecc90637e5f8c1f0d75fa7bf59b40547472d52ac9638badf83ea2437f1f4faa463371312861fec45b6ad3993ada17a7b35923ee52ce38e79829cfd29c5b9bba33b2290c0c9f486deb518c98e97c367cf67e6b60e0500316e6b1a9be568426c159',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0D85CEC0B4F2E0F445245E4DEFB9D396','C52',1,1,'Tshmzn0jIud+hkySV6lGQw/5nR3rIDEJCT/Mn6sKt5MD2SOVm56I+639dqOtI2qSpxrJHc0NEkmh/uER/qGloMrhw0Fjj7V/ccrv3XAP4d29z9LWzraNyHp/U6AfWwvRbw3vRG2sb8hhizYKrpyd/IrXDJmCLkMdm0IQCdzWUYzsDOU8rlJ7FqgFxk+w4MyesgUwiR6mYG+z7nBiCrm0BARttyrru4qRCfEb5jGee5R2re2ytz7juq8Cs0vO4jUykFWe5uKW/Cr24YmwX4QJOZff3451UKeJeOqowxDYlXtBnB01mTLHRNTrUlvQPXY6V5dj8BnBir/PNwXSijFOOTL5S6CQH0wmNA1i/V6aGMJsloEMMwWuCNbenMVaju55Dsy+0Fo9Dk+sQk4jHPg5uN6R7BKW2rDf3vFdKgRt959IxC34bQfLyrtjcE0BaAWSAQcElz+5R6l+i6/hVqb+N2ZM5VJokhuCIFaxdrWz3sex8tvysl4YrPB0k1VQsSQ3z+Zf1QX/nJ69rfic21RXQldkHDemedJksmn9D+nuBnzALmSkEvP+mzw8LDVxhwRGxdAHNRC3uJvKcw9PNX3xx/7Bx/CZn3frKh7RCgvgJasJI4FVXoWuxUYpCHBURg9CRJZIDi+u3t6dzpI0zUOjXGswYALHWPgsSjofueoMSVoXpFKg5bF+8e5f1rLNwDmiESijlx20vfABv2wBNFiypdTzjMJyxM7kt6QbQgfKcKv7juftPwuEoxg+bDR7TR/DwOKRIzZoCtNrdxlnEhdJb+UcdxwwQqzVAiqE8gyQulba6QgPyxscC5aatKXDCcI978kPbLgLJrcPa000327FW9dQtyepSfEam+F9xRk4rN4=',X'4c55de2864c6975d2faa0452c31747a4c9978b2cacdb43959a71ee1311dea0ade4de4d64ab79fef88c2ff3285dec00fa27af79c6000f55562d958624d6140c99616fc685ef45d83f035e9a425be8acabafb14938eaa1b8c58d9b1be197ea71e70324823403a88b7e7cbeeff636b92b018bb5393f15725e915e53371255606c692d1d16aaf3bd8756326b6e7e95afc16ea20e7a7019c3c935afa75e21b5299a1cc6fee3d2367dc9de6191b62d767b335eb8cbe737c28fa38c981a7a3e50a785cfe95644ba672f9260341866a49c7e4f64d6c71b21e142b08b6e183a3c66da75c6d7d12072eb06b973685a00a1785a1c8ef756d27135b1c36782a26e3f5772d105',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('AE7C5542E08132C3A8CE96FDE775B00C','C52',1,1,'U9SLoPYJ3EfBURaP4ewZA9HokQPlt1N6wwaMQSutwwC1AlysvgCsF4QYfnYZRfP30eR5MGz6fI6EeN5svUGwwUYxiqJcrnnUr8DCnd1NXy+PALYlBVfctWCRpHLjOoBsvrJ4e0Ozoqa/ckplKA7/1ZE8646SnwUJzHc9Id6i/MUrX6zmkNzGwwhQ69ckms+UXv8bRxVKhUNj1mggf6sMFqF9nEnFBYwFEChoe+Mlpgig8BlsKJQPnBVZ40b/18o9BuQRSZGzcy4vvlQkuffNNhtWqUGYcdqWMYiw0/qYIT/vQXDnR4OuRSh37RdpX87Ynnm4X0nX00q3Oa5zenpS0lzIrttCYXsKwuvUNLUkFU07aoooT01ayVUDUwfCfsjrpyPXA8MXTmpePeCQPkRfQX+E2vXyEZlM8LPCtVmX+LtJgd8zd76bPenUxed7KKeBk3bpQOvJW5QVZa06s+03ek3Bnw90e6SMSJsAITtSXZLRlv3wRm+M9AQPT90gk3vp4aslDxQH2GLR1hcyv51sMm3yznUycxkOzdJcyT3QB1yGQR5sswFIiABF2ZWzlDVcFofQQ0INOVA00TMr8mTNfqquoli9i+20tuICC46ovgc9zQViaNP40Mk3RRRTvN7v3QGkEzS+ae+NCG8LrJEm69s4z4a4Xdu3Q879aySPo56AjpnBN+iKJlEdwUjedXHyvWj1FlFZCLOT/9gFbgudT87Y8vNHI1bJvzm7vL6EIrD6imd7VF4e283tmEvySXpxtp62CBVPVh34Nl+n4Ynq0zD4eBCoYLiX3c1NJmXWOHKqTvRS+LUL95n0eziU9u1OLAv1navs1DU1+K8nQF6d3+0br4jJxureriXqhPM66dE=',X'50a5ec15b4ac73815efa40c782dc0578a941da99ed7c26b128345ce340e611ac9e3bf4b151fa12d4edcb76995ab53aa81de3b344b5c8923c4424374fab19ae25b60a70ba4cf523d6dfbd9fe3ebab66f4990af2424821facdae5dbc6f3481b03df3fcc36891eb8efc58dd1e1fead32915af0739c22a9e863169ee9c824f97d304d4e4a6fb6088b1e90f7b7248b33eda7bc03b46a0e23c973e6c2fa48781498b92d95b6c91cf05dd52a81da828152d8509280ace50eba111ca1dbbbdb729fd983321f644f95b2337a5c7c05451c84999e55822824af4802a4af11ff15cd6d096c3489a3e682621d1e2c2f817c2b008954f452c2f673fd8399da983dcd516f1295c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('8F10D6E0737CADB7DCE5BDDC44A64951','C52',1,1,'qWtAEvgjzaj2wiPT90n7tAN6QKMGS5Fx8MpICJEXRPpJ6nV4nZmASX+WZqjUZoUxIaBqWZ5l/hYgpZFleQuMWEM7BFS5KYJMgFQhx8Y9vHKykjBCTlJGU0VF8nHqfR7Pij+hkhDQdUSsY72qhzWI1TNwopwkDyG/8xl4yxh4l3OV6OXjIX7+QXa8emW5qzoJmLc8L0weA+0pyTIHedbm5oXoT24i2TmTXqv2KRrGwUv2EBDLP6ukl4WURR4oBwwXNdy+euVdOW6p5OvPNAHkKRF39YJNuAPpux3NsnXmUYdgfZk+l7YH5yEtSvQcvXeyty9u0KrJlh/SKseN82ExB8C5zCeZNjk3C3RInnSWny7y6dHWSaPyvO930LO6NTDMmdgKkkHObAvRiT9TiSUwlz43c4KvaU5xH/8RfGnkONgAGMtu6sf6W3a0aZn0P3n+Ss9YZOCr+ryMxxU/t/gio+XdR/fF1IYk9ROigGKtQ9xI6dwujz+G2sAXFajE3UEfAnA2jEi4exk2NfP6cje7QkaxjyzYE2J0veUZHEBN3RXpP7XuO2bWx3+ltJhM09ypbFUx4AWjElxJi4SxGtiQch+N0PryozrgxBZ9b3q4Vx+NiIKVARgZ1AKcp4I3WXVnHcUOnOnW68+cF/XyIgZtPdyjOiXTvDzYFZiUlxV6cc8tnKcjqQXOLzAy30lLQRhfc/jXia2uA08nmKuqMSi09Z5X9sDCTD0UNDdBhlvzTVIQ2nMXw/uAYcqYBPP+7jgiyQipjjJ5hbeyQzchOnHqD9MklDj0kbycijFC/o5Ped0ywH9lzHJhnwfyrb6UaMuUD4Py1gb4e2V8X9433F/q9nfCa/gNi/g/hVQn4MsauODwX3IIJty1V8aedgqpwemibzI1vW5fFwKQe20oauxgW7Ybd3DtNIaDBxfG67ZpvICN1FbIfWVNo1mAmeVZEfrNlg8+BbEy8xL1t366/hb+3ekeJCwb22zwCbv9I//s2kzNtyztujtH7tuEXgCIa5K5zETtoQpS3t54z50Pmll4hN0sjW7yqkPGQhSFmIhqRy64LAdpoJhS2piJmBvbSMSQEWsTMqrOPLc2fzCVGTPWtSpuKEL0n4RdA1yfJiVZh7MsqdYThqx19+eQzBhPO1d4M3aO7ab9r+mCq1gz9xdT0AGibXk69W8oZJh5OcKb9VZTSXdMmOuUYoWILJ+GpOiklJpmUxHwgt4/P3YWh/Q+IRU7TY3U4EAIctwFVqN8mzQAs4OjMC6rpYOAXZyHLtI2TSbiSYBQx/+fHqu7f8c1ZRx9Yq00i1YVuXKHY4gG38a+J2jokI/lqqrSZFEOaOxmHjWCCkDxCkVi1z1YlRlmuiDIQypUB2N/m5074jUKhfawTeYvEKHSVqR13mXjloe+EoIuY1p6wOLa+WqPN0o/28vmDJXfcRvA2HKR/8Doo9vjj2d6gOS/Hp1vM58jP75a/umfq2iuAlfdolNten4gFw==',X'87ac84c0b4557d6919d0809eea7853f7b9373e1c942370a5ca8a0923bb071bfe5468f1e32da16ec2d7540b1be6a1f8c52704da88ccac373bbb907a67ed6052776ec1b34df6c05587d54b5a1f8d38091a36ad6d9cb837be02ed0197d9a282cdab9dd4d8a1f767e2c2dc80f3c876b98e448384444879aba858b2e12745ff00a3c9298ae4511174f2076529d941b7df9b2486539d626bc78807f326c4844f8c1c61202eafdae286d4fbaf6e9154cbf7dd78c96dd10844de6950f34746886aa5dd9fdbc0b7c29aca3e9b9618b93073ad6ee72e11e5bf2f17234a119dc84bb075ea6131e636ebcce0baa843bdf868ab824d9e56417c9ff1161332a109c7e49536ff2c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('787B995AA9CD7CDB6015B7F8E531115C','C52',1,1,'bBFc9iiNe7RuNNHqb8io4E0H4spr4GaTum8RJ4nhyHFsQurJFRo+qMPdkdhz3qRAlPYeAztMQyzyqQMyxXC9WC6w6KVImFkIrO5OyC23pwdLQDw70U5lgTdj0dJ2VfpiinHGiemLL3iZL0JRDyErGi4t60iCmo5yEcNUY6w/53pC7XXiZ54m/Y1eV02D3o2Mw4XNmqaLuBIuehQXosqBR2pXszXn/spZEEPsEnTsFD7yGReyspPRYAQ6oWWbQ9f79aDTYhOjPbml2YsC+Qc7KD1TJGaVgIRikM4Ortuf05joK1AWaPvDajPt60R6vQ2UMCQ5JquKVpmENz5nP9vL4k0aDKlbgVJerNvhjXa4TbNO7n06ZR5xLfmtZwMGI9OghSBYzGfcRQ3ZPi3PyZUUzjl88w+cOXyKE/Z+NF3NOlSk0YFpcvAthNgst0mty8Z2P8IlkY1UQQHiH0Ej5gCv/nSS5R3CSQ7OhBssE+Ogd739hHi2QGAoKzo/rKX+94VPLuHwVV+KS/mGLweU72xMotQNw9EI9hCGghEDCjNkvi++69ZE5hPTKmvORwtOxKgvWwALORrFpzhImtxHESrjygz30wkuwgNSbBC7SAzyLdht8mLcPqNd/UmLEtf/KJLuJyz5vRCdbvgsTrKR/1zawXLFb6aHHyOIDnGsXyNQF2r/etoRn3KDUVMoynDHCpl42+L6t8L1tUu9AgA0hsEfDi1v+27FQtSksjLtuBim/AfDMFY/meoo1J6ndaJF1vamxYldRsSrVTfx2iCkKdOxN4Kj4CViw3oOos0c2i5jXvUE+LfsymGhBXMJq05xLQMKFXuVAbqFv36ucfpS2wLqsBVxEjWlbOLCGnf4RE5s3+f/zkOG4tAMyCyVcuxIiG7SQfKd+T9n8G+woxoa4nuOrclfLy+JyoB2v/6eHkQohCK8BoHWqI6Gb5gX0tAI6poIteew2K+kpkHWO3OhwelRWBCATbEWNMbV52AMV07MhEL//JzCrOMs3lMZT/zxWv4jtXBXf0QEYuv2JtKk1DvnAy72AThqk5QJ8r7Zw7HNI77RQExxvUsyA74i4KUuwVynAKUJoBevJYErPumnThu4+Q0DBzubtuDawWwFlEZrwfQmTMyLoITtVtM1UIMky2oNvRw/yMzw+t6vBPFKmzxHt2/cjDK6Hudc2ef9MAAuBVSC+kRg//z1BYTV2buGwF385yuY9D2j6zqBC41A91SalAnqAfcguIjdWCD5v5OsNDj/v82+K5IqILjjerFvNbH/VVOB0ezpOorhDyuOp2sr9+yXzLpohbms5MakhDq1bZ1ynjKH4ksfclbkru97w94eVgrSidSElTJGI2f0iaWKgSJG4TEhjo/YRb6PlhqQE69T02pzW04DKPRjE0XuAqvCUAPLdla1K7Xyi6/n3gSoFYDjgTGZlDvmV6e9YzpLC8WmYkO8r1Wb609/OPxKqFfaRSuGag9OTdV30SItQA8EHQ==',X'249e9ec598d47919d946cde3680db35d2f1366251e5d143f20a0ec19fe9855ffb8c61c0fb66296608a901f56d29cd3a5bf1f27091aab434c39644056c715e20d3eba4d34543ab0102e3f66c45f6460eec40a01eca97fa8507a0846e1f513f715929ecb9625ff1060de5bf19f7a2856a5b9e1bf22206d4802614c138cc388e395e2bb2958ecb81d9d4ea29621382d756e8a5efd2fc89c4d2cd3fe688e86e9c78a972f0867a15be89dd6ac3fc9c8c3bb5e66478b1ed13aab81127a976f4ea57b5ecf4dcad77d13d7b59895a5ee3017ea919d4eb275d421706908981eea5315da0916210c98ed269f6a62dc7f6950c2cce4e75c11ed9e6d0da9ad12f2e34a4a240f',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('D2D3F02072E6996F31718601176027F3','C52',1,1,'XiG16/FiXqQUVPU7SeCHmn9rXkjg7/J9jcfFPeff7lv34xbTNpUx3VLWd2PSAscrUrcZcOp7SPcaKho/ORUmbPoG1xc+notrzZ/MK9FjWvlSD+8ljqkJEhjsjzIV7sSEXgo2TyimeXL5ewBnFk2hxWNoYOBHlINBC5aYNq560RXb0lHAkASe0ndUdeuS2XMskuC96nZPZH5ntvEpUr3Iwq3W5K2ovGKCaqHqNP3iTDwkIaHjQkaaoAr+nwppUT0cvNR8Ze9iH0ffoHf7g+Lug6uQn3pcmWPJV1ZlBAfo6E6czL9RtVAwIsxk7UCndKwLtkkKM4QqiLS0zoNhXYJLjQxiJTQqnaeh6pB8Qj8PlyuSF3kiUTy4B86Xi9jM+1h/1rF+hWTYFd2/mUXlMFGvoeC0okVAQN4AR110WsmdHLSt9Ml0grwhDXvsySddnKxtI06d/e1k6ivLUGfgQ9TaK+ulY7EtzTm+eDSWyBiDHdyZG8EYPVDeoTNTQg3Wl2g3kjGeYmPZIpDHZQspZCmrZtDN8DLaYj8AtnjppLjEKNjIPnPmTR8bzp+ev+SJuBgWkW5H4Aq7x7jcwc+fdG+VcF5mfHe7AvnQmVH9yYUMROmBbOsu96DIML8JpTmg/3qO5Lk7PK4XEtI/1d2j81K8X/dBExdI5gUyNI+p4mpLj4M7b8wbbFEfiZhxAsZK/9Z4JK+6rUGH7yG4028uBr1PRc+RfxkZnxbEbW0SNJ70F4oJ5jrYKQffQDTU60r8riVt9tpvy32tiZKAJbQMJ3zlYxgWVYYSqLxkt2YwpswrjqCRGJB38n2mjl3HGJtALuj3rewHl8aJTUJ6LRNIlUHtMHmT46sM1tP2s66qa11fRy+6sNCIo2pVx/6iSPSs7GCDH4SAYMYO4htc9N9mvy32VfDXDBvRjhzNoxsMcqiK5frloOWN+LHaO2gJ7hWBErnp+PxRIudhONt6kaCYk5drJ/9DssXiHLSlNfdHgaNC57LCy9B5wwJTdZlPKNPVVID+VtTnHffDdUlbqaOOfsCPJO5xsqpa8ogF3gF8si8vqZ3GodfClXqwg4evkYqEZZpzzJvIsSDpkktS+Eokr6xH4D4L/MCbFfwtVipVHurg79Fniagwqor/kD+deGRz2LM943JAbALxdZnBz0n0NofQB8WHjWdGagH6wesu5hJzTgERazcWTQ2yqy0YtRosSp4tF24mHRsC9cMZg89R+97zf6Uf9h2zjw3eXzYjuLRgDwdy6N2F8VZSu9A3pH/G7CNBAdgjOxvl5I5c611D2C36BJW0N1fANd3EuwZLJHzMZuU7b2BAywdmuv82/2H+KEx0Rqgn+P1dPqp0scywnqpRukhBK+od/FZCovUm0QQmmhm+LpbaQn8gL1Mv24WofOgC5jH6a4uIpaUPz0jQx6+GQt8cbQrNDvw6Jc0FnXGFLtWVQHCOqYi3YPWbJ3i/GGeG4uCn89V/+PFXbyEkNuVBbw==',X'0701f418f68ff057fe9e97780277863730ef0db0dd2e872223082585adca8958a6d2575c10cbc611d674fdbba647eac6ed92721f5300844ee4ecb1870b5c2ecfa04e70ba74437fc426764587e743f8c87142b159caabdbf8931fb053803c94f601deb4d31a7a623d0763874d3b5d84c86465bc7b4c83946e8d978bda2821a0cb95ef170bcab92270c465a7b34a77425a138d19093627a05021ae1fa1c89406ac3c184250ecb8414b9ffe3b3617918bf489bb08639e2819dd06bdb873ead7068cafbfac24eb42704a30f7a3096bfd19b3ed30c198e9f336cfa733847ba1a572201e8a357d506bc002a62209aa6f7bd68455d18dbb54292cabc4b3d398375ba7f0',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0E1D8A44B3EF657117B3CF3C28110D81','C52',1,1,'GQ18OwZg4zUoV23mXZlNx6jMwMyLVz0hRpZsUsEOkpuLLOxG8whlxzqQGMlsIab5izdQqE+vI/B+oQ8nRgySiQ8kgtuBaMVY+BUWXeJBwO3NemqFmEm6w3UA6JcHbQMYbRVd/zDV2kLH+TQIc7ZhXFBbAKq906asZhtYNqfpoS2BYXT3kYnpKWNhLbTzBoogZdAuOMZVLb3f24DiHtHdOXpbVZO2MSw7yRwQZDAo0FTzIUFiAzbKtJGRM7iAc70r6mBOB7wnzDphu3oIzlAP2rx0ctl0upjae2SvId3bCS+4adcjlwtblT+E0yuXBIP/SIlE7S9ZonOOALbuXFnhr0SXBZuuwN0NhbcjQ57afqVVv+FwAEUoNZJjLK9V3mYPJcsuvq6vdV0XRcAQqwMTxpxj6LWUQycgJahRLPyQV95dCTTsjl2ykJvcUagrxHkbFl3sU9PMpd2wolBgbaDtt2y6XY6lxeUuv/8X74frrbRNYS3DOeB7lEBHjkHsousb3dO66wNwtoh/F8i8oDMSNHL7iDSHx8mCjL/j6kA/uIOK4eKjqVr/bsC4GahIFCiYgD/lz8eyfSr7H+yHRM1vgyyT6KlZxk9jxnYWk/1BEQREBy6ba4ZTv47pX906L3cEM+KUwrXrS4x0WDt5c7C+FPRVpI8iUqAjQSxDej1rUlZJORPcx+h3gx+YZ9ry8/irPVZcZ+4KPA+RZAAFdEb5ZXjb5511gFs9upl+y6V5t0qlC85AfM6emNnu+Oj1p2EIOPv65nbfNn/EdV2oAsP4wqKx9rUr3fJQSvjlSvBVZfdp6yYPs1BRi8V/Qjfb+c02H6gcs+rgic6688WuDhCF3a9DamiDCkQYejywh+WCxlJUIb/WqE7i84pajfqDctbcOCPk5SAHqyknvmA37uD41PDuhdPvEvTbi6dAkwoQ//EfMM0FyLODCrpbX+/uRvwoqPzG/rdkPYhpQCY6Ddzn1QxBUOGzc0bglXtpct5c+ZCPLSolVFCHn+ZbmQtdyWdHrltYfygpYHaE62w9kbGqeognQ9c1BafRqts7itm10T5ryXsq9kLYOkccQO9afyOZt4ylCG3DuT6UI036YXGgXkT63GXxIyR6oTBsiGg2MZ0on/Hp64LAta5uvu5cgLMUpPlDNLAsOwb3SmPBtmHG441SVNvxdQk+1rjdGOt+0jpUOkjEOGuuLpbSaF1XJ3Z9w7/ZF77zcqUiFHzU95jX+G4KarwbfWUtXAzMO5GuQzGfuGaS218bgDCiBSX+wVmi8zCbRn0/9o2l5SPcG0ijQO/TdziA/FtUFAMWOP4QPfTTV67Tu8wrXQoGyIMswq+rT1pzvPfS08Om3jirJ/ydLc+sjBuNk5xUmYQlhTmuEppdKZnqjsOdVr0yCu6IMFOm3rDZ9R/yz8xZDzTOKSYJcqz8gGFwrmnTjuh4Fcb9XFFt9PiTeT6VPLfTsbO/Q4xL8FRXLAihtI9v2fVXwlwjiA==',X'3bc23204bd52534a890f72d82282fed94794d5a3805ea1b92f8569f1dc3d534907a0d85d90f76cb15b21003bdb6bd1bb4d5e99d9ead1259f6142959c27e42d82956b1bc2e6af0ee9b0ef4bb02e51566831b478f1472e9472f4e1958f6e05f4590ceef67b3414f7c565e46c3eb9922119254f57347516f46e13c5afa800e4f10517414df99dbab3b22b5e735e7520788279491670707e32524e3fd2d2b83bbc789ba9930ad427b2e193a2438e51c04fdbe2ed415e78900a3ec873496e3463859447e5b429cc6245420eb45d09f0d26cde166970d00e334de6b97db7231547602c94459b4b5543446de069e6b081d81715e0be8f15df1f7dca1de635a86f14e36a',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('78829EA565E904EF121658D3CA9BA900','C52',1,1,'ejZo4TWhZ7p7+qg0Kgz/AeNnwEBQua6SBzI3siLZrIt0wyYCgSardh6CywfTJsyb772hL74N3TaSDFKc9LsGfkF8gA9mv9Z0JHQSiOStWdfH/+4TB3LCKJ3YiqgnHIeiPC6YS6tFgfri80Niy6XZfAGEETyJZ3zkGSuaPMroOzq4a924Y6cN53LlUjduiNpWtLBL+1iZs6neGQKOXSy1ApyDLGjEMkIHXuzrXJde3kbG9zhRXNYek7ScKMAqGadVw5bR9OJzHfHGJDfMsPsGJkka9WgHxgGMOVi1vsp4+xmDWlr5rzJldR6pzXlhsR3R/Ce3dYsYpw8m+q5M93akPLqDIeA7oZwD20Nxy0ABliowUe70Tvg01nujGSgvwkqOfwoogt5H0niWLJgdtvt1rDpz0Pw1nyalyzz4yVsozc5kFG/tzufg/bD3JAhvXjUt4K8sFTJbSYgj3nCERK+ZoVwIsyEpYmWpwIETCQ2ui6GR87QjlL5gmcI4ZYD1n8Xvf4AvvLYPXPorvX1WvhilSFgNRnn51F4uuqrY6bfFz/2dF5okDaXGN6BDJFPSR6nKFg1tvvomyoz+N8hJDL5VasnVngFqNyUYOioSpvbirrcwKUCQ7YDMMco4TZ2E5NnRWXw+cqBja3IaCQ+ow3kwZdR6QozJcEE/rW5twToxh5N80GRtN9nBgfwJuhBS0ee/JaTsYmH8hndTD0ObtlGyDauAJ5VBb+H1qQVyXlMvhA4MKBuO++NlnZMvProimqwnvDRRGdMH9Oqcrdm7mXn3wQBnviVMGvmlUbGdDSQ3ooD6QpopvHTw+wwLN+YQIJ3Rg89qxgIrblue8OV1fSvJzqqt2QG44U1tRkoQ/RgPNDYrNHBmz0rvR9Ntwr9JohsrjFmfIQgUlqqcQfYZ/akk7O1zb8ZF/UxmisAE6Tq2SHvLHUWQcTXksVXHE0uhuA8IBEH9iO+lLNy5YoSev8yVKaRv259D2LfzEEM9kdZOh/92y2jpJcfOedqVrmtW0tFIJ/dOZf2AdOasGWzyWIlYze8Iz/qAOfWO5+AugWEm4IP2pcG21d8kXxcpRwxXsA8lzoKQk2uV8NHTfmSmsleO66wUopT3uq5yPWc2qYznUTRE+gTO9vLgQL6cyR8JGiZqYaCE2Mk5kroaiolgvLI7BxepN07e/W/n9Dd+S0X2HqP/CdHmTaUpZ9MjyWk6uKsc7ZlQvD5/VRNiMLsfG5Tbxhr2d5TlT8yXfdmRm+CS4bIfa/2n65Q2zJ/RZrdoA5KJWqdE1804C+/f188LnrBSIq9JKTdbmlRXN/ff2UyxkJvGY6cSoFCCcPQZq198hXWrVAF2vfZcQS2fArqTSh8yqC7xpg//kd7t8PSef5kwp2obKvxt6k1tG5yQHXquQWq+sAEMoKxPeXqkZ5qLc6ypI793JMIyseo6UJAEyJXtrrvLYJwE8YAJ91926REyObMwbYTKfdKjGao57P4qJeEjug==',X'1b865f03b8a05dbeb9f71529e9cb7748bf748d93e9240d82fa0ca4473256632af565313195d26a57484aca5e9763a8e7fa0635852037b13a8b63b270ed2804cb4b94c0c269df6e9bea886ba831ddb4760bfc0fbd50ba9398147395fae3d62b60e118314f780b9d82340f2e4bf2c17bf92faa3c3a96351df7be085786c9f3491adda53b55e49a8076fe7799d1760c3bcb4a71d797e83302813745003b067186abc3882018c6acb063cccb3f3c3ad676218a3d7a735483f0817395c7389609d6e7a5a21c53fbe4350c1b0e2d67f93338635301d52140d2d0883559b185ef436bd935d542ba3261bf268205175529f5b210b4f1d36662285a906af110cdc93a028b',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('1E670C090F63263F2518130DC2E17F6F','C52',1,1,'WPz/EGCHv1PezBZiQyuuhEpybcCgL6l4uvGi2sS+eK1k03zTTqgIn0ftZJSRc8/aSygfH+jK3z3RMS164ZmttRia8eELLtzCHn/R4a1/nshz65AhTTn6CJe8QuUE7/mr7wCUo71KUmkwr2z8jwf/dZJvUOYfNPwwdipaPIIhKN8eroicCimqK1teOzdlFd44EqDn3hrdT22dCrQbS6SvhUgZoet8B+Ag/cwVDX+SP5loeuQg1YhlOpjqUpIiRwgO4SZ2oN8h522SqVC9YeX5yj5i8XLUknHw9s2FEGVW37hJ2UbhNK/dN+hGq7QQy4B9Clrw+gK193V6calgFOTBKUagPY8dbMN5aCESPfjWZ8tiN6qOdZDsRqifWPbww15n7gbZd3KOiWg6mwZW15mZ6Uukz77SBQ318tx+NdEt/mfM0ZbpYD0O2d9M3Kp4Rqhe9rGHSpXI7NpuZlYSkwGAAEm+VfD366oLHz86MnMQ6LMYd+P+3Xep1fgweNzd2WoNfzZzJxsZXTcwOZjtY15rOLKaZawQG9EkAQ2lRLD78OJELDzgQUex0KTnTjroCs5j+x/wTM308NuvGSgRjKw5SpBwNSiJRtkhCm66hP8/4qOiqEQOsz4WbrW9sJTEySbM3D4Id0AX8WFnSl1UuThbFbfKszeEEEH7laS+NBrOdfXTJU06AlK5wdjXHyLgmNwIZhZIPqLB1YG2gBbz2Zsjg6JgfL7WQE5a1R2WnJDPGX5lTUuh6VFRjQb6650m9zn44ZRLMW4C6mte2jpCPfjgYyTBqQ9T6q03UzpgAyKLGAR677CkIzE7ozHKTUL0RWqlJ+PSL9zvoe9cwLz/gG1XEVaE8ADnUQmSO3DFra3ddggCpyMHwWo1wl1O/UfZdWh+sQQJqXKPo5yQQ2V7fFWNDlgYdzJ6jCUoBgV2HVxtFN3WnHHplZRIdSN8k7M9nWermH4+falX6oEnyNuVMojUSaZJaDW+ke8VozCruVUKlmvVshFiKqAoO3SrzTGC6xu5QBjdrMPKcsLpgcLGIfARRe8TpIG09N3u+vJ6ZIdcCiyHGr1yJiKsJnaVtuJbDx0bKuGL4jM3Vk50tbDnY4zH/EYjBCfhm1dCe4gL4NAdwPzg4BpcMTflyXltDAkl0Z9wcRR7+3h3Y3VOOwa8v0Afs2Us9SumQKeUqi6x2bueKaV0/TBU3AuUxvDdxM1+IGbEySYp2ydhLXqQw4zbYlX2czcRcvs8qyneZ3OLd8jwGYKj94Z6FkgRkcIEHb4ZlK5aXp++JjLy/q9Rkk6si9MUcaayX9bqrH95ahVGULAg5vVzXlSLGKswdH0pcJpYdy84kNV6nygzJ31xNGW5KMFjdtOj2FXEnEc8D3jFCgt9D0N8G2LiXRN5B63kJ2iLRTo6+Wz2H1mPY9vWJ0H/R88OKNkF42GCpxoZ2Jk/vuRgNDKBbK1v+yuj7L/New9Ya2arKRysZHc0HD2mNxHW5XREgQ==',X'0b697b9218cf83574e7bb5bb33db0a99b4d2461545851f1197480137c74fbb5f02355dcb8c7f6d8bd58febdd3a9affc4cb668acf3ac28fb51f65392f473fe1101f0e54f2577cf0ef61947bf9ed9055dc95abe3bb49fe3cb4e3fe6bb2818b4fb18518e7ea84b8fdb6066b7426b269b0287cdc27352e5f48a4a281d37381dc0326cafa98582c2550d39ca09f616bdad6551dd8a48f51ca85666c0cb1fcb4ce2b5451a3d71f851b57837a2bf76bfd1cd4df81c5bd683a27fd4396e92ea53cc5e35ef18c55a41279be33cad918081817e58a24cbd197370235c1bf2e1202319f14ec0f296c40cb9da2fa1f10761110f78dcbaab8ac7c861a06dfde5e655c72abf222',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('9390048F03ADA9F5F8167ACE14020628','C52',1,1,'zFjwZNvsjGmFJlIxlhEdbw3XI4pI8hS8TAPUy6UYGSI3wR+YoNzAehauRXyUk6ft1vM4KIawc81/RRW1G4Wsb3ydheQZKnzEakwWN+BrWcPzS4LyuVWzWGhE6tvm/EnOqs+HeNJ1D4BCwnq9Ms+PhMKmE9HY2hqk9vIBmSHV4c9zXDiZ4nMCWrCTMeiD14RvL4YqVwo5sBOKYUBoJJKFQWxLciPACSd1wvs19a/hDf4fqi0OuwUGk6dRo9gsYV73e6dmP5dP5u9tjbBwZa3rWkQfpHGwWDJMJNc7T5Cu5fi169G6cI7YAOAqaxXuS1jEuHyEUoCzimjZZP8rQvdIzuW6FOuNeka05NxjOo7t57w4rGAmCMBOR4lr0UenP0F5776sfqKSzZfCWGkfJHnaj7EOIRcoEdX2KIRu/mO1VyWgXQkXHBREMCsfFjJXB5ytSsKfRtqu1LQjbjGaYOo69sB3ObqBiO2jKnMrgn+xAgWCemOPY7S3ud+2tHoLDtXyjbOL8FnCf7vYn6/HVyRIDZVWDmpoCxAn/Gq/AxXg7anJHCSv0hlbShqxPluuiPbKMFOF4aGfRpRseywdR9enoyJVVVTbyYJ/w8JexH8gLr3Gc3vFL4+ROF1etyY/2NGSVmx5Msw8Iy7x+jRrnBvjHQ3xWhHJ/Yyyc7x56lc677F1kp69ln1yswl8i3U9dFJmdPILTmU3ETdjuX6yD9reipUNiZ34oifTTtYcMnackpANAi9hogbkDnOD9MIqFh3qzbsNqVzePbZ9sq+Ib8xKX4+RlFOo3EWDU3nC/mTSUmRQ/SX2leBjUXPk/SecAEYMXvojRyI7dTt/1ErFe6Han5x67gkl7gMsZHzHzFpnSXI6zD1Ao/OzSIc8w5DxypZ7mbtfp5OjeY5QPVx8j/Om5eUYoYS2R7mHIBoswBeFNjIBUhfYaJoAmolM5tjyrRA+ZTVdqCsMpgCzhWj+HZMfZXj9bCSijOtJJ6VsPIu6N63VXGAxdSlGCuPDnvC4D0H+XhFwvQdw9ct6vcPQyKxHQL22l8xnHn4b+z4/K9h6eoqWFg9LUqvPdcCImzMMv5K1NzTmdxAwt/a+Wqyo6hSCrYpmBm/riatpTsxIIytdINzjrQNEOmSLlQqGDg0syaNbj16eOTURXHwsr3X4POSQ6MlboHlC3Guyil7lT2Sltellgg0+k6g2gFA6taklDcSlw8oB0PYWD3X4jmtN0JFmPmbeTDdcvmeNY0NzzdI7ocfBDZ9r7wczkialjyqHHmrwU2JXLgCOMbDqWKvpgQoBNLWfYGgKNxTOANw8scRica6Svjo9CW4IibAQGRdSsBXfrL87BwnX4V1aNPFbUlwgvhGcXy8FKhH+CdeUXgRz7YQ234sTVzOPOXT5ItpfbF5E5j470rw27pHKr3wcphBrd7F/nqDQFb4O7AvpEUZk9g/pqBhKlJ2a/n3ch/1mJLk6YKPJUt7Vx/88+7vKg7NNyA==',X'3cc63b646d7f21a44c19a752d7133cb4dc470a92bcc0b4fc64b0bc73b1c3af7e1cd580cb311b486ebf3276cbee94042aa7976091a95a5244c96f4100c1f4380017000aee4601988b9555831b4cd3ea4a69d858e4f230a44dc9928a1e15493f607a1eff9e1ddabe49963aa5387e9a4dff4792b965ec9864b485815df6ed60fe8b7326c3cc4ce9d15e2512703e4fcf2437c00fa44598ae6cda911e561f5d7074d54d8ab7360d5a15a4981c940f248eaa34f8beaa57754435d1c8ef3c029a37e274307ba942c15c098529c670a2567e77a6d5de69c6e0c12d57d1a5f85a22eceb7b62efe122976e13ae8d96fef8d1bc272911bdf38fc2a2dba42bde83b86236395d',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('4D823B04892B0DA152AE5216250AC923','C52',1,1,'hW7fEcqiipjABsnVoyV2gbpgdLhcABEhaqF6jWwcOoF28wN8pyzJRs/oV1bJtP4VU8bVZr0PqROvixxiRs84N1com6qfpWjWXqzxVIQTBpxMnKAIoVtbsuHQnFEK2je4oP6cALARim8MTsicmy58oxNNFlfUQkz+elXcoA3P5D8RhmUZHmeu/lHThYAoeGE8/eKmJkwt0Q/UdlsJWnnJ33/LftOagzvTLKx0KUnQRJR5yQCREdfpl2+V+jakd4vVY760Rn+cI947loX47+9IQ6EAEccl3me2Z4WUwnMnJNzVWarXkiwFTd8AmQvLcFAlHLZuVR02kfE1DsSjSK9rsAhqJdFMJdrvq5QnmuVbYaFwgE4o5ybMZVtSV/DeZZ89LJXrOmLb6n4Aoia9RA/1UQZAT+YBewLT299lTHC+nEVvd2CykcdJUhCyB523f6gVMa2/8V+PSQNu16ohqchR2n3+Voy/bJOmtkDm3S/SPqBvRDEfTRitmPlURKbTei/Rh4sYQWhLGk1OpXyDfXSgvnMc1ATXGGIUmKWxAovrl+iisKcYZ19j5JuiHSdtKepeIFrPeiqmfRbkp1f53HkZATE6WVy928PAR8Y4qLYnbXJmvIH08Y2jftFhrCjJdFS+/s1r5TaNwiqqwat3iwh4E1a09qq1DA4JvODkmS9TLF4nHufU69D1quLGJcSS/7CrW5xnQ5yvqmVHB112t9N2TFhDXuFbJVGtMx5dGOvbZwydKevTtPmjDlH4ngnFVIbKj0EOR/fywgZ1JrF9Q7451HS9ZjpfwPHaQFtSMqASzr7u2RGuYcelzOX6f358UbQX5r8Sow5ncoQKTOxoBwh1T+SofDzHm8sNbR+UhEID44ufDrehNunLMklAuMBcEHOKp5SBXulGUMpCwnUbeTcnmCu6HYcV8SVPoL6AKO88YPpbDhjTFAtXoU1KVd2dXq1obxBr1wC1yVD17NnUkS3Gm4DNCBx/vCIOK/xh+W9UAJhhO1K8IhCbv3L0CyZN6CozHdOjvTY/AGPA/XSyfYf6GPtrUv8ZiWWUrKfvkyijevkZvgRvST+uKpGL4naEaqcqfkJKT5hubUimklygwBkdBXPCoVcB65uRPe9SNzAIKxPW/8UftJRwKuIkA+vMzqxkW86lKmqQU0TeX2bjE+3gZpRdtm3UvmBt6LAxHE9B0+LqunaT0/IPAIo/yrkPNMpV8/UZXBY+CQ9HZgB5M9vJDJsSDPcRAEHz2gxf1XLJQ9YOGkjscJYdu8Fn7PDqUdxMyQr5NHBir4WInucpMDItKs880u4LDQEKWj9wAkvM1Ko8SMboldmhHpanRV5Q9u5pyAev6Z4wdIUdQvq/HcHB/QkRrOezoegi23urKQrUZOFMjsbr1NX7+XeGvTEVYpWMPxKesMcqhurCWzam3ll/HOHLm3nukC/Mtz+uEnWTJYcFLrdDohptn/AVzRXgviTjS8Gy3FLPdR45DIerZOCcag==',X'813cc5c3229b20f26c198386271219f12610cc4c8c7e7b436c64c37318b0b5a805ddf8a4cbb8ad9cf64cc9050b6a8215db0b41b506870d187a8c1c9a1de5184a41c1befb5c75b0e15bf30fd10d18764c309c4e106c5658f077c3a40417fd1cc4d920b48b71cce988a049ed93aab0744a9de89f2c968edcff45454ab214013c3b17a6f8faafcd600dc6b1db075333f27017491713d2b6ff4cd29d93b5df855f8aa1756e6a1eb049c9c38cc87a5679ec49c1fc9503205080e4ede282922482cc8c41f976ccf4bdb95ec315119900bf9de5d342965b1f3ebc23a802541f3cf4619d7761f267bb8c56b15c71442c34460dd59cb301479e94379f35a3a4515187b1c3',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('51823D3736C5DD1E141A7756E19FE08B','C52',1,1,'pHThk3+LUvkzcqg3tnxawIaE4zPjqNJwEv/d17JxMqKtWP3yKcETJhVOUlZnI8JqE0QuPg0G6kyQzfL3iiQlFKt1g6oTYxfj4PLqsGFFY6KufmJHSJie9DNQuN8NiTYjZXLjV9bOYeHmjFWzszOKMnVjXe2Pr7OVjaFJTZvTvFyNkOIHx+5G0+5n0FEc/F9Jb+X+dNymy/eagFKirKVAmuCkj5kdQyERZrorb/cZM4p4uMW0AG3n//k8TomRTy3UsBeeGQ1C2UUQkhHF3NB8cJMzNRlUIjqoZA1KO9zfuRmhslCC9Tp5MONN/84AFKsuJ8cLrP5LQBkmkJie8jeP3Kg4YG/x4o97xnBfbvypzoM+6h4kV9oYZW9kpYGIDDOPcGRdPbOB7gD6Xl9f/WRDSaGAx9D/6r+JAe6zPMHKA8FgM1La6/60iOTAH0JmLvxjSV82Kz6bpUdkjrEOeMbVLdle430x4KHpoYBDbudRqVKZkMMVBlPRBy7GTqEUbQWhtMAhQsaSh+itijRrvubd2QZnnlGyvqJQSmz8ndnkdgclTVEsu/9dyz/iAxmKhuSoyzJrl9pLFaup0lRMhf4ugsOGPJt+Vycem1mCJPrX6kRHPHaXL+jb7cf/UxzphzCEwIbqi1o40A/5wG/LI0hDim4gpkvoR9A3BYz9KeND8Rmc3C/K0fq8a6oOfqd14IqUZg0rxKeWf5oVS7DcSzuqaCfpd0sDLbZu6b79sJy7V7t1VruJ1xE/AhHX/p4hdzVJfM7YjZwum78OlJPTX60tSVyLI+lx/nRJz6L6t7K6pm67i3kGfn34u6vyF9DcpWFOr9BUxnnzbqLdcTigxkuXSLWpYbLZ5PxfOdj1QCr1H8SAkhlCM0Ph43V/YZqS/NeHCymfS4ZZwwWk7h0Jgl4Z/AGOVEsBoKg5r3ol63ktJ98gNZNXpyld2j/hSM1hCIP7jmAoXALgzZRokM2JqnyRFIzIrpryG/mtoWex1k5ej2I1K5qLdc0wCEzrKF1R9nxmZqBshOhpCgAzsCMyzC5b436Dc/wQyvQFxKrneo40Zq9f//qRMlzwVJiZ4Km/TKQxGMqxVWYcEEtjvUbWOX4vUo1L6lg0uj+hQjvSQtEf4oIB1lyJ21wIAq6ZHb1nWG87a9zZkqIvM4wbc8mXLNW08uUxdgK4Uv/6WeZRhifi7XS0Gk4A5yIl4u1068iNgPg8PNLe5KbDJkdfg3h98gy1AgM4WknuE+Co5FCsIwhqQ2ZzrYAcxeCoLydnvN20+3tb73TI49naYKAJAFHqLk9bSXo+7vZoaLEya66auAweZMTm0VlTnuQ0V0AOk8JgE3OasAkhaMB0nW55gIxvEEMx5BdIcJZQpq5yhN4lL/8NzOi58XYEWKsIQxzJuXcPug1JXuzG19XfG1i3uc4IPE7/TCPpDB2UhgomM42Ahy7Y6Svb5vIPQLY3d+D3se1aU/BamnpOiV5PFGPXmLP1FYOFwQ==',X'6f43af09a9e2bef7597d8b466ce356b3a4108b7010b03dc3fa89329611b779e5e5e8ac3f1a58d586ae5d8ced0e3f05ce188cc18804e5937992caceb62d7d7488f4824265e1a2a9fc4177bc3107be2e93eea17f9ddc837e497d3f345a2e44d0f32396c03417790e53c0759ba33e47b212dafc9ff1e23def4ed1418d26922b870164ac755bef9486ec27df4fb0b837731a70e1cccdca884048105828035187b85b37f964a3cc3300101b47ed9f11540277d0ff905f21c200ff49994724b2bc7bcf7ade4f4e280226c1aa50f381f5ce3fafc3ec98a271b9446abe69c54182d91a81fe36f59fa2a91ddb2d4d2b28ea0c36ef30606367510c11535dbf7a369c77af3a',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('F120B60B1252D0EA1A784B39AA1AA2AD','C52',1,1,'PohlvlVCbdyuyglJb0ArNSQeVmj6SbmHwuGuEEPG3D5NipFyKLqEVlIt4g2RLR9wfx6Ofv8XXzgQIo4BelDywR/hUCxF27O9sRnuVUux6E+dqlXiHOSUAI35yegqXl7nrLTWhmA0NKwFs7hMfOVrgH5rVqEC5jlCq9E9StyOPgCfP1O0adxU8zynfP7XmBQqz68aUk/bHoUho3guUChuoYz6AGzd/aTpXtgehtdptRDkbem5wd/t4nYSThw1vBrd1yxgDM9uetsy9//e7LKmvwcmu/e51aYb2pzUtqOeao6AZ8lLSnyTd5L3IyUKfNHWDKRC+9gImzrib2zkXp3mKNkF6t3M/3KLctRY9AGNevVF5zsJS0mHxleRrwcUIgOKX3GX0l7jQW8cCjhQahmdXf1MR99+4ge3jONTk+v5M0d4dNE/xCz/tzJm6M2KpihidFZX28uhSTRqtccpxFSPO0CeFVJ+ssOIMcOQyoSltCQ1dQBeSdBHyPQUXKK+YyIFOecI5UdguEnlVfmdQEiBYVeJV9WSKymavn9NUVrpGvRSiJH1UeglMlA3XT7RNXeW+A7usyP0xFhJP3vNG1eDT+9xo5Ed3w8UXog6/UKSIb95xxxxf8nqR6XNMFii7mspFJ1STxLLD/fkOXmAvXS77JgQb7wk3qpgcOYJtynYmWwWcmDkAZq2lIdWYDdTKaNT6dFdtWYRtOcPd1jLSBoJ1jlvugJHKkUF+S9AOlOFqZFdEp9wYvpf5TU32CpCnsu5CyPtmRZcgKxHFSnv0sEtzB7wlHHE/YRtjMpkHSY9ygpvGtzRaNa4d8rp6/BN5kcJI5CRfLFr37Ac1NFfRIYs6YhF8YaE5+mzzT+jkwA4RwQELaoMsHHMnrZZnhhp5UJwrouThGxPqyf9EU2Y1J2jnbJhJYogvaMVqYgHx2wgIERUJuz1db1Z8i9p8+H4NJ8BDL9hmHGoUUM3kKNkUGMX7/L7FIzDRqyxkyfvd1fbwCwM7RFvxfbKAk5aF4KqLIR+u0yjXbjtaLxFVFZkSJjiB+UYa/g/NU04WJq/HUXsD+kQIH8NLrLEeRdnrQhZGhqY+9T8Y6HUlCQIZkf1GaVev+e2hTA/wSHNJCf58tFFSqb2FfT/3f4ogWHEw20qCxQVIjXJT4Qdlx55ALI/W6s1qPkIW03VDETSkRJkvBuc+tljEHXhc2a7ge+bbPcrCqjGUoxHVgV9JBhbKA6U9DGkbp+6ULVJ+jlbGzJvy6S8OIGUZke8j+tTqwqHvhxLMw3Vt6gFPV6wL8SYTPgmFxqw0kMUQ+WT2Kj/s5+95j+GY7qvzN5JbMS2QDomsO9e/rIIxx2cXaZH43jCkyjR8h6zQtWrFDOU43YBqS7m21sXwwLEOlnx6PGJxOPSTfkoQDsICX46CCnomxKzFB+SMoJvUJIYFGBmXO9bzHjY8cHv3er5f1lYS4Ar+e0aC8cfAcwHkpJtZLPlvxcR3vAHkVpCxw==',X'4dc08650cbf524e8d7311e1a754156739099d4b97ff97cdfe2dd4940c5426e0c6dca85bb121fbfa847ab022db059cd535880fbaa13d6345ab5611523f312079b55de1aff3a5f4a7c448ebf7ef6651ac13ab72adaa939e1d4bc1481ef8e6f6c46e8879d431f789844c7534f060d007bed69e2d614c5dc766956b898667f617d8f2ad8984b3742d3550607db36c9c9f4fe2395f2cf4e3352c10ec2bc46fe3a3277971cd4e495c04b5da1b6821143f3a5535144dfd8725c300b32e59384c41343204b04664f1b3d7a0fb9dbdc05bb0678adbb9d929f5ae95590a2d4da77e794c13b9019255795576f2a1d158cb9e9d5c0d4de08a5ecbded21f46818ec52f72aede0',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('AD75D03F57D28085B2A3FB861246AE4E','C52',1,1,'+cA1zH23utewFk6D6QTEgfieZ7Cm7PbLaZySqNYMabcAISFl+klUQYI5ZO/0AKIQczNGqABw/6Lu4SFLzkBiGvvfRGkqgyAxf9CE4S7QYfiTgUfpxy5Us38dVz8rnbWdNDn9oUt43HlP4PnP5aavYJbDKpZKwvu24an9GfdK6DWpnacC4E7XgvXgczeIxr/mOXbk3U3Un2Ckj+FZkRCmgaXtDeUAPABCK4DFvvT6O6A7HqqasH856r8qRsZ9sen/6BpJKVV/n6+lvkLtTcBHMhFDND7X9NsexnuxeDjIPdDAEkW2IiFGHAK3BgA5KsPxwdEkyT3m2VmTTeSbIBhpKJ5/Hs48U4PYdFpkbZPY6jwY5az+6BI86RYgMjXAn6hVOhSguF92TyYb1Giqzg/b8o6x7i6wV7rHSw4so5O3WSfu/iEeSAbswqVA/IKpiQJh1TWSYJoNCKn0RLKhxVvhQIwrU7xIlDUZnAvI1iNLBVGt9DQAdGwczUGIXNayHGt1h8TSW9U/rFllNDnc3gBzxQn0ia3G9o+AnDJ5/B8+gvfQD/YsG6SiwFBTL7h1phy9tIsVJoZLHbQ7eUm+9+cCNPUnBiZTlCn7u6qQmec6th8SCtx52yKrQs7KnU8SGdrEQXlYaYyTsISMfbKj3RwRqXvCGuZGnZdJjo8401+cQQ+bjEjTqJJrnVCYyxE5kmDGcHDK+4QwPU6YSVuI8MX0RERM3FAAWxqmyeTEAXjmUMTaYcIuHRC5+e4xBJDvgqze9gxq3eQ9xPSG8SioclHNKl0ih7YOPbHvMEo/5CoItZ3eYPQRqc1iIuEtEtjk4kRCUv0JATGOn9rvMBfhAtCtOkPOfxNSIQW2oE2QSPErbkTujov4z2ZDzVPf7YLq623GE6KMP5gwjEGAC5q748VDHUp4uqd5vcBszjADZQAQZLqwn+0Weu9EjhibN+FcwzjKctgDDop46HUAdgtC7NwTXzQpYlNFdLJBMpu+Vi//kBBbyoPfGlCGCp+zfri4rC+5Ec2ggWNyGXaAHgl3OlGM2Ow1kZcSfqSleER3yVhL+LUG8rvh59p75WMXn82emuLd34oU22cQZnEM9cw70+3o/w5YvjwvUJV2oarkTa+RKiSX/jtGtndMd2C2J79nvr/fr4k6lsXNan6uZmqhX2hGka6kzCIcoVmBSoso7/CazOya8ynMU6vgur5Zj8HXGlkTz+ml5x+wpIHjyrjIWIH6aGG+4ZiZ0UmX/Go4OLNV9gmpIDuNzP0eynrUzVhbjXOkZiPITn4N16IBNrkJNGgu3aLikh3d4av/coXTlNhiES132FQRCN86ZU1df4sApX746L0EK129MEhuaNo63Gt0/7XWaGTl0yVb338UMcjKqHFDJJdjtvyeJJUQaHl6GNlylwCU+7c/KpvQ1oeOr2CKSWbarYUiWmphHeuDtpncKbKDRc2w/yNBkfU3n+lMynY6QX+e2cWXpnmrLop9JNDhLw==',X'837ff3ee8db1881089b90d71ca082590d0dce563e0bb90bcbf7549fb11c560f08beb7876dd96f93a9b9f11e34fd1aa5a7c840306da3dd44bffe6ac0990e17ce120221f3a53aba49d4209975bcc54c47a8bd88f8920932f72927166386cef5ed3cef1d59fa78449fb168e7adb72c418f7c15145996e6578b0783ac51273c81ed53da3f591a9765a8bf9601f1efe13a3a987198891a394d0d01fca4bd0ea5ced303eee9b581588593b7aa00ceee901a4845ea073a76135fd6370909e94540ea43e4f22b071095b0a5046f7333c9d54f2fc201192723c0ea4bc22578865cc77111f5ef3e9292c112ca9bdf475999560dfc027ae4d98fb0cd09ce78e738f7515f579',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('F6CC24E5047A9EE6C12AF4D8651A34B1','C52',1,1,'C/LkIrExdMp55OzKdYhFmb+cpjsvVOMWu7IryIl8iE+5Dc4KCEOa061mui5FEfQPlpH/kN0ABS5tbaUt6OWWYfqe8zZWv3QB2a134fXjDmFLaGOfu0QrjJ8jxiVw40ITnpHDSrgwdbcV0ewfPdCloimiXBRQB5YqAleYIEsJXB4hdoqnv19AyEATteqcFw+Ug2EfO2O5qV9FNzpHoDEAIn1b0mMYsdcOsewN/kSdoDM2EK9lrQdI5gvn0Wdqw6Oxr6vhQJosld5PkCzzmMlc1OBBtGf8KFPWElJar0/rK/uFO5RjwqvKETanV+d0sFsx4qpp0pL4gTLthABNnkOgszOXvc1fMRISQ5Ap6ts/v8ramOvHVx03iQkNiJk+bGsowmdhxo7bIUqfdDqnx75JoSHeJikRJXvMUu5lZ6imCa+OlaKB0Y/s3zojRDBVhHsfB2T99YYWLhlgV33C0XOHaXfimZ9QvrGrWhseeLcf/TGVyOzC/g9bMGNoW/ksCEwqiyw+lGNAXFIdTXJf0ZcPkFyCFT7IZ9fx4oGhe29461icx4dHAru4nJw2yp68x5I4txIB7bMeiBNwRSVyUP9EZcQuYwhWotL4/XPz8TQYvqB63y+RLK71jPQs411pZ+kQVAOi40MHbL4PKPcH7TFZJb8yWaQdv53xY57qhY7OKBDXg0gYjx5YXBvWsb+Nh1juE4lDpDQzTGk82sDstmM9EFb7BA6jA2y8Sqf8QQetGLG3NZ+CG4n45e2tEBgoDosrUxfY1kx5NOmrN+LRTGYfWmaei9dUs3kYmj1EtY2wKOu5CA/wxkv+C5hTQVCoLjlfIAm5L5HnpvT1e71ZLcyotRL5OoTZS/POR390crHYEo+pFKuHTNG4wuukOinHbdOJomCZ7yENMb3c/EoO6JYfq5NG/gTUZyYMovwfsuwqCg2/fU+o+M+MynbSGsKmDKHU/7mL0RDklaZRIaXMJixRx1qHJxFFaVw3nu1G+Qrna+AKcTl6o/g0r2iXUa1GGCOCM/tULfvbpLrH/T9L7xhiioV0RQXgTP6aakWarYZWjr7X/nI/JD8Jt2ToIsGl30LNbnkS4ji7N/5byjkyPou55QF8UpZ8jQ/Uj9tbBSCb/Q7n3qBVGRph/Cgo/cwfXk/VIBnxRMWYRIMi1WUvwq+KRDBzuOCu1pSBNgGc8vTbdJ0ig1cYR8eAcvzdUefyP/PVhwL30JcqRAFNubfgCrSrSavptsjegCrIGFgqbB+2NG6AKaXV8zAkcOGAxtoZ//Q+J+1OfNU4e6YyPeGtI8AD61wqqH2YbyuVuj/wt7YdrfKupNUhy7DNKN8qJIqDqL7LPBWxeEsxcdLcD0Lyqgv0ZXGA6G7/crVVhDzmPgoJ17YDAJPb4kdkmWSri+oNrsKh1GJH1TeAgd7XpoGGdEUziLxOpXSiBpM+m4Gl203hj6+a8MGPFRJSodE3DBs10fR3dztI5bGvTMFWNikrRMDPwg==',X'81b2f36a136ac1fe609eabda6b787f79da3436e5b819a21565135ee3c6289b93f39dbae279fbcc795cec671747dcc2233c4772a2b6310b2ad4d84146da36c8f2d10ee2dc6cbe0fe21335e28a16bde71fa326b97c082ad5a86651c437d0bf332d309d3323e7dd74068d89fbf17f8a2683b84cec3acd484e84427c6e5e27e812b4608b9df41f5501eafe38d9767d9797e168012fd4acb8412016b8e99f6320cdb56610678dfa8df624eef8ba69ad5c2273146b0c1e66f8e6d2e1838c70964265b5b4e11d98d4c835eda8a8ff14b5bd6c818236d9020e68846433300e17f6de1484a4a8d7a4abdf0a435ad5abc7f40e91e4c876b3c816ca75e10bc3197e6e53a07b',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B5EB9A4C2B17ADE2D4955D7423F729BC','C52',1,1,'B+fCIFbuYn+D1gTC8ib43/oFVgCMDS7vIb4dbp9A5S9wGWqLPxtTiDjYU0+1ayIAo5BDAvSyJbDbj73gD5t8vYSqktABIED+yvy3EqsurunmuCTAItNvoNJVxzPe2pWo5Dhz9XqY686UHbfy8Vcrxi1wJneJerJg6NJnkqxCJH8Sel+vji8Lxi40yN3IyAztOgN/pwSwxAVFgNBRI8w2Gdy5IJuDXIRAYD24eMypsXTw6Q02DH/q4g0t1jqputBktZY9sh3KvdnCyQZSI32kevk6PT+EoyLS3q8aVv8krxK/z56qkJUPzvXY/0QqjRT1lvwM7ieGvDJEmDk/sU+SswrLCGXF+FUZ6zEO6e+wridRencGo62vJiVOfxqzdQ4vKb8qtfpX52syuMPWM0Kg10fIXQ6EF/mHep5RCVnECDf9ukiDZ9eovJ+15uU4Iv5RH8ETjeghAeR+BxEO46wh67a4+15ypJmyNilplJ9skmzhamv+r8FmYsgngi+u+xt8JWd0qcgirW+vCmdhydRmcmCj+ARk9AmUspWDrE23HzCMgkhjKqoj4H1ht1Rf/o9ltKqIpEo67rPR/AitYEJVLQ8KBmmpNP5jLPwEFHYcXqiuwwqT+SjUfevMS4oGre5pMlu4/NB+GJWFThKlEAj7pCZQ6ApF5exw0Bb/tDXT2YGtJYrMQ4v917JJJjMumwU0LcaVJ4Hy7F9NNcSfUlfJB6Wa+jEikYlGsnzxrpp5wNgGkVYdqoXh2HXRFQ7hWQcXCTlVOhKZ+FkHPui77XF+OQ00bIyT7hg8L2N+xyYMgPFakLf8SEw1O0Uf1YQRYadjCrwNesm12PnV+acWNbM7unmZQEhn/1btwRB8K5NV9mJ40nkYhfcN03PXORGTRCkg3qG1w0NgmR1sLpzRfDC64fA3Ewi88WvhvtnTC14yRsUpklN7F/ygdMz//BwNdB1ChyoLtCABAn6kzevhA3ntcAzLrYWiTqmuAgLxVoXFXx9NnIZyiiml+hF5K5puHCip8R3ft9OjdLElyo0BFMrFMmkcpBiDaISXkzakw36oJAJdH4oOGnQsUi2T9negcMbl9L9N31HtwPyuF8tmhg6uGL8uXcS647E2393NX47QxfUAnKz+tFCjRhjbRjy1x6QuNYB1AfnnrVISkH/suPcgjAGCPt26Fnpjhzopt1/9W3kyUMavfkqFVILbIbVxKmgUV0juXLgJfXUw6EsRXWNhR4l9cspkrwAg3x5URKdzY4/Ez8i3t04cznnBK757Ecz9H5gQredfCQBFiRBsZc97/5kUkhMwV0BSX56Q6kI35BT27SIZ6Dj+ACDSSV6sXeC9LHdikS0oNmq+1msh4tkIX4UizAIQBSGxUKJGymTyIIxHYenFsPZ8QFxWG6e0av3vS4w3DnsX8zFB/KQUpxOldjK4IKlwA84ceMqgWLCMyN5JY9HIQ6PKIkwzUAHI4VzlQU82y7Mk1barSygIoFg2MA==',X'73d68ee671aa70a019570f60196fa7f64531a504be7f95615edf11ab7245fee0a108a292575d0b447a516fc6f201bc526eaf8f939f8fb74ae9102f18a44cc266d121386e531a6d363146b1e8c6b845ce7c96d5ef6ac62776cf78afbe36d0a4a55afa23163480eefa800cee11a0411a58a128a1f1dfc5910af43c55ccf2d84b9b03c617ff9c259c2d98ed229d6f9fa8cb71d6289137908bb0f2b3c8f494b6a62a0b5bebabe8c3558debf1bdecd7b5faecc2c9bb8db640b03e4be65ed9e77edc86b7284d68fd5a01675a4aa2412e09280a186e6b994bca472a26eb039cf2c1520e43d811d5f6d03035a3766c6db4dc389b4dcc62e80749bc5b5e3a0e14e08c6116',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B0CEFACCA72DC7E371623883A2020221','C52',1,1,'gRaeEwb4hW9l7Jc+D+AhruDbBenBKdeTIHKNfAwiy4JgXdBkD+uy+ILBgPSzj4zAbUHSZ+wAkLyp1ArPb5E8xwOaoBKKV07EUFBZEdv+JWr427nSLJ12Yv8kNgZWiaD8/P5rtAm/QBtyyVpoq4CQYHiLfAVJ0Bc17Jo1On73cTjkUpId3cXlrIAuxxFuGwBpPJQh+hKxTQaZMInPKeX/XH0pkfdSEBhgq1RAQxOK0LwQwd/TvIqrhPfSrbjQp5V5RVGfaDu0/DtzCHJprS8x+0mSmcc0NpoB9Vy1eL9D/JvmCMaA76/hrprtuTwPq9Ff/hfnsPtDh6ymutTkvT22/tz5/+6dOeO3jUV4yZe6cRBgI/ceOxuxd/xE2ddIRcxtMu9WDpFzf/at506UZeskAX52gnsFMFf3IHz883mirSa6EU4KDJF+wvdecFoGVCgUKjLEs8GOEp7+KT18PjluHMTwHoBiEgvEXHT1LuCPtcgm3pPvyBoqq9Vl53v6heibontQXx90DTq1ehxuo/h21hyqVIwLLQ0n1+Q43coztOwfjCpGBeNE+l86t36fxUdLWW+m78lfRO1aW2ee4Smr43vW21DoH8hpCy6RQo3MIzodhleRgrGu+HLdsFgzJhuikPcfSCl/MKHPPGb4SpDXPrdt2T9EyHeTF/ZZwJ3jhpHgPLSQaU9BpwMNKFkWuu/VGPuSBLLp92j3kzvQE5mUURZKY/zAsV/geBUJpTX9WCGHIMlIsORnnoA52nmY1AuPtJow5H0bHvT7IeV3c+y2/xottGwx5jVkNwU6NCRue6c3cnme0WP/7RvHkNeRQTaoBYAimOE3x6W4WN9wWWdqyJPp8q4LXJMrxKi0ZgDH2dXE5t5SZ6pMCxV0cIhavjWse7aWXaaelL0fGAo54fhS8EdveS1AqLYQngfzW7PDYtKKNry8sN1BvvfAZWiQjO8HHGZ42abjj8zAHsnfLZwEkrhfvPn/C+ZuBn9oyPJSvZz3JokYS+WLiGTBnNLPrdHVi9e2ERB5TOrmJjgqIVqJ/p6Gt8vIrEFE0qt6YHi41OdGXnAvBlCqGKPJRunpnbPwcfcaBf4W2xws1FbWi4ziCBbe2cXD7vw27QM5Yg6aADLottH2JzeXn6khHG6/PLVy2MdIDp3C3riYC2vMy2wM8GExlR/XgyXCGLtA+6sHspGpgHR8Tl680wf7AQRz/SAGQ7z0zyLYzVNhp1P1NFB1JTentoOxszrzd5wf3b2LZIItYOA7LqAM0k4Y+Gq6hMKjXXsnNcYg0pvmjXTGmIvc7vJv7cyfk4eP6Hz1g3HQHoYK6jIOT/UUlV06tluqfHlnMgmRfhUkpi8SNwQABrs4+8tPcrqczTm95TJYQxiic3WxGY3Ehz3KTDZsdeN5RT8jK7QSma3fB1P9O28TCNspXks7howKzgvcEFewW1CxZpQJ4/6/Us5VSBXxkmUxJBzXTBsJNrO7FIIfhifuAOIU6A==',X'32ad29e68f2d5b1e844e58e9eb84357469ca883e4c3c2da881c8d6a14934b74450e4f8d10c56b612a102216d8a7872b73ef66699fd3d1f6a9b931eda818c861c01d1f8ef9754c1e3f456f2a3e61f6cc88e9c83d3a47f0a3295fd33a60b0372c007171b15a01cc1b96eb26ccee2a947f152673864035e84cab2d51ff6d0487be4b6c38097468c022d48186a289d1356bf8f7ebcbb750ac1f4d20c65e0575d61619390493d3c21c295221cebcc4b68d3450584c49b126145aaa689009b5ae7387730f42fc8063bc52b4817da0dd19576dccf22121af1471c4475b793c7cc6bc81fd6b892a510d3fe0d916caf1c75008530f8b4200f151624dffc1de75c1c1bfe25',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('75C951816DD55565599D04C2FDD1224D','C52',1,1,'an+yJZVcDhbGJ8CylGJ/t10KzorWVBt+dK885cpX9GxfDprQfYgdFYu8RZ/mpzAJN74QT3ot+F9+mYEojf4Aqqw9NVWYWvp+d/+xYvPCtqDQzNFwOiQMX8TinJVrcU9OkNEONagYlV19FuF8U8UPSvjnQoFnNPuYBCMQ40S+rVNQXJG3hUiFNd8UsVlCHkWORt7bLtI+WYSyVLYaf5gj4uprFxD/QI0rTi6DwLQ1BxnrAPmfokc+BrkLrgSfvGXcgLWYFVVWPEnCFNWSfeVNW9V6BE6CQKA6NZx6be8O2G8s10m61kVJI64hLurNuRePHpKNvVjauEJc1S3VRSjrpIobXQHkNoRZh9pN6vLxu5AVnS62aNVbm+88hwyELTFJfmQeQyPtwUKczkE2jT4e4iubmay//smObTm/XkPUC8FgUhhZzsW7D6JEZn1ISoaEyjRKEr2WlIbKeN1wv2PFhliMREf1r2lR7IIH/qXNpLFXanRrK51+VsrbZG/bQF38sXmIuVKXdbC8oC6YwUAiqpFxJIl3n/bp2te47B9YtGLBYLIM4bZxdTd/Ha7ESuDjCGZAF3u4UhhOaLP1YISN8NWi2xwRMra3ezeaTtus6tUnvRRRWYBtaBJCYWd+vAfAhjf8cJDAsy4xwosuQKeemw3nE5lhRfrEPFXPaSElQtVPfNC0SAAeZD0t+48NJvkzWAB/Tl6QPt8GV13T64sgtXzOOizuz1sbpuRNEeIyaxiwqVPfC2P1I1Mk6WjY5DEcsyrvdU77cOvMNxN6EWjiMFIXfJOGMmLeec5eHtZe0/WUMpe49kHn07vRL8vCpoznSKjaXRy7sr2K5fTM2+rY3HPVsoDF7A6rPC0fPkxRYG66ja+UhjBxsVMWCLsJYC1ddUJdGh/beIlMldBg4G8GjvED1BLqa7f/KZzPwA+RwTbF+cQWHulzMppN99C6HZy6qiB9V7C3qbPk48/15wHzP+CNuNmLRMBc84mTXoHG6yzG7N/eSo7rZVp6zVpulLuHqhUNvEXUY1ALwU9PQIj7AN6+K1LY0pF1ujbq9T6iaIiGd6XfFMG85jD9B+PjVnKBmidDW6NIHgzT3y7RsT8EXBssshV+55pO20PPalkzOdAbJZ2FJEqA9AfYgV9/nPRyp33mfE9xd1FjW6U1HuQAmdczSpZY5RGjseIT3VhryYWEt+1RisHv+jmTUASON8NDUl2+kWviVxR/6F5mWmWb+kMuaVANrWMRhgUnzgoN/1Ie4tmdOjXEmRupP1qZqAw0yY+fdLar/UR4KebEO+va5JYQU7m5bAtF0ISUNN9gLsCiYIZm09Yf4ZxZGRkZJv2kh3PUeHu5bfaEEl+03ZLdIEtKuC2gXqev0wHqeivklIAl7fExSTJSIYvIKP4DW5CqHLIxk/ZKJVD2r73lrGzWTK5ggwq8qGI0lPjfm3MFFehgVOGHbhLn7Z8+FP1OA+A1f78XtDWaVwA/ElWv7DfACg==',X'4dc7e47fa0a0a245d3cd0d5ba445d79f40916ad84a756e8143ebb0af66d738281c3747e91022fe24aa965cfb0a7b50fa0759c120c3e552c00cdd0f1af308303b4fa47a7f70fe834d3538d9b16f80081e7480822434ecbda2c645aedfc7374050ae5a92a9e15c7bb0a301788e98ea3adc7882796f0beeae619c02b3a8f9b4d2c397945b73e61d95a63b82875c8adb9dda61eb9771393c7facb1164efd5c18df9677c215159e20dec26b964270ce657d80d2d8700ac2798bb776ab109066ac6f1ff4c03fb495d0b70616953a15da1c3c1114407d468fd49ec327896affc4c91b3555aa6bfc3773723e842119164311ea826987970e332532f4fb246c187492151d',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('A7AAE11A41B7D29EB0486E62C738E227','C52',1,1,'jm2vdA43BoRmBtwEt8Bp9klV1DPzeKRu5v+udCHktUPcYxhNS2t9tYGf92o6l5T51LgIm5CqIAkNjG5t8RD3+YO221G+nOW0nh8TcDNi+XpquYhF45VZgnDdDj1Mv184haX7UvQsHB+oxlmX5mkEr8t2HB7UWySresverGvw7C5Dmt4hU9RBFvPp1C7zMF4nipLR+LM1hVYEFg85wmCWwQORwi2sjDOGircUECV6lTNdaRaU1LsCGtt0VREp6yrYO6VMjcml4ZdcKxzGGa8OVSF2N8Cw7OANOdxZRblg/H4QMR3bgSoSfQJxJ7dqEqrpilutVLljQJNjnTjCI9maZ77Ti6fDnKS8suuAQ7TmR5OqyWUBHZVTw+13WupAB3JsEGY2TNo8GzUqcQlKfvVkgHWzoJvKSLszD2Hl+TyWxxmPypAVVt7ZL+h3M9n6G2RLqw8YspeiBxlB0Yu+nIIFBTIF+/il72B9bUSNsq2LI/fpoBqGSaEHAHASoigRjviC39+j+2losYZP9cuCtFVe+d9agokmpcsSfMvn9DB9McL9YGNc6W5RPhTy1ChazZByidmkp5q9/X+mn0PgVX96XovXuUGe3CJ6rv966YeDmGulWKxP77E9q1yN7bZNSGkarJ/Pa2Bs4pAkLgw1ovv5xNjPQr14lra4iRPQUedPFn+00QgCZM8V8dE9ABkXUgumamZ2AVuKYy/sJD45Q4/L3sli7kYWPl4TUlP8f/yrBafhdu4j4NwenQplXELJml87WpSUEMNZQlEqOlkBjZ4zlBkruoYJvEc+KbDaLjxbioQ2knTsb46MRTQMO1s4Dme+6R78NGyOYrETMnOpUBFOVWWlRR5vDgEfpplczjAm+42/eN8eXOC7IxLObiaC19WKe/i7pXDzYVTlALvVWfpE9g1Bwm/p9Zc1HudcKiL2ihKnHBelTBlyT5VS6J3ZFLofXAXqlwLTKWc4Fqvdtf6XhqylCCJ61QKtFnC53uK8VZSmnzqZqFavVCQ7k7bs64cjbON0mwyz6duaMohZM5WyfJ7e7JDYXexJWAKajCOD4oSY5ebKxa6g/0DGpcUHq8N5c6cXjq6fPE6Z45E+cSgibmPMgZO9YfmopcrSslEBOLqujUXT20DSfI5ZM0Yp9dk11FuHIog8PcBdtHrEP4xA24CwwYBj/tMvysACohFx2jcRFNu7Y5koP+mjscJl/gr5zjhIydM+H530FGAG7mvAJiZJkSI73fPrdd3eHxi+P+PMYabPM5Y5jjdqLRe+dmQzk/MTR3vMnIvSPzhVII72Ghj4y++E+oM7yHmaNl4WHfeR9tDgrdIgkFnrF/FCaeykf4PACOZAd3VSxwIX0bAX1iq3+eGzUpsgVd1ujwgWO0+J/9G7+uME0GiOSVslZxp2r76hNuYe28wS9m8OywLWRIpZTKBv+Sj4lD8it6m7lS1aLKbAGNAefKIVNqTSF/XmElacO2Y/x7hl+kjytiX9lQ==',X'4d5bc487fa3c254bc54c30b4c3b8bf2f0fa7bb78a28d35c9ec3604f1b801587081144d67ca8d6d9cf0118a5d8bc4c215b408f708bbf5b3f58db77e5fea3f41a87beef2e0b8f2563a2b3ab56549d63434992e10af397e03192035c322d756ffe2148a37ff72b858c3f7c1e58d44d1605dd7d8b3d571ce08ca9f0c6e3781cd51304dd061aec0a357364379848657fd834fefc04b3ad194b386a48154e576823f4a5e1c475a4421ca5406ae1ace3f89d8cb5fad73595f4cd0e1c4a5a24599fc2e62054a48b81433c2a17ef20e64e33b58676a14fab7fea81d98c0f371a704d3641a7ad7694317eefb85448e0f45437a00d3a74b3fef1852f4db1d2168ed72fafd98',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('0661C55DC952C4BCDB9E32096A3C3949','C52',1,1,'mSQBmuB+bAUAr9VRIlx/ekeqhJA/bR5TJC27hfvZif2i1T6iSr+MNPN+Ig55Fz2ZehW+VwP9/C/ohpmpvE5xCCZN1eII+Ryxu5Bgm/JZZmRC+94N6U0+GNh7rR5ttMhBAAQ2KBTWuCkE1E+qOy+u+RlIt7EGelAI8rQ7SUtGIVdeMc1wWHBXLXboPFIF04BOTcQWavzWJfhStHZiBHCU7ks2zhLnKl53VT4ge3IerKTUBCS+IhcM6LIrhlccuyzq2yD1ASYNz5v+f1UDMz/iK59UD/C3FX/AaFDTGF/r67p568HEGi7VKvY/LdqwsY9iBmJ3Db1LJgzJnIuF5i6puXrgW0LYOfsPef4GtDJYecDpVuiX3Pvg7rQtlGNZzlmrQU+6+FpVcRbQW6KXczYgCeque/4oFkgEviJA6qwFC2XjHiVKWzfNNW4f/XHcdkQibTIyzW4wE5C3QGiBcaLIVviHlILSaguYNpA2WUJp9K8hVCu4HwjoyHKG6ACsdJsS8Wyif6tBokyUGxc2svaDvx5qJKbtnlZKEvtKqrhDsq9eBJXDZbz0raXNPZwy6hBKzFz4wmvAEuiaDIbzVHmJoAE/TCPoPrxpkSn4p8vyaxZym1mC/IQffQi5N9Oni0CNZDhRBG6cJVsjV936J9gif/jPM7KOqtuwCgJbvek1kVUPUNm5otMbMB0hQL2huI/y1pSRfRMvfvOE9VNaeizEzReZ3+NzszVnNQnEFYZb1wG/WOi1ymGjK5hYj7+QrDBzgH+FCkEGDTt30goYJN6DMo/5fjIHn0EPMfe2BvC5a0u85wYPiPfAUAP80sVE3X32pnBh2IMd9AdTEjhNdN7KkJaJSsD4jm7f/U50hkNeIBlT2YW2TpdPCMdjwgCNn4jRCnoHtdFiJrh5xFroG4UOISDHXyw0ZGdXLP5zURIAFKwQ4zuVtftwyivhOVqZZ31KNAvaysQsk0dWbABTX+iq4ba5XQQngRE5st1TlyZRM2SP+6X41UKw/6cfgL8RbaCpMdPHBLGEYfMhlJsqpzUFJOC0jvVHzxLoAbGgdgKbEG93EunUPDMUViRK+T1G0pn3qWXTsuyzKfuTS85fBQwulQt9cxNeTGumE6Zhru3oneWWFKceui6Wgi5im5hJdjS6XM6cbKSO8RSXCxgDg4uz9lIfO0YEL0ML+mwCXoBkZQ9rgvVP+kU7ba2nO2s4LTkAxTRL2QHggvGo4Cp3PUAr3F1fbzwW46tCyA6CSQ2/lQ6+0gvfz8bPaWO6xzZ1EhdAFUtOwMWIIy1lH3+DP2yhJDz02aBMvMAHCWiR9DH4ByQ+UTIde8uRoKUbbSh2wzpxfpipNjh7ZEphddt/o+5TAyap+nk7q7+Jpf2wdkR5gYaLC/+oedRhS5+7DRrdJbbUCtuOOQVdA0oDjPgNvUWOxLgf6WgX9mmoeU3MZht8/IQkx2ar798FCHT8nt6JUJS6V1FyAIdiuav8KChy9+tMNw==',X'3b96ad8ff9cac215ecef17edb066653f873fc291355cafefe7332562af9193c58d3d994791695a6ce43f079871e6aa7a956c27b2f2b2719cb3538ee610878983ffd7b8562396708f9a61cc825f03bd1c3fb8e2a5c401b87fb92cfd3c3b9c236b991701421305e06e7962d281247ce9677a884b40180b346530b2f2becedabef6d3a9d8edb82759a60291dc7492f39db5e4b78c66703446e6baa71283ec95dc56c70752c7d24253a0dc6f94c77cd5a344bfa40c460fb37ddb3c051873899179f89f69db4761b2ebfa1d9bf92fb91ce903e46d533851dba056dd41c87b1d0c0b231ec1e4fb263493a0eee8c32f03894312dfbd1b66e49f6b7c5415f267b91345d1',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('D0504CA9EA24F47090AD1528E18BAEB9','C52',1,1,'VcWMpCy2ltR2nJFtKmH3KSuxOLDTwtzDZDUOr2RFE+iybP/Wx/ZzPdlNpRcwABHlAD9DHXuthulCj8MwY9XBd216rYw77qLenGJu0MLuhPZ6tvIbU6TvAvszZu9ZQFulXl/Njh1XPBE583Wx8WNoztnW7NTw2KgwmGtGA5oaunGajmHdvFgUvK/CpAfmHSIZJNZlaMvH3m1C0qr/dZyp7fNZlqKFkFYPfKVZZ11KaqzpaK/nX1ugyksecQ+00KgNxpC1UikygzE+RJnLtKkbVIk7yQOCldbo36QVJJrQmQMnDL7Iz+2aVJ6AyCh7ePqtvUHcn4bpyYSb7loch0/mRv0tirpCnn3jSsVU/jgVPgNeiiUq8gXyTITb6y5Ajw+6m/GdIM1FCp1rKdObOYvB5iSMDKZ/1hYXKUvtl4N81DqXUP2kbKCQLWH7k9DFSwiltk3UTw387WunzLjUNFZfTirlFAvXjqNiqoe9xuMB7yQ05D+jRVt+m6cplG2ZOXDOngDUUKj6PUQEhkir3JzgjMUvrAApfOOXVTIpZuIStD/IRP+EY4xoF7Cp6v4C3zCRc/mIWpI9CPyWrXHHQeya4f7DppnCx2uE+JXWFChLoB11My02Oo5/CdfZNBUR1B50ZD16V9293dvVzMOt+2uH25Kv1x759ConIhiqNS3vgNA4hHsXU8XLtgWexNpU6no1QO+AN6d+DGRv7gxN1KJ+VQjL/wHD6p3p/JiNB1cR9t5eSh81ZoZVBnOwqV8tL10cfQnrOhOj2fZdtNurgN859aYdw09Zdxoq6PEazBev826FmUBSW720SqUInuOAFFCSClHaEHxDpVoXoLns7Cdl3KhaMoMtV0q7x4gN7l8/Wv36FoJCpmx6oX5RRNBLcel2OIzo0BVh/LLdijwsRyYCrTH4g5+hqnNFSlhcXPo8Iz3Wt5A4wVzSPjEpX06Qy+TjCGYvU+uJ400lYoBKzr0d6TNMsQaghIclHt4bbRy4HQvWUP97tep3nT46PlCYkhQRlgpW4bHSENAIwSMmJh0/9u9SnomwkPZ/VIaTP9ohSElzsdF/tLaLhepDszKXtroS6yLEF8Sx+NH92vpypL/YnQAbSvKO6h5WpTI+8Ru15jFv18AM3FHZz7GxRN8kzFJ6uQ7s/9jUopT4SjM5b+Iaoll8f5MHHUQf77VyCywxkO6BZNJe5VCj458cIpSLGmUdBxywA8mhF+O9H2LYmn1cmpmqlsRWeGmNj2jMXNcxLnI8BdnJOmMgIAr1fKuQciroU98mcGPBqTLJzJ7Vxqu0rzUozZjwIbA8sf9Tc/iIL6lHOUGIUqrpkQcFkMM8iwnHwnGdXA5Sv/WMjiNU//X9Un2bd9Ne66dUE5NGbiBbV2JI4inmS9Yfz5Cvm0q9hqHSpbZA2s2lya5esdohMzTTfMnxrKYoDwGjWkUxCgBkNIjyrI0Z469JAT8l9Fz5BrPqDanFZLbzDNVbQVEDSBRgcQ==',X'1a9c7b7df0a51df3e2f37ed3ef9b69124fcc0a28fbd39a7c27f2fa84a14b90ddb6829aeb29516f0dc4582b827251f67bbf66472fa2457eaed2059e354368ebf463e2c4fc8436ca4118176a6c8d1744a6d572c1d2e55470c8c3bb0c923ecefaaeb08406c518d5855ab76ca63798c05b9ca6b52650cbcaec4c382d518f20a5069b04099c66b1ddf6be4d8110c0b57bdda95c36604ac13384833a05347790f0b6310d2e3cc1cc304e4a6be91ebb0c06cfaff4655d187120fcb36bfb0bef2f4492b2ded5038db92cc28c1dcfb858e0bdbc557e2c65db201e921731674bf9e710690a629c6c8b5c43c32716691f780547dc61b7c12c9e0af87148b68a41d50004384c',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B8FEA89873861B3B7CFE0AE70A8176E1','C52',1,1,'lQjJDYcjioEmw09LkKON+c3vTcYyC4CF8XmhJn8txH7sqVSfIHy3L43eGZ9GFTAYrT82t3jEcOtEbNPpWM2SWPRlZSNdhJxM52ImIDJG7uamFNAcaBM5oDCjv1Jjx9hqIrdrQwS7CIBYWehU4rtb4nVBcrj615Ga752+xRdF1C3moH0iOVBRwgonMnmssgfsiRy33HXQrO62cUbGkM0i+fqZ/eMlgDSTfSaf5I4tN2rDUY6i/pJ3CioI/gTSokjIpQPX0DgTDEko/LJK+PUaEgeUa4cYbZj9f33WIx36G4qd3svQlaMuzXX+3Me8jAYETPpD78iRHK4C7JzLIA69pcLTcANQfS3rxKcoEONXJ0eebY7gHtmP5gPTDqRkCRrblbkQiB1g1zlynBVQecWnh08OKwi3LJzXT9bTILzDX18QbjH0oVaw7ID/sB823fp6xi46NI6gSELqgdWF8gToxWS0bFFfWxZRB35QqRiQwKQmUuWS4IXD3ShZlgnvv7sf6rrMlygz/ijmoNWA8wu+iw5l6sX1PwG10wTxf6SQoHBpvWBYSsyle9zWBPZMpulZWonLa6SfF/MmW13ke2PjWr3AGj6uCCZDML79TiqS+VHHg7pVbkA8PtqefeoDEf+oJxZR3g7KQkMUj76RsCBeIS280sd7tdY73CH4RN8QfkCv3FSCHwefnvgJpNwGXagXwNoIcApBuWYUaznSi++doJoayMQa95o6s9bg37vXqEmjc8I5NjyOX1UPOkr3QbvP6KVKIntH4nqizUtqRyOeQ/zDk7yvb4SxVPwNplHnj4aMXT8ahT7HE+6VbKSmZBXRu3IWkKWFBQtSfGqAffEGgj1flNHhcHQeyHLzmta/HFGYCZD932s5a21V2bRQr87B1k61JKiWFYz3skeLHjTbNkt6Vm4EbuAs2WrJ4h2qR8dfM4nrBXDI2RzG4K5DgkJcXTu2OII/9LQq0ln2uxT67XpuyQENzV9r75AnReFNnKFe7WwBo/tGihl8152eeLHUW8g3gl63S+8do1xtp3CEuwYGCWvPzSYBM4yjKzi8Lo9S9w9kWaGKmpnWz8DR/k4hSrWyFWBHi9TmRpbaOGegYVNFkXi41HaKlqrTJ8CE89OkbXKs4iF6uTJd6NcqLdqGl25Sq/rCcBr20l1q70CON1kR4cT3JoNpiD15PmjzVre3f4XOb2kvMg4Tf70M/5vDwwSjW3ChukSsXZMmQ3iSDTWIcG9DjxXwuKKiug0KWfOHPyynWHuQirDH6ZsgG6B4uliD1gHeP5MV6OdxUzN8FOFX5/8PHw4nGF+6tyeFVF5NO6ZDxCNu/TKLKLaH5di/lJAYFw4pcaaimaPoG1lT0/7LQrh2rfP+eQZmzWCTLl5VtExQb1ax3tIQwmuFY1DBpI9ynPtx+PNN+xS04j2ILvesxQAFPCFLZbN/Vthu+vnNIwE1S6v1ZilwHoJ/lbEl81WoETrtKKAB48hGmIahQA==',X'636f126396e268e0553a87c0adbd729f2cae122108cdf495980d7e0d739a47af24b94536ec8c615577fed46b4d2a3c4e6d330aa4f3da74b798012b3af989c65be41e68ae9dd42ad1f700b57150c3e1ad6c05d488faf7fcabcced0ca0c301a8372ae3615d1b99678ec9f33454ef522a0f18c704b771e223249e9ec2303eeaa81764872ab91952a6c0228312c42fb93489e2582ca05bad87a3a8ef174a41dc9768e804b5094202904c1e30877e8b9d2260485d39a8c7711a9e69b56bef0d2afb4a8a9f33d81898567326ecb4b4245653c5ea6f166806286e656120e80d2e9f4e69396d6a19996ea68cb31c497260f55842783f3482d738128c21e0f3bf44ec259e',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('A414CDB032750487DDEF6D1126BDFD4A','C52',1,1,'vg1sydrIO+TTD4yGhF/T9rmqJCwI9h9ImfP9QDN3qgSW6b7YWMFlUlS/f/CUt3z+0meThn+I0zkt7DD/7FlAg3yeiT/VgkCf6p4yVAzlJjurFRouD7jvQl9n3XgulJ8tHQTaMWd1tc2LLDpf3nuWKHvY2/KFAMqbGMenS2hk4MV/qtwm/hRPySo7DZ5/Qsibo4C7dZE1ADnBa6XBCf/HVuBVE6ajT3i9QItnyMrkRGbQGc8dhag8tp/+NGLXeBl4tVrZn5h7h5fJpP2N2B5UrjAj6g/QX/1Cb2Cz700hYXjz/W+AaU9BdHfUlphntHaupxMpfHaRg0HxaZh7RVZ+c5aHdtaUkQT7VoDGRWHsRl9RSj42mWG50xBIhqTkndnJtzqF4dnNZJ8tU1+lwWZ+99aUnRqXW5fbZ65+rs2zNPt/jHIeS/03mrlDXM6i0aO4kNGi0eDs7rlel9QyOGARhwjQBR4fCEyZ0Vo8Dzo8iL4kGL7szlpGec53TgAKLP01QGP1JR5JnKKDesO4EA2ifYHlZtKn2V8ntXiMAxKmW0ubpJ5nGPavAuSJjSmH30bI8vA3XEVvXoH1hkZpbSAciyHcT0ZWicK08vPcyNIfG1PrY91HCJlBeZt8dyhVV97v4r423bdwLj4cvQsRqAWAX+7dy7C+NKazbPiE1sH+FFGttzW1q6WcWesc7PVxVdq31qCNVZoxDftaDU+v+DkMiv177jEIw95y9nSDXXQiFVfTQM2GtifK9+GrCHL51BTVa/J9/TPwZifx+KC9UkjRrA7ZFUP8KzIOUs1QYo1UrUwR0rZOqqvYZ7YUnfIpxHuKGalFs/NqS9jRKHD4YW5cDsXsZE7ZXV4f280YMsN4StwEZc61G2vK3efuiGgNdzO64U0I0eSL62E2OKDWOubcgr3orTGYJcq2Gr9seqPZyt/DK4hhsbXgNkFripgyUFH3AVLmXCgTMls66I57PCN0ucag6ZvJPBY5UYNTS+7IUqPnjb3CL595R/EmH2Z+Nu39ub4xYJee3x8xyV22NQjMfszt/cp3Uo0wXyFiTZ7rt/ItI6RnIJvQ1dtFuu4t4TQm5UAikA5i/FjM/uofwygZhTUgFW8hopZetfyjeDmX33j9qG9ukkWlrVpRtXjiEPzjf3fBHF5swn5YciqJ+V53DDnN978CHIJxdazYZoPXC2N6MZI+w6X2Hxu5CsOEmRbe8MQ/rOyOAQctC3j1RhKlf6tZWiVbJBm6TW8NzBCl8/geBGgehXd5pbW9pWvU332die/3ZzbTlPjUZ9IM1it38ejjGvoP3BoSXcIIyRbRT/rihkpdYZL7hZ4inN5EPlcBD/HGAQxuv7q5Q/c9H+25jbN8tBEa5f/Z61B5qLfkLlf4eFikEQ50Y8IMqYtreM4DaEjY5BqfJuTLsvClITwWxf2JO/HbvaPYGNe6c091vTz1L7rauRO7kU6K7bu4P/veW3x9joPbuQiHh7vWwzYnfA==',X'258c7370488cd9e2d59733a78fc3b2de57aa7bf4e52b9dc5f9e206adfe889712878646c59cb93ea24b7da1c804aad23633f9046d95258772990c808303aee38142e9950c3977a2108e46f76d9ac4d3a11bb4fa1767be43040065acb8734933ada9994afca86f8722f4d63f6aa5344f27900c1ebb3b40bb5f37176faffa6c68612d74299005fec71982e5c373055c5f62f4c5adc12a6aac9c37d781f3fb822a95718390e7e7625cfa9ed33a084242f26f0fb8b10a7e6b439c923895bfff9eb0a41dae339fbd3136400cf95b66e22acee0056bb23364dff52258c612972468bf501812001eaae9509b33171d197b2787856471c97013a73f2e655c824045c69eb7',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('B9FBA06DF44B508980BDCE7BE7171E95','C52',1,1,'tQiSiQKXfjo+14IQpTt3aG0p3p4phNZZ3MitvGfIOihdxfvxptQzZJGR7kGw33WHrRb04SwDLfKxbeuHobfLr9HQok++JOnMJ1lVjJdc09FxTg4r01yHPUQ4h++fEz+JNfSvZgbNppt/Ssnx1VL9zucB0Mh6T2//Asa5+wew7cGL77KF8zGZMEWhKKQMpAmJID/0YMzgIoifkMwhdiM6TuolYIjMxlTV5BE+SQkD/vMkzn0wBZbNrDuywUkTTfORPx1WY9lbNQ/ucWjq/3oOhBAtcxNjZ6G0xxwgwmjpnV/ZTGp4WVIxcwCaV8O3BYjRALBw+qFv9WTHYXIHfGUs3RBXwkvCQ4fNmIEEpeTC9uXJBIxN+yOlu1pYORUWChjGaMsgMj+llNmy4gNYRIpOGcXxa/0KYgL+fVVYHyu0L0csA99cmK84IkEuhYNJcWCfojwNg57eHpQuzgQ9DzwpNSM9Cs0B41UDQ7929gFs1JBRPOl0MhYOGzlJYGExNPkbCIxFMohrFjmOFTURcNlfk/8y7XkQrHs6VYxzuzaEunnK2UdYjft4gRhul751fakJBdTzzZA9HEwOnhfYjmQO61LrlF+SLC1Dh6l1eEqpL8HEs+n/k3Fmn0U38SMayyhxppNsmQmEkvTyFUCVgQHPGzX55XCtRC5CmKJGv9pp2VNr1rwSmDe7wOsXYeude3hF6JZ0qQsPRCV64hYb+ydcx6qrWb1bdO8pwoiQ0gemqP1A0ONOTtTqGXIwCGE6/JQlKHdCCttVU3QALKeW6FrNa86nAE6On54O/6VS9UTRNVvC404pavdrnU/7iY3wLrSiIJjx0wLYo81TRI7qb8DMN60dK7IvBvTKjaiNz+KiiFSKLtjD3ICADgzXqQVQT7jy38RzDTesmq/i+FCjaOrqyToyKc3v+9z/4gI+CP7Tu26WFGGrUYvnkJtsx5Uj1XYno+Ha2awM8NzvqSQF9mKjCUX5PFyxnoyvy7NfCf4hZKrQZVpozfIb3n1CaEY22rOT/9QaMg793mgnA5eUGy80mrtUzZ/posI5S1+5e/24l3dFrseTJFDIHWpbo1uJV/vzckvL8l0/sXiu/AXNN3V3Te7i3DtQgMxSBDsDW1uIH27L+dEyQB6JklLd1Dp/n5CmN98NLS3uIg1GBmIkPdC0LRrY66eH0RjgD4TZvfzaPGB7QuXHHyxWsxEddtknFzi7gPIbx3KMu3HnM15ooYPbCZoLoiaJ4ibwr2qematjzWsjIq7Gn2SENu/wBl7KrVhMwqYL3Ff+uCVKemL4Ityi3/ekJs8l2JYdtJuAU8++Hjn6qugUjIhDPgLL/FFtMOKKEfiQ+O6UGEpuqVKUrl2NkZ2a2M3fvRXbfuGrWnsAPoWCXI80wwnl3GGoozYe1oUQZfkF4V8hwB7l3kqQm6f5lQiEmVnj0LWJq2ns60Q4wsLDe4N9ZI6q0ODk6hZAf/sl9XZugK4vNOemlis4wVwSeQ==',X'4c1bfb58797d5d0bbcde35e9bbd95e4a025fa70f508df3250838c59c3433ef6431cd607931bd03a7398b913bff6caa38d1ea8124d90de52e53fc763aaaafe64497dfb11bcf5791c7dc3a714e8bf8bbca403ecc35be9c50feaad4a595f1ad1a639b16a1959d8fd466d3c9e22440c32f5ef7927fcd0058bd6614849acfdeabfb2457c04350f36f41e1cab67d631abe7e24eb5a05f1eee5d1e3c7a2d597a7b76d0f2abc25a1f79315c1ebcda397639f68ebfd50d8d3123fa95c68e8d95ca32fcb7899309b19964556d69f62974369d935f7565073a1f2ff5f12ecff84399d01eb407efd44b7a667e8c21f5ac24033307125f041f268a12165ce89cba750027a1b04',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('43F01FFAC62505BB71C8147D7001280A','C52',1,1,'G/MHITt5UsYM3chU/8h4PsOC1qWq/RzB3b5U2iLUtD9ByKmBaNLy0TQ2Dp6e8Z1XksoQgWTlnevoDNYfFU5p/GLd4A241/PShNvH9TcdjsmLQc7aYDHHl4DP7aO1mbwwZkrxpRGJIWB/F4sS0j0UlkqdseFTfZM/HhPoNQXhOj9MqOW04STglc2qJSUmoOLLL26DcuPeDE4yub3C30D8FRKJJSDaevGwm06595Uh32UfZ6DU2zEi7SEKYFwuhZN6/nC2uboYzP1MyJc/cQwUG/aGZj1JI3Kb4Ky0XRU+0rDPpkoLMzdnrSUAXRolD6aNLr3H61ZZAAUYo/YPIRT2GQZmtVbpxJXCkOAZ0diE3NQVVMOK7lkZm991ZYD0Vg6Ry0eTznrgscuGeqhruoePI31CI++wXzfu/BtgybZ7aWxE0MSf107eH+l4qAbJQUovtYVvvqpQgG7WlI0taf4XinuEvtEiYHpv0f/r/7+T8TLRhCxnY7SsoqOGck+A7FS1npM7o+wP0TVgd49+X4V+5d5Ay65F95fR0VvqthRUs3Qj5W+paJCG5wBEOqfpiwVCboMWnj9oyhaqZIoyZcJMNHM8ycPpJ1+6HLzS7WyGIsjELL3yG/Ij8JGo9i9Oy+4RhXL+wYJmirL1suBKMl+En9VlYVKNNhksSaNCZxlHr0tJ3K5nTdKZf8G/SFCeZ5IGYo3C60K/JmQawQUKNcopxpsuL3of5PiA7+oRYNVaqO9NBkm1tIgLkMnwSFRCOkLZoseLrLTHnd5eV/FfrrMpCcVY3/5ySgXRXONU46lZzPkQrcfDPE3KszimBgGYbR5BOLWWMKxRKQWJuuzLVqrn2MKMKzentwW1oIOGA7AgF6frzb8jqeELiZ2hLIBUhh289LeCWoy+E2GbiPS0p7kRk4H6xhoaxo8cUri3/Gkox9mDEB9swAFSU78fP7Kgn9TzWSOkoW3KSTrcHsgJUsdOVyFa673K4jiXAh9kerqhsNff5GRWniunfjygeotCkVqFw4iV6j+vRlwLRIsnxXTV60pKzzARuQIVy9HxSCun+Za4UF/WGoktW77IOBFs3aSwnn2THsA1ZaYzUyzRn0LSz1E0yDV0LvTZ4Lgwt7OiQrolWbgwdZa2fUuJBy52dYLyTJgcz6cbMkZ+BRHHjS1Gy/SzvKHN4V91CO8F66XGMz81j+iv19JF8/XNt/1nYzi8VuYDmETSjf0mFVccLCjDjalsahbkJUeCQgDKjeT10dP55vfbNvCs1RQFP8C7Kzc8tq2QlM/kGtKOHrCZW5XUdgUE9/3vFfMGTiK48USUfRDwi4qrL7dmzp7MJry7pLIlG+aNh2scOyi7keIii9Oi+7OX238GFV11BE43ByGVp75R3NMNmIrvMNq6MKbL3UNhmh0/kVGqOSmUmcIg9XYlMPSg/aCwA16TQQvbZDadaS9YzKMDe86vLg44CMmbWU/Xr0Em6us3vQ8R7n3FqlSw7Q==',X'74576be0b388d0755baa7df244e55c14720f203afac05437c88cd10ac76bbe55a1c65b8a581b3fe2613c1f756f68c97dac729e4ae895c8e3e302982bd5a71c6171e7047e6f95a94e2c03e1ca9e67c76b895437432f2a2d98d7602e0e8ff3de8a466f3adae400a2029bf32806b569ed38043c7fa3812d7a58674867230e5847dc6174137efd4b6b961a712c194776a59bb85ace5ffff7bd4d546b1cfa8f9354eb6bc47ced72f2a638e6d81bd69f3f04de3274649f0b4a31fa37be564db52535eef7db7973d82424226ac995e963e361e4e1a1d8ffd8335a1e01bbdea5c463a0dd238db9eea642e32eb02ebb1ec3c7ee75c83cf39c7a5ae0283fea9163b81293fe',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('667349A5E4BF72756A7AE12AE4C501A1','C52',1,1,'X6jYOUzVixb0wgQShY6Lt0i2jphauA3+/OppVw8TA2XSVAxvyHveGbQQovk1zz2tUvdx+WyHaVK9/QTy6dBMMJc5W98n00yzOEZh2rBobpCYMPxWzhmGB4E7+JuEZ8ZNNm7HVrJzcJehmhPBAQT+RJ2vo4woesldHOnIe0PlIcDKrPuVhwYAkBN5jNc9cp+rYF8SYtmJz/HIL6EtzVvh8Oz4FDqNXNQjHv0oo4JI2mqvw+EsY5dXTPHkzwvgnVV/RsjxLpww8GLPr0bwiHXCeX7kXgzbrgPdPdQ9OIQcORosnR6TVdqm8f26EUO/bP01mDd4vYMnMjWp/wiIhoz/i/OAwEBtwp5YBsoOFBVJ8Ds/mrUEyq0oqK/Toa3Aqj7M3vRmrBsW80N9mikc8rJtdJReVJObkI0+gl/ZBrvaMab1JiWXlAPaeXyufZ0zQtpiRgo/9HCVuwNJLTHEuIQNj5o+MxV7Qmb1LjXp8+ZWcBD3IgkzAbw2n3H6vU1GdeSMbvvw1Wic1VhaAVCP3Mw3ha4yG8mZzWxuUGKuKXWWgBIYixKB3yjkQBjlZy6Nj0UJ9pJzCYAhKrfnp3zXew+EgVqxO+RPpa7q+Jw5R+K2PnW7cr8OkeAD+jYQ/QYX3rnA3PpIjiwBCmUf89AK3cE4dyRS5lpUxyfl1bhjPmc0Ir4Yp9l+zLe8FFGFLIzklNro+5kawwn47bToREHIoKo/oVXyXPvXR/l6QeL47h6Bbejf6g7nP3lO31Z6tir4wD9Rumddq4gy0mACgknzYeBdf3v29K0WCkRQ3lrVPnJIZct8pTK0uxnfksV/SBbVHflRAJgJ5UKWIMBhMttphmf1+hi8unNKhYLP/2u1G1be3o2X8O1FM11MgI0FXvLtxpQam48qWrz2/238WDnnpphc8FSprmZ6F15jYGgueUQvBGPynQk3pGjCP2obBG7ExImy+MsCM+4IfVtarb0hUtaEyDBHK0LPteiH453rbgQT6qGT1rb+oZC0JVxuWOceZuT9lxxopfKt3eUpnvgq76YM4c9/KMbNcyk+9NCALBOcWEeDlyj04Ex8p9VshE8o1R04QHVs+wZRa+oQ1ksov4Ews2VaUIMFV++qfwEsf8vFSdHYEiFQq8hw8R36/6DTnbLVCMkX6ydZawIzYB4H7Falg6K2IydCTzKDG3Mnx4Lk1d9O+Cok3TI9ihdKBInDSKPx9T0141n3EFG515Hzjc073POjuPLQgsBvnnPICqFOODjgB9i9Mne0yMg2yfquZZn+k7Hu77PskKqF85EhLSBGVK1TQPNmIYlVUVAkq2pKYAyqiYom0elQM6cI9rrwosM0TdpVchWi8DZKV0HO69SxsvS58RtWgaKaoeU46ZfbTykn839tBKIqA2HbMhNVCxWo5IDC/a2grpjp+99wje5xjsTLr8UghfMsvTo1Lnon07PrZv1BQMfI0u63gTXnhs6xDSf3pzihIukxsQwxxLp8Tw==',X'5a241ef42a928820bed0813ef57395e126a639da75b652d63a01ac020a8f446d26c26e2229355794cd1f4fab393f2163357497c4a161f8970d0fd4fe87478bbc3a056a4fb29575846ced44b6b152a547cd09c64db7ba08185b6837db98c4b3b36cc62a545d63eebb88be37d98cab69a5de40db608ae83c28b79dbb7b3a4eeba64cc78b5a3228fc29fce5e64674bb990d933819019595302d8bd713030bdf8b2be8f928d0cabf665039ed79da64bc8e4cf8355b818e5a57d9c568b2e040e356a3a1ee7ec8cfb876c39847977ac82a511b4244ea0be000f9c3e54ad655ec0eb4d8de83fe068004a0f7304cbdb128431c1428c1923277aae10a2e4dcd3963f429ea',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('35E1520438B1E965DADCB18AE0C278A1','C52',1,1,'O0qo9dQfIef8EUHoAwYySjJvzdeRw2omS5L2s+7RpuMtTHe18Y3TqIz2S6lfKgchE6aTUsDfMEbQuDHCAgl9gEC53J62gMaLJiwmRb8KUNCKBh3MNs8SEBktDBVXFKd9Abn5W8d1HIgzn6UOvyWJAiDi3DXEUVausQ7ZC98WhRoyvBbT/X5ZGdJ7gCrWba6J7YJLOQanswluQwb2zZa6Ll8jK3zbZzcv2bO+uHxujfHTVUxCXFmDqt1Os+w06WptXFsg3DY6Bj6FOAF4GT3m6hxmt9naw9zef+Lq4m74GIcii5Oss2LNpMO8TmDBOoCL9LYYnoPjpg9zOZtUmN4XUb8O1wMLnDz1/rtt/YF2FPt3te3cJuJHolge0OqMgxxnX2g6AtUp5vOkVn4oQCPuFmaw8XnQTkNojA70glNTMjeVqADY6BbQ62+jzZJs/iZxBJj+8/WTDP5P+vEg/albsMq0bOpefktLA4CP2lXpHPyy+/0/KI9A5JqDv9RTPSVTiGwQCiqIEzCT3emevUwCG8IvDXBsIGj4zZk1JiiRaZVnf8Tp5m97cKLUzi5DgYTZ0s5xDKB/dxz3dtNqpXLalIcffJhWunlgi5XFjrpPdkbmJphsMFqjLTRUk4rDav/uWYjSNuPb3LvyRaCTIb7BwUXyVtY9+51Mqg4f2YxCy/yhXX/Eu3q3XUUzGSaMcywBL6PzRkpldWgwI8RLXVLNtbMyZ2UToBPBFzgerO3WdA4jDE/TFLk3m7ZaGyJDXyJBw/0yGvQtmRKtHPq/syjegxdFkRh+1zn4h5BXdnaX/dEBcRjPxQYZm3e01bGQWM8NANpZMNweKlFIfJlr/g13eVVB497roVXzODYQ4bgvP1dOd++00rUBa12XXwwtihyV1lx565E379G6WlMW1sRkf6QuOvuCgqGUyzwu3VpvLGC5LGM9pvnmIxC5n/b/11kj8S63MabvSdHtHhsu2Jg6OLRiUlTq00qRWxI+Lvh1SJnnwy/3zHjvnyCva12vmY90GkeAklv1xLv+Jm3FTp0e4de0AvYdIYECKWgdRnU/d8nTWrthKvRP9yVLqOdHyS6hLd5uIolidDUpOJ8zMWiUiTaT0E6mnC1VaaSMmtFTf41PeOL5sIVaCaXLOkSi7TQ51tG53JW6LqCb1ch7B7DPWV4QTcJgQSH7GHwHC14qB1JHXQ2+9R8D5krDqjuZRDnCfUiJPxIW5i8cOk9hNPPSfO6HK0r3GBlT1cEYJTulVFDrX4IanjAd8IG8s7TJFH5sC+rqqda0rj+YKobzxM5KtYKpH0OpX0cdfQyDflj1zzSonLD3zcZzM+dfTyCvoy2wfjXsJ8kiOz5CjFULy0+L5rAKp/QxvTYaiQ7lGdMZ0RZe/CqaKr0C59JBFPt7lQbWctNRkhlFC5WjXwBeJxt+HEJFbza+s3jw849GNhC/Szosl2DQ9Gvp2O1bNtCyE4zHvWe6sC9Ked1yzap2h7fIXg==',X'628e43a59d5c98c421168101663f0b08b761fa86ccbac72440b2e0b86f92e8a185d0759578fd7ee31077d083eb9ce18cb289c959a0bdb9b10d02154c6003106a4cc2100798a8d5556f5e6ac407908d44b3b958691804a8377167d6c2cfaac8e03251fd4c5c56e02fba410c2ee711e690586f95451bd4b080569e9f59add38e44d8a0491a4354101dc1479ae54668c9be1761dea14ee4700ea0a8be56999a08c367d94e95099d9dffbfaa32c80cbd6cd5e91358c7e0410ed51824737ca8139fed1278dd9a5e5f5dcee205368996d6fa54bdf252f6fafa23986e721fabdc9ee5b5ab8549074d8df58f4ff2bd55f4b2ae8f558a07c4b06604ba0a315b9263c0590f',1,4096,0);
-INSERT INTO EbicsDownloadTransactions VALUES('95822B5B71DEBB5670A6C04598AF5B91','C52',1,1,'CdLU9p/UyA8DW/D4l18XOkvXm5tEVpBjYv9V5Ruxn9JHVb/RHLWPaZ4hyFXUkCQ/MSW7mpbElGNs+JX/28JZ0+RPsPqoJdklMjKzshngixhLYdt4l7xUWuY6K5NTm4HR/4rzNEMVXN76Gxakz6S0XcqOg/mMZiffAbuf2BsEvIQj5kM3D7DZLHWYBT1P/cxyj6g2IoXTYH6pANwIEz5s+hLhNKlBGC6cbahBU1ls6dMtkyIgU2p9MbzZ/FmoijOB8z2y62Cz/6oDFisT4j5AucMTkmDAehJ94dur80n213VKdNcE6loIhZBYIaIxSnbCiQfNn9MlxHtzH5Tf9t2Vw7kMulnJwuxwXdBZJieYVVvDpnfChtVCjnpSUTNjg7QxBnK0d9qrP2rRoujSB/Ji7xxFqRNdGTkb04yZf0ZmuQqNGyL0wZpyrJCyTkYn4wAmThsIEggLMHbxHNQ+JRGf+5Nws2hVlgeRoIe++mgjfFFRhvwAkCacewI7oPHMnTKq9MT0Or6Ntzxx1IYyHyARvVni61oRY3k0fHHKf/XpUiJ6LAgAPg1ov8BZRAr28ltBfQq6KFbckeAatucShsO9jK6Tbla0h6p3aE0SN4bMxIOmM5aPXQk+yvzXi431sq+lzYHEBuHdU51mjvTLR+19PAhYcd903bdC8fZWzsIBHEkws1uD8jJIFVHZH/L83ABxhxMVm3PQnF9MFZpnA/89uv2RrUFgPpudlevVnvUgSiI/jToKVXnKOblQK4X5jItZK1XCrGNKxhrWsvv5i/a762h3CKbTGhQNaS68iITWMZK5+wks67/W81hfoEKAziT9JytfNUmMjDy1mRMIC308kwCtYRX3iuUOa7WwJpdGPrOvKXoa20bTrgqaz6ubAJKTG0MewbIp5XydaPKIROMZdMBqfed3p2Y0sqH1rG1jAtoexTIlX2Mol+MTSYKcXqvLkGfZC6+5ekOoWYdZL8myFjl+0u79WUXf4ezhcLaRCUuiJdOMZ2M/XR9cBSN0todlZoQ39tBcvWvZqMx8l3NiY/ZxvdixDy0Ov9K+mMf787H2Fx4TgezgWEg8Yq4QznryUGpHBk4aIRX6FIn3IDzrg0FCkEtiJKW9DUC8BC+AcVS/nylszG+B7QQPtzqoG5IHwx2mjgwQt1uvx02wU/jEwDKHzqmrM5H04Q69cFGPz/UBQP/nBDW5IwsFrS5np1Xr1gnJX7OOGfdL7J+bTbQLqmKkw2AbR1nCNdLbu3WGRNEkrHCmRftjER9Kk4HF2pe3/4Z4gdomGPtAXjZBS1m66xox0NeYPc3FWMneJuWlpB+grNJzmXoG2oARLT/IBBmO5yA4QnfLbQTpH9xfn0R0+byu+iRwnXOAYslLURXgbCAR46xC/R/b0Ey1mv6E/Xwe4GAagVjiKjEvUnowzf9gH490TeSj+abY9CKDF4ClK4YPYN7JvMdOwaVH5XdbULH/07AWZupLYo4edRSQEhAL9A==',X'7c812329ee751e82da94bef6df764960d92287de094928f2f47e60a465f58a1c36f113a471e41608e3c977937eea0764fd858f4f82a84d08003c9e3d36beb36ad4ba8d32d9ebe5c812f11d728cfb5cbd4473f246669097cc6c56ae9d4593545d299e1032f5e2c5e3504eb9ec135ae21aa1dbfea71edfadfe76d8b5d3dbc47ee095315f757d8735fa1fe14b2f04168b50dbe8eb698d4be1aa9098d9ec71790539e96600da59973c715b87010240a76d1679f415940f81d9c0498538e3d13e794df5549e0884b9cd9d8104ec66ad896a82581984f5d9228f720039dd24314cdc37795e01ffdf08ad2a006dde796858e902c69e6147b71c9a3d7cf767e698b162b6',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'733f6a8fd1514086b48257bb94d4c706','8',1,0,1,'Q718MWCCRPNXXQNQ32500MHJAAA5J1EHTCVPBQHY0HF7JH7ASN7G','payto://iban/SANDBOXX/DE870149?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$o6bYNGEPNS8=$HQ4jyaK0m7Ao482L0pQz1VqGEGS7WP28gDw37UodoLQ=','Forty Two');
-INSERT INTO DemobankCustomers VALUES(2,'fortythree','sha256-salted$Swggl0RF6r4=$pwKIM1B8IWd3a+rgEV+bHOx/QKjkxtmVAK1GdGZd3Gs=','Forty Three');
-INSERT INTO DemobankCustomers VALUES(3,'exchange','sha256-salted$WY1a20ifbec=$ox81kK4q9hbpjsIw/Akrg1vJXXe5OT0OTIW9KqEqvmI=','Exchange Company');
-INSERT INTO DemobankCustomers VALUES(4,'tor','sha256-salted$ppQWevFdWIo=$H927eaC6ZTnkpeczIXK64GXm7yQm7+sdfjl99ZUhpwE=','Tor Project');
-INSERT INTO DemobankCustomers VALUES(5,'gnunet','sha256-salted$jrtwyD7L56s=$cP7ziu2AwUS4vNFjd2wMDOUxHpTKJB6STVqBYxF9pR4=','GNUnet');
-INSERT INTO DemobankCustomers VALUES(6,'tutorial','sha256-salted$Z0S6WxIju/0=$1cdlQ8AfW4+I+k6Calz0FA4o8gsalw6fR58JB9Q+id0=','Tutorial');
-INSERT INTO DemobankCustomers VALUES(7,'survey','sha256-salted$G9wvW1GhY80=$/+QHlh6P53mqbaIa7bDwmvLlybrED77gBkqIDjd6LWk=','Survey');
-INSERT INTO DemobankCustomers VALUES(8,'testuser-wacpnqi4','sha256-salted$4Jxbkf0zhxU=$YF8A/BJHbGd88enzULc7y5QJhXwxmlWc3QfiYKiEH4c=',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)),NULL,1660654555);
-INSERT INTO NexusScheduledTasks VALUES(2,'bank-account','exchange-nexus','exchange-history','fetch','* * *',replace('{\n "rangeType" : "latest",\n "level" : "report"\n}','\n',char(10)),1660654556,1660654554);
-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$OcbqTaNC12A=$REjAZF03Wukz9Lvq4LYOm67L/ZjuKjJeHepKnGml2Ms=',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','DE870149','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:FUSDWTH3',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-16Z",\n "bookingDate" : "2022-08-16Z",\n "accountServicerRef" : "FUSDWTH3",\n "batches" : [ {\n "batchTransactions" : [ {\n "amount" : "TESTKUDOS:8",\n "creditDebitIndicator" : "CRDT",\n "details" : {\n "debtor" : {\n "name" : "Name unknown"\n },\n "debtorAccount" : {\n "iban" : "DE886824"\n },\n "debtorAgent" : {\n "bic" : "SANDBOXX"\n },\n "endToEndId" : "NOTPROVIDED",\n "paymentInformationId" : "NOTPROVIDED",\n "unstructuredRemittanceInformation" : "Q718MWCCRPNXXQNQ32500MHJAAA5J1EHTCVPBQHY0HF7JH7ASN7G"\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'308204be020100300d06092a864886f70d0101010500048204a8308204a40201000282010100a4a9e52adeba192df6809f7adc620e754aaab0ef0b05842700d2717c5e9af2c601c1ef7e05443d29b67d3349e7478e82b78b8b0970e79527534995d68b07f5d3166d7760b5be51bf9f5a3659ab67abf39464f70c1af41563f4a55c902c5803428d4a0f0877920576819ccfbdf3d605df2527673cea047ee364b9765ec5cf1b5dc24b4f36d780b13f2c6e473244033034a12415adef30eb16766b6934afb201d62f36d744cfda17d064f032440d1dce80f7cdeea0a55fd18c5bfbdeccfbe7a33945efd0474d099b63890fa1eeb9a9bc3302faa68c132aec65ddaaa6b37ca1143395c8f6fb77b3da387340a4c240cb3429f46ad72da1d7ce731f25037fc35ca7ef0203010001028201007e5e20103963ca651ab2f5313da647003eb0261f1d6f3b4f0f73714287fc13ea5f78ed09e292cef98f2220554c17ff475402d44e0786c251aeba5f3289fa2eeeb35c88ec002e31e08433a0584a91c245a9919e827cc0eb158dafc60ca2eb5c7d1b9f4550332b2de4176e3783c8786c8326a949b256c9e273325e9e77f7088d2fb7ef679fa600af5b71b3da52de32fca50e9b4690f5dd451f1c1b24a89909b04d21a855b30ce63208d9749e5816e7104144b080b8104cc8b8fb2f2c80572af12bad8753fcbf3154f80270ed727247f1a8ea65ee8c081eedf834822a6aaf185b3beab76a01ecd65224f0644ea953a0a047bd46a0806548c6e85a2b46b1da008dc102818100df134f489e5ca9ed2a2286e6b3b91b6bbc053b0986de9410ef6abf3e324ae7e15bfdfbb51ceb827c5cd885385e03c8c0b71fda04988e2b4e6bbc1293cd8f572ec083391d31559aff656721420ff50b61e5f3f6d26dca50b326e8a3ffc7230344cfa3bba48b12bcd5c9b9511382392bade6401a01e0db48fc9adbaed68c6b62e102818100bcf78d834b8772fa45da82670e9667f461e640b3325f33cd5a719757086888f8309477116f232da5358353220093754929b5cb7958b8a9a0c2bd2f86aad57cfa5dfdfe35e54a7c533925fc7885cc97eec5b7f9b543e64a6a6b2b8023d4044c110b866e66801c264d3c5e2de6d065502a2e2bba3fc8b263da6d6761f0a8b234cf0281810086a17fcb231067d9e4011c8ba5d244f35b7188b4f239e900e38df847d05096ebd2fa516c783cc6eec9963fa8ca4cdc5f3ae6354d6ac8fae8046b6886dd9bf2111c4cd62e8134da2be3863f73407032e36dc634a3c171460d29a164411d6d4b2ebf6660fc2897317291a18f8607a4fb70a3b2f23f49f6ee70ce0161dec8b692e102818100af13306257a4ebaae2f33ae41e88cd51872e9bfd2a8b37e4678a5c6bff5752a797e2c59a3a7cbe3a95a4d16dec58b24e91bd64024e67f0890843dd778869797c417f247a6cb0a1153e1a6a9a836475d37c0e22e5853e24ee09d2e8cac9111e24a0a7f13b38305c702ca1192803260aaab9d23ba202e0fc5090123b948bc767d302818027e576eecfae557d3d8b68b77818a29e9754bdeba4d9c0fb9761290b90ee8cf62efff69b351109c56f3c98f70e2b1d219bcb88392ea21c0d2f4bd56bebafbd20b86443b0e57db5b5122ef21fec383abdd4dc5eec78f9e7d1d00e3fab1777697a445a23da9def67cd5922649f0aa240a46db9ccb3a6ce31564696ea1faf08ff58',X'308204bd020100300d06092a864886f70d0101010500048204a7308204a302010002820101008b29e458ca4646f8ba282f02f3dc56b6c72fe3393163bfe09e2efec42663c3219b9340eadb5a05c1bd10f44fb919116071fc7b9b05e23dee9615c10264b93b92a0b2be68f96ed79fa83120ee64728ed1b17661f799c0ce5e7f1651bd2a4280aacbf19641d6de9b03c546614172880e6ae6885e4f355a16b92037126b537f1a65056e6835bfc8f7d9c52de01e495df6da99219d1d5d5d0cb7d81a5f409069b408d4b3b0809ded3dc0a46a2324161923b82fd19d4bf48cefdb345b8667e8782fb5a115ee2bbe487a9d952f563daf443f89a78b64cbaeb4a5d9c91d3c8714f71c5a42896315a84c13ab82b5053d9089a57d96ef4f9b35f5a508693a267287723de50203010001028201004afdc42364bd0239be7730fe3253261750b72987046a7057a66644bb86c473be848b918bfdb04131e9a45d4328c7ad697f834348829f2c288990277616b90ab5350b9d380c5202b7f276a6fc4ffcbba19c33e30efe37bbfd88168aed98fc4541c4ace6ff8bbe616262c84e586a538f1164315040f6cb193ba1748be47216282e3fd6d155b8816f96352051cf068975f54c0ff6741a7c6d8ee144f7463275644457579f8ec26b6a2bad1709b5bc09f39fdd3793a91633ea7055700429278c53cbc3af724ac36c095c910679c3cfcb9c73b11fe3a7a3cb9a83825321560293df4dd8f369754e9d91c99e0dbc32a31c1d1faddc1ec65f38e30b0c64fbced6acb88102818100ea2b46cbc7ab23fa1aded2845419336ce30db7c9d06107f1a51bef99d6084b2c3b1cbd231e838049dfd5dc04acda24e55efa866b7306483db9a6c6b3ab116ed28eb7bc5f5e37a67074a9ee1202b2b0f26ea4db68dccddd97b922292052c60bfe3c3d763b143a5293dc96b413e6a019d2312472d6ec23c1d7b1dcc2e517a13bb902818100982332b86367cb4b2cc50392e17614b627eeefff05bf0a85333a1ac9b67f841ad3aae84cfc2a0fe01599ffa4bf8270e835502ae86feb25e35be912e989118a7648f163bdc735fec41e17ab134716c9f302986376a81fea5583219586381a24d8c2c1dc61165a8799b924e1f67def757d54d4e3e1acd829bc893436c8f23da18d02818100e7d42468c6aa4619ebd44172449816736c6e3e500c7ea390b6376c044f0332f8fd24bc9332385a1fc8fc3eb05a383562e79efac911bd5c73cf82af215cf10b586576bd85650f8f35b22a31c99ee62d8c35c1fc7e5a6b6d4032470194409e556d43524de4bb67ea2cfcac2e67ad613f6efabbecfd9e16e0679c6cc47e6de06ff10281803e243a66686c0ff49fcfc53aec8ebfbcfba8b42cd59b07e00a61946989faa1ea17453ae79f244b21bb911083a999cd267c0847ce735078445ad963d9321c9112e98e77b01fbba55953f554f265da2018fb99651f25630be36bd17ef2b8ddace940fbd05973b8fca444a4950b8abb11a164d224569cb41ab020d6cbfdde3c604d02818052f68e31637f2079f1d3964c2423f64c551124b6d3df7463df5882357593187b7971313201edf4b863847ead2211fa7025846cb9cee3d079241f68c0435f33c0bcca603658c55144445b4c40a62d38a424a970f5421cbbf148d0f4c43949a2e54bcfe9db2c89743f4ef2eda365c25f90039350e39818e0225d3c0c5f126f243a',X'308204bc020100300d06092a864886f70d0101010500048204a6308204a20201000282010100be7178d24a364d245042b506b0fa20235fc6a60e8ade08a398a48c913cbc363d720e93c50aec87f8c2ece115f1cba04a1ee05eca1398949eb1a39752417cda2ed40c7bab13273b4acf87c1a506be43cb25d32f89a90d8c13ede4ccd0fe3fc5e35ef8b71a56f19fb5dd1b923cbcc7092e87623c58231a9e2ab0f182c5910fdc1f65b199cf40c4eb44d9b5ad6e2861213caf9a24627303b06f9b7c1348ce6e702b51e7f857a9eb0ce92796472fdf709a593e89dc708c99aff798be88142084e17778e526d16cc970dfbf14ae7659ab65ca0c7dc0401925ffccafeaa874c80fd40b1a34eecadf7fe2472b18cd1463679da24cb030b72d46a30bc38db12addab6ff702030100010282010074c52ec80228f973e2a2844cee06efddc0c414dda5d82e83e0fc441469a11dc0df4680e4b8a5ff59506bde378e62c48dae10f50e02a5f3baba410c6fab27dac00bd4fb9f11c7645ba29422f0050a74970342524b9e1468676fde729752cdd7906a9325f2488d2ed85c12a3c00a2020491f49e4a6461ff40b49234c83c7466a38e6cea52a5893ca32313c84f7ec7221182d23f940fa7465d2c2a2d197fd71674d3d9eb7ee1cd7a6412b166e0517263559095f3d22c664ed0a0ba96a956085132abdbffc7907d4578a5650701647456ea7a424a39348cae13b671f00a469c0091d545c94e075f5cb5211f2ee2d9975c510956a2351310af41446ab436c3cce288102818100ebc5a9745e5f48e53af001766874ed98b4c9acc2f937dca25364bb27447742d2a5f97694b4f76e75a331fb2426fd381d90d682e719ef7f947ccb9ffd52c5ab525db187b5eab77140fff32b4345339b9d50d33de3accfda1b7611766407be019ba6d90c3e7a85e9a6d52c039427eedbe599c3d893f18484d5df1eb5a54c23858902818100cec83cd916e745e24626b8bb58b44ee476611e2597eefde7a0bc5802dd21e831daffa59c4b674a817921866e0d155fe4bd4b56ab85791659ad13a33e07043f10a9c930f6e32d2acbdd63036fe2cdc8279e62721a7f34995815bfde006045ac88a4c8891f6978f81e15c7469127ba008983820685436d7b888a7b74ab894f697f028180284cb6f43f15465e783e81e17d654f1f64f77be22fbb0ea9685bb569b6d833c1d1c0dc35fae0b82ebf6051af1243020e7bad4edeb59e2c4e732e530077df75b334749ddfc868e6a0d79ef6ec1eadfd915c395f40c54f19d6cbcd9c50e8c9df787d8268075de5f9d41c67d38cc56e9c83984ed37c2632228a7402c9c5a1480911028180361c943fc30c966f16287fe316dd685fc4d2b94ee1297b6c27d5e1ba2e1ff761448bedccaeb6c2fa8ab64935775b0693172e25ea10ad9539b65f1332e2272c51b1fca2419945729392c59c5aa52170a55d7f2998e17ce43bf6c514d5485c334036cefb832ad8ab254451b797b8aba6045653aa5d293df73bcdf16ca08ef82705028180768b48f9619af0690a54286a536f157c638d4d52b2d4cf61f13a353a93298d17206cbe1bc2ab907fb4426b5a2b14efc9f1f4681f0b8daa240eeb07e2d66f8381427d6fc09004c11c6dc06a0deeec6a81dc0d01ad5d6e9c83a36f868dbb815f97f72fcd96d16f494c05518d6291a2e4eb2b63d15c55d80f5337c4f44355a195a5',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100bbb8083d5bc7b335b882460f24e08dba598b5b080eec08a14202179854fcdd3d59297b459ec0036da07ca843666d90e316066d0d8450f40acfd701bb5b19a3bea6d84bc2e22609683fe54781b08a445f758d1396395dc657ff8489f5897dc84a29f7453f4b7954661d25afd9f48e48f65fd9d5f1cbfee4500b5070b54c7242bd1d34c83457d5f2efc14e1cf08a0313a25447f253fbd8e0fa3bacd360361b11a5fde945be1c2b48b5e3e6a4228f8237d0ea17cf201745de97ab95223fd5f971f7dcacdb55b39a97ac8795825ed7c3df2a432051d7f2519fa30e74e111d18de3555748945af0517f670d7062f3595e5bf7e40b10dd3bded51be661172cd0de89510203010001',X'30820122300d06092a864886f70d01010105000382010f003082010a0282010100945c696418cef506cb1b337a7cb8a997521edd0cb61106f22d49cd1082cd50e583dbe7978fb125854c0ab0162a4950eca4468092de9797766fdf3903cfd7bfb8c2f9c871134ae50b004dc7ceded9c55f9f80341e970c6b94f675a65340233a4db515a245609dfecb45a7be51e171046af9d9211bd8931c6e131a4674d62d875d3de3e34d7b442eff7e38c94a7f3f0458f5e95d3ba285ebe55a68c16ee8a6682efa3311b7672ed20bad2aae53d5aea8a95d35bd77cd98a6c640664b790006c43cb9a1cd590b3fb85fab76137ff51116e30ee6f93cda4d51c89cf6634c3f4416c53886c3cf18f423b62b6f18c312d96735972caff261c632bdfeab04a3069b6b810203010001',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,'Q718MWCCRPNXXQNQ32500MHJAAA5J1EHTCVPBQHY0HF7JH7ASN7G',1660654502639,'payto://iban/SANDBOXX/DE886824?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-1660654491119','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343439313131393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35312e31313934375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35312e31313934375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(2,1,'sandbox-1660654493458','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343439333435383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35332e3435383734345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35332e3435383734345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(3,1,'sandbox-1660654495702','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343439353730323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35352e37303230315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35352e37303230315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(4,1,'sandbox-1660654497922','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343439373932323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35372e3932323939335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35343a35372e3932323939335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(5,1,'sandbox-1660654500124','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343530303132343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30302e3132343634325a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30302e3132343634325a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(6,1,'sandbox-1660654502367','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343530323336373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30322e3336373834395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30322e3336373834395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(7,1,'sandbox-1660654504718','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343530343731383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30342e3731383831395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30342e3731383831395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(8,1,'sandbox-1660654506934','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343530363933343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30362e39333435355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30362e39333435355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(9,1,'sandbox-1660654509109','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343530393130393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30392e3130393531345a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a30392e3130393531345a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(10,1,'sandbox-1660654511286','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343531313238363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31312e3238363630315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31312e3238363630315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(11,1,'sandbox-1660654513449','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343531333434393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31332e3434393830315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31332e3434393830315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(12,1,'sandbox-1660654515625','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343531353632353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31352e3632353532395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31352e3632353532395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(13,1,'sandbox-1660654517784','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343531373738343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31372e3738343536365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31372e3738343536365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(14,1,'sandbox-1660654519946','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343531393934363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31392e3934363334385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a31392e3934363334385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(15,1,'sandbox-1660654522116','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343532323131363c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32322e3131363633395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32322e3131363633395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(16,1,'sandbox-1660654524281','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343532343238313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32342e3238313231395a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32342e3238313231395a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(17,1,'sandbox-1660654526439','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343532363433393c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32362e34333931375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32362e34333931375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(18,1,'sandbox-1660654528605','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343532383630353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32382e3630353734365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a32382e3630353734365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(19,1,'sandbox-1660654530742','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343533303734323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33302e3734323234355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33302e3734323234355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(20,1,'sandbox-1660654532887','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343533323838373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33322e3838373133355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33322e3838373133355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(21,1,'sandbox-1660654535025','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343533353032353c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33352e3032353732375a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33352e3032353732375a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(22,1,'sandbox-1660654537168','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343533373136383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33372e3136383635315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33372e3136383635315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(23,1,'sandbox-1660654539337','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343533393333373c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33392e3333373034315a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a33392e3333373034315a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(24,1,'sandbox-1660654541474','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343534313437343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34312e3437343435355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34312e3437343435355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(25,1,'sandbox-1660654543623','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343534333632333c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34332e36323339355a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34332e36323339355a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(26,1,'sandbox-1660654545752','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343534353735323c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34352e3735323639365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34352e3735323639365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(27,1,'sandbox-1660654547891','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343534373839313c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34372e3839313539365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a34372e3839313539365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(28,1,'sandbox-1660654550024','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343535303032343c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35302e3032343431365a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35302e3032343431365a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(29,1,'sandbox-1660654552168','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343535323136383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35322e3136383730385a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35322e3136383730385a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',0);
-INSERT INTO NexusBankMessages VALUES(30,1,'sandbox-1660654554308','C52',X'3c3f786d6c2076657273696f6e3d22312e302220656e636f64696e673d225554462d3822207374616e64616c6f6e653d22796573223f3e0a3c446f63756d656e7420786d6c6e733d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322220786d6c6e733a7873693d22687474703a2f2f7777772e77332e6f72672f323030312f584d4c536368656d612d696e7374616e636522207873693a736368656d614c6f636174696f6e3d2275726e3a69736f3a7374643a69736f3a32303032323a746563683a7873643a63616d742e3035322e3030312e30322063616d742e3035322e3030312e30322e787364223e0a20203c426b546f4373746d72416363745270743e0a202020203c4772704864723e0a2020202020203c4d736749643e73616e64626f782d313636303635343535343330383c2f4d736749643e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35342e3330383033335a3c2f4372654474546d3e0a202020203c2f4772704864723e0a202020203c5270743e0a2020202020203c49643e303c2f49643e0a2020202020203c456c6374726e635365714e623e303c2f456c6374726e635365714e623e0a2020202020203c4c676c5365714e623e303c2f4c676c5365714e623e0a2020202020203c4372654474546d3e323032322d30382d31365431323a35353a35342e3330383033335a3c2f4372654474546d3e0a2020202020203c416363743e0a20202020202020203c49643e0a202020202020202020203c4942414e3e44453837303134393c2f4942414e3e0a20202020202020203c2f49643e0a20202020202020203c4363793e544553544b55444f533c2f4363793e0a20202020202020203c4f776e723e0a202020202020202020203c4e6d3e44656269746f722f4f776e6572204e616d653c2f4e6d3e0a20202020202020203c2f4f776e723e0a20202020202020203c537663723e0a202020202020202020203c46696e496e73746e49643e0a2020202020202020202020203c4e6d3e4c6962657566696e2042616e6b3c2f4e6d3e0a2020202020202020202020203c4f7468723e0a20202020202020202020202020203c49643e303c2f49643e0a20202020202020202020202020203c497373723e58593c2f497373723e0a2020202020202020202020203c2f4f7468723e0a202020202020202020203c2f46696e496e73746e49643e0a20202020202020203c2f537663723e0a2020202020203c2f416363743e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e505243443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e303c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c42616c3e0a20202020202020203c54703e0a202020202020202020203c43644f7250727472793e0a2020202020202020202020203c43643e434c42443c2f43643e0a202020202020202020203c2f43644f7250727472793e0a20202020202020203c2f54703e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f44743e0a2020202020203c2f42616c3e0a2020202020203c4e7472793e0a20202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020203c436474446274496e643e435244543c2f436474446274496e643e0a20202020202020203c5374733e424f4f4b3c2f5374733e0a20202020202020203c426f6f6b6744743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f426f6f6b6744743e0a20202020202020203c56616c44743e0a202020202020202020203c44743e323032322d30382d31365a3c2f44743e0a20202020202020203c2f56616c44743e0a20202020202020203c41636374537663725265663e46555344575448333c2f41636374537663725265663e0a20202020202020203c426b547843643e0a202020202020202020203c446f6d6e3e0a2020202020202020202020203c43643e504d4e543c2f43643e0a2020202020202020202020203c466d6c793e0a20202020202020202020202020203c43643e494344543c2f43643e0a20202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a2020202020202020202020203c2f466d6c793e0a202020202020202020203c2f446f6d6e3e0a202020202020202020203c50727472793e0a2020202020202020202020203c43643e303c2f43643e0a2020202020202020202020203c497373723e58593c2f497373723e0a202020202020202020203c2f50727472793e0a20202020202020203c2f426b547843643e0a20202020202020203c4e74727944746c733e0a202020202020202020203c547844746c733e0a2020202020202020202020203c526566733e0a20202020202020202020202020203c4d736749643e4e4f5450524f56494445443c2f4d736749643e0a20202020202020202020202020203c506d74496e6649643e4e4f5450524f56494445443c2f506d74496e6649643e0a20202020202020202020202020203c456e64546f456e6449643e4e4f5450524f56494445443c2f456e64546f456e6449643e0a2020202020202020202020203c2f526566733e0a2020202020202020202020203c416d7444746c733e0a20202020202020202020202020203c5478416d743e0a202020202020202020202020202020203c416d74204363793d22544553544b55444f53223e383c2f416d743e0a20202020202020202020202020203c2f5478416d743e0a2020202020202020202020203c2f416d7444746c733e0a2020202020202020202020203c426b547843643e0a20202020202020202020202020203c446f6d6e3e0a202020202020202020202020202020203c43643e504d4e543c2f43643e0a202020202020202020202020202020203c466d6c793e0a2020202020202020202020202020202020203c43643e494344543c2f43643e0a2020202020202020202020202020202020203c537562466d6c7943643e455343543c2f537562466d6c7943643e0a202020202020202020202020202020203c2f466d6c793e0a20202020202020202020202020203c2f446f6d6e3e0a20202020202020202020202020203c50727472793e0a202020202020202020202020202020203c43643e303c2f43643e0a202020202020202020202020202020203c497373723e58593c2f497373723e0a20202020202020202020202020203c2f50727472793e0a2020202020202020202020203c2f426b547843643e0a2020202020202020202020203c526c746450746965733e0a20202020202020202020202020203c446274723e0a202020202020202020202020202020203c4e6d3e4e616d6520756e6b6e6f776e3c2f4e6d3e0a20202020202020202020202020203c2f446274723e0a20202020202020202020202020203c44627472416363743e0a202020202020202020202020202020203c49643e0a2020202020202020202020202020202020203c4942414e3e44453838363832343c2f4942414e3e0a202020202020202020202020202020203c2f49643e0a20202020202020202020202020203c2f44627472416363743e0a2020202020202020202020203c2f526c746450746965733e0a2020202020202020202020203c526c7464416774733e0a20202020202020202020202020203c446274724167743e0a202020202020202020202020202020203c46696e496e73746e49643e0a2020202020202020202020202020202020203c4249433e53414e44424f58583c2f4249433e0a202020202020202020202020202020203c2f46696e496e73746e49643e0a20202020202020202020202020203c2f446274724167743e0a2020202020202020202020203c2f526c7464416774733e0a2020202020202020202020203c526d74496e663e0a20202020202020202020202020203c55737472643e513731384d57434352504e5858514e5133323530304d484a414141354a3145485443565042514859304846374a483741534e37473c2f55737472643e0a2020202020202020202020203c2f526d74496e663e0a202020202020202020203c2f547844746c733e0a20202020202020203c2f4e74727944746c733e0a2020202020203c2f4e7472793e0a202020203c2f5270743e0a20203c2f426b546f4373746d72416363745270743e0a3c2f446f63756d656e743e',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,'DE870149','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 5bdeeca09..000000000
--- a/src/auditor/revoke-basedb.age
+++ /dev/null
@@ -1 +0,0 @@
-1660654556
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 4a9e784de..000000000
--- a/src/auditor/revoke-basedb.mpub
+++ /dev/null
@@ -1 +0,0 @@
-31R45JTGD05G4DMD0HQSDVJ4NBMQSVFBCMBFVV52YK9J4C4MC9ZG
diff --git a/src/auditor/revoke-basedb.sql b/src/auditor/revoke-basedb.sql
deleted file mode 100644
index 726c55bc0..000000000
--- a/src/auditor/revoke-basedb.sql
+++ /dev/null
@@ -1,15920 +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)'
- ',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'
- ') %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, bigint); 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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;
- 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;
- 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;
- RETURN;
- END IF;
-
- -- "success"
- out_conflict=FALSE;
- RETURN;
-END IF;
-out_conflict=FALSE;
-
-ASSERT NOT my_finished, 'internal invariant failed';
-
-
--- Initialize reserve, if not yet exists.
-INSERT INTO reserves
- (reserve_pub
- ,expiration_date
- ,gc_date)
- VALUES
- (in_reserve_pub
- ,in_expiration_date
- ,in_expiration_date)
- ON CONFLICT DO NOTHING;
-
-
-
-
--- 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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_expiration_date bigint, OUT out_no_partner boolean, OUT out_no_balance 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); 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, OUT out_no_funds 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_reserve=FALSE;
- out_no_funds=FALSE;
- RETURN;
- END IF;
-
- -- "success"
- out_conflict=FALSE;
- out_no_funds=FALSE;
- out_no_reserve=FALSE;
- RETURN;
-END IF;
-out_conflict=FALSE;
-
-PERFORM
- FROM exchange.reserves
- WHERE reserve_pub=in_reserve_pub;
-
-IF NOT FOUND
-THEN
- out_no_reserve=TRUE;
- out_no_funds=TRUE;
- RETURN;
-END IF;
-out_no_reserve=FALSE;
-
-IF (in_reserve_quota)
-THEN
- -- Increment active purses per reserve (and check this is allowed)
- UPDATE reserves
- SET purses_active=purses_active+1
- 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
- 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, OUT out_no_funds 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, OUT out_no_funds 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: 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 integer 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,
- 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.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,
- 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,
- 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: 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,
- 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-16 14:54:34.489951+02 grothoff {} {}
-merchant-0001 2022-08-16 14:54:35.567276+02 grothoff {} {}
-merchant-0002 2022-08-16 14:54:35.998201+02 grothoff {} {}
-auditor-0001 2022-08-16 14:54:36.138069+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;
-\\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f 1660654489000000 1667912089000000 1670331289000000 \\xc32561194b4b6682cb7029e149cb59c85de1968e440502f57040754b2a678892 \\x7264213ac164de65e186b021d57d7cb94ec27245ce25c0caf460ff9dad3463d213f644235699fd4cd0a4150f5f3d92c99da5d6d4d873ae93dac4407775bb6d03
-\.
-
-
---
--- Data for Name: auditor_exchanges; Type: TABLE DATA; Schema: auditor; Owner: -
---
-
-COPY auditor.auditor_exchanges (master_pub, exchange_url) FROM stdin;
-\\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f 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;
-\\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f 1 \\x00cdc96040fdb55b71f39af7132cb8d53a818197207e1160a403edf2de1588e579dd07e454b85706ec6df8f07fcfe773dfc1a5861f8eaa7b90e20ada26986c50 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x4e5560fd6aaedc6a128debf56db7f43664b46eaf7a1707c518d899179a3d7cd4d3c7da4e984a05978144f9d14943fa4a1ededd44e4be39ef34a1d81afea70050 1660654520000000 1660655418000000 1660655418000000 0 98000000 \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x81494bb48a83f0f03d5d0c86d1e6cae6b2b3713275415be99e113d1ff4eadfe4529cc7fc87e739ab13f1e0c9f0d1b8c709dcbe5b11bbc0f2626a5e8ce6d4a202 \\xc32561194b4b6682cb7029e149cb59c85de1968e440502f57040754b2a678892 \\x40127465ff7f00001da97e72d85500002d291374d85500008a281374d855000070281374d855000074281374d8550000c0b11374d85500000000000000000000
-\\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f 2 \\xc322b4ebdf16614d1c5a72ba91989486cda1e26b02ef26d105f71bd952f2f22b9f798dab19b98bf191c662338f571a6c295caf24ef961390262b67f697a5c7c7 \\x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 \\x4e5560fd6aaedc6a128debf56db7f43664b46eaf7a1707c518d899179a3d7cd4d3c7da4e984a05978144f9d14943fa4a1ededd44e4be39ef34a1d81afea70050 1661259354000000 1660655450000000 1660655450000000 0 0 \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x585af5eda8b3f8b06ba72dac11f599f6cdeb4996814c59096b018dfff955571aa2bb3366c4fdf4a92e56b9f97f92db2483d5b6ecae4b8eec1e4d4a767147b20d \\xc32561194b4b6682cb7029e149cb59c85de1968e440502f57040754b2a678892 \\x40127465ff7f00001da97e72d85500008d591474d8550000ea581474d8550000d0581474d8550000d4581474d855000070281374d85500000000000000000000
-\.
-
-
---
--- 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 53 \\x4c4f77bc94921b6d4b36416bb72f48dfd007196cbf7f63789aea562be867b0293e3e7e1f0675044bd9030822e1067e090224e832ee753138312dbbac853ec208
-2 1 188 \\xb6419a9217afb165fe8d76551f1ff6126ca7e9ac1f35a3f750faafa32047e896ad3c76965d6ee186f087b06d3e9983c52210bd59dbbee3b7983c8d403ab83a09
-3 1 235 \\xe7970f69f7de28f1d40d4316ca7e93e6d4ce7d658cb6f67ac7fd32957790c9c603439e5f4bf6e9c0e6e2e23640069eb85ef59b0fb691cb09e47d6df48cff670d
-4 1 73 \\xdc72947120cb534440d4a71fc7ecf9ebb81124854e6744cad13dd758ac432e23dc1dd2816b357eaf254925ede3d0fca309a038a02ee5e5f96109ebdd9b806d0c
-5 1 122 \\x39d00248c92e8934de06e2841255bd40d1d5648a26f8190168edc1280a8ed9a580caefd42a970ba39a429f7ab51ea4eef1d384a4e8e499c643261e1953532605
-6 1 130 \\x2967414d578a310e89baf62c9f93090580676f7be2af9e1a0c890d2f99d6d723abc7ad0f7bfc2c53c9dd888fa867ffd94ec1598b7225af55cd528e56eacb7701
-7 1 154 \\x1012cad01868c8c7b91e2f0de7909fc3319cf7634a73b29b777d04ee1dca4134297a31e8cb06d7dfefdd23bea3f7817d928b1ab21642ae3cd002f0fc9cac0105
-8 1 307 \\x654bf2a169b5e7965fdd31d535c554dbf75bb0d6b61a20f51aed8357c52789945ac5e9f5727d461b0c34864db06e56d9ddb32650b92f99361ea198c3d92cb80a
-9 1 146 \\x9d355ac4fc8efeaf4208a9be9fc3ca3a2c14cad52ce7109e5175ce895464e26768456c32c6efa867ad9e17a574d703b17568ad2c964d4e65accdab6fe356c301
-10 1 60 \\x67424679473907702e34a0cfea23136922232479fe6b4a3c5c63c197288061452f5c49ad0a537e460f600bc43b8b5d8eee9663b343a3a8dee56c576747f7b80a
-11 1 99 \\x96f4345f54791d1720fa24537b0e4b93afb2f4bc1efd112942c6e4a23ff248438322e581eed26ec14ee54e883b8b149bf6c34376affdf0d57d2ae24c961de20c
-12 1 300 \\x16f42ac5697c7e7a3a763b37b83b1ed18c75e5fc1ddd74b34a980e7b115f41602130c2d427aa9fc3d7e418ece1f8c9ebd1e2ebccca3392ab7a672fc7dad02d0b
-13 1 128 \\x42bf41de89ee5164e903f8de18d9fd40884c3be360b843903485d67cf5334c0b273fa6570339105a121e87347c47b6c467169ce80ecf6e3e36e8b476c8735201
-14 1 416 \\x2f1dd914dd3c5126560285df5424a54205a16d2c129b67b7988f77a74fe703cb01d0e87fb7f0838680924ee3c67543e61481070277455d21576e6d548f0ae30f
-15 1 219 \\x593d58832520a809470a273dcbab695bee86005c06ddff6c5cf3d3f5cbf2d5e59a5f4799de25380e64ea1d6e18bb6020e71274125c8aea4757e60f7ca2bf8e00
-16 1 4 \\xf64d60cb74156f70eaa610e187d9a0726bed94f65bef058384fc7c81f9d0ad63b0faf148ecabb89f3584de95492b22b86dc1dadc7963ae866f05dd2b5dff9701
-17 1 313 \\xdbea3d147468a1a416e870e16c862734ed7e18b4b8158784e9aa863adb6724f407e1d7bdc074f236de7e9cf69f3944e974fac1b60577b313ce5f735647f0cb08
-18 1 380 \\x2f467fbbd6cd022505f62dcffbfe5b19393c441fc99f948e2eb51d56ef0b35ca3cb35cbedcd2881d94b8a545b7f71889d5d9f72da14cf447bc80e2ce8a842f08
-19 1 79 \\x276b7a10386f95f5866b09ae341d558e8d1e19665cae8aa89f80b0b0f59c76b0c9b057b60e3306ab2a9b5cf4aba33f2dde043db9a1dc0426f24f881bdc38d90b
-20 1 327 \\x3d6fdce891597b9a9fc0fe661b406b605859fee79b6b9302cb59e6d9441e68e35f9c02e94e76d42eb57e54142290fdb1fa4955ad107896863e50cb7d65d90d08
-21 1 408 \\x349a338eb7fc190c674bf7286fef803df4f15c4b31ebc5fd0a940e37e9391aeb2d5d4a47954787763d45ccab0aa345fb7ef94647a5492576e40650e85a682408
-22 1 202 \\x2279ef08f36b417d8d0955a3826ec744f7e2d6a88f574d3af09a9605d808bfa7fc8d2d315eafb51f00d61d082b069dbe361c367c1abc5a44f4ceefdc65e2440d
-23 1 245 \\xcdb357bfaecf3998ff7d2d3df31dd34b14f08424a29c91f51ee4e29497a02b9ef79bca598e5bf0fc93c67554f986fd45bad43bb3ec3511fb5dbb6eb8bc31a108
-24 1 279 \\xe0b14ef36ccab98640fe28f943d21828ae3b6de38f9a2b89de5f6cf05f31c316c1c94ed9a2ccb768991f5a38b9818d57748eda2f8f2631425fbbafd9afd5b307
-25 1 240 \\xa3c6c052e2f7c574bc49518df2c6d74991cce6b4c4dc6e574dc88402ec44220206bd7d094632f487c65959967263f7581a923ca8ebd50c61c04853c04be6f405
-26 1 326 \\xe94a30ac6b4c505aafc8bdfaa31e789ce2824685fa84c9c3ea950d33d5b15e0e987fa75c4e400b2f7cf4856d36d78344c14d343ceeb583b32da562150a23940d
-27 1 120 \\xaedae874a778212dfdcf9623df4c95e272a014d665385dccb9876bfa0b1443125dde124a18373210ca436a373d9176a8c246bb1dc3faa89536460bab2d5a9f00
-28 1 54 \\xce340e000f547e4c759f61ce610448a89a7da414475188b9dc7d4e8454e8dd3ae95d57a50b28188a06f5b7d7a44bb7ea59669a20644b5e1213670f8ac1b60109
-29 1 320 \\x8fbcbc8bc2dd02b8e92ab91caa5596bf5fdb651fc5cccdf0f9e0899e890696d28133fd631dc7623c0a368331d9af508efb13ecfb2cc4dc91c3a70b1c2e264b09
-30 1 177 \\x1cf7a4eac1c7228eb8dd3cc965cf1d05819d8926804eac0c3f3b16fd9250e7a789a1f06e5932bf25142ef5833082adc1e73d5ac1d66a156ab3d216c5da39960d
-31 1 321 \\x4f6c3912947eeeed495fe987b06105c9a0b340c057a641f1fb57e0dde3e45d29479d4bf695aadd70264bb4c7829c472fd8a27c2ae48e40ac7ef304fcc66b0305
-32 1 115 \\xcb6c9729de7ceee55dc89109819074dff030a7adaf7b7ab17d3a2643d03107d3b87c1c79ba39ca8f8e0b68df55e6ad787cdac07936de27cf262d170bf5fcc007
-33 1 26 \\x4038511d6aa4f3c9f3a69f0360078fd0b2becec0ec798a39b2e47718255e6c9d7f94a9f8e2bb4d7ed5047e7639a690bd78c09dfdee87eca03cbcc1adea9ffb03
-34 1 399 \\x1d9a5a34180426b9dae75de5ea716879dc57fc29e1e6e4ee7439d7f6cb7fd44cadc869d91844fa010ed1a90cd3a6f2d5415cbabfc97016fddeb7e8d8e8e79a0b
-35 1 220 \\x07803f3a6e3c1c17ed00652bfccdcedfe847d8bf3bc081b9db90821339212a4b60b62734a658a5481f4ba46aa6d7081d6d77316d4ef515e051e4a9aa2f025d0b
-36 1 232 \\xbfbf2c5952bba44e00712dd8ccf5f974c5bc05d7f2d1598bd8329541fdc3ce2040d9a4d2485553fc5c0278e3f16057a4ccc5fe90e610519a7b4392b2911bbf03
-37 1 342 \\x67d065c8d9b9ed9a5831e7dd295a679788afcd0389773acf8ba60b02b5716549b4d33fa45fa52e006e53c1f5f972bc6bb1def854f2881bdd3d7badef56271606
-38 1 273 \\xc3ac2d95d054e45a18c6130d7c16f6820ee0a2defac14cec580fb0c92a4d86b941bb2bc890133f91db05f63c13754121f749ac9c38a310e7945b8e7b30ebfc03
-39 1 347 \\x29e5cdc40c5187d4ff3cfbeda899c1a1a04f68fe7c3d19c69ac66972f3dfb1dfa1df096b0347b5919b71d0ef7be7ace81791325468bf4a713b26118a29d0a803
-40 1 190 \\x6329fe5316b2c7650c0c4853750c3bad50726202e57bec8080600ea4498efdfe457703ca58369a159ddf2627f02e9774580a1f379be59c41d2fbb5650ba61602
-41 1 324 \\xf841d341f796fc34470ee2a7225445e976df4a244b9919eeef2904f5f9029cefbe3e42d961c3382b78a678c079eb8aa20f542a6e5eec6ba2876a9a9976e0320f
-42 1 82 \\xf342abfe1464e4942082686ca5e1ffe6138bfc142e609656c54f4abd509cbcaf23c6a47bbdcb3b5afd7e4292ad6448dfb74e9e7e372828bfbea079e5ba4b4504
-43 1 422 \\x995ccac775d53f8d53bce5c991cbf08f5b1123a0042d67301e0d9790c263ff0b3a8cc6e138f1320ea7361f4a9a90d9347f88734b885ee2188d9042d6dde1040a
-44 1 216 \\xfa141b8f45f6d5fe3ffec005978b1f381d21d90f45a4068d06a92278106e9a585b934d36d6fa7987255e3c006f2023e6a88a5076491a220e02926d266a457d07
-45 1 78 \\xc15565ba53a0e7bb2e91dac46d91936528ef8a3cac9931f0093f87db0a587cbd03a9b98102d68757dbc192a41dc434acde771eebadfa2815ba09f93e52e2bc0d
-46 1 392 \\x008f28ca38e33cd5d3aa0258995817e81f86425e58eb16eaa034fca1aa62456c5aefceb4c261549ff22b88e689d42ccf62f6d6878de08cc3a7233cb08bf73909
-47 1 49 \\x3486460fa6bd6fe8d4f6d2fdb7f5e151728283581e679ed255602b42e9abf59591c2cc0da4c8a6184b2ebd2e562d22c775d60d060f5afb6438e6f9537922c604
-48 1 40 \\x584e06f1accaeb58a066f2a90d5decc1f1d490ad5c05412b9b3f8eace0f20f44438381b4d903461534e7d25577779af7edd7eb6f9888e10ab3645d4e14c82c06
-49 1 226 \\x4316f7530852e995d2b5c13d0ba622e896844c8afcb95d7e8af2725437d3a615f548fd06839d2d3ebe388e498b6346e63513021331fcb73c15415e3bac576503
-50 1 83 \\xa21f993cc7bd4008aef4087be2672cee4124d9715248485d8401684ad67787a68e3cc38e0d901f38cafb6e82edfaa87bf29a0556e23e8d6edeba2bd2102cc10f
-51 1 401 \\xe63ddaf736a36a789304a0d68a7255186efd69673e6c370d48dde41cbb1fd919de83c439f807041e046848dfc1a5c8a726716a2a0ff829cf6f791a0ff21b570b
-52 1 277 \\x160a21896f8f0fbce1b290f4d8ff267e14168a3381c0fb0c9f085efdbc0dbeca931c1eb7ed5656c9160e4c50dd087b69dd106439bb1b36ee9ae10a4f34fed70c
-53 1 368 \\x9e14262a6f3422e73988901c7773e473fe050bdd5628a91fdd235ec551b8e28e0062ef8fe05d0f85e529fd9592298988b69ea7ac4e513d063a5bca1ed207bf0e
-54 1 251 \\x6bcbc2a74959e206fbe0a2ac9589e2cabd54b931fd3bddf86124da39f6ce0aaa44372e25d307c57d64a6c0b9f54afb36877d20c955869980251e03aeed24140c
-55 1 227 \\x221806fa78b3a4f8a1ad493e5adba82dd360ee088bdbebd60e700ec7f0391ca88db3f98788e468cec702113b3587a27a17d24322d3c40edd5134da431a044c03
-56 1 389 \\x3d473ff8d748547b2db5fc6299773f411fe90ac869520dc6668fb4f99db3c8b80538db0298825954e5d99005d3610bdf0a3b1d54c966b40d2b6ffcfa5dd4fa0f
-57 1 27 \\xa12f3fa362efc945c2c302fb54bfead972ce51d61cfd46985d9630cc18e4ce1aa3170f5e014dbab715027ed55faeb0e56eeed7f614f02f38fcecd062b380190f
-58 1 248 \\xe02ecbbdb0b07c82c33697c181c53e30f858e131255ee431a6c1693f71fad142e63328b825307a5a12b33a6e6a1431b85e75d6e0e8e2f61f1b1e1002398c8c02
-59 1 335 \\xcadcb708d07d74515f9b709f0fcb60575edaf72bce1e30a41c93e283df5a95544de6a416f76b8133942103f2461c1c561e8f48dbb8e4b3c99ad15a64b5259701
-60 1 413 \\x7200f8972ad6788a49ab9677fb07accce3312a1ca909d2aaccdfd5affcf7fae86be85bcaa997f97f2fca5fac6c5a1472cc75514676a2a9080e3b1c3f46347706
-61 1 58 \\x1224fb4812c96f4bc3c92642fcf6cad284f5987fc601bfb5a70bbc358c0ac022849778e9fde647ef16d1a492bffeafb04590a5db081ffa16067960a09b28b20c
-62 1 168 \\xa96ff1920490b887c52f8bd36b9db5e948846633da517e362387260d3ebe6f5bf3eead0c5fef0f86374c39b64370a59bc82299fa65990a0de3d6a8263e97db01
-63 1 97 \\xedac6d7b2477b0d548d8ece9c193940ff84774380967f5f7b271ee86405b9aa539da2097eb7fff97ef4bf04155e238e38030576817e25ef19fc6eb121b036a08
-64 1 370 \\xa45dbc3a983df1cab301fb251003b08ed7773a46fcdd59232b52b63ad1156e348376daa6b6d38276a8f5b490bb4790d569fbc88588e59690583ec43566f4ba0d
-65 1 31 \\x7ee4d20dd710b4006c7b24d6ac515982f6aaf1c54632a0f66bdd607da047e3a893f910b83ed4cfa3b127fce28e37624d4701c2dc1ff05991926752ddc631d907
-66 1 7 \\x7801e1e0f11e76b38beb091b2e190d39c6b78582b85d82f23b8f60ea7fa8aca4feb88103a56450bab391557eaa1da69b91e0a6762cefc30bee2619e0da8ddb04
-67 1 199 \\x1a3a5364d6174cac29cc427163d0037e6ee5c0e70215dde3f43b67eba902412a648cf90875021de6270362c02f7331f7ec737792dd78de49d6237b1be06d4607
-68 1 252 \\x5b1509ba91769b682ee5880a1932bb9e3955f3a9b3d64ac9c087690a7c850ec842ce2e4c9e4806f9544366721a41544b4867b951b289288d4526b00675a09501
-69 1 209 \\x71cebb36bad4638ac9c625187c87ffd997bc3d23753f461d1cc9b226f6385ed9006fa1c2f80297bfd10c49ef02cd4f03456d5eae11686051de2c96c07a496203
-70 1 253 \\x142c81663bdc42ef08485e86a284d00c763acb3ed808a98d83f903acb07145af7de5f08406fceebec59439a3f7659c0bc1a236fa2853fd134abed9507e3f2905
-71 1 341 \\x8caf5253319635284cdfdd5bc295f1aa15eaa47e809997f294f4f69b64a98ac55f1d3dd6ac8780fbf15e1a550d73e7947cb0632c455873b8ddc4cf566500e206
-72 1 156 \\xf85a84fdb46a631f2fbda5e287fdf1fc2fceead3320ad5e7d3001be0587051a02803b0d05c597d3f81401e79f0f1e9f5010f348e19c440f6936f8600e297a20d
-73 1 96 \\x8c94b0a326365f591b9dd0082ba20da105f691ae6ebaa506ea40130187c242e21f48c751dfcc7901bf71ec9c4171849930fd11a1c1725b43713028deb0200002
-74 1 424 \\x2406f4e30d5bad7516c4c9e685784b279986e9b19e193a4b3ddb09dd6899066c1f03013e7dd808c787462cf8b5b845b9704858d06c09207e5d7e908e79841d07
-75 1 237 \\xd0e062fce024ee2820f3b0900b623c7e0d5c6e25eb47a80ce3dfed57477c6b3eb969e64dea8ed91002208b34627bcd2433cbab3252c5fcdf667b9b0733c7890b
-76 1 403 \\x1b72f2976e9f4519c58bd82e6619f37221c9bd9eba167141e901e2010911fedd266ec77fb2be2e161f99f82de3b2e2ca7ff765416ea1bc2b785cac31816ded01
-77 1 244 \\x59aa6351b5e5d0d955ddc6c3ba7c75ec58ec027b263782be8d24f145714434ff3ec568f088182e9367e8ae94edab7eea7d3162569bdc22ad45fefbf0b6abf10d
-78 1 121 \\x55e1a80f3ac48beb4f9a0b1630f70045ebddd2fef99ff83d84df7ac3e474e70b200803642eb1631916105f16cd3aa5dc0401e62fd44fee31b5247bc6a292d904
-79 1 161 \\x5fd281225cf0e00440aaafe826435492b2aeaaf056be0f10c0a782aeb98da00693b9a50a0c4e68636b6dd8057b15cf9c31054e3deacc15c90ef3d681297e3f02
-80 1 387 \\x7f8fd658e4258a322731080a904293f391114716fea8ec9c1717301724e7afa2d35df99534e0e00ace0611373410eaba1a40963b3749f469c54183299e2dbe01
-81 1 28 \\x1ef888175ce54df70a33c67ce6f94faaa8d1fcf22e7abefe2abc9c81dc17f6ab7ea6d6201c7a40aae85fd0ff7e6acef7eb200290afbf81eb028bb24b6f8fe404
-82 1 283 \\x4060596f3cbb4a2d3cbceb620e975b37ae03ea8ce5f3d7b4e3c933e9502f4767ab4abe20bc3a19ba847f30fc9c5421322a781b930a63eb5bceefdf7fc2384e0e
-83 1 288 \\xeb8780b1d57cd86303db8ef431954ec7c36ee32d13813c300d3bf2965124c99096dc51743d2590d4f555cd4ea1b9221a73d52fccd9e5ac94ebf96f16240c700e
-84 1 308 \\x1c9eab03ab01761143685e08d50f1bae610fc5dd5a9a34a6fb14b4e31b0a328a3dcd2d10f4ffdbec3ca2f9932c8c87ae0db2d1f8adce58e9d8815ba75e326108
-85 1 317 \\x643a4c6a4cf8f5732251b1f4a4848d7b948f57d453302856738e0d375f5ab1ca9c4018e63f4625d759114581225e0bce63e609b33403ebdbcead2c80f887cb09
-86 1 345 \\xa22038d0db05aa0148f35b9970d8fa6b4f84ba34021f8c21ae2a76ca095f140ab3de3858e85f2a02fbe904d72a40acd8caf8a609221579aae8f7c95ccd381105
-87 1 359 \\x3768baa99a696860a732e12b2b11751ea1d0729600ae9cfdbafbc1d73bad27902f3907c753c4690a46a4d4c6979b47a7ecdb66218beb04f2aad4690d4514b90a
-88 1 101 \\xb02bea281314a37fab55142c8525cd1dc48c8dc6555dd298ef3620f2ec0b96d432db905c8a03316a7f0f03df7693fa78b74e49bbb7e1e9d103caceed0eb60409
-89 1 390 \\x72064e7f772c743fe9ddf40912cabfe14fd6ffc49c47d899c8f80702405447fbc808ac13581316c342492ad31c3e5af16f288d51d2faebd2c9a11c5dbf3b2309
-90 1 2 \\x6c1e484b628aa6b988a146228e60e824ccb3f240b5a311c846368924a1f8b30a6d0db4aba9781c8f4f7d2ddf52cc943494472bf4fb6038cfcbb56a0118a0ff0c
-91 1 1 \\x2f40cf862fed49ac7dcabd9d117a55cc5d749adec51cf27eb49738e801533593a8c8b6e7aa76134c1949a900db730065b39f957c7793e28f11c87a468a40de06
-92 1 222 \\xdfc499b44904144c942818ad52a5d12d70d6a92192879c1aa0d884001b5c39e38cb43a3b026c480c56648e7c965ce9940351eb463e79cd75782a6fd7b92e2507
-93 1 211 \\x4a5219beb499f156dd2590ad7adff27e0adc3ba9add5850a4a24468b57fc921532ea54b5ac74c344eb7135a0fbd3ff37b644a3ef6bd82c6c9f4b90b46fa45706
-94 1 19 \\x0e804d1e76186a649d32c42c7c60b975c632489ead28a276fd90ca15b785d123c67cf456f78b0a817559490d5aaa5d8ad14c49b326cb2a344b10b0638503ce06
-95 1 257 \\x24343877fa13abea9143f65ff1dbf42dd43255151ddd46dae6cba21c2364ba4906169fae96d31972883b33e3e5342ef8d9b290fe487196d39d0c00224a0c3b0d
-96 1 155 \\xa3af41ce2ffe8236d49be56a47190686a560c5f3259fd56bfd679f2ea1c43070a4d820ff198a4658c4ff9b493447b96d21281e327bf7572eba6ef39ffe995e0b
-97 1 131 \\x44797f1b787b7e23998ce6cfe0595a622df6effd0545ac39bd47740e986b50de02ccfc3729e19f4406ca660fa26c7f3d0d03c9cff4db0a39043c107d4ddc0a0e
-98 1 136 \\x95e87561c022a87fc82cb48a2d0bec7102e4b9965506edf4cddedcec04ee1e173a3564ec3e90afdb2da8e202b658fbf9135ef2da1585157472334e16bd756904
-99 1 103 \\xc42651ef5e18df07c1765293615e95b0e4865d2a13bf6b2f0527ca0345589001d977b08d55cd674fd566fefd27e9eb72d5953c6d688c9e43f45c6385c05aac0e
-100 1 289 \\x8d489996740e4bf2e78d89384e4e232636ed23d1103f76843f585c22e65920738964f6d8dac1e9f9e5b8b0d6f287a73831a22587bccd519e1e25360ec3a1ea0f
-101 1 296 \\x271d574284da0078754310cd4c9d23d030f55e59e41bb47d8b30a183e88f64619a7e78835dd76c1ba48e32c29c271fa6ad1d861f73fe7677b9a31f7d7def7208
-102 1 105 \\x85a82168db0e3e9926508663031b50b0dd82068a105e4d8f4a14d8fdd5031bc6ccef2aa7593ba2754b2ba0ca90771dfbe3a9aa859274448b16a4561653ebdd00
-103 1 276 \\x428e46af1df1939aa83cb5edac3e7be9a595d9adba92aad47e646f2fea488153324eb33d2e3a05cbb17e915d51ec2aaacc51caff5720cac4a9b1ca8d703a0109
-104 1 64 \\x8c43de44a9286b845b14399770672c44d8d4f0248c2df89c79e4bbe827ce9b70a3960fa8709a0ad740b42a9a7a91e56c0735a26c8e2c65a2448a44e3903a1a0c
-105 1 46 \\x527fd5d3d6ea0903d2a5df4c7a4bd07c0adb051b3f4da063f553cee75aa6a701bf01e118cd3b270f00734d1737fbf84a5b514e23716ac4c83e14ce99d1b02f0e
-106 1 113 \\xd23a8413c9e1eed2dd4618c0fd6d399a5a0a7f7c0ccf110fc600e25a9a6976fdf1e7437c4994da9c306df6c43be7961025aabb379c7ca6e0ac6bf67786664608
-107 1 135 \\x9aafa37ac7f93b98f95c9a1bef53946c79ecf8d3a3b19ff8c15251d152872d9bc3dd15099717eb5ab212525801ffdc680dfeb09e56ec702e4aa70f2f48132100
-108 1 89 \\x5439f420f0b37a5f01e8f9e5528590343235c58630df74f7739615abca3d4a01a691855e70866ffb8e3477a1c9569b854f2f7e0058b7c4f2175f6eb717512707
-109 1 166 \\x520a594d262ec37021a77a248f72c2d40677c742abaf4af9b9a517436764f726fbb8486b8a72db8520adfa1fc779167ab80e5103487c20ea79f717c53b51700d
-110 1 309 \\xccfe33f46ad032f07dac333005177fca570252caaf5732fa9be8cfcdce630a0c2973fe94a37e4a88668820b4ce1429e623850fd8150e3702cfc63349d2f20e09
-111 1 129 \\x25593036580fada162e6472791fb61709201ca3434c7387afffd2e52e220ed27f53fb689bddc521b1b185d4b25dbdcae8e6cf48d7dc7beae8d3985795ff1b608
-112 1 107 \\x80e9d7ef1ba2fe62139751a71cb6b1f524dc2a6a57e18e6fc02de09ee205289a483dd567aa7f17831a33d4af79b44b78a5a790a53481ab73e6c4c66dd468a201
-113 1 92 \\x1afd24e9328b35ad9c8097cce573227883982937d5b81d06a8bfd6b8f9b93ea65ed37f2c92b226c219897385c447d4807b571e41d44f447ea8f9090346c7f805
-114 1 293 \\x0cbc513206a57f10a4b8b36808cee36f1b6477c8df31abb14c3255b41fd5438645eb5e325f8c6294850c08c301317431e4cc170d34488c49d70db159d575dd07
-115 1 59 \\x21edf8876dbb0070f9b58589bb7ffb4ce964b9e2eacf75889dbcadcf29528397eccc34109647d73bd1852a85b681a89f4b816fe6f63894625ef2d495f7cf0d06
-116 1 42 \\x1d0eaa6053d867103e202b3ba80a9136cfc2fceb8f317a2787b6d3712271beb3303fcb372929fab2b9453c87688d57784923446b7b5c45b62043ba1f0824ed0c
-117 1 303 \\xa658479802be8fcd9d0ca7f5e0f24840f9b6e9e90c5e937af1a0cb707acc1147d732fa82f243a8a8eb9fdcd03ebdd1f2a7798caee24a449f81e9f5638a0da309
-118 1 271 \\xa344792a849a45b67a73cc0e3b2b8694e1edd5fe1d823ca5dccea131b2056e0380b6a52c8d59727ef755e2c29acde5719de2629d865b2c1bd2f78c5cac12620b
-119 1 20 \\xef38c5d066d9b828b8ac1953a303ba5958d9f3620a8565d46ae84cdfb03030d902c2aeac5474c847cbc903cea2f34fb7b39c5e76e836c94b0da2ec98ebcd1008
-120 1 369 \\x5b89eb8a51b7f670f89fb00a07e26d8386bae6bca35e1db0871bb5062cda7cde8e5b222cd3874229d2e05bed2a6748b6ca870149e1181b86002b8048c09c4c0f
-121 1 132 \\x621b397884398e962a2ade46250969f7f718587971d3ad37fb35f3bf7979715b5fb01c4fc174ad7cae5177eddb69d8b32ecc01fd1ccea7da7a227c5015360a02
-122 1 119 \\x41f2297dc3b605e5fcef456298c62b8b248b7da6f5a1c72f68b509806008a85c314b14b8b90373356a79ffde310e6c61210b9dbf47db51d2f1cdc08b8ded5709
-123 1 282 \\x81b08fecbb20e800de75ac1e7dc372d8c9f12d7b235dca4de45b351f3e21ef67b341bc8188798e5bba59cf937fe780ceb21b1fa41c5848a2d4077936a65c710d
-124 1 63 \\x085671f7e1f7402c65be3ab384873b866262b53320dc661987c97a1579dfeb1caea451b86234ce0867bdbd8ec24d9ffaa75f6483c3b446baa4cada3c920a3f00
-125 1 81 \\x93e9a41c682e0bbdcfea28f05d03ae2bc3999037599678d5eb8bd0e2eae020163e8ce318949edde0afa2f7ef835cba2ee1600c117ecfbd73bec17976c912f606
-126 1 414 \\x7a727e467546420aca395c788eb720c3b422b475c40e60efaae1e05242dffc8774a9b7ba0a7a7e2e1e0f5547185008404647a9bcf591180851d409e1084f1808
-127 1 192 \\x9bc48acae4d46ae792ee3e62f04b3b178c746a43aab29b53e48935aed196cb230aafad74d19a2f3816dd09c600bbd605705e9abe1acb59181f8e0e086861fb05
-128 1 195 \\x3155b20450c21776b642cd6712f1883333aea3518d70f9ab9bbf0121293ecdf7223120cca6efb731ccac678424d8fbf11427a158a06012d1957882c11726aa09
-129 1 238 \\x68bc3baf76709f39542459d89d8c9ef5101a0b06af652fefd353955f4b4d4525694bdf20d94183877c70de5fd46fc8666cdac47f4f0146d7170ba5f4baa28705
-130 1 80 \\xcddd221abd813be052a97c92b90e93af2ebe70000d94ba828e3657123bcce88e84f810d9c64eee6933ce8226d5ea49ed8f4de303b486c7ddf5b42d74ddbd2803
-131 1 310 \\x325588970567b0afdc7668ff8681d27e47f663e3d5c62a17ff1cd4863dba06da4c5b1441bb015cfbecee0d47d7de79cadc783bf3aae798f710c21af8573b520d
-132 1 125 \\x492f9c640923c0fb8d1e18c26e9c57e6788d98d5bdbc6309da2b2b160cbbd4e9c564a2bcc99b6990decfcf3f774c5fc1517d32bc2474dbce42f6a71d60dc650c
-133 1 44 \\x339b9f4cafb6f332ec07265226dad8a5c4125aa5ba0982f658f59d8bad21e00101d43bfb77a26d4296e46a234030cb5b2d6c8d76633affcc73e47e47be7c0b08
-134 1 48 \\x191978e7413b529e4b81e64529d77520679b311c98f1a6132e407c1f4db11ce26f74eaac6949beab9b898ff8acfbdb5193a1c29322a2ce910fb358a0452a0404
-135 1 367 \\xd5996d14efc2d4eb0cfa5d6afdc66210ce46c7f98bd3d0a01e409df5163404d2d482e61748ca534e6b83581507bb65440d1a739d6d64f42bc900709b9014e90e
-136 1 410 \\xaebfd5839907d6149f7fbcb4fd7b912b971cde1467871255f5b64293bb113cc4fed2724579b9793e876f0c0eb95e9c5040b8ef19a3c1a0f8b21958be6bd81906
-137 1 360 \\x144ccbbd2dff5805033a46f063185e79386435eca2f916a2a6534db35c1ea75577e82e3ac66a14d38ddb94599dbb304c96a65bf5024febc9d1c660a686c4e60e
-138 1 363 \\xf9e0d67f0ae01b45012a8d11e739b4bcb4a46a059e023c9b981cb53000a897d22fca10cd94a6ab9c2d98bf67fe85e95f0cb51cde19492ef67c7f8a1689258806
-139 1 395 \\x4546cfacba7d11d41a1f96c12a255508157482f6d98fb0841948d647cbb2cc14c110890317dd588b2edc1191cea2b736b031a51890dc5ddaeeca2c7df8f7420e
-140 1 30 \\xd4173c06d6b1966925cbc25b0ce0c56cb10cc317e89c5ec799d1746fd3e1355894672aefa4ecf282d0dab0f94aa7e8435298f7b225653e0ea358e3539972810e
-141 1 126 \\x9cdeae5b905fe8229b9891e128dcad6ed81afb4de16957d2be05a0e5d7f2beaab929bea9369799e556acdccb56382acac0c198e1fbb8d067395be64d47623109
-142 1 275 \\x152c6c3d7fdbcc2cfd73acd5cb80373dcceef5f08a120e4170a192742deac4b92acdaab1c6ec18926592b2824c83ae5f32907c246014d55802e8fe626947400a
-143 1 247 \\x4220df190ea191b8443c4e2bad57955301dc6f0c4624d0ce5b183a24710f05f9b50d7430873ead1088b9dbb46f1cecc1dfbd404d6989b2d5228321a863eb0204
-144 1 176 \\x0da560b48d7e78809d915c5c2171227ad0bbfc643b4fc4ec6b08d3d194cb1752cf5a6615b7889459dd992726d12405a3d60be59e966da2a878dfc16f8e36610d
-145 1 332 \\xebfdf06ddd0bac34a1e2737e2d02815b42381e57248d0f2d8e936b05ea565961f10e16dd8147b2a7c75bdb499173404e33ac8ce609fdec95aa5d3dae2a2d7f04
-146 1 396 \\xd2a50a22765d7bd6fa13abd633d2dabf438988dd39b1f9a3f53f91be496ee42f99cf1d2ea989fe440d55ef2c70fda2afded8e031e0d89c5182772147b7025103
-147 1 17 \\xc4a0a6f1d816ab4591aa23847253730cf3b02ce718badf22d7cbf603014d21a99f30e853444614bb5e9e1e9ed62f78b41de594398c448fa81d4d1322fcdda604
-148 1 259 \\x8852205e7597a8e668f4a85238d6f978172faf5eeb8c14b526bab15a63fc0b5ed7418e7774e22c049160f926f84f468b6727cf07661af13fc6e50e3606134905
-149 1 149 \\xc63a5d9fa4a410449698038454b7f8525c3a955e3272da45cf5016882775433b3f1a184f39b572bde2531dfd7835f9471011edaf8d2b849be2d02461a873790b
-150 1 336 \\x9ea9deb1719070ed4edc3fb79e38527ae79a31ade7329521fd0122524148b550f806b2366fdfe829e21241b32bfbfc757152f4015dd58976cda46c78fa087208
-151 1 108 \\x40048c178fd68b9ec4081c15b6fccd8d2add6312763c960ca11427224a3d8c9bf581040f3e5dd063222431f24cf04b4e2937c06dde190d7db501172fbdd59e03
-152 1 225 \\xe13013693de0270e616f2326b3ff7f0b3153ee0fd69a84e1b3b774c02884540f23d651804182710abdcb630284329ad5c175be070403bffa227eb7078df3bc02
-153 1 333 \\xf637475ed929b04fc77cfa411264ab0958bb62acd4dda12692400a3029fff3689125153839d5a8ee6a792a81ec7219bb3af31e00b18ab9275b7f76dcf8045207
-154 1 200 \\xdecfef87d29459bfd0322d067a2a323d306656cab85dd100a2ddce92b73f0911e5c191f7c04b4c11b2986118955301ff31c4dfdba3134d471dc0dbdbf2f99f05
-155 1 39 \\x3a7d50972e403c2100294a4e7de731cba62217e36852882d8d42f1bac6a75375e339481b2155adf3fe574c1171aab6233ac23bee038ff02a170ec16e02bbfd00
-156 1 205 \\x3d69909619c0034be5196403c516fe2f575d9575c7882362c2bfd7865dcdd2adf21f83ba0d612bba46c69ec8b37fee58fc4c5ab6b8f794b951e8ba445829770a
-157 1 322 \\x654b379a5d409bd7c1af70078a53c0924c0223108e1d15a8c19faf341a987d5bf991fb83f93570e5a123270f50f14f8ac4c9e0952af49874778a64562f82380e
-158 1 100 \\x5823a4409e7ea7e34edf152a633de8d6e5d6f173031b1e53d14eab8f99e6e2b7451deb0d5be839e6d61f2a17de513998f6d14b6bd17165f165992d160e90870f
-159 1 270 \\xb7d576b38b80127377bbb3971d3a6f4ec9c0fb5fb802ae3a6e8413fd1fda55c6f45f5c98a72cda88f821dbb964f71e1c583810533384db3fde6770a7f26f3207
-160 1 246 \\xc54309606f0e6744ab324cca818894b66d3c23fc1c3efdd5d3ef4a5fc8d5614bf99f567c1448eb3047cfd59bb0ec483997a84a45cd60fea183314cc37a729c05
-161 1 400 \\x1ec77290ced57389fdc531d7fb9af4cf5591e16f0ed7f6ff6e444cf9806896d67d91348bddb2b2bf5e4fa1ea3527798a4b4504abf3b8ac27ad72b1033191da04
-162 1 153 \\x20f1996060dcdb039bb2da77dd5611ba32a004f149f4940636ecc10316ee5c6b432475ea4b607c11de3c213d492df1f24993833370fcbbe8f8e793e538f88b04
-163 1 213 \\x4445205aece715895ec7c55daf5156e44e354aeb4e5bf35f4e3c668cdb76ba0d71fa043c83e65b8df98fa0d39512fc798ce1e41af9c9c246d02a2407409b2805
-164 1 386 \\xf9d5d8dc3ed7326bfd3fb7e4bff21b16aaed4262d06c03d63c7ce73261c34f210b0d63d9f93954f8094fa50153bb96c8d777cfafdf108573995aefce28b23b07
-165 1 208 \\x66ef9ecae4be4fbb2b6a67ce1221ba2f204f32e490c6c8e001a0d418440305940a709e95050b19a7c30cbcac804405e1032d003f53fcf1c51ae3d673c011770e
-166 1 143 \\x212ea014567eb1cd9d7544621d2f50eaa745a5dc7a3ea47dcfbb4b2d6863198c4886754f67d290731e66c68c98f313ce87dbd039138e3774f5fd20888c364606
-167 1 124 \\x57990f1f6bdc9f4b4248458eedf9d84deee9832e98e00427459883ff05d8de95cd5ad4bfee230b5b6f4b3de4d7475cd5c8641fcda82585e4d584a1cbff619f0e
-168 1 311 \\xa8d918afc637b68225c919b1a9c3495e45be0073b94f3bc7a9d939194aa6b593faee826ac3cb3a5fc31b115863b899e7fe6e7024af3746062814f0364fea5501
-169 1 183 \\x17ecb0d143a3d5b8029dce152088e11e15e65aea6a915592b1a0bbf74f04ebf4071ad306f9901a0b6752550199682a8601a6d1b17e5206236521ca358781a506
-170 1 106 \\x329741e716291637752fce3ebc3eb98639ee4f4fe1225fa331086ff9e4ee11a30f4383db829558c54d20f9ec7b27eb171c6d6d2dbc252b6e87a2eb3f1634bd0f
-171 1 140 \\x59897e55ac78acabf5f99a6b59229c431204fcba91e910e1caeccd2adfdcaa164e687751b588053bb93a854664356e7ad70b6e996114eb702b413fcb5a500600
-172 1 214 \\x2678a9096866266934285975952e920af5645dd17e42214e75629a216ea59045ee7b1b605b93bc7087dd90a13b9516d1a9d19dc0c7bdc61a65522ac7a7842108
-173 1 138 \\x41804b310e6d9d97bc99b0679f2c76931e76ff5be01b9284bc5428488c3a1ed88f962a8da2eeb892bb4352216c38e0b1ec75c76e145ad6a694824c2aa299220b
-174 1 180 \\xa025c214a75121591db78105225aee9fe6f2ca9190e85c2727abdd387250c04666f85deaa7df5ed17818a59b2cc86e4647424a58f5d346170b221062afa54b0f
-175 1 373 \\xae7c3a52722da88d9a35e33935d3613f37640c3993c9b0153478df5aa671fb0011e485e028e9461d11ce305caf6c5a3823d8c47f09059e1866a9b44d4b398806
-176 1 139 \\x818eccd0e74ec8e57a879cd9097512ca7bc93156237cd50f13aaea1d01787b9cafc132e032f4595cbec6d30792075475e046bbbd85b52bc5b3d8102cd78f270b
-177 1 110 \\x0170c7f8f84bc6b1294fa8eb0d24d97c5de395bb2bbd7683a0765f385316103d1b5a309901565f9d58e7805936c876a1fd76325ec827cb329fefc712f8dc5205
-178 1 102 \\x686870875f263361b2db3c26ae84888d0d35bfd79431f17a07beb51700e786cba76479113b8374fe045f5eaf4fde25bd1bb60ac500dcbb960773875f85636504
-179 1 374 \\xe1188b4c042a6aabff9325d82b16b8b31ce090f1a57f77245ad76dc25b66774bcab3f7babcc1b91e7919d48ba302c272d79595469bd37790a0f01a7a34674002
-180 1 212 \\x61d07ce5127d1fa1b423f2cd77c942f0dd1267efb87b205c961646c5d2e652ac1ee059183ea88002013002719a90faed487e60f85015b14ce1142eb7f5895a05
-181 1 61 \\x656cdad6c820ccaf05f6321e2d1a484317478294961f3371448ff22eab75623e7e7b97e3e439106b5c3fc9ae95cdce1fa169841d334bdee528698505e1c74002
-182 1 281 \\x742766933a5fff18094bf834f5a9206bf7d7f80e7545771b5ca613d81fcb9d38d1a68541bd17381b8bf2ca2eb021f045b39893ef00b9ae8c123cb4d087947e0e
-183 1 37 \\xfb5c026f8d6c457686258c68d2a384e1053b4138dd54b65de10321d7b667eb99d249d0c300bbfd9d9bf6df20bf13ba098cfbc8fc42c650998668ccc73a5de00b
-184 1 302 \\xa7e0633d78308575c28418d232d4295a04ca78c7a6128f63a49d17c2ece39f2d9317a73fb9dae24ea8057218fd4ed64ddb23956814214930aeb3f436b83dfc01
-185 1 170 \\x287ba99205efa07a33e7e6ca334c7cf415dd03a95c0845fc922701dda6db3d46f18301a85e874dd76eedc3d95d6c9e5ed9218528e246f5b8500ec5ef6c45b507
-186 1 423 \\x54b18c7d4556c8d83ecb294a6fa9b0fb3e2d2dd1a9701415e799cab168f500ceababcc758b02e26cf3331c0a880732b9bf5029bdfd5b819648112f3ce3011205
-187 1 398 \\xd98f408ceca3b59ccc835f9a02d6e48d3aa6211ed0f43ba256a5d9f249b111c0ce7cbb04b32fdf0c7cacaaf8cba93d16c2c77d7fb67349ef91f7138b03d4c50b
-188 1 158 \\x5bb0ed8006ce3151d67b00815688e529dc4b0215acc4b1c0a5cbc3ba61c73b01b2e7930e1ac9d111259321c6293c7f67e2553c006e6947aa033faeb669245405
-189 1 249 \\x2ee9961f2f5aa86010e99f385877a737840d5dd99894cfce596ff801d360d1315e0bf7cf4826a9d853dde973a72ba9c81c6623e6b3c1419a6e59c97d3953b503
-190 1 375 \\x2e4ce05db04b30432248fd2e38231cf8bee89c8844ea9030138a496c2d70cd5bde4165e3aad403e16c5ab5b9fc572fc2916b2fc93c48dc5b61491ee0d1ca7f0b
-191 1 52 \\xac362a15948508490aa3bbb00d9373dbf43933da588472957706483307a131b47f4f4cdc891b1c04bee81ef4df6560d4848e417e12ba647c5a2e8281fda6490c
-192 1 292 \\xe2c7fbd0c528cab2a53eb039680d29b710cdddd598293fcc4bc74100e351da45415dc3ffd334dc7a517652838a3eafc50ac955d09b34996afc146d4e6450bf0a
-193 1 198 \\x6632a71691c92ec25579af7a803994273c3e7afa1826860da57d59fa0c9586a7622253fa694cd812e640ab403c4a441277d8d5932430fbaa9465ab1e09f20604
-194 1 207 \\x0f0ce7ae80663392f16ca9c136c793f5199fd7ebcdaee8039bb85476e0410e4032ea05f29a56981a745a8a0106b9c6d241beca368ddeacdcc8401eecd0d2fc0d
-195 1 294 \\x45123aa83e99c8fd77188be20a5accc5bcff3c888ce17e75f0da4488b89c68a1275ff21762ce3827e9c17557cb46ea10bc9babda8ebbd91509a294e6acb5b40d
-196 1 256 \\xe05d255a291cbe1d0eac6f3d397612bad7db98474de51ce26c26742d44b5e276970f9b2a6f3e0cf509e365f6e70e857a818eb74220a854b0420f84ec8ffd760a
-197 1 163 \\xf9de65f69f8957cd9c74a6e3c070588ddb85adf902584954ae6f31a523bf493221422e64b16055961abbb32c74edc975b95a94c5feaba37b24afd5610ca2950f
-198 1 376 \\xc5ff88dcc439cc610a96ed5e2ad6f930050774f558a0adc4cc3bf517fed5952c02ce132bb7a7d57d490f18047cc72a5fe3ea6f7039e9e1ca5630eab8a45caa07
-199 1 117 \\xbcf26fdfd56a1906f1adc5662edf1a5c5044e25ff1d8a4432667efd48c9e86d35e3dc37a82e0b4c730f8643ab54064762d54e3b50407e8de7dced0ebd1b6cf09
-200 1 150 \\xf4fe58ffb75b2328dbfae68fdbfebd322ebe159c3686e296c3f9c36b61d21d11e66240fa54f6b109983a8eedacde2879a4e45753998fdc0bc6d391e1cd288f0b
-201 1 137 \\xe8277cc5f113ae47e15e00e3cd14314c0c55c878618d3aded8b5d568e305a0c05ced0f1b5f33025b43d65fbd1c5b3dee34a0f89604dfe3cfffe064c8ace11506
-202 1 285 \\x6c884ccce13280db3fb5d3ef5a91e3c5f9df3ec27b1a014a223bb759be78fead6915ac12d557afdead39d229b6227518afacf0787f4015a5e3a41077da3e2f0a
-203 1 383 \\x5c4f60601d83f8fc5d489a5e2f7dfcc56010593f7f1759d9b209e3811127afb0469fb1da9d9d1c18bb3e7a488969b8b613297977059bd0a52600e8b8f4e66502
-204 1 381 \\x6c7549a2438ae6f01046fea4886c7a9fabc0e8d0afeedcf344dd6f8dad10f3fec45cc9f6ff7691ef50ed9a1f559d79130cbec38bf8040f26cadae7b3e9dc7b0b
-205 1 407 \\x19d894bbd172823901fcb34f94b361fbf726b6a3fbc468746f1a5de98cef7e77580fb80d5e2a6d6d42a4bd3fd7905975e667c210ea8299be76d9d6df9184b408
-206 1 305 \\x583344196477b02799119f9d527640b7354c641df0f5538b4c2bea750f800515be805c5140f8658b8ae1fd007e381ad541d7d66ad7244afad921305a8a0bdf04
-207 1 74 \\x13e2c1dead06dd485751176127272b0660842767a67b55658aec55ce6a6e012feab8a3f52ed10d56167d1690bde046e0240b1163d762e404f1ecaabc2fc6f101
-208 1 365 \\xc6bd40dd47aea1125d34139e3584ac178e530138af3e511ef1e9c0d8700018fa80721efccdfd5e865cba339945ffd72c0c114a88c7b3d929ff1aac046607430f
-209 1 323 \\x41981b5ba651d7ba61cd4361617c471296c875224bc27dd1dc2374b2e945df6f3eb21bb538d53cd036eea0a71c062df79a55ae442a66d8fcee446208f6eb460a
-210 1 337 \\x06b44c1f48329091cf0c3e6f6cfa133a733085c43dbdde6a1bd9c9926032b5d3f11c90fabb193857cf7ff0fb69e18170bc9bf48c995ff1a76ebc3f34fdd91200
-211 1 179 \\xbc2ed7fd3b4796d818bfb274f9b9e4290afb8a34a4f70861b7f2963fa8e1c315138c80d0814026d3d998c0d9111e32eae1b98e78ca13b561f76ff782fc31d503
-212 1 98 \\xa026bd161890dace3556a5319afcadd8337fa9f0d4bbd73a1aec4cef8169d50fab6ff93fe072251df1f0b3452a188cdb363af7ae9bae9437b48872b9613ef40d
-213 1 116 \\x1ae33e1ec5814f1a66b252252f0e00d218cc86ee9db5071f7f29593b914bd038afea34ba02b5601d7470bf369f7ab4b4e36434d83abd0481937e4107eaf80d08
-214 1 382 \\xbd3b0a79634d2dfc64542e1b1b5d0bda883e206a4c206eff91ba365188ce26d4214c92e202ee633921028f76cd596f3d98122150ec8d784f4600cc90d8ba5c0d
-215 1 355 \\x220e25a3f07f70ea5f1200511b30d29b60be2c467f49ab0df2baecac4860cb1bf22d9a8fc912fb8327c0abe7d3096a7b8c161faf67ecba21cd6f137029bf5e0e
-216 1 164 \\x8f4bc7650a3f9bcbfcd33861f9bce0ff937fe4979ebdee90fd7b38e396208ed682b29b031f8c2418c7674517a299d1595a0f1cf413d400ca801143ffce7e8f08
-217 1 299 \\x50da37e55939cf2cc9d040784b8f52ec2724d293cfb64f7f80ba8d5bbe12a3e0663812778b81ceec796397390e5438b7462fa2bed395d049790e629ecc5c9606
-218 1 402 \\x2c67c7f28d4b5ce291dc0bc48db4e3be941b0d6980c07ce588f4aa8024c876c1f498db19133e7eade281b62c07354df716dcbc81c74cf581dbedd472ac9ae108
-219 1 343 \\xb24bda960f49bb7a3c6c6a601f1c34c1014547a3e7565d7857cc077d66dce3d99c54fc89d1b7c365640b6d71089846b7521e090c889e701714cadac0d4bb940e
-220 1 215 \\x2d0dd16b874272187a7b4d7c67dab9f97533b5ae942e19c97bf3d45fbe32ff9034bf3ae22ededfcc8cda31a54f305d661696c73a658042ef28213a5926eeab0c
-221 1 241 \\x3597feac4f2db02d0e4a470c4b7ff0a4de026b17e6f50da6c4dda4f59d53feadf272db2ff4c741a4172eceb49e69cd1aa3ee28e0a0d38096c4d1d55092b6580e
-222 1 301 \\xef90d97716c648bc615a92b6f0acd97a4273a745746935e85b8c2355785fad463cccc877eccb0ca336060bf7a90e842dda7456dbb4832a279a07424e48674d0c
-223 1 118 \\xf1953fb98f9e70dedd4114e2a2a4b36cabc62e178a2b88ed03d75fed4b8d3f6493e0bb257b598050c1f821af1a62cd864d80d2510dba285bb23329b1c4e80f08
-224 1 412 \\x251e030b9c1c1ba21996dac7c48426c2cfdb5f6143f210f7bc7eadc1108a78887e6bf327f2b5713b29778c611e8ea9e1d8920eb2f182f4fade0f85dc9d29f802
-225 1 404 \\xdef336dcb4fa8699ad00b2c0457faba323ed09cd0765eaf034c892efb6d90e2e828804763c28e7178382d2bb2cc5a5b07a4c918e314aa6d4b9baa7e08ffe2309
-226 1 144 \\x6cceda0605a8db700ce4d50d1a26dc3f1db30b7f85af249e5d5169e9bff373df4915b66a60bac633104d7227e8de32b60fe43edf6df59429d90a3d1920de9204
-227 1 134 \\x4ac6a7f5c2b384be6e6fb814211cb652a653fcbc54e7781ebaa55ff424a615d6a40b4571449974b6e1f42ba086f7d755300da4b2467fe8341247014ba4f2540f
-228 1 406 \\x083658431f90ec4374711d42d8a0b4466e237a27aa9e04682a38f369481514bb6ef40276ecab879d81bdf9ba3ef584a09dcd004e2c90013d1d57b1f2e7a6e806
-229 1 8 \\xb2ae761067a328266b4d07bf97031311d83fc7e8419de0fe389ab4456636b19496cd574945cfc93aa8d0f3d8dc560a842292b93ddcafb67e9264b2702fbb3c0e
-230 1 304 \\x142e96e5555083d4dd0d301918382a77526f757d62a5f5a66fa2faa3c520e16877f36e9238bc815fde869fa56abc27a261e818d94f7a0cc7a70c1107649c8a0e
-231 1 242 \\x0c76ad1d5b22ffec5b497c2d52a9d59d02de510eb5092fc4d4dec573c14fd423de969a779a8563ad7ebf282bcef846021db551f3192465525e2cbae4c4738500
-232 1 397 \\xe65e52a15d88ec2d8278ce0978e7b6f63aa347d2cca2823ce737d7b4ae49030cf5f23786a0c9690a0dd24f56e6a5c4b667921e89f396c0f0c46b82489790440c
-233 1 263 \\xbe73e3a541eb1060978cd9306f3d59e62fd664b45d89ec16acd99e85f0b198e136a43fcf05a65005e77a5a4ff1383682f874a94176ae24e281d44d084a984708
-234 1 357 \\x07dbb350b1ab249a81d29add38edc63741f5106c853e055aeb3940586bccafeae06884c52238c1ccf5828481eac6aceaac4ab20cf1cba49a90b274641e5a2f01
-235 1 66 \\x8fcc3f51e3162973d9d5a4dbb574a2f952897d9f32695b3e9cbcea66fb47c3173d0dc210846f0ccf9be44801191f4b0f0011704ba5457f7220dd196c21cdcd0f
-236 1 56 \\xf2be19a5770e7e6b39331981b70727e7a415e3f72de1e816b6bfc38464501dfd431029a5a4a34412e70f7069d818af01b7951fedf1a65b2268dac28484769e0a
-237 1 338 \\xf9c670afb19a43363b1b0ce4ef90f08f5bfa214c810de92cb97cf53ef4c89141712b791727354448b5bedf533050b7cb7ab0f888e9ae70237b8f37b3c9ae990f
-238 1 14 \\xe192eb07cddea2d95d1884401df9a6532ca8d9ee1a94ee99096a3fc6de3c62a34326d508b9155872e11597f4fceff90bcc4ff48efffb97a2bd809ac701a5af01
-239 1 286 \\x135542c739f669bd38d12152aa1ba1bec26cf2f6293476b11aba1920952a16c139b5ab55b4443ff135da9ee5d8899c5da55c4d608fc0aa78db94067c8ce8a50b
-240 1 91 \\xbb17ba7cf9cf409476faaf4c058a1deea6da472b47915931b4e5113c8e56537f75f9bf741cae6919e4570332f71167044238a2e5655a7c4747bdccd40126e50e
-241 1 94 \\x3218cd7827f0e1a19cf3ae822c8e6d87986da6d43ea4c21e882d26f1000812758cd0d872f6b5650b95a651caa36bc57fd3e53d2bf8f815984121a9e133084f07
-242 1 274 \\x29a6d9107709d8657c81298e53a2e2e75a0d1972c1ce335dc3e87ce733685f95df59718b7656b64da201f9d4810d45db4ffb2b046bbc9c4047e15ceda968880b
-243 1 218 \\xbe1f2e28d44437841360d765135ffd800bae7b4d06966aa7d08173f3bf1ebc5635694f3e66e0928c029771e780fefbdc8594353f5502cb6ba7e5697ffd5e5f04
-244 1 47 \\xd68af42897500e82002ae67c5a2c950b213b58f24448669fde8dcf8a8de783d2dc0553271408820fc8da5878927b7525c7890bec96a0bbb3fd46bbd806b2be00
-245 1 417 \\x64dce0a165ea61a016c539ef8d777affcb992a440462be338fc640a93fa535deca175c59570d301c57648f0e22ad9ad5aa456459dc5d5ca140c8511d0a9a780f
-246 1 233 \\x239c1477bca84d875e8ee0fffea0e30c7ead9aa74e1777d5cbda84d3a2251afc2f427a4ad8bd5c9a53c247309194eb066657b5c6b5830e9cfc81030ba9722502
-247 1 11 \\x00cb2936da04b7f94ee240f21543a7e7cdc28e7f1d741a9590a48232d0e9115242fde45703545a7944870a39a889702382c683ba229a192cf702ae1c41950a07
-248 1 230 \\xd4789f56a4e32dc37938dd0e68f42e5c017535c1a1deb681e9e79d288af9b68d2c7820d5e7d03821bb7b99529dc7ea9a4806b2535c4ea495257d9487ed45cf05
-249 1 15 \\x815b75509dd33f5054035527f76b4bb0f4f41990d68e946e1957b228e5346da2818583e8d3425912cdd59a8f79430a427b134a41bfde20bb0cbf2e75df2fc301
-250 1 217 \\xb75916ee9077c97fc23d8646e80fe0c8407cab8a5524abed87490e9736442ea8ac5ae50e1177acb2e0aaea2c5e4f58ac1b7169e7d7c21c7890d441a39e8b9007
-251 1 87 \\x51b659b371670dfd8124d33fda8ddfef1c7be71e6565598cfea11db3596e111f076c1faa1036f13af365a200c4c7c368c5f8986e0b71e10734c780db88f14907
-252 1 169 \\x62b7a3c3c17c4f353f88be1a033faa9881b4d9a4799f41bda68b2d0b34c591bac7d5a193cd88b09794a7f4518e829213db3dbb7fd3668b77673fa9405f7a8802
-253 1 148 \\xa9d9b94e972a8da4339c68299651e91e8feecec163f73fa4d8da93bcfc7c245ee0f96147082e0b162c5137c71fd95d77b3d3158a7e8514e96136f7af30854a0d
-254 1 90 \\x2ad00b438f4f060e21cde38d46452cd7172940b3e822cc9981c1fe6b1674b19342533e5f82f4f9f6ad1b55fd5a60c0708c45406edcdc781ae8909885aa0dd304
-255 1 196 \\xa674d0660629bc0f743bd4a60fab5b98f16154f5cead885a91bac9ff9a3d676040d16a9d75e022f0924b4bd65aea85de6de532c97fb98df5540894bc36ee560d
-256 1 261 \\x8d8786080371a2b4470c58c4e28bd24bb7fcaf97b723fcc014079785314cb9c46656f0b30a63488e3739fb3329921a6684baa83b3f9706bdfbb2b79386e6f209
-257 1 9 \\x252d9cfd3612eee8224a5f250d05c3f142c52dcafce6d88b8807cea679a75f7c3ba4975961ddbf62c2ce01b907eb5b2f2731e177b09f2a2a8181f13af676b90d
-258 1 243 \\xfb5b8038ed56eae2cfca52d10259750ae8b23fb95b0faa63adad17c8326f93630a1b54303a363ff26ca30e5970bec17777e6a420ba3a01a6239562776b8fb506
-259 1 172 \\xb1d34e32bb172f96b2e0ed5804250dbaa36cc644eddd795936660e56a752ee43c78058fc3c3a73eb34234829d2e862fc148aab6f4992c4523e5ec76ea4197209
-260 1 265 \\x8001cbaac48fdacab12b2f81d97cd124ad5ec9224f913dda91f1cd61357591e6ff92900cd59577103c7903072c0e09d7f012116f039a8b9a785b896d30c3c702
-261 1 127 \\x4c6d8663014cf5d4b5382b6b83830e9e69713936f4e7ca980a0a8f66713cfeac22dd5e66b63bd4cd4c90631788366f223c915ba05e565e14aae511350b7c2b07
-262 1 224 \\x95767f807f322ea02659eebcfac576f0654685c641b4785d350108eb6388d521386094ea1e32d755753456ab5865ac137af580bac87a9e5e5e6a568ec498e606
-263 1 18 \\x4d001facba407347ef05151483dda9c0cd442e4844838acc0044d252f2073c93905961e2fdda96bcd137f0c4ebb3e578a757a481fdb4abd562a30467f5ec3000
-264 1 206 \\x8526537014dcaed885ed49e35e7b22e59453f59c7c8d7f8eea321b63b1ac55840b54c9cf3441b3fa9a68f94f9f571e5d82057a38ac150d18837291fcdb157d0a
-265 1 32 \\xb27d4ed4c2f55c442afa750c82e4283442abc2d2c077fe94362ab6d8e5498d5477d3a8b0e483aa3f577416221f228756fd2a0287deff84f69b1e78c762681804
-266 1 34 \\xb03cc8612dd629bf724f514a2a6cf1529267316923eb581528b4b2ace2768e6697e9ee54a62f9dc3fcd86d13a70ab8d578870daedb2e84641bffaf1ac0fc8803
-267 1 312 \\xe1e05f8afc4160ec51c226e80606a8052b2fc4e12fb329bf6de6ef173b2b7f3694ad4b9a6e4fc7b9991ada15d2c3bc7205c9201f8f6b40261c0f3e303c1e110a
-268 1 260 \\xe486c3b4eb562552371a0e3753567a84d748fa758c5e6e3bc73fb818e633e3543af9ed62fe006c77fc082a25ead4c6683d3e9b335e1875a62545d0f278adb601
-269 1 415 \\xb4de5776929e0f39b81cbdbc41faae8a40d02c82324f99481d181ca1169e9eea81ceb01a03b3018a3e0789817be2ca4809c6ac44867e6fecde9ed2caeb4cd20f
-270 1 362 \\xc7b2d2587c4389e19c6d9bb0d15a3b00a27dd0d0c6512cf45e681292783f0a22fe28455ce1ff836853592a17cf211c2e713a158ffba8b91462e960bc0173320f
-271 1 111 \\x5658559898bf17d2f57d602c2e6fc47a9112fd3cfcf88f3abc4e65458871b218ccef665ea9743376137a8c3c2ec68fe6b2e310734e47609d7e4b8b578170a00e
-272 1 152 \\xaaba09fcda06cfc017e99c25dfd2b7bb03c402d3a09bd9c6a45b85a497f100a93f41b9820d012d2ceb363fade3af98560791b0e4c924d2115a5d629b67955503
-273 1 354 \\x34b2ceac1f1a1f9b1be35621e7c1b8cbbe89058ca1f2e9ecbe2cab912302b7916c62408c5e1d66039a70bed617314ffebc47cd5df03f7d3795faab759b25fc08
-274 1 314 \\x9684526b29bffa86a51b607f2d10d48746935b9af4eca16b50b9a89346ac134dd6b99152dcfbed45eb04b3dc8a2f7a4157c3d2dafc0c5baff4446b953e26bc0b
-275 1 348 \\x9b37adac2e32c541d145f846f0d3d29d8d0d0a4560b48dde35b703b521b7379211336d5993d6925e53c41b0ab4b7335daee5b640fa1ee5f9c2c30315809faf09
-276 1 5 \\x716d7418fb8491d008315f0f58e84c5d28f4e3a60606bd4e148646c58919ebdbfdb8a32800e6cf5c5be79a113c3abf0d88f76a51e5217b34afd9340af84fe30b
-277 1 366 \\x1c1a95decab3d058f3e1ac84de2deb7718d96b8543186a941ccef4871947b7682136d7439b0f431d81bb247a1717915bbbdeeb6c1a4b79f95e22abf917e8a309
-278 1 185 \\x8c90084795c5b04e2e39f225f982c35707b58cafb3ab5e3a61429a886957f376deaa318bdaf8aeaee3a3c243da565b1667aa63db08ecd71738b8be2357802404
-279 1 351 \\x1082780d998e6bf3f65d7e6319faa6a33c9bee9e2d7f1c16d3cb42017f32e304942c7a4c6613468308dbbc1f938ab3135fa9309cb1d644471cbba056f1a81c00
-280 1 268 \\x16677376387165cb95c6f64872aa1ef03634ba86866f13c1235273a5e7454fc0ae35d14ea327565ece6482302c0d10942d96f3ce86e025af67b0d6142d40600b
-281 1 38 \\x69600c01cf7eca2e1d05f1317b653a61c3981b3cbe73e15a51d2bf6b2a245b19cf70bc5f2f5951bd2e53cb9da07b30bdfaa614c861c5f747251b4b38a13b720f
-282 1 22 \\xb27a0e825c5203df456bf9c85a77e27316d558a3129df840fce3851524a4cb24f5844c75c37d52b64600a36d8568c5ac4a02630c85b5cc936d7df4da3cbb0c03
-283 1 72 \\x75903fd7d7fc0034d579e1cc43b6c98aef39a17a874792770469ec57cbfc70968436a817ff5fa9a350f0917281486e158708edf0bbfa6e6546b8ab6eff10a10f
-284 1 173 \\xb49e18f83a9d9babfc683b4c4f11be877a5d54452bd8d7a8f8710646a422bcd8490da942aee530acf0667ef46a3cda5fe36dce9abd29c65998f073832b105d0d
-285 1 186 \\xafff9f847333998afba4adb46dc13538fe4ddd387636986a8c38034593be1019d777e34f31b1283548ffdc4fb349078ded2a4a00f88003c1325fd13214b42c0b
-286 1 330 \\x33756c9114944bc7fca8300273a94a1c0341378c9e08e3ceadb9ad43f1dc6d089fa3d022a53f7c1644b6c903cb95069c804417eba41608d847599bf5017b1e0b
-287 1 95 \\x5d211bf6c7b2ca11f83b48dd787e391298eb873987d4974ff32229745d9bb891bb54085cf8fe41856147124f0bf0d015429bc8bb2826d3d8d2bb1f5b9f1a4e05
-288 1 67 \\x4f3c3620ef7b853eb0e9a9bfcafb65fbf2d578a1d3da0fc36e2b0c77a6d2074e3513eb28a0a2a9cee87666c36262314e27502adc84474e1380b19e06cd5db108
-289 1 57 \\x1303c0941c7d905ce2328638627eadf3e13408f1ca7b765fee25fe7c8512cb29a132f51cbf7a1f52fb41a6fdcd12b6fbc97ed307d348e372eb4f854cee768306
-290 1 358 \\x5c127bafe48c49fb77958781cd7719921a273f0da3d2209a7277dc0962e179c4b3d22420464037c7d977a994cadbf0f631e9e543d89eaceac4014f5283539b0b
-291 1 306 \\x18fba33635379312bf2c7b7c833c37792683644f651aacbb4a6e4912701400d9be3a2dc44894d206369c604cad27418f55c31ed0d8d41e5127143a2beafc5600
-292 1 165 \\xefea07899144b46d6f69b0ad0d2b8097f29f2f8a9ffa759c15c8b66fa8835936323ad74ada4cc6bb993913e048ac5c5c678d770802f7e6058804466c82641608
-293 1 295 \\x17a83e65a454f5634645297538a867062b4c0533202f10478d50e60395cc8b5a6bc3684b138cbda586907cfc2b2ee7d78e9bd12f989500127547476cadfd6803
-294 1 77 \\xd0e49d176db6ab3b762ac367f76f89163d34335e010e672c3c8513c354cf760dfcd8557d2a4afcaf70f65bf6da6bf9644b69725d48fb4ab3108919f3bb69bf09
-295 1 379 \\xb5d500b50ca6d62b07d5615caef60ea0c73a2739b616ac953de089a2f0354321ba3ccf8f278d54ea610b3919d594010c20e94121770a14bee9a9a567ab58790d
-296 1 191 \\x53fb90b1d90eb8fcbcd874e108665399902c3e672f5bf74b64d0f8891d6911d931c897d6c9b29e5b60f5a7cdf318f3041fe5da9cfc68a99ad14e631b880d510b
-297 1 418 \\xc44c514018db48fd578663c9292456d40c00340c3c62d79534172b579e76e896f7a2c26c2c595afdc6708a6e6698e6f950d5439273c64e15e11de3ba8f756d04
-298 1 378 \\x06c04862688f83e547324849667625d378291a87ffe036f4d1fd27eeeb5cbc4837b53cfa07b4ebc1046b2a103274ef8203f75e292ac05556590b7a34ea3bcf0b
-299 1 62 \\xeb5fe2f02101af74aac3dafa375687bfcbd787d4ab3f05ead326b1b42101536e037f4dfc66857bf3bb691300affded88df75a18a42181660a7c517b72afcd10a
-300 1 189 \\x73577ad2330ce275bc851756543dea9312893f9a05ca15e0ec7f921ecc80ec72487a08cad433f1213088296160cb5b2c2d7f6758efc14557a9c221b739e9df06
-301 1 391 \\x1de5c55796db9cb2020c27a48ec7e53fe30d2d5bc94d75dc71abae04f00c9ea77e0d76a550e2d523d460141b5fe3517036178fce6216d7882069479da5fa9d07
-302 1 16 \\x58893025ba8ed220275abe7e1842a9b5be5d76f42102bff7e487c3f6dedb597aebe4345b386bcb8a054879e225579a569ef4ac9c7cf54b24d91058f9b0c9170c
-303 1 266 \\x46304d5c0174f685ce3e05234cd1c68e1144527dba23de578fd44e8529b2c67bbbd1d5b0fcb40cee11b5f094517dc30d051e612fae360212cc7b376754ae4807
-304 1 394 \\xa6eda72eca4620f7f2e3fea6d89b23e3d9b8fd34fe59909d06736aa1c4cb0af304ae5d2553b952e2ce237c2ecb3c87226852f85645b46fcdc72357542965370d
-305 1 231 \\x39ead56256e3d0eb177a59a3c06effe30c11d3052effa4eee7d9d0a23f1ef3f6829b7198768fa135c4d03b652703df9bd5ef8e2f373b04eb3821197e3a80ff08
-306 1 151 \\x26b4f71f2135c3ceebd62f97e69d8404b84824d82fae7b5222d73f98c19d54ff11d674b5e560f6d5069ea037f0d94f4b09cf90d0329329ca824d15289fad580b
-307 1 204 \\x8799cbe1a33bda2be034a30734156fe11de14827e7f8a82f93b89dcfdc0250ed1e0425b28a9b933905280b09899a5821b724d3e95c850948aed743d1bf4d4a07
-308 1 201 \\x5437d3248b0bb177d2962d017059ed9fcd408cf178b4839fdfe05f08eb8e54ea0b5c86e8265ae6dcaedccdb92b835bc91ea1de9166f11d3d4a4f59c632e50904
-309 1 197 \\x398e50db69607abd37afd52cb9aceea6f8b865a1668eaee57110c3bf1d5e7cb4e395bb93e64da6fc7f882955d7f3d0dfef1b6f6378c5a1cdb449e09c1a1f730c
-310 1 388 \\xa3407ce05e4b885bb27d5e4ac619d4ee0735cfdde5489a5fe46a9c03ec35995745d701775becf6318d1d1e12ba3e7d35537215e605d8240becd874cf85565a09
-311 1 221 \\xe40b7f44a279a5b1fe59859b87e06e2d1d8cae36c9593160752d2413ced3b33cfc7adab3198e39d20b2f80485449e58481a9e69fe11e960dc6fc8872bca4ca09
-312 1 290 \\xba9e30d48fdb1d7b60f952de4881e928db00be360f21dc1a172df38b23a37261c3d78e219cf74ae62fc92cccc935b1cad63f32147b883af4ef3e6c7200e5340e
-313 1 182 \\xc0830788d55f9470e4cbca9a24b015867482dc86e33f2c53670d2fed0e8de4c6b17ff916b7859a853f0e4cfd3d130c22570373e77ab03898277ada36e0944809
-314 1 43 \\x81890a41db2a282a1f5d9649912603658cf71f0f8ed376a68d9df3e53b7144760af00077cbd883963dd2e8d509a6c4c61f527c4dac33f74fc47956154cd5b709
-315 1 147 \\x62bfff6cf984156499833c397cf32b3a32e86b81575a0c20f30b7cd811cd1f7e880059be19f1f367fdecff9086b86a62defb9113a18f218d4cebf1b087010901
-316 1 203 \\xc88de98d30693835052e48d24f48d873d7e80cb9a5814288b1a1e240bfbcd2521d2ae455ec4ad32cb61c1ae24db3dc62fbcf5ed5e57d8e9259ff53e64b421b0e
-317 1 29 \\xbbdba22e34fc713c10a2e6c53420a7a0067676bee4b4a80be6ee333a6b0fefee64eeda498066ccf85c0cf8180289952dbd6e9e2aeb86f4fc1fa556c1dcbdcf03
-318 1 377 \\x007040d23ff801abaeb812c4d0efdc3eefcde0cf2c590f1a177d1078a5b49124b3599e79e3e22388213190b04fc3a6a4b4b9af69e2904417cfdd7692ea0b0609
-319 1 93 \\x5424f708085705d9bb68c9dc32574eac0b1b54887201fbdedad77c5f126390dca327961f9644ba015fb7da7799b697ac26455a71c9cfb5a061e30983da14e90e
-320 1 421 \\x418f353d28636f409ffcf446a332f12b4da8e79c0469137763ea89b5b053905ca159f70427334f0f2d7d5aebe5d622c2db7e1e47ce0998b733c6f91303d58f0d
-321 1 141 \\xa55b727a7096cfa681b90e880acae5750e8136dd34e1e7cdc73dc9ff11bc3dc70bccf8af7f22c4d60ab1cc2ffdfc53b1c33914e7d05159be83c3eba88a988e0d
-322 1 385 \\xd7d52fa4e336fee988908a9fd40aed5cb9d991fc37c17d589eaa70c25499a24070f713dd280d6f11f0a502a1cec8c94bdcf3d03b097212dba97f57c5da708c0b
-323 1 315 \\xef45721a58391ff83fd574478ed79b05e6e543fd68324ae9a347fae9229cfeed13dc974362bbc34c9ab681e91f3b08f718164ab270f0e58b7c5d2096b60d9100
-324 1 10 \\xccba775f41abfe74a96e1e8b72d457eb662fb0d5ccbc7eef7925937a08f6781467f7b7f393be893f357f03f135fb8c41459a0000c60433ba51a83485187b8803
-325 1 287 \\xecd2135277669f05d6b8c309554616b22bbf37e98a23f5be655b40a92344359ada0a7a29738a782d6836806edc700a5ccf4febf6d4586ae6bbd23f3147c3df0a
-326 1 255 \\x8617f2ca41501b964d85fba8987389cf869627d128b390849ddd3b5ca8df854fb969411cf0bf92c008788532b035c623b5cc2fd1710a82d2398e546df97e090d
-327 1 409 \\x34af038f74cf01ca258f6aa8e1884ab10ddbc9136f1d7c02c0fd1a9d0b80b3e0b87b64e71de5bd93c6ef27f7555423cd6641e9f0aea6220955f9721ef7e8150f
-328 1 419 \\x44a3ffdb5d8f8573b4785f6dbf8b0d4402c6eb7b68d4f64b6817466b8baf8c05f159139fbba5cf86496deaddf53d93579c3dbd45e308980c317f33dbeb033409
-329 1 267 \\x0eb3950269c34241b66fec934e714a50764ad0aea935a60a9f6d5c142dd1663f8ae19ecb004a87345294f755ae0d21ef31f74b39dc861d8737a1fdff71ddb50a
-330 1 84 \\xd8fbce046212f91e2ec882791c4e5fe94fd73cb8b71e87ce36d9247e8e533d7f39bc07d702def69c597685cfdf62719a5ee0290de3c3fd25abfa5adeb4593e0c
-331 1 328 \\x21cd86c1a1470ff257bdcc6b871ac2669bc48f26fa0b3edd032a2494b21dab51c0d1fa554c143bd7360a4209e3d48415179b47832874ee2924800bd31a4e8702
-332 1 65 \\xf39ac32a6b6ae9e96346aedb9081b2aa64ca669e5cf656e0960876e6b015956dfbd099a46b234433ab9b9f9b07fadef236c361d8513b2b42ab36acead5e6a402
-333 1 160 \\x96ab2043ce76418c2ada58f344addaf50e30089848a4587ebb29f45c8f4cfe6aa0c3b318033340f04a979a60f1c023c3b0d6f28a737c0483d20b14a9ca084504
-334 1 319 \\xab90d321e361bf80a06ae0d4f7efda09da4fc73494177e0048914960f999491cda1d807e95d99e331d191efa68fe2144a1ead59024fd6b28d066959a9cb32403
-335 1 194 \\x602fbab68486f71baf5538be91dd46853f70c4ba1b26e62231cf5fd802603439bcd2842b4b5c4deb071049b81c0702fea85ce6007023ca31d387de46e1ae6804
-336 1 175 \\x257cb8848b448b21d18c3f331222e58973429affd3b56ffda5904af59f03a07dd01d89fb97b8c6e596bc8a2fa29f2ec5dc5bc9b5bdd4ab697fdbbb2f2796700c
-337 1 269 \\xb0e61d4fa0da87ad70355e2b83bb610438da62d8d52bb212caa7452796f10e7c37fca08e0ae885a0fe09c9ca06799e6ce41c1cc1229bfe7f804c787385eb6e08
-338 1 142 \\x26bd7b57667e704bd0a4067bf1663578a3ce94285eebe317a4c27f898f46e37e0e37578a7f2fd5dc7e76648d078958e52065309aa860a951ba6f7bbe966c0305
-339 1 114 \\xda00c4831befd4ba70f97ba5cc1c6ab462e3a4cec76e8a2aeee00d6560ff702613abb26cd9c84fcda4a195c559ace9eb9a317394a323e3a25b16b8aae1b4370b
-340 1 157 \\xb06e0727d606c7151edba2b82a2fec8b80301dee48bc9235359783e7af05434c7db7ec5f7ff6c1957a5343c81392d61e2ea7b8be8b10bb11123de50ed26d9f07
-341 1 411 \\x9c2985debae7454be39b39ec87668979deb7135907b1bb1db0e94dfc3378aafafe63d19946c4c6f70a9af80aacc8c21a254b93e148154bc93e38d345a3790e0a
-342 1 254 \\x48c9dbd67332de7bf3be715d72f1a288d52ebbef04527bff1cd7529eabd96cbee5f475f0b49493d2c2f17c1a3d923f14ef12882d76ed0744eeb5b6c5ce119d0f
-343 1 239 \\xc6b0ef4f839808870c40af24208ad8157262c628f572a62962300f69b96c548d0cbe9e3a5ee805027825421221e38f18f2a3925415eb1bf9830fb16c793bfa0d
-344 1 145 \\xdf3e481e997e5bd09d272c54e49a4bb057dd062bd76df90cbba8f94d27140c8537764ab30a7fe14ff6cdd2e2381932e06e309054e3ee683ae93b37f94829c303
-345 1 364 \\xd7950c003c8c2dfb71c237a7c0d2f8923aaf778dba6eda9077fa77474add14791e7f4d66021032989a87e8bd326bf62eb5c275cc63f63542bce9b57cc90dbe0e
-346 1 250 \\x04e4711b47270aade5d59df81b829103cb43162a89e205e1b869d9d9feb4042d52b54a0a318b3ee2866375acb46185f5b69602b8fdbfdc623ecfe7609276f60c
-347 1 349 \\x35cda316a0d8d775a3295774ff9f1898520a3ee84076880c27b435a41f5b8e3f43e9513bb7838de7a05885d79b5a5126d7274bb7314cac346286028ae1855d02
-348 1 280 \\x4f91aceeb064ac8b2b89045cb2c923744d34079be86cb81114bf4a242d1a79ab9c4f7120868a4cdb6e350052ae8c42647b3263e7093520bf237e8bac9bb88c09
-349 1 159 \\x2707668bb95e5fc7d47b91b36af0a4bed72b3ca8612aef8f8edd3307589aae97249560a4c424b55d8da53f18cf5551c79099e0da3ebef1fb9296b3ca6ebe5004
-350 1 339 \\xb1047014cd307d04d19624fad6ccb16aab0a076a1a2d401d0cabf9e61325852f8631d59ed7c3915d5d4b205ccbcd749b939a1fade276d6b54b564fc41ac86503
-351 1 76 \\xe5a37a7bf911e1ec7a47043b10ada7b9456a07ef2ade58b824ea6afe7893625d0b742681924a5d01cc26fa725a11b7da6183aaf52265bf996241a9650c41180a
-352 1 12 \\x4a2c4c85ca02364e6c8165bb9c29a61b139d1ef721d78882436b63d801131b1837d800958449165cc206815289e28873860462893a864a51773145eaa1e9b90e
-353 1 184 \\xdea7a8e808b88591b19e44bfeb56839f7e06703dfad61b51817676a637c971738df179e02730c0bcd25155c25a095230689db5bb02e38b0ed63abb77656e000c
-354 1 55 \\x9ddff88029dc803a29d89e549334e14293a3e5c463129a1d9e1f34bc8d3f5c0d8c21c7b2c2790be441db4eb911a9aeabeb1aac3b83ebf09cdadfd566d1ce330d
-355 1 291 \\xa6167b8ffd1c17ec551e4773e2bc75f806e51d9444e775dc9a5e2060a5eb5481e562d8adeddbfdea57f2c1d925f2481833bae95d54c85155e7b1ac0271b93200
-356 1 262 \\x00ac03570efcdb60bb9b2e2345611ae20b1c3cb5e9e01f28889eaee99f90d5655ff3d71a43167b30d831c051d5ef0cada1a5176974bc5af71e35a246f2441c0c
-357 1 325 \\xeac9ed340c88965ddbf92a74f3689585d2115901522293dd7eef591726deb840237ef67d3948651e3d34c474a86a35e5d7ad72cceb548f8c2f93f43d5b35b303
-358 1 223 \\x3d7131abf2add93b5a41fe06eaa82af8135adddb68abcc365778c807a8f51d40403fe2939a9dff556bbead742adc2105573df81944d15254aa21de485e13cf0b
-359 1 88 \\x6bb4855f2eb100fcc083bff6b250d9ecdfa24a1f6e9457f46fc075d93c3fd33f7f8df67d3edb564ef7f5fee427bbda65bcb4a625826f58387bfe2ceb3b5f3109
-360 1 272 \\x2bbb52489acc3723abd858f82172478f4ef5b5545c2cbbce0f3ba4bfbccc747c917b5dd87eca27f5db0cb44c55477d561baaa012cb868574b0d8d37b916a0001
-361 1 229 \\xc4208038a86df0bb5bdedb0d746ffc0fe7a1facd0ecfaae2b81c1de41fcfdd756d174edd6ccb2b2b4839afdc5a1b20984707f857df9ebf8ef883187fcf4fb00a
-362 1 352 \\x4bfe981f78759ee6e8f652a006e953ebbf6b7112cd0d519a391a19c0fb42cae320cdf7dc1a754d8f331ce41c6bcf189b013881fa254a96b282cc49ea08ec5909
-363 1 36 \\x5d742d8276abc616d11d0ef4d0bb12db5e848e93726362b71e47a4490abecf7ce171d99d89fdea14692db8d15b64932d20564ca0f3bb3e0c0ecb64d75fe78a07
-364 1 171 \\x84c19caa9a030249e881bb724da9f07b24336964e5b4b957821438c97decbd74a8cad5763762171a448a1834aede2a09ad1ec4523d3d4f97945392ef7351ff0e
-365 1 174 \\xaec2b134ce5acc667216e4510d5a74b3955fe571fc3af918212008e51b9310d2b727e2bae26cfa5d4d49272855446d288ace8b5f3fae7aa6c5d1616657841608
-366 1 35 \\x7f484483a667b1c7f178585fdca8961d2a24ab550c2f5425ca1db5a50ebcf8447157edc0c1270d97ff8acc37d3441819ac8187ea5cca1d9bceb2f27678be6d03
-367 1 234 \\x1bf7c2d065ff8118de71a2e202f0339ba0ca6273edf727322b7bab2a3850212ad25d778b0b5f79b8a434cd7c692b2e94f5b68281fc697377b715ff6338324103
-368 1 340 \\x5496c3be99a9ac561103ea0c43922cb0b979a4b5a5105187588625cfc8cb417b636d564c17d57fe4389f57cb445a2d0031a4e5b4bcbeef04aa324cbac402860c
-369 1 420 \\xd0008d6af26e7ed789ae7a1ca51f4508555333c74542288be7dacb56dfdd8ec234c6cb0e3efb6644d704718b2daa718c8f4a7a2772ecaac51548ee2b0b925c03
-370 1 297 \\x3f42340b4aed77688ccc0360af19361d4265656629dc4245b587ca8c33495888a7562a9603ebc76ba033d8af8e8ed34f51b637d306283db3fde76838f4b71b01
-371 1 316 \\x4affa12946fadf2ed30f9a0bfb200a2f2697c5c578f0acbed3455b25a5c166509d1eca373d9ffd369872e07653f28cd3e147877ce006b2daade19ae66ca4620a
-372 1 86 \\x28a00abd3ebf833c98ee866aa6a6cb7f9d4b43cf731e03372d726d6794f11f849102bc3ab915d3523c399a8addaaebed6b19da91a7e4d9d480b15ccdab4fa009
-373 1 112 \\xd229b39fe8cab14d2d38b657d5ecac4200c847d4be01c36f6900d871381c6f06763c5ae42e507a9a78ed73bbd18c1b936c135f4859f7178b83a1309f4d026b02
-374 1 24 \\x98bddffebb8e5597cd781f358ce8673435ff96e17eac81800b6ca61eeb57b474955dbe86186a5992f6cebef12061af64ae69404bfb24a4e747d9bfa303ec0306
-375 1 258 \\x31a2f314381d18c88d54ac5e6088f07a48a08cca272dac2ecafb1a6e7ac1cdbe95c46d8cdc9e0efcea4571f705f1bb267f21bb7dae7dcfe6968a36e9a94b270f
-376 1 133 \\x9fa7b9a7b662d1fe1f64ba99696a7cd526e75bb852959ab74e93df46e8ae831a17abc1b340204da9ad2aa58ec2289786ce8d8b26dfb9442ead78e37d3fa6870b
-377 1 50 \\x46bd49d52a2ac12de93881cb3ea6f8e079e769cd5b171f3e300fc4911a1e11f5718f082dd7fe940c4b513f858f77eb6d8ba4d9310ae45bd10038e34e2dcf1402
-378 1 318 \\xf96058a8775f7b60187f5aad2875515326cd85349c22ba8ca425a2be855a1ce8b51647cdbf40854c7ef647054b27e43cfa9fbafc96039230281a2f4f8d831e08
-379 1 350 \\x3559bc9a24c2b11415d19dffa1084d89f27f6f8cb3ba5ff70cbe9703050c7357aa5faf42af100ce0035aaa4f0132e2cac7d1113e54354c080301728981ff4806
-380 1 85 \\x8a4ce8dc1afa094ce476859894127c4c345f42d727462cd14760b7e5bd55169897a2c24e6ea054297ae468075d141199efb2197fcd602b33f1930e01cf315808
-381 1 356 \\xd195c44d3f918d099a4fd2587c5ec89eb8ca0e9c0d92e7d4ad7b59e74056e4947a976ebf6a39e7f49273a92103e700ba1cc5c1a835624c59a890e1732b602c0f
-382 1 75 \\xad88f728b5926a4052e5d29fbc217c98ea3ab43fd0a3896cf25cc1483db9d941ae954cea7f516261e9e56121571b8519b84a229d3c21e33103899d01da326809
-383 1 25 \\x19da6c26e301e2f053571eff66beb9e15f0bda89e828b2da6c5fc97c01b1b0745261f51534dbe7c1ec3ab3430df3e0a59970c62e374779990d416af86036b404
-384 1 162 \\xb863680bce4996b4351cfd06a21fcaf793e15141be305ae9c3adc504d9fdaffbd749649819a7e2e32728868026dc3f4113fd6b77bb58d05e4da61a8184355b09
-385 1 23 \\x97dee425fb4fe1660b652600adae8476ff95f2d214d475596c4b4f57297ba4d02eadfdeb96fc19027cc6b4bdf5a876d5ec5c98085f721d30fa676bac16ba3305
-386 1 167 \\xef8024c473b15a6b2e9350ee1131eca532db700b7398384aba1ef1d6beba1378fb6ff9011ccc1596680ed3b9da4c6836e0a20cac73ed770dc02ff31070581708
-387 1 69 \\x48e882b6cfbf683656082bf213932b18cd7e1743f43c9f13885b811d374e2b353ed1fca7121f846d0f8c223273dc559410315d0d3445fe84c44901c1992d430f
-388 1 21 \\xd84a73467c9afd868be62e6af6785a2b187e9064018ee8cd4cf48d96bbcecf976374b471b64d5fb8e24f4994518f5f17bf814101e7fc3446ecd98602cb8bcc0a
-389 1 187 \\x04c23692ce92247ccf7e2497ceb1f08357be3bf2f59aa0753764bec27c65b2c7453afb009b58c427c658edd2f1fba7fa0bd71fec7fa12cd216c5ee335144ab05
-390 1 298 \\x71b8b6739759ecbed039dc38eacc24429798aa7859df51c5da1d35335cd0fc6f48287cbb8261824fd412a31e7347beb7ffadc9a7d3632319afe1837aed8c420a
-391 1 41 \\xd9a91103c20470fc6635d7cac1cd91b5c38d0c779fe241a2c91d117caabceaf8111395f23904fc79b7f93f09741d6e63fc5fd98e038b786944401420f7a53f0a
-392 1 284 \\x906d6f735a2f910365db4259dd985d70d9a100a79a25a0a652a6a9f2ba7caf70a5f244e36815480730d9ef6032fcedae37621429607fc3cd24bf9e893cc51e02
-393 1 13 \\x1c38f990b6ca51445f282d29a3aeeea0e304375beae241098754c31ff79831057300904194d729522a0ca68698ff870fa177af807c569717645f2b8961eee203
-394 1 393 \\x3fc74532c46a9ef452fc6448e2fde18fac7ef522effc04b1adda4fbd9e1abd4415ae88b8a7de4d68d75ac1b36a08a82e1ef222187bdbb60050c25fec40390e04
-395 1 33 \\x00886a87ce5ac00e39a4106c37dff86303b45cbae7ad1314f9d069fdee27d1cbf99d6f306ef2377ed037aba650c8618fcf00e209ec7f89460b0c3f686a2c920b
-396 1 361 \\xc09272bd77f666fdb1c9407aa803ba453c50c35ad95c9b6638d549ce2dc0032e83c9c47c6ad181c6c0ef2935619113769b31faaae28df207b2abc69972e65a0c
-397 1 123 \\xe0fa6ba192f291d304569172955492d71448cdcdbb7a23e5d242e75471b3ad28f2a42d215ece4247fe331ba2cbc9f907b665ed5bdfa6adbc06c325657eef600a
-398 1 278 \\x27c58b48213fffde7364072edee20bf012d0385a780136d8203462e4b11771a9773668098590b9868883a7a65227e8c730996fe30aed383881f7b0822832d40d
-399 1 344 \\xb01d7318b737d398d5813f820112febbec28917c7820bb0612130a159c67bb2925457ff85744ac76bcbb163f0efaa742ec59f6669b4c73a33f46e01c8d645701
-400 1 236 \\x89509ac5536c607638a9d4b897649e8c6da815276ac7ef8b8b2feda0f401d716bcb95bd9e542b01e31964ace8e4c74595396960646e405be5d3529fb01304406
-401 1 346 \\x5c99b6d28a10aa14a68df9dfbded38f58d1dee2e3f221516af82219d9573e9a91ef4eb7ad85c204d4016fd50fb2a7204121ff1a47e4b53002b83b566c73c9d0b
-402 1 51 \\xa8e2b71d33c049b2bd141102f989c16ee779e985ca1abdc00ce0bb4e4a58abb8949b58572ffd2a5a9f64341ef1d46d18fd94a1df5625fcd68fc10a8310ae320e
-403 1 331 \\x258e728676298ee106762a7ec721e467208dab6f8a202998e3160d0fae7e2ec152e9577b9d6b799272ca25668e1da753ccc3733281d3ffbe5cbf49db43c38403
-404 1 68 \\xf27942457702619602dfd5afdbf79ef6449815e39667edfcf1414a30ec99a73fcd917ba52d046ac3dd81ce25ca8bcc1d326b5c04e46d82195ef850c950e4e704
-405 1 109 \\x904eb0b8a28b79bcd8f4f7f8e4dd9ec5c138a94aef59a802bfbf07bb47cfb4e6df6e217a839c73bf1e561610eaee02d70291ca52d6af3f72cbc01fee32b33e0c
-406 1 372 \\xbc4cf164dbd3e59ee1930dfe91d06e7b5ade161f937a6e37f448dd8238da46f089206eb9973598bd11e53009c5c72aa8e293bef246a663dd5c0982153889000f
-407 1 178 \\x9c7359f690a2895ed9c6733e55e34a9482715bd290b6845146982acb5d1ae9c5923fd30b8b32ec06f3de69bd2e040a38778a35c235630d39d07cfc993695f906
-408 1 371 \\xadd7772ac703c96d2f7dc510fb6f3b4eec9de204422e2869d27fdbc281d155d4b4727e9fce58f0bdcbe70e4027cdd3c5a024232971159b912af3daefd06beb02
-409 1 405 \\x40441de34136b61f8ce5eb7b24aa83631a3c1677d4c4889465306ec46b4a84e34a5b24020953ae1833702151e4a5300e284d173ca28ecd26ff4b57efd56bb30b
-410 1 71 \\xf79f76a215e01e0be2f1d8976e24d039197ee3478c82bac777503c65cbc5745e9c8572a97d92ba4deae3228d15a5ac406f8c476e1d085a81910afccd3b163509
-411 1 329 \\x37e9464680398ac83d6577c5bcb2acdb7c220b4e288d30d83f3bdef935e5b2b87cb7b5dff99a6eb181e94d225331d96a6a9f5331dc1413ada1a5ed8c0841ef02
-412 1 45 \\x27c2c09db09ef6c2f57653b1b65e51f3e12c9d0a1b0e462973c7bfe6594b017404dec41532032fde8672a300cb2bde2db1c18919310582ec1cffaadfd8273c03
-413 1 193 \\x63609b16149e10ba0ea4b07dacc4ff748c5700ca80cb0a2cf225662754ef74145dfc5269f7dbaa20ca8b1627507b0b3dfa68d18664855d5ff5d585d11645d40c
-414 1 264 \\xfba30d5183831e4b6cf7c673c379eab0e9e5dabe110cf69923707176d338aaf4397ef83b3c75feeeab3a7e0d5415b38c467a706be915a43f5a858390c5e7e00c
-415 1 228 \\x6918b6a52c5ce89f8a2611ad5efe9c9ae082837c9186d39f7ea857f1eb9baf125808120b27d9dd6eff9731a9b452bbb915e81e652ae9557e63e20493ec361e0c
-416 1 334 \\x1e7f50b8a8a8d03394ad0c0e829044cdcb4a0e55771bddff39cb729b558f800f2e5bf4ef45fbf729317214d8e49f3675e3df602f69bc1254eef7fba1c17aac03
-417 1 3 \\xac9945ee31669e1fa4c6e7e84d0446e693a63aa73c5263c1dd5114fc5e0ce55a377f9db8220235d4c3cfa38f18447ecf66c3e132eceaf748db96f85c74f09a07
-418 1 210 \\x1aff25668aa9962d6bf0b06729ce9f2e1373106d4ea8a844c01427f0b35d4c79eefc7d8e4458ae0f2f12a4cb7dc12b5784cc709c1f6aea64f9391f48048b6e0e
-419 1 70 \\x6a56757d3ca6709d02698e35e8900a6905677297e8f42a8652cfb30acc4e494e164de94b0471339e4dcc4cd7b10f03297b279ee9ea5e2e928a96247db1daf80e
-420 1 384 \\x8024621a4bd9310aa016ec170f4339db733b9866c54aa46c4e54856fee8f17798c8c366e5babe75f31160b9390f628a3fd83cbfad46eeb88a1f50c80fe616206
-421 1 353 \\x4d44e0a39e92b51030ca7c051ea6a79367aa584914c79a81612d974e8d0199fe1b50bb5bade5e9aff81376ca9f0cadd32a8b8d4b9c2faa73ea3824d0f1c92d0e
-422 1 6 \\x712589007d765917f09bb4419698942d2210bc0760b8a0d8bed468300ed3bbfa083e6dc28d8a785a1ed1e89b11c15b1aab5531e6cde80c18f0cff8cce4e05107
-423 1 181 \\x6c0a0610c530bb5321328a44e2246fecd71e3fb58f21fb125260d3faa625a91a61cc12d42782b9cff809554fbf412ea8a14245acb06941f2bee72d1533402801
-424 1 104 \\xf2684c36ab39e85b2e3c456dd71a4d70f7447798999c496f317477cad43d093fd9f936237e0730da684b833169186dc7f0900cd0cdd34dae1428860fcfce6b0c
-\.
-
-
---
--- 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 \\x28c303bd44cf2932c4c07648c472632b09ea70bd26d3fb442442d4f16d7976d7 TESTKUDOS Auditor http://localhost:8083/ t 1660654496000000
-\.
-
-
---
--- 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 3 \\x607d26e58a91bfb241dbcf01f99ea2a512b16a12681573a42e814ffb721a265992dc958947d47d60e581f33a7255d1d8ea7d1798c95661b3e5474c947c87580b
-2 228 \\x522b2f1b9ba6505e5ce4275c8294427043d82546c7ac0e6d5d3db7277e4385efae67bcdf1392d69afd1cb4375d9f71dc294752c65040b4791444e03039986901
-\.
-
-
---
--- 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 \\x00b06faeb6e532e151b3473ff1aca08cc5666ca63e2350152789e84515cc108392238c0270b68d988ea9eeef2906751ea923eeb9572a501d01724042f7f5eeb6 1 0 \\x000000010000000000800003dda14c02893abbc149ce0da89e162c036ad9e8e67eb2c491f9fd643fd855d6698f0b0f1daacc5671f9d30dbf430967624bc223d28a46caff79f27b73353faa4758c6e25af01f8d0fdf9992f7c5941cb76e86ebb34f9b57b15c96eedc026b267fc6780620ff32c20af2465874a15d5592a7e8df9cece207f513d6d230d666612d010001 \\xf2501ccda29d5785f52ba5467afd949afd0ce9180786e0d0c9f9a111dec83dc1b42107a4a5253c766c2ee614ecac604e48018d0ec599c792af921ef4ee1f130a 1685438989000000 1686043789000000 1749115789000000 1843723789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-2 \\x05748f14db2f6ace8f06c2325b5f69e51ee4180dd6002c13adcedad9a4cae4bfcfca9533dc89ad7c56d8db73197c167b76e8c0beb3b19c37111f8f10c2e79865 1 0 \\x000000010000000000800003b3c8f5418eb645be454cfb78109f1c825f8a8aff73ae006def491f90ed63334fb8c09a549546bf17c36c7e3ef728c0cdff98794f0d8b6eee05db8288bf0ee316f8ee7953e5ffeb8dbb117556935264dec29b79d85af57d6cb2bb960b530e1dce9b6edc915861010ca347d0d4ddeef7dfdeddaa18b413c0890a6e9a8cc6ad55db010001 \\xc942a18ea2980935644f8aa08b3fa6a399ae4f1467019e628740c37016ea642e387d1edf1662c6d706ffc38ee3c7af2bf93581ccac6891da4a2091a83d386d07 1685438989000000 1686043789000000 1749115789000000 1843723789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-3 \\x0560e21036d3ebefa8ec29de004cd164623eebd00ace97f014520f79d95466a55f8598566286e831033865f53ed8f61a9743c56a4196b9d84c59ed96952e0830 1 0 \\x000000010000000000800003be472fa3940d1d42f8143f93e62ac271f3adff8b0a9a91f5003139e01053d4609e9b27ca769104649fc9dbf02b91aa6e0a7c02189e7413343c1f5744a07dcd29383b3f2cbc93699505621b65568209cc270c86fe827702599b197b851bd5c800209711dffed7e663e020f15a018f2bc9c0d47644e8cd06118368e142725612cd010001 \\xb226bc05c3c3fe8fd3d895c5dc2071d4293d17790b663154382243e5aabade050c5d23231066040e7e8efbc6b5f171bd1eae7f777da63658bbf07cd5c2fd8900 1660654489000000 1661259289000000 1724331289000000 1818939289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-4 \\x05001455a02ed1f93d00cf44496715950bf588188d9ac46a2f24a630208e444f847d95caa299754b9245d3bed06a568fdc5391f75a14cc668d86e0e09c65804d 1 0 \\x000000010000000000800003db38978be361449dbdfac5b6a62deef17b4da7ee5dbbfd72a6e985f4b02ab65bf5c3ad7e90099373c6dadcfb38147069501c52110527ebb07999b1987a777c4b172e5f6e3144c238f45d4b2ea106659069d644b5e6c6d468539584c3387d5fbf7fbb652f13f9065d175f0b3e4cbd6469165aef931a1749aed2188384e0a66e03010001 \\x3392e86e21b6d344d4e2e515497e5586171a23ad8a6a030e55645a0b8312cfba78326fdd44a1245ca5ae81f13c80aa1b9765ced788f5ba4907d7529ca5559b01 1691483989000000 1692088789000000 1755160789000000 1849768789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-5 \\x07b43578bc643c89cf224bbc05ba169ad60b93c55fd208b5d89b20a3d636164dbb57c522baa33c69d154bb423aaf38b61dc43bf5d195d71dbc9056a415408284 1 0 \\x000000010000000000800003ca5eec68201017629da7a6e86377df4e00933313395e4628004c28eba84ffb9cbaaec17c3a4efd2f9e133d090e375444741753db3fda008d128e9fe6b343564d9f4c3a2c30c557bafdb69c01a3c45d758a317eb7c7256dcee195960c7ed371981a4cd243eab9b22c4d0a883cc5cafb39b6c6400e22cc635212635b6a29e5dedb010001 \\x55e52571dc9747287fdacb00b451fefddcdb710a9b728dc5e0be9afdbec89782156a03ea1ccfa6bf9d7d5750f26275d0c69adda37c9efe2f7e8bb74efa970a09 1671535489000000 1672140289000000 1735212289000000 1829820289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-6 \\x09b019ba4a0a3088e5ed64c73d1b55f41e9fb6d3b7370f702a22e90d52cf0521f9dbfd052ae227743b09761338ee41389d54403f087e95d1d429b02d803e1e29 1 0 \\x000000010000000000800003d12deada637d84225321891cc7036352d53039f74426c63945f7f2655be59bfd4ec5daa54f23fb56e604a5ec71c877137df26c9e6ca44725889416147cac2c0ee940251e7746d3218ced499a8f464ac2f5f49eb62f892dc19eedec596a8dad08366a1f8d144b5f36a9633e522bcb5354dc9131e5e4c6fa46a9362700c455fec1010001 \\xcc9534a7c125f80364cc9afe55c3fddcca5438cccc289f42dba777d0cb3cfe68661136dca1673716242707356a03db6970c0a7a5082e7a4b04d14f54a6978900 1660654489000000 1661259289000000 1724331289000000 1818939289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-7 \\x0cf4b91cb0201e9bfed6bc331b000d11a73b20ae40e9eac38dd901992281e45dcbfdeb67b8453cf6c66f2fedb47a1c3a3396aa5f743f0406f96d5fcc3eab830e 1 0 \\x000000010000000000800003b6f7f688fe8a233916f7fd3344501a11237021d15d7b99e29d6b3803a628883ad0b482b516db993ee65f8a9e654eaf1368dec93f5d6899b8fdb14b2c920e73dc726e6f04e417e2a140a288c50b00916cc9a45fa9c42e8c5a191fa5fe9373558e0b478844b43b52d7bde3c8118d6414c9a9fcafbd0381c40ba5feab32ace83175010001 \\x712b8e696315529c2a26028f443d056d72d99b327f7faca72d8482074ebdc8f7839b9ae898d395dfc96f2cf096929e9e58890f989fa9df1e955d3d9171d27301 1687252489000000 1687857289000000 1750929289000000 1845537289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-8 \\x0f7010d16aade91b92edd4c1edca5a475ffe5cc5b88427072cfcd98a576d63bf2eb3cf4cb8239da7c528f73cc3087e85491da59a6873985c8f6b0eea9adda7c3 1 0 \\x0000000100000000008000039ee705789c4e0bdfedf672bfc0d016495e4e2cb4078656bb6dc6755a1bd71c66d0341fa67f28ac60f81522c3d5292212eeb7247af2fc7b17b5002c128eda47bdeefc4137c08ad2eaf066d709fdd19092468bb2a85e2dbba492295647473a3fce978a8af8d2ad86db7ab7533f162c7b45d4b67b800839d2be649101a8c1a79e0d010001 \\x10a413e31ea0c28e937bd7dfc8f92e273cbbc83d92be39df0d1d25f981c777d2c8caf2f9fb459a8f1386c795eba130421fb1a4a4238c7aa1d531c7abdecd5a0c 1675162489000000 1675767289000000 1738839289000000 1833447289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-9 \\x13bc52a51bcb8fd54618da17e9cd306180c72a576b0ee3a69ef1aeefb9a7839241beb2a0ee6eccf6396279f91c3a97e9e1d2f61a3d8ba7f8776dd6eaec2904f3 1 0 \\x000000010000000000800003d165642c824d80828a1a4d2b027bb692d6c6e284572a9bb252e8605cbd9c98abdce01f9c64365d800139a93c3424792a634e18cecb0fd4b13adb670008404e2a95c738401a5d0b016b6617345847011f8fbb3e625d1280950bf202b5f6901d40a3af51b7d8e95c72fd21ebe2665202c48c82456a0965cae0f90d0f1b2e7c4237010001 \\x90774982ff88f5538f6005f4d3f6d9dbb9c6f74e79e035997fdd83264b97408350ce2d0713f3cc632056a7f8a743230408b3f8ea981b137569a9289d5c491506 1672744489000000 1673349289000000 1736421289000000 1831029289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-10 \\x1414bcb4d095eddfbe632130ffda1218601efd7de1af79430286f67fd9b404b59df165c3e40e1cd3d6a047961ef902b32a3db1a703f8ee6f759191d8acb62c43 1 0 \\x000000010000000000800003c10f0e436989cc8f5737fbb6f4e4c52c9a8568f70665585c5b5b95bf34784b1b5ef2f28116aaac363831caa5bd8f85efbe50b72c02d5dd5b2800f4edbcc26a7349b5996fd09b9688c85e9ba607b54941c0f57aff9072326b984aa30b0630262df2068b501d48befe1d4b0445f846ccda2d9fa562b0545b8a7edbba329fdb8ed5010001 \\xa63cf5507bf135726144da968633dc0fe2f2605d83fc8ea6694c6a8d44a3d513fac76e23f31328e4792bf899b641d53d3194bf1a9809167e6576d583fc379106 1667908489000000 1668513289000000 1731585289000000 1826193289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-11 \\x142484b969d0691aead192fc2466ebea93e58a0f389880be2801155d0fd32b12289891ae0aded390dfb60bbd87d84cc52d1e9fc421772f4da80e42b0dbd4eef3 1 0 \\x000000010000000000800003b87f65dbe7f3ccec8eae9e7fc3ca058992485a01a381c9063c0e6e792ac36ff8e0939bd0b0ce0c774837f2bf1bbc51a89b497ab3be48484182b74aa11413dd6eef4f3cf46465413e3f2b97d59c4b912d68d1b8e277243a8d5d0d0563eb36b7200ba522d062afa114a298ef948879b03d6d55f47355b60e0a66237ee2c6463bbb010001 \\x6830433ead6b27f9f220292ca7324a73dab2c3d9504d4aa9ea0c900b2085ebd59c1a15eaf8d00eb7cda6b17828d503f774ce32e0b3dac16bcc989fba5ffe6608 1673953489000000 1674558289000000 1737630289000000 1832238289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-12 \\x15f4f7c6aa625f799be25c5e9ea2a88ca6b2e52fccea1a67e9118423305613c8054d733c809a8f6c7d536eb1d8d76af2b5e27b82614db6ebf60168d26655dd13 1 0 \\x000000010000000000800003ab699bcb69d0bf72b91e880eadd42fc6e84bf7e47cc83afd95cdbdcdeeebd461a9fcbe32889e4d3c4870b756e2f447cfe8e372e4a0f6ec3b32c90525cc901532404b49f5a6f3c60f3b828caac29b6ce1ac5dd671125917b5fbaaa1adae4e9fed84e495c3b67b1ed3fed05c95fa623c2001704f3fa6b7d66521670abe06800199010001 \\x6cf35c2551c49d0c8cbb4319987db25c787950688447a5e4639a653a6774131020502e9cc23d6bcccb55dada6e5069d36d2ae29f4029c65815a7b290c3d6f000 1666094989000000 1666699789000000 1729771789000000 1824379789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-13 \\x1764f41a9244c00dcd4f6e2f1a61cfee7dae79c10353751bb0639b886b6fd879e4f395b69278ccc6b07f54b968224caf2c0d65d4d43c25f6830d2f01c32e1422 1 0 \\x000000010000000000800003b582ffdcfa7ee50761be0b417d0148d0eec2c93cf65ac702714e33502a646a23062fc5f3403ac6bec5875e0016dffadc91961474e437b157b12a6fbc0474c48497d3ff5ba59f7927993d339cd0407e08ccb6b65e176ab5c5cbd30f0f3eeabdc5d74c976c927ab9a5e077b4b9014bca133f5630fa4ff53ca893c46f854ad04749010001 \\x9646515f49cb5237f32b3c7c5a102b2b5d316c6303f6b3d4b2bde0cfdd8154078402d88fe1d8d062b9e12b2c44a22885f9c093804db69e23240a14dc03b38603 1662467989000000 1663072789000000 1726144789000000 1820752789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-14 \\x1990987f985a95f05f09bf4949dbed8b1c9a03a29192ef46958a140fb9075948d1922cef357aea660eb7aecdc087e2debce9065c1116981697df5d58552f0b13 1 0 \\x000000010000000000800003c270329272aa3a5114c8117efd90d36eb71068a9e9957c9bf42246689955868795be28d4621b6d346104fabe0b191b211d221c38bda6d97ceca4d376d4a0e1c92f33168a4293821ec575f2150bf393d17230edaa19d2e288b7c176dc530202f13a80372b62dcac5c2b5d9e3631fdb8a09e38ccbfd80c7062e568ca5ac1f03645010001 \\x33508e25937166e27d05c5bb721ceef25051f2d7a54f6b1c7d0ebdc52a74a5b5b8d8a5468107534d8d326e855bdd9033e26a13aca095e45d30fd58fe9295680e 1674557989000000 1675162789000000 1738234789000000 1832842789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-15 \\x23bc55e2dd4cfe8c01ed92102ddfdf25c466eb76a07fcbdb0b2a992512ac48b3c567df3f7cab5299f57a9b8fcaa77b8bb94f160a98945c2f1eab7b021981cacc 1 0 \\x000000010000000000800003d3945e4cdc833ce1ec1203dec2c79d5d5c7643e3fd677d94abedcd364075a4895c4df324e4248d18d01e8665526a1bdae2053fc47062516f04051b98378168145e31a0b2cf3d2371216b3f8332a41563f1f4e5b61386932b62dc4ff7a85b86833b90755691e6b682da694f153106ef1a91223b5fd83f45c5e0b9c18affaabdad010001 \\x95786d8c9201856db6013dbd13a2e4283ab15f8326cffef5d8f266b86c04f0191591c1a0c14f9f93b37bb9ffb50c824a373c4de9640c2a1697126a486e877b0e 1673348989000000 1673953789000000 1737025789000000 1831633789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-16 \\x24cccff66244c384340bd88524d582f09127bf09e3d0892423d1a6aa799dc09ad2206e21f767636537eee75ca1c5885ba50f0a67da92bcc48f7d3e54ea6189e4 1 0 \\x000000010000000000800003bd62d553d5af7b09659186a90e730cdeef5f1dbe90e77e660d37b8d357cc988895acec3a90ffdd8262c44cf7ae1ae281a4f835727060a1aa261bb74b5c4df344c86772c6cd37a0780f1a3bbd3ddbdac6942af9909db58c1736892b0f7d6d2e65c1b8773d211abd8ba74eaaf743ad997172f891f530a3493f5774896c4fddc3e9010001 \\xa7eba54a3dfbc43017a4d3f0f7c1d6d58c133754a93de35c87d203d17fe04542f5f370c87d493383bc9ea9630c4dc50c369b603d90aa6ff37fc5d66ba423fa0d 1669721989000000 1670326789000000 1733398789000000 1828006789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-17 \\x25d4bf4b60976f16ac27fae0c7d4ec9de21318b575068b6f76a01911ab8ba323cda6bf1a61de7978c6bba60a7d82de884bd20bd18a34608c16944a5d147afd6d 1 0 \\x000000010000000000800003d2dce87303007e9d1fd1cee7eb6f155bd254054bb27dc7109ddeede53caa5a1abe60cd0de7d3e12e11deafa1c7a7a4a0f44bf99d2572b5bd451dcd54795c7997494a3357808155aaa9fbe4e2c6ea68e3bd9225c83f02e8f5a3880d484d669fb526cbb77a5a067bad51cf66414d1fcf01b220d17e6de7193dd10aa67491d54f85010001 \\x1460cecae0ef05557f173f9dd4c49f98831fa824b61ede45b8987e8d5372cfe70fa0adfaeca2c2ac511f26709b536f217d098f432fa6c8ac3f3611f89897f601 1681207489000000 1681812289000000 1744884289000000 1839492289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-18 \\x298497a558268311a412cf7aa8409cc2a8ab114a9e4c314abcda787ccec174c154f923b54ac324356b5590693e249860b9be9011f68c078e4b3cc015259b08c0 1 0 \\x0000000100000000008000039d52d6740ec43726cccc90d57fa35cd05dc91b5cd8002d713612c0b3a7e6bc10ad5a4f3dca97b712a2f12487ee94542877542b40eae485e82870fa29e0599765abddacd2f81f191b44c300e7bae38b6fe0175bc5fe26270b4d3c0819c6754521343ddb0a547c8d7f5dc832e4ef76ce1ca79c130ffdb408f13590c1d1c5b3afa7010001 \\x7b49cdfa5387ec501566738f270c48a9bc13b2816d23866ff33d3fa49568d7d8a7b8f39b4eaedc483a422b6ce6e6b38b6ac24386b6d03f8829a611ecec9d0208 1672744489000000 1673349289000000 1736421289000000 1831029289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-19 \\x31a4c19b1a7e6a1aae752b3a0e6fb7e2dc4ae3daab05090a06809ca809f5740f590fca09ba099ed11baad9d7cee7f219b5396ce0433907c6e426c8cf608c34e0 1 0 \\x000000010000000000800003de531caf80c94d6d927df689458b9aa25ea03ade54cb2e9f65119e84ffd17446fb4649fc4edd003a03be53d2a9deebc8eccebeb45bde7c3676774bcb67e3a15c2fe6ab6f3665223c325c979b317b462cdbf3c929620b484b98110a3a8f4021d1d3d7a13f263b204c69343230e1122e6ba49899ba6ae5d48c9d39f8a5a41b1747010001 \\x133f16c411aec815ea7cef032bb5cb4cb7574280a9ab47978aa130abd214493c51e887bc5bae322e8defb140bb8ecbe71b808eb3da6b01a57d8c8c6de9687503 1685438989000000 1686043789000000 1749115789000000 1843723789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-20 \\x326435c799170acb2b2c3872a4e62717b920566537d70f57e4bea4f7a8adb6afac41c0aac900601e722307bae3bae33c622907a28d6d353ae2546b13e3e66c8b 1 0 \\x000000010000000000800003ba7ecd2c23246a0ed3dcf3fb59148b9bc9d7274f3d2c85a9bb72382352a57ff3a11bc3cedb0b8c41221cdf34b56053c13cbfb91b5084fb142a305850f9c98a3985a94604200ed0378c4b023cc6b8226817492113bbe3b04b27635c38e8c1b31e840f2f443024c14bd5c61faf59241d4c6dc00077e920459227c44dd3fd4e72b9010001 \\x74a7524b454ff6f2d9a91459b84f3a0c43a7c63e932cc4328a24bac52964d67ed6849558b9f6acb6aaa48e0f55ec1711a0ab247da24c48c186f265dfba988504 1683625489000000 1684230289000000 1747302289000000 1841910289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-21 \\x364067c0248c1f09bb257af097a0cae754e54722464a06aaec638fb2043c77c9104233a8f62622a23e33d20d6c11012160fc8a1234cf1c63fd1e74f0d517247d 1 0 \\x000000010000000000800003a8b0c27caecf32585d4736db7d659b715986b7958338efb34b9e28f6ea81e43f6cbd960b3f46e213233457368aa3b0c7fefccdf397e57039d92acfa88f8a0dfde84e3d8c6bdb6e0aa69f84d7864ab13b4eff8c220a5715fea769d9af68d74c3eecaf3670013127e4c7c736394d0e57414f7140a6d2ff6ee7c217be25af49c213010001 \\x8885d4150e56e065f8c1454791484df38d285ecea635c738f9276141aea09fe2b44b2d299b6738f1feb0d8c6e4e60c9a51a1fdeec069055a2babb53b3a89a000 1663072489000000 1663677289000000 1726749289000000 1821357289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-22 \\x39dc49df328b52382a44bbe572de2e37b789171e4ec39a11bbb3704d3731786688016fa79b029dde4541ba630f88c3e5de495d7c65998a8e92bb9275572f3685 1 0 \\x000000010000000000800003b0ccc2b28f15f75d8c663b49a417a916b7776767542bcd3695f5cf59993b8185ae8927c648ebbf6036293713c767be8c62a12cc3cbb4be7f8741e1479bda06a5ade53934eb8efbcc8c54049a7bc3b79fcdb2cbdc2748eba963d95719f15f62c849a34f146fdb382b02967c47ea99780852ba6088f835d42c616175c784cee3eb010001 \\x362174162db88dd4a2fc54a4d2d8045936dd95278af75e2e47e259f744419d59f4a947713368237e3f279158f0f4b0ac94eabfa140b33f4ecdd39a85acbc5e0e 1670930989000000 1671535789000000 1734607789000000 1829215789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-23 \\x3ad8031638f3273fa756a7ec35f313219f3747c0ae27b4050dd5844d87f38b5001b14dced86fef8bb6d84256497a9d0aaa20eee3a7dfc7c47fd9f5e15ce54b7a 1 0 \\x000000010000000000800003ce1cd8b4b59c49ffc2416abdd2e0acb0be9d2e9c37b005986a40448fbdd4a878339577036c07e541b3524946ebf2b436692ddf5b90aa49eed29cfdd4a07c55358dfd32a145829e71875723ef544ce1fcd68aca65d55e8e667bbf7383741224300931d367293e460812615514996da7314c20ea811ed7d1a8e3ef984003441e03010001 \\x7f68a2cedbbdb369ccde87d5b8c2573b123b4ba6fdd946ac0b3bc912c0578b56e42e53e402a90444e216f4acd5879db6c0c18c30d62dceb0feaded4296e3d703 1663072489000000 1663677289000000 1726749289000000 1821357289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-24 \\x3a8c2ae755179d485522c2dde89af64840f46ad46f1bc4b555751131bebb1e25125c23c1475252843a596bfa84deec34ad769430b04caeffad8a40122507c13f 1 0 \\x000000010000000000800003a2410207a49786d4211c144c31e220a557cc31f746db16e990ad72b9949c0b82a4e2f934f1cc46f37015027e934b9d55e509bd1415a973ec1d7a0cf43ac6196ef58b56d47621b750f06faaf0c8f3af978911ac4ec2f2967e11b6ac0f8aeabf29fa88f63d46008c9483b1a6c56f97951b5684956786d8780bf7757eb6c6d67771010001 \\x1d686a74179b68975ee9a439da484a6d116c35038e435b1c05528c626e01498fe530feea860b34e4cf8224080c5fe858dd6d1e8f3dc409cb5af6d1dfbdcddb0a 1664281489000000 1664886289000000 1727958289000000 1822566289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-25 \\x3b2c9f356cc0adb895683d2da429ea359815198e471d661681980dc9026adc1a422c0e3d95364aed9908a4a2aa882fe88614ddd4ec417b48cf8a4cdea35b5b21 1 0 \\x000000010000000000800003b36e139b8713ca6e22719af18081f6a7ebc93ec82c87e03bf5e44d598773f3f729fa668e1dea6b68ca86dab0a4dbe1f1298efb50b0a8ae351ec76afdc24df8a84848b792afc062e5f60f669e34f5ea6364e7105586f59799aabc6dbb8bc23cb4540c349d505ec856264481dad6830861d83b4e3cffff58149ee5515771d6fa87010001 \\x112f59e0d0575af163e08e613e83de8a184091412475d1b25801d1d791e1077abd888e565a4978ede636ddcb0dbf0fc89d1093ee4b3325112f2acb84a80d5006 1663676989000000 1664281789000000 1727353789000000 1821961789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-26 \\x3c70f8468a74c2e948537c90391c1155c4c22645dc424b0344a5df91af32c7cdff11a67a666144c67116c567e09d89e2583c5c316cb2937b3d01701bed3def2d 1 0 \\x000000010000000000800003c2c00e7b14358466b86587cbe7043bfa5a5776e5924f8eef55aaed3e8376516b867b73c33ef791061a0e8940bfc26155e87f778cb5657688e8288a10099e5b5b4083f5000d436a197d492be9d6a27ecd717264da5b4991fb5d4a8f21ba55bf11677f87d36af599939e19990fd0a60baeebd7d624afecc332f13149f7f92a627b010001 \\x1b22befe7cf8960068bc78fd808c47574c9c785916353436dc18983be6006cb467b4d4181e04a0d3b3dee7ab04db1d84deb129884b9fe2763f388e0fe11d2a01 1689670489000000 1690275289000000 1753347289000000 1847955289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-27 \\x3e90be0323fc3e4cb9d9f1fd8ff7bee6bdec055a0bd546ed2bb5e7f36ca925fc92d70e7257fb43e7db07c9b980d1e994ae5284acc8140ff7976767e162bf4964 1 0 \\x000000010000000000800003c8e5522142ea58cdb3e06de0a7c50a00e26162c79e8bc40fef5ff6e51042bb9a070a21359918607df6c82303188881d6b1176ad3e5aeb6d1a7cb279f04417d865c1e33d5705b6997f6c66728c8b658044a44ecb8b7123e9a03941ae674d09282e6d3592cb8ab3b3fa4e63668fa7fc1976bfadef9a1e40b9b08a797abb1cf3c2f010001 \\x06481e842bb886d3b5e9b936d79d8fca41fe08335b12743ed9d3681a6c67d269dccf834a889e47de75715e650a6959eef11ecaf6c700b8b4bdf7a7f3e11d310f 1687856989000000 1688461789000000 1751533789000000 1846141789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-28 \\x40a8bcddd230f0416d348f64c17bda0c70e80519939f59b1f0ac64784bb4a8560227b198b58765721b5f44409e9394d923b27bf2d8e9012292db52d3715a7a24 1 0 \\x000000010000000000800003aee96a211afdfde0b9c742f65646b340fd3d6ecc94b8e9065b47e34d8d6d22e2fb32ea17a5721c0e12124e0135b0119eb99268a1904d2231feff897af702a0a35172e64b22e83b5575754eae854900475705bc312d4404e1c39f99a3b0619696f99e76c8a51b875483288067e0f9fdc5db4ad0a72886efdec580eef436a03f6f010001 \\xc64558cee47cf3d0636c1a2e6d1e66aad5efd878f6a56dd3e0cffdaabdf7269c980c73083dcd1d5c66ef1dff3a87d81e0e6c2fc109e824487b9bdcbc4a7b0f0d 1686043489000000 1686648289000000 1749720289000000 1844328289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-29 \\x41186b27451b29f3edbd0ff0745d8623bdd0a76f1f853b4b04a30addfd5bfb1e1b03a503564176389214bbff206888d1640b7a3e35b4f3024e7b7254b48d5f94 1 0 \\x000000010000000000800003c16fea64614f56ff39a06be38af022b94821cc55e4390574b1a1be84377e0dd7f6a34b47c41a15446ea91995de5495043ca6a51174e28d30476cc3f65b7da1c9c10e7996ae81fd8ac843a03f54eb820a5d7ca81a4637c3f089321d69fc20ff7d624a47f87f08b11bf7e09d92a3dea19a6dbe360877aa3471ad49d434cfc1620d010001 \\x77625dc720d8cc2a123c6be5e477c083170bb56265c90f3dc35d68ab6104edc833f7758e5562ed2aa0aa2f276e609c42512a27433a9a72b7197aebb93e5d0a07 1668512989000000 1669117789000000 1732189789000000 1826797789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-30 \\x44848ebdd494c89120f68667f39ac017fba65f153a21f658a0af35d19d35f994dd9a74b35c5a7a5a6e2dbfc8cc56385961bc06da213fe08ca6ab4d209557baa3 1 0 \\x000000010000000000800003cfb0c7baf5d6b445757b98aedb3c74cbd5cb08f71d4edaf09de8f7b5cbf55b73aab9b0882d8451aee6f3146189e035d587a44f869ae45c3dd6e7fa3843cf9d53430c4b97eb06bae8a08afc02e6aaee628218c0c45e65a5b4e2d463f573fe3f19d26ac3d2de0e250065afe6591c2a84381c5f9f90bf4af3c14becd88e41f94207010001 \\x8f31a5ac3579149ed4ca75d18c523a5b8d4d9d45c45f84602a1d7aecd2e0cb7d1578e26521e029bdb8d709ee2d4739a5bbab57b70ca0530468eceba1da0f5804 1681811989000000 1682416789000000 1745488789000000 1840096789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-31 \\x45d8b8776b1804c3a02a249d8cae851d3150057f0f218388fb59cffa614669e2d1e811a99ec81e16a97c0f0d93eb17f6d1c1a4f5a65633b8d3ddf9db267b2cbb 1 0 \\x000000010000000000800003ac4cf88da530fe076f35d2dc4c6395500a7c1b7b9c7b34c5439589cf3e3d947f9144c90ff3ce72a5ce3516ac49aad1ce99c75b35731838d4a3ea1dc1b95a6e30180a3d909f7cd666c0892446c49f61583bbf637a74b253065f08817575e38aaf1798db5ed88d98973ca9b0c8184411c0f1b3f7fb0d71759e7efb864e36979643010001 \\x66cb4a8947e17f709131c8ab68e3dab00e547bab32d43249781480d22b8ab7c27e883b77e3f74cc704859cd73b77a06944f2b1f9febc8f89ee0e83a37b21a401 1687252489000000 1687857289000000 1750929289000000 1845537289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-32 \\x46c0f55c6962f8df01fada202b99c197cbbfc78526b888020b4a7aed9fa17edde5c153f6e49e716e1ffafef1ea0d752dad5ca07340116e7debbcab7d8099f354 1 0 \\x000000010000000000800003a344b7d78c040172a852de315f94dfc6028c5b66857c0ef1ea59b966cd713bc6cd19239f3ed161f16a52353a27fde160a4f4dc539fd1951cc4633c6dd05ee5a464b4e90395db80d01aa8c6fbae2015dd777b32821636fdbff6d7d27d343241730ec134e87928b9b29db04aee55d7a3ac2031a4b7f5786bd90c58aec0ce1f08c3010001 \\xb89d97172362e291aecbf6bb61902df352abb2d7077b340d7d27c86b7fca37b109d2b28335876923f103f38aa86fe58f68d5f6f8ce4f6613c0c5341cfd97a807 1672139989000000 1672744789000000 1735816789000000 1830424789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-33 \\x47c069716cb002cae0a4790c9522bf5c5b3fe0aa565e6a0ed85b2190923e2c5ec3545973d1c94a0134d879717205b5b0be99884ba9821dd93aeca31153947866 1 0 \\x000000010000000000800003ec334267fb41505e3ee1bd81cb5c5064768881cc3d7de91ab5a9b62c591eab3f1c9ba0d5435e4dfe0bbf678a0ae7c21d66709b925376b78be42702708fe48575254d5764e439274a06a0be4e4786c0cf7deaa53771ad6862c90a2261ce2f8c4f993b4253a393aa38c7140323283d06407d9e8644df44654dfd5ce529a858abed010001 \\xd83bff9a5ad3ce348165d3a2a504d5a2cfcacf9920bdb8a18fdb04ef31a33d07a5fd9bea0f6f64006243c6af460460e83015136446da9cf926a1f0b0f2e9ae0e 1662467989000000 1663072789000000 1726144789000000 1820752789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-34 \\x487c76b6af732fd34a0589304964ccf5016df78441ad9fe2bd7d9fa9d0dee01ae88e5e31b1cb56554d75c263049423d5a5939d9ed6006fd41ee43b443441dad2 1 0 \\x000000010000000000800003b9c31d8f72976fcfcf549d3fcc5f75fa07174eb70fcbcc7123fab1191d3e11a6a58168907874d5ab9fe7930e98abe140d45ef7441e69c5813eb93f1bd4efd85c718bd9bc0fa0d5dbfe467146cdbde07bbdab87ec47fd321ba7b1e2ee0b2d8b8260fea5719494467f52697f790df53966bb0b62398a6c63b8991c7c575098f759010001 \\x7a898f9a95790eb12d2ca69e9ec33b58475b1c19e7d54481bf71a96070953a92eb2766527ff806e6583375110863f3ca545230179e3aeed2a80eaa3d94e9b401 1672139989000000 1672744789000000 1735816789000000 1830424789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-35 \\x518cf0d65524719d0eee8856188ca67859590d6ec1b3b7113ae8a0e0b59cc5a75ae1d912acd65553db94ea90f40413d20da0788b13e338063e670f628ef08d18 1 0 \\x000000010000000000800003e34952fd616114f2852826ab5bb847a934d17417da9447836037908b2837b0db534a7aaff3ca298c6cb9df469c6b08a0aa22caff21b77631a80d27399365da771dc74ca9efaddcf720f71348b94447611ad4d4570a94eb260dcc185a110f7da2a35594090910384e2cfc2f5fffeb47ae02b4dc3082bdd17554ce811f98ee5925010001 \\x6b81cb1bb351107acfcdf9e5d12b9d446b8379bfaba1e40e63da3bdda70feb59fc15172b913d23baa58bb9988dd070a598aa6904c318f54ee4eaff36ab923505 1664885989000000 1665490789000000 1728562789000000 1823170789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-36 \\x5894e67e1352b388226a0ae1813db9286de57fddac29789edc9bd3dbd0b3cb9fbf4d2ca44edea1c492b475cfb2902b3873f18454ffb408e6be2d553f4d74d361 1 0 \\x000000010000000000800003a9fbcb42a3370cb1596c78a2326ef5fd9e977730e32b1215d109e1400deb8289e1f1b46cfe064b2766ec409f76a2ac53c8f42246f35f24c6b0305ee21edaf5a5d9f06bca260942b7c0ebab0a13b6f341014ba4cf4541f667843fe23ebe16e37cd41d4b876d7a9bc8bc5d353fd653aea73b12c03ca9ea6d78b8af553deeed773d010001 \\x8377f03bfd1aed926fbdf83641cb858d63b9428ad32a9524de4bdda0ac7a8fa7b477be4352fd4046c41912b7cbd8536f18849ee7dec44607b1f45d4ab718840e 1664885989000000 1665490789000000 1728562789000000 1823170789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-37 \\x5b5443c53abe35d153b3cc3d2e59780be684ec92095a0dde3ac28cc43bbefb67e5a6ac98e02e54edb508de23b3fb71701b33d5864748049007257bc5184d2b67 1 0 \\x000000010000000000800003bf832c79f1a8c484c7bcd400676ffeb700f8819f6fa9bb40733e9e076a4d58588bc3fb4e548a703f7ae766d73ae870fd8ca82b09e113d8dcc1e8ee7df06ca72cebaea1cc9a08d9da03e619c5c54c1ed401350345141e343b43728921f8804acb4c5c5818ec637b097d4492670629da7cb11e31bdd901553a276b24bd721e4d1b010001 \\x857a175558877d65c26af7b135e1e98c0d56974e73d6ab3d1db5a1deec0df23cf0e4cd3bceee011ffb2fd33c6aa110cc2f4afd4c032b63daf97d8d370341fe00 1678789489000000 1679394289000000 1742466289000000 1837074289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-38 \\x5dece051dc64f651e156eec85effebf35f2b6fbfd60ac6f8433548d8d55c0e3391ff4486126cc39ebaa457ef5e3d560f88ca6426a5068a2e0b908bfccdfab768 1 0 \\x000000010000000000800003b9e0ac46b121f6289f2e82fcd6edf950d56a2f97cbdb2499b4d0f4999798d3fa8915a7931892b37d83acab2a59e420c295f69acb22205b6623408c9aecf40bccc12e888901d76c1bc218f57945df782b47b7c2f890fb3b324f3997b2c616414b7064cd9f17ebd2a1102290919188128fc3953af20a34d32b1f285c55fdd58c25010001 \\xfd996a0957e06eb510daae298814ec56165a29effc65ceab5ba49d1582d65219f5115ab586af9711779dc010e3f98bc274c049ec716ec4f138283d6b72cb7d0f 1670930989000000 1671535789000000 1734607789000000 1829215789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-39 \\x5ea8b54cd81d002305f1aaae15fe99afa34d94da4577295f9a24060786a89f926f850a747a88407ae6781ff80348659c56330a24d31bfaa48f879d7aefcb35d5 1 0 \\x000000010000000000800003a79a8fda653d832aca7d764be08d3ec2d8837a9d480a4d4cf4a9109ca47f0a711575551c799ef85ceee17079871fc1e72722d016ad68f99c997f8a6b4535fc675f8c46e9cb62de82c8a983dde2711c190cca66f72a8c5a155c3349f1bbbe83b3fb601d908491cd1bb059aa8442dc5bbe3b8e49121796f419d5d3c80c6c95a7b5010001 \\xf25994852bfcdb6850d405fb8c227eda2d0c95a9248c8974e7c87a0f756dc5a519cb67f6b196a304ef32a8a9cf4d5b77a63bc21e08c4232edb207b35fe363007 1680602989000000 1681207789000000 1744279789000000 1838887789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-40 \\x60447f96ca50becf5a2a3162f9c3db5e23c01a4684c4f0a28011eef545ef8905a37ffa72daee5baae35608356d883b95a5c51710c5e6f8d48fb5e28809e44d63 1 0 \\x000000010000000000800003bf6c99a2f14bf606b8fa3f56e4d6db9454888c11e8316df3ee1d3bec7f632d8a8c13b2ff4b814463d55f460d67276c64dba9bdb714589c9c319cbd70f3ec0c2131ce03a18bb736a3f87b6f0852bcad48263710cde24621d8ea934c384dd5e888ce10f47ce9e9c13c8f95d6cabf5da03401616e765099f572b235303de35177a3010001 \\x14b0ecb85f39af6be94183b8ea481fdeca1b4b8ebddfbf2ff1b726b9d36e57a0682100d05ee2aeaf9b04054b81bfdd785f3a38236f9bfd1b7298aedf84d94f05 1689065989000000 1689670789000000 1752742789000000 1847350789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-41 \\x60388b9fc5d8cb29647422517f29768d87b9ceb224f96b1a35d2db5707e9b444927c959c4fcf0e0f2c6d7d780d43913b69a9cc0fb4347383d80df19047125ae5 1 0 \\x000000010000000000800003bebe0b49bd2d5d25d4e81ac15de8cd5579678317438ff8e67a1ac3b20f9eaf1078c534ac62712b40314a0584f43c1152890121fe42504c93b99d4f0937249c24b3309fe320c145d3cb43c0fafb8ca0894b93388d57c67321ba081e114a06ef939c72d2e6188befc6900a9c1cfac0f2e70d8298cc0bd681b6ea4feb1b5eb09d9f010001 \\x1680bf8a65db693ab54b83e6aa8a597f0a0a55906647e11aff46dfb82a9fa076689f6152c52c7a558a117249e9e375befb99c24dfbbd9ea736c87f465ad8e801 1663072489000000 1663677289000000 1726749289000000 1821357289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-42 \\x6254f4f91abbfeaf6885c8c7ba3874a086f68c30fed583b7f663c137c6860b9beacc2dcf82d8582a5dc49ee023fc0fca0bf7e4c07ec51b54142ec873c97382fb 1 0 \\x000000010000000000800003c8ea80e170d436f1250794ad78a5c94f2000dccb04a1116669331a5382f0f2b385e83667b91f04027a090a972397c15fe4ec60b88af8dc2d6951438c320298f393532f58732517fedd7ced428df706813fd66b1e5a6b4417a0aa085bd28b85618919c21a73e59be1875696c7e755f76b421f46d4fa9b6607d3848e10a10cbb41010001 \\x343779b88291cafbd3857fe3d758d4a002e96e910d3b431997a9447916184ce42186de906bfe13bfc3d8063c3edf4f0e22d9fb159197b13b0110fc21f0aa850b 1683625489000000 1684230289000000 1747302289000000 1841910289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-43 \\x6328e49bafd3986f02dffdcdb806c804e1e4bc8114604149e44230a8c8f2d4d0354eda6f3e253b7ca5789eab5b64b3acda02fc4e7f2b8c7267336acd92230329 1 0 \\x000000010000000000800003b308ef716bd60db2623f48e3dd2d8861c536dbe15b084604e95d0970a0dc6d308d14e4e31b71e065330a5f039b40d2b2c085d1323d93c23e0efb8408214a956e091b0af8ccd1ac5a04ef5257e28830db8e4ce14cbe5debf58c7b55277c75f6a6c31aa66431472c40cab2380bf38cf066a91d6bd9466aa2d5e8b8230c6edd15cb010001 \\x62678106debb39b8451598c48b77cf12e6cbd0ecf56201996031d126bb85377caaca4467ab3034f3b39560081d38b1dca6ccdf3a5bc21d5f4d2e3df0e6973b0b 1668512989000000 1669117789000000 1732189789000000 1826797789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-44 \\x64e074d42b76c8cf300c1c02e8ca01ef2af6f96eb871b9a92d738c83a42e072d45c9b1c4a0a7644ffa0638b83636b0cec7b5b8b96412ca411186a8ec49f0503a 1 0 \\x000000010000000000800003affbdcaae40aea5f53c5790e6528b89b998a27396e11b2af3a5525984a65a067b9b163ae8ddfc346868b6310bee0ef58250023174bf5385326227e7605330e6d6b02ffc1ec81d597d646944c29dc053704011cc213522cc3f7e1a5bb02af06f0852b0d02f462b8af62102f5e988eb4d68a5de02d9860a2ac980910ea0fc5e02f010001 \\x6f62f495c792f7eec269c0e0c831c1fbd7a027cc81ea6cf7ebcf331d4fb5ee3c7de5ff62533f82bea2a23d7e9debddcca6605bcaf5e891d33df9caebfdf9ea0d 1682416489000000 1683021289000000 1746093289000000 1840701289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-45 \\x64845e35095a3916de75baffcf00ad73fa842ce321ee86128f16e6cc17abe76ba32c69dfd2e168fbbc565f2a9261c43875646ea3f47e0ee4de9b8d7e0ab763d0 1 0 \\x000000010000000000800003be48f3b49fb21be31a5a5ced731bed6f824b2b2be95a16fd273472cfe719957334242242eb7eefcedf16b34af1553c59ad4a6e56202dd3a0aba97ad601d3df28e92f5104c0eb6a853f2a20e5276fb88abf33ac8d8352dcf257d4f0f28159a59a387c23962851f282b426375d8ffaf34fe84e33bfb5b45b16cd84333335219917010001 \\xf599ee4b5f10de625810bf973882120496eaca769e8af3a01ed33eb2517de3aad1e672eda7cecff0610729158a07ace4cb5325ecfb2d50669d8b2e7e443c0208 1661258989000000 1661863789000000 1724935789000000 1819543789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-46 \\x65304b98169884b714c74f2e147024118a2f8dc7128ef3420aca179fecc7b174b89796adc20fbcc88962018eb1256fcf7c346b8ebe5ee33921599cffb3a011e2 1 0 \\x000000010000000000800003e3cea7eca1778ee67fa3dfd9d8d9476a925b21f63a8dd2631860a9f8781b53b1d65f507682325f3802e98d43f4ffa704ab40e4e77413f909b44580724586822c2dfdb40cf5c06ed3f5b496575ef57d3e43e84565c768fd5a812bd4af4ce60a136b9dbff93210e2887cb0cf60dceea45a09792e69944b6a6c571bfcbb5f5151ed010001 \\xad889120d62c487aa872ab6ac8878927e25a24a1fac63b470b78ef48f58d6de954b42ee86a8c753f37448dd174af7575027eee4fb2a0309fa7b21bd7954bfa09 1684229989000000 1684834789000000 1747906789000000 1842514789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-47 \\x6624fce8b7259ad7808a1fe0fafbb9ad80b2e5673b8f8f5da3038d7baf39917de06f9a7ba424cca26a07dcf80645f19043f827d0e49a945725bd334e9802779b 1 0 \\x000000010000000000800003ada6de6ed5456d916f4f4b16ccc17f658d4454445a670e21f56087dbb80a6ea4ff61f10647c7dbd308b7bbc8c78c2b64ae405b1d74b21dd624e21f64788bfeb911830b9cee89d9092e203afe21db6a3b81c18d88f5a7cf4f395822be20e3df24429f7befea66ecfaba4fc926147e88864ea81bbb5b376f98e73f1ad581f89c9d010001 \\x37a094d95e3cb96f1657efc8221559f319956eca8cce52441f57f029872dbfe69edc91f8eac828c90f1117940c1436616d82effeb50d718491622d7394682409 1673953489000000 1674558289000000 1737630289000000 1832238289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-48 \\x687893c60273c2d11ea5e35893ba1c9548810d542c4f021f5dc162cebf74d3f38ce9029048a2e89479b8338e1ede1d2f8782a0b96764abc5130790b106d4b413 1 0 \\x000000010000000000800003b7b65dfe949f2db635c3f66de7b670b003da53ac7e309ddd7d0051c7834fc62ef517421fea079f893a0a6be68de82052e182de9cafa52f0dcff8b0f9c8e2b4bc58992f053e20150247d29c76ed3154141dca060e1d78d2ef98e7cd9796e0e55c2ac9eaf14791408036dfda0da237fea93a24b139438e39cef801bcc0ef6b21dd010001 \\x652a8dd86bf49afa2d7e502ebee71e399e6afa5e6c7ffd4868b24860b5497e14b9ee212e85d50939d5eb4523a88fd9bd3c037249fc3b1c95e44948fb3fcff60e 1682416489000000 1683021289000000 1746093289000000 1840701289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-49 \\x69040c899f056127c3ce94480e61bd489f4ab2b6a989dffd2c0d51dd3290f740d8e25602cee611c623dc623248e5a02b7154fa790816465ba2e68c2c57985f8d 1 0 \\x000000010000000000800003de7d358ae856d42e239105cdccc1bae18722ef2a0f9c8bc1fa5e23f4f0e0c983ba7a2d325ca144fd5402632b7c375e80f68717aa824a07144f3b358893a333ee0990c11969e00ec702d319654d3356a074b3c5f5fab5e5190d4403ab6533a276c75b97dc37de5b0c3b249ce2c09c863b9b1a4e4d5bf37f612728e78af5a2e4a7010001 \\x8daeff80b4f62067af0e41960456f14d83b41131606666b23a7d47b7c4bd67e8f996ddc429a0fa83f601fc012f5e8ea8d74c6df921d358b2c29613ef329e7c00 1689065989000000 1689670789000000 1752742789000000 1847350789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-50 \\x69f8bf41c3e02335c9d88588cda8e3bec8d42c5089f86d5c8a21de368e852285b5d42b12cb1804b23881eae6598f3912c65d6622c107d677591b210421351d59 1 0 \\x000000010000000000800003e89b7efd9c476a2481fb4d21bd5c38a2fe1fffc0c32cd6eeef86a5db5c81f1bc3321e67ccc3bbd1980a3af2b27f864fd866d07cf2638be37fb1e70df878c163896340b951fe3cb1588d8162e38b6d22cbf3ca92ee325b98a46f62dd6d7179852af6f341b23a06a484b45b2e5a6ac1d900e816d5402044a3cdfc792bcdfed227b010001 \\x115308ea4cd1556ae7e2cdfd96a092095908a8d96fbd292e42f5949bf02ebb524325962ca15697f8185e83cb1f743f6297ae56d32f0172f6436c90285b3b1b02 1663676989000000 1664281789000000 1727353789000000 1821961789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-51 \\x6aecd7f555725d078e889013bba5b0c571e6f87c02676f8a321c3d12e5b409f3bf0c223fd00388ec9a8662dd000d384022158208153f3cd7555b97093fd374d4 1 0 \\x000000010000000000800003b6dff1063f401d8b9303f5d5554e2db8b7994380b5871a45aa27b4bed87c78eb1cdcaef95e5334838bc39f3b1334fee1e4e4fb238dbd6329dec16054fdece50e4941c519552ac781b1b70f5bf08c36cc1257f042a3383e9e097c7ba9a275b6c27a890efdc5fd7b07e983262241aae4f7bffce177585f46d40b12a10e8994a777010001 \\xb29dcbf9fa643be460f7a26a5423d38632e84035595b6aa2b941002662742334afdefd4813f727b67aea2e73e844178f1a888f88c724cd5747ec0ff470b97601 1661863489000000 1662468289000000 1725540289000000 1820148289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-52 \\x6cb05ec1305ec2ad488794f5faad976df5923f061e99eec7917db82721eb1f1ad83c2fdc52b8cbc75e5ecd9bea67d737df363dc2f06c8ef241238be0e7564b49 1 0 \\x0000000100000000008000039c43cc825b89a86fdeedebe784fb0c6cafbd3fb4691e2c407445a10fbcaaad9b06402d896fe0b5082d997b4244789c2a0f44c47d4a041c84245c9c9c5474a937a0b7662611141ea3082d4dbb52c0834fa3a43d78f7a1b5f7a3ea7ca47ecba7fd7ebf74c3b3345b86ed1e3ebb4ad7fe249752b7861fc6f118ebaaae04d66d4441010001 \\x5f59f2108538e7ef97b9b52ddb8595b36cb6a70f23a3be2121d5a31996be498842c15b6b4251d37e44e664c624ae6d3fea0976e0c98b2813166b360390a9a109 1678184989000000 1678789789000000 1741861789000000 1836469789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-53 \\x6e5c7edb65cee56787e405cf5358915435844aa0abf3675b23c208de82ed1c22ba6c7ae0c27a5c8d19679c7cf27c8745ddd6e5b6a5b4a2ce4d09884c92739ac0 1 0 \\x000000010000000000800003b7236d920efae147a95d2910f564609766a3a599efc98a7a49751bd87078cd71849c8d243ea18181b4aa15d7a0ca8437424b0b638fd999967816fe3a3915931702c64af539c61cb483568382f238c2cb6ca19c4d64e976ca8314e29081548669ce211277e44ff3001ab8b35dd8242810a390406b11a72874c744f4d1ca6815b5010001 \\x2e0654b65f1ae9b91f743e434fc1889e26b77c57efcbc416e05646460400105a75117a7f4ac11f56aa8d80265f59e73bcf0cf5e31ec24db0d052befe1bc71902 1692088489000000 1692693289000000 1755765289000000 1850373289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-54 \\x73f8ee4097b366bd67817ffedb181019409a77fd2c99d6468877fe9058128de336122f0ea1435ff245100c51d60557be6fc72f80f935a073e601e26b1ec6f703 1 0 \\x000000010000000000800003e8617a4c785bed0931526951337b5a42e5cd9a4c0b51696d349a3adbd59354995988573306789366c04bdec18874b2317f1a331f30e0a294bb5cfe99dfeace6583eb85349b44f35c16b7f3186a0d22db04e1b2549cb84a25e0779f0085ad361d6bd05253d14e58c08a7d34a83168d6a30e2f479e938cfb800711ceffefa6777b010001 \\x94daba5092637f59069014b567843ccf55f942f0d3b282e8c76e082c960ee3ef021916b763fd9ca0955cd79118d8a86f16829c539f7f2ded8deb25be2d0fa500 1690274989000000 1690879789000000 1753951789000000 1848559789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-55 \\x7750c75ef75cbf40ef25efa7bcf7f3002c62f557c939f26e8daa20ebb628c767b0ff684d47e2bf82bc46bde55fda137586209fbdc3dbd1ccff36be5280c2ea0b 1 0 \\x000000010000000000800003c94388cd2fcc21467e2a25d67f30c34e1c5fdeaf22b3dd412edd192904bcdf66712b2440c12d4280350f1a10d2d2f0103534a7a1d65fa56ffdc2e052fbed99f4e45af9cb1f1e50cc19690fe4d1db5ee196a266be20d00623a885f173c2c503d4c9fb107350e7a2dfd3f17c36dc25278e8c36a732e11f749cbffcf1e2b8285287010001 \\x3d32d12b9c92403001a32db9639e88d1e904f9d420b2725afa0fb41414ef67ee434789c53f2394b3f81cf96e6d1e69359a5c5bb2baca13d74c3f74c4631c140f 1665490489000000 1666095289000000 1729167289000000 1823775289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-56 \\x7714d4ce3b1bb9117ffcef1c93a316aa0588298cf012beb4faccc1c3c75645244c1a7f1f608ca045dadb90c4c6e5bd4a0ece75f2a9fd5027c6197fb777c8abe5 1 0 \\x000000010000000000800003d5fd4735d7432a2f8327360e0649a802c80be119c42262701b41e26d887565deb2a992f740f53dc81c3e11bf34091c4f53e0889cb69c7807966994cabc25d8b67e5e378464e2b4115aa0ab83d2d439a6bccbf4f50179e8f9627234da0e4e1e6196c805a1ed7614aa5108027733a181d1071450bd31b2228a4b8d73cf6fab82e3010001 \\x36bfcaefaee8e27a0b847614eda49f4a3c8631bddeda059fdcfc261df5fcfc8f9a084f8181fc5ff7b4d1fcdab5220df59f1b4e670892e5bbe3763fe8a593a002 1674557989000000 1675162789000000 1738234789000000 1832842789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-57 \\x789470f487bea612d30eb89451401802386ca52a15f2662d5b401bda120a917d9bc99304aa3c30fcc2e454a4812832c767f11e72558f21ca75b7bc5c64cf12e4 1 0 \\x000000010000000000800003b804c1ab6bfc74e6b3c84cba8ad6ab9234fe80d7d12a3fce1e29c049fe10fe7c869ef724b1258c841aeee13cfc0dd3721eea87db6345ebb5345cbbf1887e839663aacf9f7702acee5e2bb5dd44c5df40772d713d768c0ad2d83642bcd8db68d5b729dc428173eabcfe0850c909dbd458ab20cc5d7d4521e96ae366f4dca9c6a7010001 \\xe836fc2afe40350538f0ad818a5040b3159d863ee39312e7d864dac4c0e1e594df1045f0b952c33fabbbe05a740ec6184d4655a9988d8073cbfdbcaf7cd88605 1670326489000000 1670931289000000 1734003289000000 1828611289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-58 \\x79f4b9f8a78ad8c481074d465edfc702b8a0e2a0ecf9cc516d3f41d8862a7e86025747b68858c3f2b43c4bfb4557295f27bf95c23d9cdc692aaa29e8ac82e8e1 1 0 \\x000000010000000000800003c84b25d5bfd0ee68c3f299cf43945ed53b0b57d63006324e8fd914fc82ae45ec59ef7aeaf026e50b27073585d4a6bd9f071e88009f40bfc823c75edbb4d01b0ab6fd9673936695430d2af5e75495af696cfba4c7661658aa36d575f07f85355cdf4f1b4b94b56d87bd4f25fc8a12820853b862bbad83a58f4e7c23c7d89e28b3010001 \\xdfda524e64672ee68339612e78d6de9a13601daaf449f5e57fa8856f76431bf675faaa4ee6db992df750234c505ba9688b54fe84ce9b1765d761127e5a8f430b 1687856989000000 1688461789000000 1751533789000000 1846141789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-59 \\x7b04fc81ef60359d631ce438f1300708f4ede1936fdd556cbfd75f3d07ad95f25c5688654b9b00a8e64fc39ea6560d7262edfa2766f7522b9beea6e2d37b10bf 1 0 \\x000000010000000000800003d2ef221728fe9244685f57f39c612d12b847469aad2964ecf7d0ff20c3d1340ef931bbec4fa61dd6f31be65190883efc2d9ea51f62c4fb2c115e259b4579b69c9ab8acd5001cb3e6fae09341b9e1d5cfe6c832f86b281e977cb63a56e14a5aafe2a12fb3be2ded625d39cd257800363be9b088e2afc121c5cc2b73c2bccfb98b010001 \\xe6d97bed0709306d32147066951633b66501204ebdc0c2f52b40c72ae971ae71dad691378a857670373d3bd197bb8250d1c0093be91426080c57fd520f8ddc0a 1683625489000000 1684230289000000 1747302289000000 1841910289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-60 \\x7bd030363390d78a03c5a3f2906a922b9c66fbba3dc0de8b01dff5c45af7751cc74be430fbb62b0182adb3e9c594c2b7499767e0219b4fa6f574f90f823d8988 1 0 \\x000000010000000000800003ae02189b011b389944f5f726d3cfdd749c700062be9b4059f3194f770d28453281241e8cd5b2cb495dd6b6b043222f996ad243d0ee9088e78ddb2d4366c8341e83ac8ad6c4a992e453ee002c5acccb33bcd6b6461d66f812486f25b1478361236902a60940d7154b823d5946cfd6fbac15d07b30931d685d0ae377575aafb87d010001 \\xc625418e483a0edd12f566d1ffbdd74d095e71396cd8b88f48c3cab2122930fcad3b855e42bb3acd79beef5aaa7c8acb97ad9e2a25bd8bf4c24b83eae126aa02 1691483989000000 1692088789000000 1755160789000000 1849768789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-61 \\x7d1c5b1ad8dac9be4a79be5eebdea5ef81f1f0e1e6085f0f371c9926fea7e55cd4c0408b1d7cba3f7d8e1a8d2db447b37f6fe802c0e37d1280e1a4a834ab0c2e 1 0 \\x000000010000000000800003dc0087be316faa7a5914633f03c239509d2117f2688e35a4643af001a50434f13313902a2090ae756ab874717fc7fa184bf5843e6a33bafc70b7cc03b936c56e490fcd627d87586d0479ef5c5a5affbe88b6f8bdb20f39e805481d40ceb1663db5d4c7d6efabc653ff0944b4481943ed82bcda03b097c79d27a4559b62e81a0d010001 \\xf93d6dec103a2f5c86c2388cdbab13ca69597696f6de8653d20a3e9c400ecb6c3422943ec569dd0ed5ad4d2c63216966a6ca649be75fcb12fc896a772dee1b03 1678789489000000 1679394289000000 1742466289000000 1837074289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-62 \\x7d309e16df33d7f6f3b1a12e12c21bed5156be95f70e07af9314866e05b307391a75aa4c9aaaa959d44581dccc31be3861b70773e259ffdf37fe903268379192 1 0 \\x000000010000000000800003caf92544523bb201a86ec4c9ca4cd2b2e4c4a3852c5066722f48848d759bf59803be7d6211478319812324acffb30c232a56b5a5c4042f72d0aa6979505e9be43617f3b532d3d7fbf4976068386db25a41b7aa0b21ea8ffebe92e73c6e38c2acd793850aecfc2b9331591e94f1a81cd8162a3c84b0ad4aced85c847b6a036317010001 \\x7fbfdd53c4735c251f7c2836fdd3f22b233588253e2e7766a0e674e13b1d8bd83d7bbad9a515f8761d53e1ac82ddfa80644450d6f634b859bfc0e5ee1e66b809 1669721989000000 1670326789000000 1733398789000000 1828006789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-63 \\x8168d47bdc02f8e5672ce16ebcab4784789e563a2f86c42a34b323c9f1ca960f5169f9a729af453107e33c2872314560c66e2e891a3ea4b039c8672f8a635118 1 0 \\x000000010000000000800003c5fed91cc627e9b2e03ca61fa484866dea704cb91490efa8b724fc6be1ab41b255e68dbdd0dc82e489846c2be31c0127d6d27bc55215058f7e68f7423a85d138a1d1cc90e30fb00263164331e0f935bc54387e1ab353fcbaecf9cfc5ee7de32908613fffb23045a4e6a8e8a15ddc265ca499fbb41272f3364144f6d73c697f9b010001 \\xab0cf7b97354d3c256ef9f48f0a946cfea7713ec44b2e10a62c580c0125d3b4b26ac237c0e8a2a156b4430855ba8baf7b8d57cf0beb16fac81d8bc56a3295403 1683020989000000 1683625789000000 1746697789000000 1841305789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-64 \\x86781c80b56dde0e7e7fb060457ae27ab0d1cb905e08ab2d9ed2ece45a0af7f750a9740a0f9002065b829038b2aeffe1ff50a4297345768ec8337096453ec37a 1 0 \\x000000010000000000800003de494926c48fd95f10f1a323b788b863dc9802cb39d0d679620641978d4439db41f74989c58e24f8f34cce52ebed52e3546a58ea923042908fd86ef341a5e2d9e092baf3eab692df1b57dae703cb5330c217abf312576daf99c5b55697a30b66a7d75d290cac940d5668b77985f3f714d1484e6b1adcd299c8b6157a4a3fbccd010001 \\x3eb23ceea76416474f47cdda548087d5fa242cf8e5a60880476b1925ccba3d924fb2ddbb4ca5ebc72095b75d20af790da85f30093e9c0f7c357179c4310bb306 1684834489000000 1685439289000000 1748511289000000 1843119289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-65 \\x884475a340547de5ca8dc4c1df0214ef4cd4bccaf674081b8f373c25aee17929e2c3497791565723020e5c0aca34221c2d2ded6a01bac1370fe06c5932c28d9a 1 0 \\x000000010000000000800003d650c6ade4cb370ca600a95e7233851b32f4169d9c6bc7bd492a9d40927a35e215106159cbef3c4bd382d5a9c2f5e0ee29d58ca4176270a332014aa506c7fadbd82ac979d6272abc27f0903d9607d5c0c1b3bbb18416341a60d7ac1256394f774eebd430f3dfdb03e96364f369c3af88602c7e82678b57d985064f21085cd8ff010001 \\xfe2b98045ce0c5fa5f82fe72653dafbd7dc07d82c2959e1f7f4a455f84ce6ca4e8b14442e2e1ba5fd1689fb6b56a5a61cee81009a1d9e3ad71479536d4f2fb05 1667303989000000 1667908789000000 1730980789000000 1825588789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-66 \\x8c68711d64ad365a81539d33cdd71e50963553f8bfe4d7208fefadf3f6671f861e95212a197d401c65e11c748471c80a148b1ac1e82cc11f0b55f5ad5401e98e 1 0 \\x000000010000000000800003be2a3f3ca8fe4894148e1872aa07a3dee3f3cc2a5647ff152a6a37cf6f445547f5bae0a4c7646a5adf3c346319da16f498f9bdfe9662f52d49b7e0b5e8af5581f58b9b12c0960b8c756b9e444b1225c5949168689bb998d0aa275bd01b33df3c9ac7500da66f4a8097dcb60ca9b53a9a0c22ca42eb7f812448b700b39b016999010001 \\x0dda8ae946ae0f80682587bdc2845a8d0c8a7141f5500d6301110d9ff379652529b36061c50646490397cf527adfbdec4e4a5bbc7d70a04548f453cce644ad00 1674557989000000 1675162789000000 1738234789000000 1832842789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-67 \\x8c08bd737db52cb4fe263fbb085f1f7d9ee7203511aa4f8f095f6c1f28c378a35073c37cd4f514e12239ea4b713666d15ff6826e43e8f44bb16622dfa67e773f 1 0 \\x000000010000000000800003b395287abb99d4148f05be1517ac9e5daf27f3ff9a82af5b2567088cffa211fc28c32b3f7b3821276fe46b3b57d6abf7b70ef585a7ffcdbbc2c9f142dc26c5c4d4d23e703b81b65792c2a06ebe6bd377d38091b639698dc9218aa936ab9d3fd5b2711d696fcb4770c8b4c2e7354fdc39e3ca70d4aff2ff1800c7145bf8510a99010001 \\x107ab7bf86932b8138530f3587a2af614b4088bd4fd40e4e1d6be62cb57e34c4206955db7d119c5cd03cac902cc15c194e597f24b41d1bc0dc2aafbc20271c04 1670930989000000 1671535789000000 1734607789000000 1829215789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-68 \\x986000cff56586a07ffadfb76e5b58cb115e783acdf7d4f3e397addf460262f48c805bd8cf52d2df998fed180ba7b7cf62855ee5abe452d97e0e38bb2c9adcc0 1 0 \\x000000010000000000800003effeb7c61ac24027caea63ae579ce913c3842a7f7c3ae00fc4c172d9caa6e47a221f1523ad65fcebade5d579dcff285b73a29f587daf1e99ada0d37723fa65912bf5d23e6b5f85c47df7128bad364bbec3976ddc55d6e881dc6a020a7031f54e2ad82a38c6cb444f2451e25458a23c143b946fc73eeab83227b5d68a97a2b621010001 \\x617a253c6a9ce566f9d36d06838062e4483db5cee9068e7856c3d7ec15782c9c47fcec7247ea89929d11aa444270402fa5eaf26c9241ea7a15fd2e0b81f29805 1661863489000000 1662468289000000 1725540289000000 1820148289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-69 \\x9e4cfe072cdab40c22811ff5635354dbbea5301dc73063bf8c5172b9c5c7e169412c94a23177d2c5ae82cf512d174e5e9f78e65e2336e94bf417285fdb4e06e9 1 0 \\x000000010000000000800003bb99232a721e7a342b4458e6d73065978a12c6acc9af84ab5b50446c347fb6d8b3e73fc1674732d745d127e077f4cd55f8a77a520be62e37a46db7e66e1b03ad128d17a6c5fc81edba7dcad9009a1fe0a9b156488e7efd1d48fec502494bd75fd037eb68e1b14077de536b8f2e79df268075e12587bbfdbb0e522c7f018d13a3010001 \\xa955fb80a9d87bbee226c52ad9dcf3295f7987c8eac597802b16ed38d0d2955856400d1a919e6872f800150cbbb7e6c1bd57d499ffc095bb61b272e8b2203304 1663072489000000 1663677289000000 1726749289000000 1821357289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-70 \\xa27854c1eb0fef36dfdf8b1079efe00d7a8ef83a8d85b41a8041869aee1295dec66e28cac30736c8bbad4c716db5ee5e55bbfa9bfcc67e366f507318c00f2b94 1 0 \\x000000010000000000800003e964bc454d00b14f5a52c5a1bcbb7d3f6513e3750cab2d3ecfd7bbe8e5760d4c32b1e8468473e96f48b16dfa98a11d7ab1c3ecffb5c9e534594cb76bea6165910c2f3c78ab2739fd6e30223030d82f268133a8c27c4280f972467de5125e2df97aeb3931a161e178e588284284b660eab965e7a4882db4f16f2bcf2922a92779010001 \\xfb70687491bf3c1f3fb9a5867a16efaf3e7421c8c9ef4dc6787a4fb9dd20433691dd767cc5a0d5a32e51dfc5b8094df1b709f2d606815d983ad53ffd20c9b40c 1660654489000000 1661259289000000 1724331289000000 1818939289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-71 \\xa2584c191368887b1328d32459ccdabb36b8e6b3dcc1c6bd0b6dfd3ed5154995fd9aeb0a24dd30c27eba59e2a4eb4b66aedb251856b278f1994f837789520903 1 0 \\x000000010000000000800003c7fb26567e6717bc5bd324ab903a84d6462708692a36d065ddaf4deff6ca8cf82a66e6c2effa54cf7a5c2fdd54d7e947a799874d85607959f441eb53534de2e93052bdba4096ed5e39701b1ef45871aff6c6da2037171b7188d5daa58fb6cb72b87afe3a5a4f64bac084c4226c71d6173e6196871d505a42de22800539c74ad3010001 \\xd5dc66a509fedc9b80acc7961fa0d2db212d21b3954e3758905dbdc7798661d8234763bb8121644040a256889c74972a3375c4680fb40d4bd3c7db1c16c32404 1661258989000000 1661863789000000 1724935789000000 1819543789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-72 \\xa744edb264643da72255f9833a3377b78429231dbf3dbd33d433f2bc02f1580abf9094556d6755de21fd6531d377d2b685713587677d2852ce0dde5a73a5a615 1 0 \\x000000010000000000800003cf7a2de70fa5b1a44f63d50efe9b97ba39d31925207b2f7deaf6643ebe6901e6d4dad6e9e3d3106a0640254406f8ebd37c97b092257586c7226707c1341725492add5414b6c3378ef58bbe73f05197b428fd7cd593523601d2f63213ffcd6be7d28ab6aa1dc9b12554d7c5aa783399ab0f2231ec259a97fec32102fb04e11a9f010001 \\xe7a91918fb2d669f49e3dee094645890149c56c4a4a454000180a65c3a361c9266a1b2c94cc9e9c54dfbfe4b413851554bf0a7aea1519b98db62e636094f2f00 1670930989000000 1671535789000000 1734607789000000 1829215789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-73 \\xaf9cbaf5119640227296a865a5cad37b364d44cf9576f932cbd9f247977ba570cdc7eac327bd5dd104096707e54a976d8579bfb902e421e1553a59172524e0e8 1 0 \\x000000010000000000800003f01a31ea6ef206ba8472075c05110f66a3839d1ed93c4b4142c9b067704ed7954b3b75199526053f19c1da8833c9a5468a50da77aa286bb49d16fd02a6ec363c280f4a6f92b2ab86538ebd8f016844ef0f4615d4fd64abc3daf32134eac2b82b2353bcabf43451acca66ea5b849033ac20945426cc8150b245307c03fe65b333010001 \\x7f0abc524cb4cff9ae7d9f83126f874624e23ab008301de6f381f23c2e6d32d5c2cf6fd75126420819936f354d5131e22ffb3f41ea7e520313b90581bf05e800 1692088489000000 1692693289000000 1755765289000000 1850373289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-74 \\xb10c9413d230a2d3429d8e3598017f312d229b552f4ff0989b90dadfe4d8982d60b8453960b4d307698582ade6b15de9a469ad7d58fbe4ba1a4969d1a7a45491 1 0 \\x0000000100000000008000039a21a9729211b6a254683cd5bc0d8a27074c837aa43804f19ee3ed3aa21c946606ab9250452fad17d988467cfd91ac479c0ad7026454a50fb34ed4203479e891098a1e28e06722b19406a66c1ad06761730e80ff232d268e69c425368876b976fe2f4ab0d0e0a91e5d7fa17582f5121e803e396163127253fb38abda70ac572f010001 \\x939bdab968609e1fb1894feec28eb1c12d02598726a0b80dabc5aa41de28477b33edba1e278e31f96f4a86d9735b36cdd6fb5f94b970735ea8c7b4259bbf750e 1676975989000000 1677580789000000 1740652789000000 1835260789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-75 \\xb698c42d060ae7b02cbc7f4e07790adca61bec33d5938e664eb422c3493158d994898a7c9b5742c463b681a2666e13dd95be730e0005750024ca04f9df1c9c00 1 0 \\x000000010000000000800003df63d8aac4fb5bf5583ed9e6db4ae7719d983b0bcad63c5fc6e543cfee7da1c34f4395e8a2f0d5526b1155f79d0a85295e98895955648ddef792d62e25c3e789e76bc747d6152fd8a010595c8cf5e2eb584512ed13243b5fb8ebc195d5c2d2d0de061d6d2d73e66274247bd214a63097baf3d52478eb4d64f8fecce14411b8c1010001 \\x597463c5b8267dac3c5af8a42e67fd5880c18f7ad3c9d06afa6082699b71d05bcb406854f246ecb9b1908c4560874dd87e6035a5833f5743402188023926bd0d 1663676989000000 1664281789000000 1727353789000000 1821961789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-76 \\xb74c635dd1ec677ee5f56efb8c558199e03636312e7f7a527476a93caf3af0bcaaf99db59e719b0c6f0190fe597ead3bff6b261acf2b097929f6b79b5b9480f2 1 0 \\x000000010000000000800003c491b1b3cfb8fbfd4593a46df2e2be4edbf4a0d3bda6fb933a4ce3b419ff7fa3352167a073c9e21a5279c56ede21d35c4350acd9ff3dcbfc6ba04a8d733dcc17e9abaebc829e8056f863184d15d7f7c36de4b1d69741a61f508c82d38dbf735a4400540b8dbb92395a9650b25cf204ba1068671f90e296f77ceda32b399c1eb1010001 \\xd89e472e04cad086a4c7c8c55aa46e5e06ed2e671d8a4ab198a70aa0833bc4ce839ac5ea8e127a25503a671ddce01b3cc4f9033e9fadd4fcf1debc557888f40b 1666094989000000 1666699789000000 1729771789000000 1824379789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-77 \\xb7b0f8d8eb21a477cf21038fc724c7f0f68efb383ed4980ced1360d761a17a17c71f0f2d7189fcd3b4e8115fac9aec502955e42ddbfd034fad8b0f88af12f88f 1 0 \\x000000010000000000800003d59059b66f2e458ecace9c4637fd19e7cb244a4ff81ec61f8769abbacd94101dcc67b4093dd8b0fd8bcd39a8bbc643cef9319059110b082300dfbf09f5224877b259e4481b3d0581de43c3ffca4a728d3d39b6f39e3639df53258487c9586ea3c8a1d53eda284abcb864898df59870795c9dc25335ae679c87b34c86e2e6f2d1010001 \\x9123179d0cacc220869d25268e7ea9518e6746d727ca5487891e0857fee7facb83b3bb7e3b24fc6e566cbb2ffb24bda58fe269e0e9211c5b484a06e542d4ea0f 1670326489000000 1670931289000000 1734003289000000 1828611289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-78 \\xbc90e46fc0148ea9b1c111eabd7b0b370b480f5def539ad4c6a75c7709e83273a83d689549bfe5a0362d82425a543dd15e5e66486bcebba69dd1712bc9a30a2a 1 0 \\x000000010000000000800003b7125628240d63c66657815ddb099f949142f6e0a73874108c41b9e334ed2e9e19e793c9584db3fc49a8e464d7b8dcce3370e90a36898e8dde8ae912c94fc3d54c6b9a38d99aace219203a06dcd3b5455c4e0556f6655e8bd4c435bc9f7935ccdc29fb625f3211bf0a24ec83eb46030b5ca88f0c71af3a841a25167320cdcf2f010001 \\xe06ab53043762eecdd75b7d531e553b4ed273a496afe6914a08df57a4492049f592444b660a4e4f424b994c746a0cbff268355566884acb87fa46b35e8f91b04 1689065989000000 1689670789000000 1752742789000000 1847350789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-79 \\xbff8825f39835e2eec5c5b80b9a7fce18fef459ecca6785dd41294381160d9bdb89696c66b3ec0c7fb722a3c2b8c12cb3e68ce990cfac5b278a9ce96f61290c9 1 0 \\x000000010000000000800003b65f2d0c12b143911d941088b968a8ca42324d11c8ddf1d52e7135e431bccb430eb27c5ba2ccc77bcf6fd63b01c6992e54806272f4397c6cf7c86be6496444a62150aea0d7939278b65ba301bf484e3e57ebbdd4e69ac15398ed9d60e74c129159a2a17be1ce45e536f0808cc72b5f5ec2be78e933813e3b9a505f65316f67ad010001 \\x3c39ec6e06b472b259613f2a582aae2ba6c4c4cf0e83df626e822699ab7b7385e566419c89d0d9ab1abb6d4ed7724b1f4fc227e488d0ab96ee46a3f970afc006 1690879489000000 1691484289000000 1754556289000000 1849164289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-80 \\xc6b44fb0222e0bbc6b2d65045cb9fc304b83458ad1d09f7a5433564bc7a587697f8ae1f67b6be16a01e0b5b7285fb67b11ddaf70bc0a959dfc39894b1c316674 1 0 \\x000000010000000000800003d02a660d0140e2383f9cadb7f2da09ff18471823616c4de290ad618bba33ea63afd58e46d71805c128af550eb9569d74deeb4ada61df029eef57ea18d984e4fa53ea929bba7012843e26349e34a66369b3bbdd149ec8040f8c7b140a652d467a0aabe9839b4af57ad525e2d228739227937ba43bf5b76f02200de7ee4ca2e9dd010001 \\xf417c6a45d9c8500ac13d5fee0cf22aa82fedd50eb981150364c2bfa733be49d603b710f29702bb101ea7a2424bd7b6c6ce0a28ec51ce25e5d432ed2f7ee3c08 1682416489000000 1683021289000000 1746093289000000 1840701289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-81 \\xc920ae42a2b524095d0802330368e04134f33ea0e07755ec5f2f0a69a39d3d4657a9a34845412390dd8b36d5df8ad3c9e7e5bae17b5156b862c2e291b3734180 1 0 \\x000000010000000000800003a0aabd6c1b897b7708c728c3ac358320ff97382aab6e355bbe6f54279efe1bbf481a8d87a8b4b2ddf6aafc9bc78a09c478b24fafd51013cbc52296661dfc8be426daf47cfa9ea2b1ac355868e8ccfd5020744aa94fdc68d130c7ad93b65b54b6b60f90250bb5cfa5fc6a32ef8b8028655a5c0b5376f4f1b02279cea2410a5179010001 \\x2d60f67fe3c6ff43617462779e644d3da2f02f1520ab857900badfed3f82a0c0615f0c28d1c71f96c499e26190bc9322bf75bb95d96a937e3e8fe4896a13630c 1683020989000000 1683625789000000 1746697789000000 1841305789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-82 \\xcc0460a7612d410f475a5e0f67f87c56b80844d74d4fcfc3b306576927a29bea378c1a763e993bf821f131adeac1cd9045817920858203e900f134a2fab269d2 1 0 \\x000000010000000000800003e303da977dd4d7c2fd43f1651178d30f4cfddc3eb361d669cf88bb94e19dc56575bbbb48478ea2c0d9aa2e5e75311713398244f8d9f09f75de4367a20b5e471f9235457d02d8e50c1db12d9853258fff8ff5d3f618318b1368a2a26c49be802558de2bc3b6615c34b3e04cf984fe8e6b96c08ca9424ba93c7d0f00df83409d7b010001 \\xfd6685f01a108e55188ce082407752b4d6e727aa77882eafc57572b39debfd132213bc0ba4742c82684023d7515a728bf7941efbc500ec6f25ed7f5c84928e0b 1689065989000000 1689670789000000 1752742789000000 1847350789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-83 \\xccd8f140db776dd5f342b20e8217ed20fd1efaf596ac28118894e1c5e718ff7e489f6e4892ddc0db0c1b660a04a83bc614d746cf80fcf036faea5e9a808ad0f7 1 0 \\x00000001000000000080000396334d49a28b75788b42052b8ffcb579b96354b2d6c27e7d0b92cfd617090e41095b8f97a566dc906485f646f2f77f44f5e7219ceb2f7c0606eafc75859673675b21832d33ed23068a94de913976541fe2fbf1e7431c63acf94a07fbfa85882beace16af910f3a5321bea4420ecddb74127c89859775b31e01a8e419891a95e3010001 \\x8e6688fa0743e43562ca47c97756e93bf2ae8df30e954d139021fb9a4e04aa6f1642c4144f5112fc98b547f2e978d7e735118f7e63b6adf14e70358e85a45805 1688461489000000 1689066289000000 1752138289000000 1846746289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-84 \\xce6851e9414d423e18f5b25f7f3fb4af801bb8f9f37cb1b8e6843a0ec0bb2daabd138966a55b3002c86d87b03aeae152b00fa2a19353fe5a2fdc037e288d7389 1 0 \\x000000010000000000800003dd63d1a32e284522817826e9884df10cf77abc9f0899cbd6f49823aff8af1d96f6f6e45093c4edaaec0f5346e5523cd784d5f2ae31f0388f7a7f5eddbccf296f12076648b1287f6f40078f65c828ade5b601466dc98c5fd3a1f3181eda33d7f71d2c6832bbc9107ad7c0e8a4d6de9ec8b28b1da967f17fa6dbdcdcb606a48e49010001 \\xe1400da1b6ec01186819088118358dd7f852cb28104bbea826b112a492885a2cda07a0be6f93fd2ba0bb70d6578022890fe275d24fde1d05ff5002ac7f5ac60f 1667303989000000 1667908789000000 1730980789000000 1825588789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-85 \\xd048ed61c39231eea5185aa780b07a7f46a359b9c68ab2e771a3b276f66d1ecf5a6b443d9a5728909133a4a0bda18ea4a84c88427cffba8085e2befaae439cd3 1 0 \\x000000010000000000800003dd184ccba05bf893097115378038ecf9602803c2f0b02ea216b5828da22393ba440330aaf76fd83ccdf5c603756021c62db2b8d4e5963ffe9c4f575642eb77d4ff8908159522fe2a2fb15516c351d26827c7a752d2e01d5ce822029b5d7faa1f6422878693d3e6c93d087c5cdc8546ac188f3402aa79538802bc119323cbee17010001 \\x5487110c8f432a07a0df3ab4c0ff2f3027ec98bee545abae4a476022225042e0f14a486024ff8b3fb6ec3434e9468ba5f209b211d1fa215b72f0d2d044170806 1663676989000000 1664281789000000 1727353789000000 1821961789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-86 \\xd1a41bf9a5e625321799ff8be56853bea8081876f9b892854d216136710e8fd07260356fd82598a141c7fc84a4c16470cc9ee74a52756f24b4301cbebee7673e 1 0 \\x000000010000000000800003aa144b5220fa57ceffe198e6f83a189ea2976d8eabd7b8d9e992799ff07da5d745dd56039c3c39e0b5b6ea302fa13ed731451e7dfe3ff71417a4b2c280b8af0d23035c44da8269fa28045629689d792c0a961bc462b141d22d4723db421b2533d9ab209c898624f9f009ff800d26f8d43c01d7db9cc61c0c9894c40d9d74af39010001 \\x04bf9f27751faea902a646b64db80eb559a89bc96127e6e48e017c356ec2b69f2753de30ef51586a35aa419fba5b35e67d13f06ee7f5be8aac1757a24a289201 1664281489000000 1664886289000000 1727958289000000 1822566289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-87 \\xd1f42cda7c72b9e3d249107d4381ffbdd588303a72e0b0811138776b5207a451688c986c6be463687ee97217bd69f90113ec5c0bfa1eb8b8609400be0ddaf4f1 1 0 \\x000000010000000000800003e94afc660b32d11e05dba2a39d222528ecdb2d18ad3ef59d16536365e0b614bf8d833115692b67b8e6278282ea00e16ab9f1df84ab0c68b6040084bf5ae65960d58b0110b50d0669687b76843fe3787dbccfe15aba58510349eef496cdba4d7b190d56d81b7562fe1c93d93c87a5aa8fec1b943373fb3553374d45042b359305010001 \\xe9d64ab4ace45c377ff033f8d60716bc0fcd5524ac065e84a522ea02b002acd005bff2dd576e6cea9dc7cc14a9c3bb54a5904735b5c0befea055f30d9540920e 1673348989000000 1673953789000000 1737025789000000 1831633789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-88 \\xd8d8b9f84bd915373bb5403052ecc1d94481383cda2d2c0c75ba2bc095a39ae7c44146c08f798015eb7b3de942328f6987c3fcfc5b6ee08968fc0cb9cd125015 1 0 \\x000000010000000000800003c2f7c9b1d8ec981d17ef08aa58a2e24e6cf20e82c1c36cffe420fe1423a5c3467fe51c00b261bdcdce9c6d19e53386531ecf920f61d196ea440ba55712c0bc974e48d896185213191e09d3aaefb99bf7b6fac5459443e0d3d95f5b9c842643994a887b3856ad21bdfa2e93e64c25eaf643f19f036d0cabab293e2d1e2826d8b3010001 \\xe302a24cc7deb26777daf25f69ff3fc8415dc8ec18d602fc260b34a2ac7f02b42901bfd0652297e7774ca2b89847e03d504d637140aa6f57d9001abefd137c04 1665490489000000 1666095289000000 1729167289000000 1823775289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-89 \\xdda0f9864dffc82d43c8df6cd2718b9c400f3359a86252a44631820341f3c00f4d0776db9c45508eeb8b8eee2e2f0f4d1ddf92caf7c41c97f14fe6a95e19961b 1 0 \\x000000010000000000800003c0181ceb64163990c3e8b9336809079f353ed24088f7b15cc2f22443a3f8e1d509874465182103585798812b2b541dfced58e99b6d8cf149d3b3465cfff82e3f8225981e34aafacc4c27693c3df0a875d53d265df55ad024f5d6a0e5d9ed5390ec891521267c96f04d0a0f4f7e36f5de42ac628e52d839cb47148c958ad976c1010001 \\x5a3a973547d1155cc4d666c27ec37a3a825f8607fd92c70aa02192c23f03439828b559f2cd30aa6b61afa41c97d18d474cc4773a2510c5e53c3f5cea733bc603 1684229989000000 1684834789000000 1747906789000000 1842514789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-90 \\xdd8879d3e40e0946e88dc8db83f137bcec6014eabd449cd845cf17849271dc58af0228587575283a1da43986eb98ce12683b5875bdfd3afe58cc6b9dcfd6b9e6 1 0 \\x000000010000000000800003dfa4c6e2ae538cdd614455e929021202476cf21dbf2b8614f242412b9d9178fed7e9eb1759b782415b077ab6be6a9b9eb5f0615e870588b55d07f8aa3615c5416afd55f9c00c11dc99c9d02930b2f67a73e89d163d993d5c92c022f85dae688de1f0a518b5bebd39cbeba75fec3e69dd20103892529fa44d140597f0b67cd967010001 \\x57b6bbd231ba204487377b0471530b77fb5545db48f20593a4b81ee51d0c124baed96b71332923975610ed4013ec7e4e3eac84994aeabb00d15870d0654d1b09 1673348989000000 1673953789000000 1737025789000000 1831633789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-91 \\xdf28ceb2d0c0cabad0c608986107c276ccd82c328bc85e0aa9ec0f4fd904fe46e0b0d5f090c669aa312bc2492eb767068c372a0370002ba56c60fe96d94257c4 1 0 \\x000000010000000000800003dec96227ff0ec8f476a4d9e6f6bda8f6a9083405ec06cfc14a5d712177fe170d3580be9f7faa0be88db1fe9769749be2e6d38bf4dd8b5d9ea5bead10b6be736ceb59020bb4607c30e016bf69479d3c7fa4b9b87d2fb4626564c266f39c836bf869792ff8c51c79dba4091afd0fe7a928082c93e0ea795a94723f24521c9c5053010001 \\xb0556b6cd1bb219435eb835ae15208b5c6753d75e82d7cffa08b5d2ed2fc194eee2caa3b1856532c42c780a51c9469d84a90eb30be743cd13c172e4eab514c0a 1674557989000000 1675162789000000 1738234789000000 1832842789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-92 \\xdf24049b9da25c55cfd5897da9581208233d5875bb39a485ace8285775057c47f5cb0542182528e75de69f3b6df53183531b790f92bed0d588c3777bb46e9efd 1 0 \\x000000010000000000800003be740cb4311d3830a5359b066086971b6f8b1125cbaf2531cfd36e90e2b429b7d11de54ea828c2691c90202e959cd2045a1200f1fdca02494f6ec560c3739c72fc031fbfe963b161a74e99317c423d75dda85c98ee6a8d322041cbf3dffbd7e0e85dd23df6208e1a66651538fb038a2e979e80feb837ef482e4f88c14de61d6d010001 \\x4a425f1bfcc47d1b711b5037678544b402669e3504566ee918cc2f35da3edeff0c735718f1b6c36fd7d54f8a1e5a58500638776d9920dc2200f6d70fe6ed0007 1683625489000000 1684230289000000 1747302289000000 1841910289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-93 \\xe1dc4293b45a53788fb7613b94cdfa2af989d78b40d585f019d59253e66ec6015882be52403a17ed8ab3682510772dbd508fe38d09a169e54f4d951f749bedc7 1 0 \\x000000010000000000800003c430e34bd169fa019e9a6d9b69141914f5122abcc6a752cf8c3de31ac47ba0fd9dd127f4397177c91b85c6d9e6e5da36937f82a257232a714cfd8dfa54be2c668b10dd68d1f54b997b20d69e316c59db776af7b854a2133099f94dcd70923188f27e15b5e3441876416801ce4d889d51eca96008658534cec53dd6394213f7c7010001 \\xf96f97f00f7356ccb800829eb680eb969f978d919c53289c4319e623694f767b6c2298442e446389e077070d32e400f48a6768e26d529c5a535bad353473a604 1668512989000000 1669117789000000 1732189789000000 1826797789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-94 \\xe5a41a7e840325f3cd6d077554027e9ed768aade1f9bbc249271b25e0d81ac6c6ee92e13957c6bdedd65051c033385f35b15f4cda6ce700635ade1af8f644acf 1 0 \\x000000010000000000800003c27a18309f2ce3750bdc066a438258d966366f271824a9f3bca65694016450933ccdb6f2c7577a36e8a5b700c6d09da6b7242d66ef0c4ba23e276b371ed27addbd3cc69e14724639faa74ce55fb0f3da78c2edb06f2cc538414568573049f81ea7e96e3dee29766658bf76ab1b6564c8a0ca23e65a360dce9c1104d87546af5f010001 \\x33c3f6c55de34bbf567f820607c617f3a49214e11b16e7b1675bcf03010351212fa735f6c8a0df5214b6c22f561322452f60ba1c563e9a7335ff13eb0c6c0001 1673953489000000 1674558289000000 1737630289000000 1832238289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-95 \\xe5e0cebab42c75e130067967acc2ebcb11dcea66328235da0eae449f323bf8a17892c10fab90a4dbf00863fd8dee941e997d03c91ae0a54aa7dfb1ca0aaeac20 1 0 \\x000000010000000000800003a1f8a776def4c673355f1550594c5ea20433704e6c380a5d7473ebd2c043a29b3cea34dbd3ff59d09f168b9830f7c1d658d4f2853bae58ad72478b63a375716d5bc368bc65616a3e0759d0eeb591bcf72f3762f4b578dfce05d7350542b92727f20a34c09473f208ead781efda4e2617d4af3fc7dc4ac2dc2cdae2c901617105010001 \\x3d4826714f2cbb7c205d4b1172e125043e4632def40d2660fb0d1ea2b46934eea71bae55c8709d0c3916739718039604e1cafcf096f5c9de5bbe317a9ea88907 1670930989000000 1671535789000000 1734607789000000 1829215789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-96 \\xe7e00ee825ad64e756b78c89dba8480a0fd6a67253d2bae0d0560ae46aaa80ed9b21c3e4674000d26847f261de745cf7b20275e352aa6193d1a78a3ad7b6f956 1 0 \\x000000010000000000800003b9542cf0d31b3cd204fdef6c9de8e8c9fc6cd67d25dd27ec639d1e1915e27da7a0dde6beeaa7538651166828e3e469b31fbb7508b9f31d364918e94c19ec45e67378369b0c693b392da06a34a9ecf22cda5d44c3acb374f13e873720d40ef72941307f6ef494de14ac23fc2c73b58c0cd851103f81d5985d99b030c51b68ed63010001 \\x091977053c3ec9943fc0ad13e23540f0036f8baeeaf4b29b212e68364dd7c866070d6be741e8f072e2cc7e3ea242941bf0e7f92c6efe6725de40d96b6311220a 1686647989000000 1687252789000000 1750324789000000 1844932789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-97 \\xea3cba10e26f188477e2abfe507265c48ddbcfc087b679f1738e2d02f79f24e57a671fc611d13a909289b80b515786ca90bd4dbbd4a454453cea3561ba42c60d 1 0 \\x000000010000000000800003b50ade26fd4378fdd8d595714cebb6337cac9646da50d778b9e7ad67ea0f1b70688f8fef8f3c95f063df5ff2b71f8d06993d71cc99042b290b4d3c268c9f60f0721c8822270c3f4e0c8f5de43121ce15ba35ee3161d44ae68c392a60b0f0243b189dab033a77bc31852a1c8f8338d9b69e4728ddb732648cb4d3076d2ea62729010001 \\x0b8719ba9442336e004c3a5a658dfc1d9fe11535e8ce439dda725d786c747748ae0853cdef6561c5dc6cb0092a10463b183147a27fc8d19b550d3ba48a69a90c 1687856989000000 1688461789000000 1751533789000000 1846141789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-98 \\xecbc7ea91aff381c8d38bde3596c49ddff0156543cb7df6842ed6b779187a18dc566d259c3f7884e65bdbe159e74cc0185f95f265723e40d08415505c15e6f01 1 0 \\x000000010000000000800003d6b947257f92918dbf7f253858bfe04063b094ba26f7148c2451da7aabef9fa853daf7e38d0ff96ce44ab58794535d9d9fdcc6555e37b88a87c1868395d300f518d1c9438ddba58e976bbc69d393d82164c6feaef6028a061e17222900c0de404c467cf7eb21fd3f4e23f1f141d95dcd4efc930bccc8d6ecdc94989bfbc1e6af010001 \\xfddd51fbcb918c83a1ad985a5abbf5c20d90374a8bdb2e712b750023fb3c383a21bd9c4d2e55de5e6a517b608d6b22b439d4fc5b0839ca81c7e40cc54ad72909 1676371489000000 1676976289000000 1740048289000000 1834656289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-99 \\xee74a1059e35cf60599632fe5475bab1c01723278df4d0a6f0e80a9943a397fdb3541f54293e8c6ac5315427610de7de4d6ca3555099674e20db2f83276bdd7d 1 0 \\x000000010000000000800003bd592e70395cc506e0d5f61ef9c6f6352f2b984c51ee1be0d52abb1f3358b58265ef08a0308ca952134c5def4fa44a58c99fa4c218a21a366cbf9af28c1a6ce471eae5448752595ff2cd9c59bc9abbeaf31632e6c0955c40a3e5af76fa8555114c77b4712ecf9cf65d6fb6e9d6641181d633db93e0893c8cedd0c59db3ea29d3010001 \\xe2273f79824478ed9d629558ec5e996a48a9c26e0f34b16c90110000768dfbf9bed55c6601fc073ba44dbf6abaad036bb4fa866d59248896b6c72e3aacf52c05 1691483989000000 1692088789000000 1755160789000000 1849768789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-100 \\xeff0537151779669538bd3985c5c8528779a29bc1c219bf2d424328101e8ea4184872a8389a79f34018e8d3b0e6e35029013480bbe3c381300022c4398c925a6 1 0 \\x000000010000000000800003a53d3cbdb5cf2a978661f2d4b9a5c3ed7e1b0d667b96d41d9fdfc9776bfff94e4be123e187353e6d169d0e0eb6b9e7e07922c8eb2d82e078f513f363b252a21504060e5eacc83f773cf3c7c434d50eee8f3741d7aebdd23150efe24f9db82222980d23dfe869ce65e43a0799e3200a16d1cb7964238fb46858be5e75099f7c3b010001 \\xece5c513354286ad73a49e72021f7bbec8c2af29d8ff72250e317ee05e46222479a2261ec3b7d1376a4cf2ee62278614174c439e7af4b29a8dab59f67231de09 1680602989000000 1681207789000000 1744279789000000 1838887789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-101 \\xf0aca35194b8b06b148bf31c97d79c8d7aec225ad64e76d33bd5200cbab4d8b6694fb35a4ed6e335309b805f03fa885a2ce2a9272865de06e40b02cdbab5908a 1 0 \\x000000010000000000800003d4f4a541e6a4e305e06b89505928ba8f12024750f15602f01640e97c9cb47fcde3ae4acec65cf8680af71f6d71dbbae8b34cf759edd3ed606b7afc9d6a006e5d0b912cf55d0df9a9caca7ea0202eb35b0609d14979f88dbcb4565f9f29814f5493df5776ba5b918ea0cfafb07915068e0dfd4722cf2b2acef47a9ec770fc45e9010001 \\xda4d11a4904eec452bb15a21b736727a485875c81637535bf1e1d38ac9f026a23376f0dbfde1868a9a7255ae58acb9098a7bc91269a81c4d2fb5904efee24d07 1686043489000000 1686648289000000 1749720289000000 1844328289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-102 \\xf04883aa3756930452a3640703608dce16f0d77c2ec6605abe951a4bf4097a14e52376ed024bc6558ce7dd31cf68a53d1a39c7b4441206837ba8d4112d475345 1 0 \\x000000010000000000800003db65ac5c4f7185b9df5281c2412afea8533674480ca277934a02cd0e6d91bf0cecec25bd9d4aa14fd23373a9dc9f334a986927e1bfefda4d97e952ed2058cc8b7a2c7ef72ad57d9377a134d62ffc54cd8d90e4319a7ee7096b150c0228fc5d0978154d909919624af540f68c775bac0bdcb382e1ee1618a98c09c91be65c3a15010001 \\xcfaa0724d8c24ea025a87dd914c2a4a968809122628b9642f360aaa6fc6af8f13dcf6ae0f25868a10e6a5a8db54fc4514143526769b260720b2ff2be60350206 1678789489000000 1679394289000000 1742466289000000 1837074289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-103 \\xf50c62c17ad6de86a08d3ec47f8f5c58926df9e5f7a72e05362a9fb232b997e71c1a84ceca4ed30702c1b0ab65c46755150a8c99b2f3fa481b56d34886c04c61 1 0 \\x000000010000000000800003deba660dbdd13fa7c5f456b44bfdbaf57a60a2481dc4b2c1c7f641c8eb28f881ebb6536f36c869b25269e59b78517fdad30dce2f62e6f097c702b00be4aa1f645aa8c958c2e4ceda03b3b21a93f2da4103061e766a7a35fbeb75c777a470eaac3e8123b449eeed255fef0122d3d2e6edbf9eec3b8c4d2eafe70f0cfc59803c3b010001 \\x6afa896b1cb71d064060b8f23ebeecc1bbfd683415f783942e96b0d51f7b30df7e2be067e64e0faa30374853ec1c65681fb3f8e4be40993cdcb27dc410e4980c 1684834489000000 1685439289000000 1748511289000000 1843119289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-104 \\xf738380fd3745e2970d034791408e26018b4b23ab2310a96cf5e2a7be9f223ef187cda7e6b5f1b91c92637257aebde21e7242479807c8a1d2c620e36d1f0c48d 1 0 \\x000000010000000000800003b5a76226f4493c8340bd278347e0eb0723fc1c697827a66cf7dc3ae5546c7c388cf924bc15e86e2d070666eed17c8c9362f0dd814f66a6ab51125df784bd2da83a19f1ecc2d8b45e189b41e9f1831ea9ada39114a92eca71817ababd09ca07e69550932e936211d90d3e2062e311f8565ec39d1adb6cbd4a8d0ccf870fed23e9010001 \\x95a827c7010b0beed3fa7877855cba86f3bd14aaed9045526b201c7dfa14b5bce380d471e22bfe4c8059382eac8345c8f86ae3f4809e264f01876b32e77f7200 1660654489000000 1661259289000000 1724331289000000 1818939289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-105 \\xf850e782601b856801bd1e425764add8d8fe9650450f6e8cc3b8e4a7b3bccffa847df3680f4e9b21642e77b4dbadc5fb594c593965bb03074095bc126f2a3f07 1 0 \\x000000010000000000800003e01b0913bbb780dbe1de266162c0844d766b37e7c8d58219414c44d1e529553a1ee644697cc721e0ef0381dd3764091b431ed4cfdb4ce24d4cefa94842a9271ffe48e8a1cebdafab77cbe4be34c08115fc2e5740db5be056f3eac4dd7e5978e036fb1f6df7c318d04fd575e01e7aff1288d488482bd9199305fb87434a0c83e5010001 \\x9a38bb05e65d99153735fb9630eba5a61628f4ae1c14cfecf55f403f740fa1308ff87cc8af78457e744c6ba6f900aa0985dbc0e14ad62158699b8ad0cc185f01 1684834489000000 1685439289000000 1748511289000000 1843119289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-106 \\xfbdcb006eb7a4b67a79dd32c41d8e8a67965ade1126e9bc889fb3a574fde84a25125a8a5cb708655acbce2e57ccd487bc1d6c915a244dc81e43daae8884bdb92 1 0 \\x000000010000000000800003b1e41f7cc27c35c34bd9bf685c4f5f172682be0dfcb8404b6f0c9ec93119d86b03b92826511834668a5c93e3b3170575f6cfc4888a04f94b147fbb4e08601e0eeab18987c699b82f40c6998d778341aeccf2e316796c26ca0f5b9d97205a05edd9420b5d300aa93cbc3bb4255a137198a4a99c6abf51db6e471f5fcc4bf8d687010001 \\xc25de3661d8cf6fd8be61051fd27f9a69dc9e92fc1c7aa33d06bb2deace046cb3c875c743400cabc8eb4a2627241638f5235e8e9971c6008dea7cd930a293307 1679393989000000 1679998789000000 1743070789000000 1837678789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-107 \\xfc88f9fdf180b5c7ac2428474aa359362a8cca050bc975ee6a625c4c79d4f8c789248a1ec2af703cc08bad928b2c369b2ee2e5b96a0260bd0eb6e8d6a65758c9 1 0 \\x000000010000000000800003c574be67a34e9a8fc6b7f0412e701ab6893aea5479261c650e318a7a103e0690504a57941dcec87b82882f4ed66ed28a2c2b5d276a31adbc2d5d0ec90c1a1856d6ebc8ac76090777a1f8cb6f804315bc9451dd2dc26345cd47d3dad476e0523ffd5ff560b042c37a5db89695e63fffd92e2fba588fb0fa70563be731a72b1bbf010001 \\x000692cb771836f0df3d59373d6d420872f8f0201a333a07447d372081c57d5092ff6b3adb71b13d857a7e90df9136f62157d87c8a3f5ffeb90bf5c555f67300 1684229989000000 1684834789000000 1747906789000000 1842514789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-108 \\xfe14bcfd9d4df4bced9c314b93877c9c4ff77b2ca713882a5fa67634ab94f68ef6bf4c1f04d10459a43244fdabcfd89174029c9bd7fbf9ac5a5db3e5d512250d 1 0 \\x000000010000000000800003b98f94b43314c9d0bb796b21e77a8f43f0caff845231906604ca00339a706aaf4a6d5e05d72c26b99ed938864f4f58310c906371ae39bf1b2343b555f92fd79096cc310f5becfb62faf121125d7dd597afde2373e4ee6a389fd6ac7c66df526df6dab9f5b285c8b5783ed01e4f6c9f24c9fd3489c11690f59cdfcd67dca03a7d010001 \\x1daba977c70b899ce4c031dbd66cf62649042b395c3565b0881a6050d3ec9534404da94ef27623b43da2d65de62ac0a4086ace140244e1f9d5f1e0bac2246e0f 1681207489000000 1681812289000000 1744884289000000 1839492289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-109 \\xffd488788075949413ff853cc266223a77a6eb43b7d646b575bdd8fedb2bed6ba93376f0a5c2cc25c2ffc79da325d780fb948c6a0855ad55783e255e8f9571c4 1 0 \\x000000010000000000800003d8049c275469464a7f7596bda32b6175e09696027c7f5a49e2c6b9ffe7450adb9ffb0b61698348f1d972ae0e2172a01ef5b69a2493258aa3affe65e40bec034b5f42a107cfc60008c22d6ff2c0405ae8f670a66d2e5450e2dd8ae34243ed4e41df8d7789e42509ce5e86e5e9cc56be1cd8894e6509b4ff0de11a742f8938b717010001 \\x4601ccdeccb0b2e6ded76642a117dbba384396ff119ad272590833f8c58af3bc1cf3753fe76b47f60cb29788564739fddc084de2997424343e126ed942c88a0a 1661863489000000 1662468289000000 1725540289000000 1820148289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-110 \\x01f1a524b845a3a0e1e188526c046ab003a56dfe6aeb1a16b805f7a789f3d6cd0973d205b7c28364003d876d00b166688f3a8daa8a9db93d7828169af25d34c0 1 0 \\x000000010000000000800003cecb952333438f97de1f26132c8474d680b3cbaef4de390dafa5cc741d6d8f8aaddb821ab3ee9acc26245cc1224bd4707796fff4ae59327f138cf41086e0fbb55c77dddcfe5feef3f7ef519fa4411b2ae35ae969a959b32845ff0e94d87dc057dff259fae53acb9b05db79239c3a359d4f7fb21f2bdc2b2b3249830d552a597d010001 \\xa3ba88a0956ae3d83330ce18d0df8939b8bfd6f073d25fa89586b9a62c9e69c79bd36023ace19066e10d9db34ae501028a8457f65af8480a9d3a23d15fb81900 1678789489000000 1679394289000000 1742466289000000 1837074289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-111 \\x03293f99780d3ab2f8620ded35b1ee34d94ce5080131f8bf9ee51c94d29b7e1a25e09d7df471b227fd9ef29b962dabfd4fdb3149b92caa19571f966350b8b263 1 0 \\x0000000100000000008000039ffbd92ee4658f6ee90e6b50aa6aebbe4b9121fd329ce254911702e4478243793612b3a9ad45a04285d0e8da6431c5f785264a7c9f72dcc76ec1bb6f23c60b0df7fa720edeb731aac5e6f4a4547e638a1b15382af8f516eef9e45d15b9f80247ca7877d1178f308719423390b52d5426dc090ee4b7bf8926df55f6c71bb3aceb010001 \\xc14cd29905827021ae6bd830fcdf57875ffed66a4af049e867430bd0f7015745e34a66eb11c0a17a1cc960572e8d0458611db7cb94ee572359089d62b57c1000 1672139989000000 1672744789000000 1735816789000000 1830424789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-112 \\x05b17e20898557abe137b48584ca7f46aaa4effee693d9556c9f5474301cc94d5d0e7b880448a7f32b4c9468972ca70bb5ed341486eab8cd493f1e92fb27a5d0 1 0 \\x000000010000000000800003c5d80c7dcc6de2252b98b63dff89172f1cd8964c0308481383acaa0f1bb32d42968c85f50a598b33268a33ae9315373ba5ff484f10c35b633cedeb3d2cef8756a6ad1ef1e68f0ffd0d9d7cbb518784df3e717d7ca4b3e669e692dc1ff5da9f58e6403041adbdc9c2ab2e6bb79d96d03c68b110600cce7dd8d169fccc0a5b34b3010001 \\x0af63bbdc856d5548733284b75250b9374ea6356737cf83b0357f5fe5cd22284b4b02f471ece0253d35b9500a727ecca0f442f84befa56fd4b9e87ce18e5a208 1664281489000000 1664886289000000 1727958289000000 1822566289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-113 \\x06c9efc4c98330307f3b0d9884712f4c5b3b2741e65ec28bef4897ee57be7515191e84041b906518ffb399d4c10e81de0b4971149f317e28cd1856b7e5350d85 1 0 \\x000000010000000000800003d4ec3b32dca3d11345e5cf82154c7ff31e9553a28f1d63cedb35bf5eef4f9f42109e72962d625ad39ee0bdc9eb4d8e57a5a3b08c660c7e2f13cb29d44845782f965f187096682f3c8a11277c38e83207a7332f44418fedef0973e0ba01d78f97fb2644a948f38be28874dd503dec1aa4011af35236999d303c4161461b1ae7eb010001 \\x29a408cad79e9aca9f9ac01d745d2853959f75a8e8df221fc33e967df65ec622debcae61870e02de95ff911923e4b24f645dedde0cda3b67a251f15f52486f0e 1684229989000000 1684834789000000 1747906789000000 1842514789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-114 \\x08016a0f301be86d02aac28ab1376430357cc36fb13d9a04d0181413d22cfabb55f5d6ed444167549b65c1fd9a0802398f29503e5d70a82a3ecd647b66381b24 1 0 \\x000000010000000000800003b67ca25cd9035c365ff185d3027e668bf63685a0bbc6fe6939f4a8870b84ded7c541b8da5e735686659ecb2a5aa219c0a303c6ed662faa4a0056818e01676e476a86a8bcc4a09c4d528cedc5e1f48b1ec7f2ceaccd705baec58a71e4c732af05c5691ba76371c6031c14496ea6a90152b443882e8583cf6a44fe2ae890f40409010001 \\x1ba4147e7fa861015a4a80a5efa0d11f59c0ae4e82d95c9fcf8a61b8b6b6d6e5f3f23eb8b1ce104db0021a9d6770e3caee2f55ae76a67651aa4ab0f211c76a01 1666699489000000 1667304289000000 1730376289000000 1824984289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-115 \\x0c954204b5dbece3792c04001fb65c1a9a7cfb654bcb30f2c6634bf32696afdff472baefed7a016291165fb2a0039ad4ffbab929b989e7c01bd553070dd97b3c 1 0 \\x000000010000000000800003a29b4fb846ba2423c95fccecc59ce32ee96aaf23b2aa5aeb7ef612ee95c230d980548efcf19e87ad53c720eebf5568738f1d280c33f9d2cdf6b67ba1295c942a882528679279ef88724b53d6f55ec22236279823a518dfc5d2e1614f01909abc128ea20a364cda6d16f64d7b883fd9e85c6a9c11365627cc68f3ea52c69679e9010001 \\x53e6f19691e97af4494712abf711be1a7c2e3e9e93a9396afa7bf090791da8f99650c55acb48ec7750b5f4e64c9a1580c37407fe42f51d6ff8257506fe9e950b 1690274989000000 1690879789000000 1753951789000000 1848559789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-116 \\x0e854e874d53c36c3da0af7e3ce8bbd5fb7a58c8168ce93933e5b0ae52f7b914f5803669db34b60a331686b4bb5f79870a38ce35e18d675f77d6917c70789b7f 1 0 \\x0000000100000000008000039b98bcd2bdb84b19545cc157e318064e88a2ade36fc1cad09260dc3bee30a319e4dddac1fa1307b0ef59897305d1c0cb3cb80c80507cdb81843b5c610fea8af22245df716c17cb0875f74a848bc06e6418a4341345e6dd4d15673fd0fdbed54a4d47802c16e91798d348823502568ebd29934e1daf2936dda4a54d65bec3d8eb010001 \\xc4c77d2ca203340a930038c632b8a2cc99ae8a5a07a7344ed58a21bd95aa6c4c106d6f3ebe58066afc484118352213f4155abd84220140b28d7417cda04bcd02 1676371489000000 1676976289000000 1740048289000000 1834656289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-117 \\x0fd1b475743f2226e2462e0ba22d51e77c5561ef1fabca46c280ec8329e0ea5bfabb144e7009a6d166c9bb4cae8d5611d42a1e75319cb774aff5b48e117da9af 1 0 \\x0000000100000000008000039e6f62c067df541f257d2144bf09b0f12aeefb531b550e10ec4cf93bc4941aa0573d87925baceacc866fc2b1fefd0f6e0e0751a083e0f7945164d86b807638434c43ad31e07809774f50cefb14c0e26f916bd5c699c27b3596364b17ee1072396cf9be51af93d1b2a188f6b1cc30565c7596e517be5840cd899aef891c376549010001 \\xb11a0842d8d5ac45ebc23d1ed86e6eb60b473e6e1e384c1ccad6ac9cbb5f0c019731ebb4c0e057ebc92d9ff4645a6e516129b75704ce96b18530f89ab9b5920a 1677580489000000 1678185289000000 1741257289000000 1835865289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-118 \\x111d4bfc32cae68bbff763334d038bb62e2655af9b1edd35837e69605ca9baf06bef7e75a7795cb16c713d29d489a3bcbcc835df303e9340ddb34d2533d2ef2f 1 0 \\x000000010000000000800003b00de7525b17b721a4c7f4215a487ff8aa6f3391d468f20142ae0ab5347ccbe1e63ec47c527fd814f63420351679c02839d4a9625d72ca5fc8e123e5b481ea7a75ada696681433ca30ce701e82199be7ee587c221b50a80d2e80fa17553c01381a199424d7b6ea9d03690321c9190b99609e017a253f3ead428a3c2563202d49010001 \\xe98d4a863d0147ce16024fe924c27c5e193516ac82475e057a6d79b05bd0057cae90df75701a656a26aa00294a005e1f81207605e913fc61c698096ff52f9a00 1675766989000000 1676371789000000 1739443789000000 1834051789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-119 \\x1899c30f62754e685d79bedcc5f37267aceca650176172900cba697881d4d541006a950ef6d2c5bdb57675d6547ad1dc401c25bc734ad8f7239032a16b2ed9b7 1 0 \\x000000010000000000800003cb283c2810adbb7850781084a313b7ef9129bebc278adf0e9c9818d3c80f9eecae6f0db0e9d2ddbd3563198b5c07255b64bd4a5dc1c9143253ee5e25689a316a8d3be35b27f7d6f41f90a2221313e6f1ec28fdfd95aab7d873a49b4c0524825c77d2479587e020cddf2213e49c3e9233cf573b74d4a5667a89468199bdf4970f010001 \\x9c83bf93f29c50d8bd525024738923cdab3e5c38ccfa6ebc7636187dec4fe401714fece4079d39970d7051a9432b66012e51b0894171fccd6a52f9353537e006 1683020989000000 1683625789000000 1746697789000000 1841305789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-120 \\x1c9902e6b76c8c6734f7d31e4eaa1434b3c54b2d5cad457b51a470531acb3cb0c368cf213b45a242e9e1e3b0985c6fffb5c27555d0b9a1126fec25b73cb11ee5 1 0 \\x000000010000000000800003bb026fe50a674899533a3953d3e0eff56c77c24d7425e01c1d9d3c019289ba3c021228497f3865c9f194d6cd1c24790b593643a7387bebd034b3800c28b757cddc9cd3145018b8120886df673443664c84747fe3218027452426ba469bd2b7e788fccbde8940935c86a1b96867b45e1d0cef80d1afd3ac5dd4049192808db391010001 \\x23663230d00d6c29ceeb445fcd847a28f7d446f276970e7f1f1eb8b3bb5b66940d4b48538c273e3b22f4fc2dae30fa9e35dc4cf9e064ed957f53f6934b339804 1690274989000000 1690879789000000 1753951789000000 1848559789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-121 \\x1f653f9c068caeef8dd88ef60d0b87aeff63c1b640566d6c57b2a3442489d0ded2f7e4d698df5b56bfa3955412c1e870ddeed1c95ae6c9de08fa687d64c8333f 1 0 \\x000000010000000000800003cb3e6fee6f8680c6a735be7071386960c3e97519106ce0349bafd992613c87533fc5c135ca9cf36a007948645a3166f7668a6e402e0b4c595cd90f68c6d8d6f8e9b4dd4c5990792ff3f92ca054c6444a0733972fdb0fd17f4139ecf504cf0c386e9cf8b63742e348e56321783df99fa34cdc0223ca16e0c3526e956f96397355010001 \\xf6e678b9ae3771afb1b7c78dd754de67781ab330e42bf506f6485c78c169d287802f2d11c03567b2245fccdc96a99398d900505a1c2ff5372e59338d9a57e901 1686647989000000 1687252789000000 1750324789000000 1844932789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-122 \\x229135271ee9e34f4126927f4dd59dae89ddc10a5b7547d445f2ea8ab3476aa1aafc61dd42dba9bab649040502c64123af2325650053c066a8ed579e3283f94c 1 0 \\x000000010000000000800003e599c711585c74eec7d6f0765dd3603ba4f5cf09c0ba79672aefe84277b2eb9203420c96e4f1cbb43a349159e099f8baf2228169e6b2843ab37dfae43025b8dc3c453cb603b6f5fba02c29438453df63401d584a63123025f753e34fde67b98f23016e690df708cf5ae87c462bd1a45c6176243b61ecbcb258410ed9a427fdd5010001 \\xb69ad95bcfe3b15b35f136209c8c029d4c9d903c04010b82f57a7fb85a70a6f941ad3175211670f5f712c7c52c2712371bd9fb74af191a4513a2e9ecfa523909 1692088489000000 1692693289000000 1755765289000000 1850373289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-123 \\x249dad5066c3056d41c18930cadceaefb54948cf685709b255cb0af727c98c89e53a714d9346ca0f8ae895ec9857055f4850bb28278f813a156e456972a3f0ae 1 0 \\x0000000100000000008000039a0ebabd01da3cc9403fb81057c445af7b96dd865c1eee19c6f0f18b47560c313e98636240942fe5be8143d31d4113dcbe208f32f9f746be11e43193095b5160d12f68e60a69c086c8a81957d1de68549bf5a9f6d2d00811156cfff2b7f5936d34daec51f04c464e54f22155180a3f63a25b8196c2e57c51f70b5684a3c6d297010001 \\x8e59ee1fbe22a95cea05a3242199aa4f656398e330422366d4bf9f9b5abf1e16b8212f167224c154e5277424fe843a58a0540d3e56a5677982d3a41fbf4daf03 1662467989000000 1663072789000000 1726144789000000 1820752789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-124 \\x261909e816633f96804547419bf07f3cebfa53ccc3480a16125d47943910c3b248196dc70cc1d4bab263a5da6ba757f614d3f94292ccac7d707cc8af2b276084 1 0 \\x000000010000000000800003f61624ebf0ecccfd3506a150cf7ddbdca4f7ac5f983e31efb3c6808c7b07ef7be1296f2c77386fc0b61f06b009bc02d1763409748dc7ac72f6f81aeebdca8739a9c2ac3adef32e8183244ddb72fbf4262f38beb7e7d2dc98404aceae48b87d0aaf35c163971ca319e2a07a929903616a6b2e317720ea86a1dda112448950d817010001 \\x1d5994ed7e22672158b7db730ef923698055548b98a593a077956366796f2f24ef05297046a0bed82341406754dd862f2c94459e7b6bacb5e27b59994e6c1604 1679998489000000 1680603289000000 1743675289000000 1838283289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-125 \\x26398967212d681878c1ca0d410ae7ab655e4955cfedfc30edf329ba5d2532b60faa90594fd7e6a4b6617376031bd1ff04f7dd62296c41bb964d892906193d6c 1 0 \\x000000010000000000800003d72e5b5c4b919b0ea590a230901bedc61decaa6e29fe7cec5c0448f471cbc37f1606d45116501598a03dfb0e618b493207c346d25cf233c2e4679895faf6e1b27850531e7bb27d5c26f00003e7ac3a0ed8653508e91c9ee6ad51613a20ee34dbeff6dc6b3ca4a35dbcb951b1207b7b6314e476dcc05d0bc7be154e1ae32f85dd010001 \\x070efe186323a77f7857ccb1cfb143138439cd713dace35b1fba845fe3a9b9b449060f184a349fde0a4d3d0a7a66a846ea9675e5aed56e1d3e17a65acfd5370d 1682416489000000 1683021289000000 1746093289000000 1840701289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-126 \\x2bb1dc2bedd29a61a63b0e535a8a68d86f00d153a9d00e8602ddd66f9460d02fb997c0c6a8b5337fbf42ec88e27738bbab87b8c311b13ee830314523d87bf7be 1 0 \\x000000010000000000800003a92f04a31f546d53150a1ef89d68e962786c459853a7d71cc8d8eb1ea1c2b95dc2a1698fb70d6f203ae119f26c25d748de17a6f8409d663840deb9f26496aac8945701ae2ef5798c57481b6375a84188683bea99128d6793f1993f1bd40939489aa7f1e46b09f8efdf472d728073b53e7240f1f9806f1450e65341ecdf8e602d010001 \\x8d50f759fa4e6dff56538cdb43ae81b4111d248c3237d6a4891f8470a984baf44e3b7725a6a8568f51c4f2f4f43638eac47351a0475c9fd44a98d58a093dc106 1681811989000000 1682416789000000 1745488789000000 1840096789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-127 \\x2eb94d7ba5dc027b186cb675e8cb328e6ab74b45828c8a47f20c9b87141f58a53b08ae631abafc470bee0c63c6bcdadb067cee18d07354603125461d95772b02 1 0 \\x000000010000000000800003b465f312a6a0f93837856d6bfb47f1560ecd48e33cbe167a9e498f3c85b60f11f100398f7c888cf590af68821d01b528edbe873403c206551d6b377f059232ec740e02e0a83b9c214f44b9700cd53c9c61508ee76c2913dc85ca5eb108fe6a671e10dddec92de93d6d000df04399cc44bbca4cc357e8976868e5494df08665dd010001 \\xa6b45e413fd2d187078197b7d5513ec3d872ddd16928e5b5a06ef6ed1397c05a91c6d0efa81038f998d8a734d9b6c5c787211ba6787d7e813075ad1cffe1e507 1672744489000000 1673349289000000 1736421289000000 1831029289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-128 \\x31fd5f619d7cf668d33dec106801f67d849644bcb7639f43616f46c481f7d7fe18de78d930dc1c86411fa0cec9dc018d4cb42bebac07dd4835dedd554f2fc95b 1 0 \\x000000010000000000800003d48fbc281fd6fcbe32ae54e6e98990eaa2aba1eaf0ee19a0120cc69099e1593953aab6da1cadddf0134ef08991d28ee20ac185d2cf9f65029fb1ad97f35555fc8ac6c4c0242b98c36462dd71647c26902da29ec54da9f8e742c7c4d5e1a575405f3ebe6ed6f357e9ce7c4c04ae8afe288347dc96b8b229c490f86c61978c7889010001 \\x71bb21c18ee4d8e9500b6e5a983489d40cc5440d84dc7eaa589e687366534a030f448e82fa33f76ecf01311b8d407203ebdc65899f7865bca1d1eb9017542302 1691483989000000 1692088789000000 1755160789000000 1849768789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-129 \\x34916402d938dd19a927fde7bb51c2bdbeff89ed8e5c8bbdf34fc4c579503a25ac9c6923d6f487221eddb3344c7d263da4db23793a43717e062617720257c171 1 0 \\x000000010000000000800003d1b505e2ace95848b90d779d231af2841603c0727771e2fd72a0dcf611099fbc6d9c68f1872e911a403d01b37c2b6030b6e483235e089490b3f4d16b46daae834c9f32244ba14a9f509928f13965648e90ee7672d177f95b85b348b228b57b35fc25c72fb7b656ab496930fb58b60cc69c26f3e9cfcfa1a094901be52d127f61010001 \\x7b1226b4db5abf5b12dd2b8cae2ff497caf87f7b2e49b63df2b96b635c07cbd4903743f8b4b556caa421b324edf9066b7f37d609984b96bd14d563ca0325d200 1684229989000000 1684834789000000 1747906789000000 1842514789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-130 \\x36cde1d68e1464b3cf74dd1d9db135c27437824c5438284128718f69a0b515e65e13b7851d9608ae0f0edc2bf2ae81a1f4666bd57a0f9e5b44565db90e6acbe8 1 0 \\x000000010000000000800003bd045a48d1c6ea98259662b98c4cc71947a271b71bc7d03342f61ab07e8098e661f973dcdec9e1d34b37782494e9f687e9f9d43d70828e9ed19b24a2409debbef48debdb132093518b4d106b9983f0c80e9c7129bd90472793ed457a28658b1fc6c2fd125cbad15ad46024c668b86fcfb6fe6a67a9e0980999deff42f5b2152d010001 \\x8a3ad67f0bdb6cd549bd46877eac55445ce16c61054df44868d35b34023d0969934b3109e976e40fe6ed8f95d5bb4568991fb26f25c60557c989ae181c69fe02 1692088489000000 1692693289000000 1755765289000000 1850373289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-131 \\x384dbfaf459f22b74f319b0bade7c72004f20d64d7889a94ab57c5a5ffc411be698a370ba1ccb65c3a2d983a3b3fb1483630b7cd9bfa1d19e50f8b7a9b6a2d46 1 0 \\x000000010000000000800003d8ea2cf687556fb257dd5c9ef10460639d9f13e85c79488a143e51feb5268823b7478be722aaf82c5d9bffdf77fbf76b04efa71a1c6bc157f581feca863490ea727674fc41f6e9af996ae98e21c47a10c19503843c0c5574ece7cbf8ad2950fb3c8bc6277fad00562c8489ed7d8b2b30f5361452786a42596cb07e3d844c4abd010001 \\x32b07251160040cb716d7184a4e08ef4d75a027e0abdd43b9b9cc259ee58ab7c9934fae1a7ef51d6086b39a77b896d682708152c09268aa61a53cca03e7d1800 1684834489000000 1685439289000000 1748511289000000 1843119289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-132 \\x407dc8a07af9917073e40472afbba9d9b73ea9ea6b7f571c9fefc0d2e799fb69486f475a3f8b6c167339ab7d9310c3e5409b5c0862b4429b7d7de8c103a5d66a 1 0 \\x0000000100000000008000039e23d5e706ee0fc7494682d9ef85389d6e3544618c6a31bc2e74f5eaa0b4cae5a951e2c4586df062be8d8d58f4e9ec74cdebc35e9708a9f44b39a9aa988976103799e697bf6b4c96f1b37011be67e66a575272366f50e5c75495952393624ef74f48d5a0cb3c9e7cfc0739b34a47b04e1c9fb097fc0eb1193b9da05b6c02cb73010001 \\xf6ad4cfdd4948f5196358a4752a80e4d1796f65fdbc0de7a93f5931733152c25656b9dd8698b6be1507afcc3541fc002b5eb541fb2bec0a74eb10e414bd33006 1683020989000000 1683625789000000 1746697789000000 1841305789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-133 \\x426d6b4d4c405f6bb904ab35536bdaed14009282741008de82200a5a3496c0c3df8d2f459a6233c9dafbec248376d13105df738be9e8de6a6bd8059e10ffda19 1 0 \\x000000010000000000800003ce9bb6539d23c180fcd06612582acd2474cbcc70f3b48a2236718b8b533b8189e60dd0ab013e65a2efbc169ff9a3dd4e6e29d01ce73897cc51560698ca22e10cf0004ab24f5bafac70c12b9e2842c6f6f16da6ff73929f0318ace2370d3302e8f957f6d3fa6c565de890dfaeb9d87035bd90c0e477637ebda7a093d434ab85ef010001 \\x017f9581040b3dde12b3cd7350db5364d9589cf1ee5fa766d6ee0680ac907ec28927455031d5079e4bebc4ca588df7779d0b83f7cca8ecb5f6ad1979fd63e605 1664281489000000 1664886289000000 1727958289000000 1822566289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-134 \\x4325afd338fe137fd63bf8fc5653875679a0ab08fdfbb20194f005443a928cf8d7961638aa0441e8c7d0f1d0dbc9f9657686e4679237f95528bdc6b3bcdaa899 1 0 \\x0000000100000000008000039460eda30f15221ea746b005dc339334af024e4f82084eb0d3c85529c2b020a4c1c504938222a65e9735b391a34f13ed74a262450a3c263b5807781f869ce3876e83a5c95713a85857f549dffa0b9698989a1aa4051c02f0c140f2705b21e6612cac604086f6c9bd6fd3e1204bb7a22f5aa6c0f3466b1a0b09abd59228916f3d010001 \\x72959d085b84e6f1bd0a78a9b0137a3e96c24f16996d148f93e29b5e6a40bb3f81c777198d08b9a2a6830c7ce806544901d3e4ebdf653c24aa3194db8097150a 1675162489000000 1675767289000000 1738839289000000 1833447289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-135 \\x442d43c0122143bcd15fb6d6c6cd9e2505f6168c494ee41302212f48dcd1485767226f45aa27be0ddd224fa931f162430d962edbafb8ad577539a157d2f60db0 1 0 \\x000000010000000000800003dd2b32732b7b4245925dbd600d1095711539a86fd2fc8f8a7daea127062e705d0394194f8ddf208467e1061b5d5676c624d5a4d9b3c1170a38f4f971265056d08ac58ba5cf8cd8cb99834d1f1257031124b2b0c92e6001886dfc155774da831bd8e9e878666202000586fb79099edecbc52d9f6e485f0a4a4a29b62285c69afb010001 \\xc3cf9d0d4274b0b62ba530c9db2759558629289bd804c24d25eff358dd5c8ec4dd8f75b72f5896e51765ff6a3c7e24b6b2d701093991318de192eb6f7e40720c 1684229989000000 1684834789000000 1747906789000000 1842514789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-136 \\x45b5d1384555cd292edde79971f804e405bf6d58e51a47137e9457cb87d9d3ad80fa86791b044baeba75f2a91ea0292b1bf01067fd320903db71f068d4c29c59 1 0 \\x000000010000000000800003f4c4bfca0cbe326e84188ec6c60eb02f3f28da29d466a8e4bb6260a7aed7025fd179bf741366978d0f30d5b47baeb38704d17e306e8b05ffdf67de8440fb5dd08260f25cd94a21ca0c394a36782fa2b44b379e1abe4ba46e0699079fca9c3d93cdc52f2ac3f05b6c7d521897d28703ae14c07c4b853de242b202c9e63ad92073010001 \\x98a9150277100febf3e138e920ba5b9530cbc50056e438273bff21a229c7df65ae0b7abb02086805521caa8d8613205b430ffa4260f0a2c9b3d502877825160b 1684834489000000 1685439289000000 1748511289000000 1843119289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-137 \\x50c1a933a6f6e6550ad97f384f96524d4945ae2e32acd47588b58fc6c6b46125a4a0cea4432a26e54c9c936aa01678f021ac00399b845d871be0e61101ce4394 1 0 \\x000000010000000000800003baf81055ab9e47039526790f824af0af2b1ea430bcc1358270ff160f73342c4d421830cb34e2ff6779ccae6a723274966000fcb81f5dd5ec62be437d97d274bf83ca036108d6a2115a59dd78d31df510a90aeea779786f00d0d536f5cf58a40c3cbc144e289ce5700d9e359d06e311f0b4fa9e5e6883c50f34bbe846fec4a8e9010001 \\x3a8c07f042c3d3c04751dd3a59a854c265a4559f630a9f9732b460ccf03380103b8d805b29a52587f2b8d28578c312c32c65abdb0af75208f51635e13ab6d40b 1676975989000000 1677580789000000 1740652789000000 1835260789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-138 \\x556940877f83da6189c512c6f2f0be556c2cbadf655954bbbef00b48b8ef3689b7aa66818e937931db7e6889b2a5e4dc85e02b18f9b56a18b54cf9a00a3828cb 1 0 \\x000000010000000000800003db318e69f6b4d051e913855e85fcb009d5b5760414912030bdc6c3f7d9023174523381999820eaea35c58aa25c908016c9fa13c4b06bc8da70ff0acbf699becb2b81eff9392483b39ecaec97cd6c516fd4a8365e79d65b02b6bd964612d8925da23f160dd9dce3e362db0d2826d51bc1f14a921a2c685308c454604801f9ba4f010001 \\x63ea29dd37c0f8b387862ed6ef72a8e2f2a75bf03702842fc5c3ed0cb3e0ccf965fc62dbf9814bdcbda1119cfda8a6a826f92cdcfa1a48429ad4f6a7862f310b 1679393989000000 1679998789000000 1743070789000000 1837678789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-139 \\x57112e59920847c83c8ecc058fa690b30a098824845b2400efbff7ad9a08686a7e438ddc51c24b5a385f5f8c7b0c8f946a4aa4b3e525510601cbf6baaa1bd8ed 1 0 \\x000000010000000000800003d2707412f7046e8d02192fc4930f209f74c3cb47d2d9729f0e7cc4d40d75b550b86010986c942394962d51b5cad3c38e0d131024a70fa55faf23531d555dfef24b838c51f7c3a0bd1e36da2ab2296a8a53793172c4c314d595ed20a82334bcf1ddbf0fd18b0992596ac11fcc4505fa83264fbdf94542cf621abfe1cd340dbc81010001 \\xc05d3d7aafbf372f37fc0d395d74df5903425ddec856ae7b46401d65841b517d9a830ad246b21677af24ebe3c5d43e8eff62308b972a95e12fcb6b05a8ef2d04 1679393989000000 1679998789000000 1743070789000000 1837678789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-140 \\x59b9f49d8b942d4e8d8fa3a16d9855c0318ef67f0c9dcbf64d56af65509dcd45a8498f2dd119ee8ffaf7f74e5a38430b3637f73db80ef81f68b719acd7a6ccc8 1 0 \\x000000010000000000800003b7928a0e1a40f022c3843521353e28b3b379598daed068b59aba1226940eb02368311eb033a6bc06a0084bb85b75c2708a68c0507777584f389d8cab03c35b7bc41a6b76e2c0114911855cb85672959455430234d038b0ac365651cef654912b0cc9b1afef46362bd524d071b423e27a602994eaf00ee2e6e7df22e5e08215ab010001 \\x7bdb4a883c89ef5c84327a9a5c9e797646f4cab32ece5de3c4e9555dc02391977213c119747bfe25ec877ccd0c6cd453595d180394a05baf4b38fab2768bfc04 1679393989000000 1679998789000000 1743070789000000 1837678789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-141 \\x596d32e609d7b95cd32b1b247b4757e47f8d6be046f080e749f4db1d09a45e612d01afe17a35407622675ded1cb4e167f0eeffc256fff28afdb3c226f444c009 1 0 \\x000000010000000000800003eadbfc8fdf909f0402a352a6383bda9538f44c3f9f0632f87be671e7b712223bdced8670dd16958bb18d5013f359245b2d48f4991bd7fdf2720fe63cf0275e6fd8657e92611b37ffe333ada0dba129ba9805e56ea99cb575946bd6b3571e26fd862a48045144663aee08a30cd9c75ab0616f69b8084c4b51c957b8c9e7c4d873010001 \\xbee68c876a3e904b3d8d28e44304fac3530c0e9c9494990c9724897058f02ed88734355380c9cdbae6b6b1a729c341bdd7ae3461740b50df2653022262cb4801 1667908489000000 1668513289000000 1731585289000000 1826193289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-142 \\x5a9db7c943586d89aa4a306900dbd7e1915daf7701068a4a397f9a31fed86babcaa95717eef396c67866402d2a0acc5ed15637e4b77260ea76228a63fffed20a 1 0 \\x000000010000000000800003c130305a0dce7136766cb50ea46b4ab424d3bcb5697b212ba06c32338e2d27cddfe207ab456e605a5d4efa126ad1c6acc8bcf47e5fcc2a92091727dc6e2e20a818af9199a43b8b4429da44d7fdc448f972a36c493a1e23c3c75410cb05f2f23d5fc2b3c1b0169e417407ce3a2b05bbee6830e52a9d793312e35403b6ab50f85f010001 \\x0300e32057f333d7ef83919f9b5658018dbc1953f66f28fe327780daf7fb262b6a3a97addcefbdd770ae00f0e6758fecaa0ac399fdc0616ee32cdcf7f562760f 1666699489000000 1667304289000000 1730376289000000 1824984289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-143 \\x5b859bbb4b06332e740bce24f2529ccba53a56df61f396ddeec12c0c855a0e61e037ac3fdb5aede6c0e112ead3412487652ba9a8f5037db471e2eefa8e59d3ed 1 0 \\x000000010000000000800003e5fd0698d0081908d5d74cb1414ac796a1d2524b49bf278ca2f4072138956e198690d1c0c6c35d7ab6be8e2905f3948207a729a2c9bad4c4deece527e648ecb8b88177275fd57227e15d544a8bf5aca782996e5d91af65a38896a706aa9691e39f682c2f28ee9bd22768147fd7c3c8bb0399ba4f82dc1a0060bb7535967be433010001 \\x487f5b33af313e54f949be484b9e3b52b8866a09fc1a68bab3ebd33d7e7c07d7d6013499c602c22df4ae47417ff892da382f3e1640e545c0b98db8ef63996006 1679998489000000 1680603289000000 1743675289000000 1838283289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-144 \\x5f3d87d68b46b03a6b3858c8fbb281319232ed9c1786c33b70eae477cccec68f3e88c4d3c6f042278850529e5ebd4db3fa95f33d62b9cbe63107e2235fdabf8a 1 0 \\x000000010000000000800003a460247a4f8e5722446213ea594f79a592a5142ac0245655b730b87043f9f44bce8dcd5e35f66386b4cccf068ca47ba94b8e01198af406aa27c1d94390a6ffdb22c5cc5556f39f8263e90aca1817a821cb4850fdae34e00e0e147cc7a16c9c86936a1ec1c838f0a327af89b1c89172ecd3052bda864bd0c11297fae15a9162d1010001 \\xfe86bd29a1c1a43c9e776da28a2f7152e6fb2d728095c98c32b17cc35643cb914cddd6bcd8dcb44800ffadc7278ae9aa1f98a4e1396764fa85bbb1771c49b400 1675162489000000 1675767289000000 1738839289000000 1833447289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-145 \\x60594c7ef0238a1ddee78b49e83b1f9641f260df66d827e6d285653136ceab783a25f0a80e6bf8683cf16fc0c534bf71c102d5ac09a609435e756b0aeaead663 1 0 \\x000000010000000000800003cc9cb064aa297edb65f4b8c4bb27161a7bc18aa922563082320c5915fd693a5b93331a72de12d8faa43ac20bda6009b561e292b952dc76195396a27b276e5caa73db94a06a6077f13b1e0cfe957ea23485f15eab5bd1ef2f72dd781ebc2adc06a86fac4668bde129120eae43ff617198c98660b81c43348939954677cd84cc05010001 \\xafac629e8f4fdce38b8f4321bd1e663255a72ceccd9625802858187e1773626238bd4fc9431fb7697614c44954052135f1e265478111845908198a0925bf2801 1666699489000000 1667304289000000 1730376289000000 1824984289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-146 \\x6261c911c1e9eb0233c6e5aaa19d681cd70116d807622cebf3b9702219a689fd61fd450fd4e84df599165eb8d81e2f614ffd969d8dcad7b0b1727121bc33182b 1 0 \\x0000000100000000008000039533e8331dc402d1cabdd4d03c90df85bb9338b903d2db9b9ad681e1aea2460cb99c7ffa9687b230ca0440f622ff8b2ba19d8896e49970d7696336fd68065650c698987093b4e5af8d45c29235bfb215a5c595c6a48629f8cf6bf6cd2fcbf34a61c82ce2fba1d450fd89d3d9afcaf911d82a79ac0f9fd83b9a1d4a2edd7f9469010001 \\x7ec68f6475bdc4ffb3a6d7b18948ebdf30c76d0995336825818fc38684fe92ca460e6632b5ebb4a5b5f376b5ea1663ef945378f21a2123e6f44b86c923c4750d 1691483989000000 1692088789000000 1755160789000000 1849768789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-147 \\x641d2881d5934bc9a612bcf5a5ad36187909febeafd9ee7502c03c4092f6aed0bbec2c3abe45135bee6da1f5fb158dad1446ba1a8cd1858e8556871d55b196cf 1 0 \\x000000010000000000800003e8545279cfb8e626aaf498a3b54196978d5623805e2561823001d9a13acf6832c7e0ab836e0a4f9f3a541e9ac61cd958f3db21abc03437805c46c63a93b352605460fbebbff45e5201539307d0d6b9266a93984d7968137caf9b813a522ad2976c976f44f24bd3ded041a654aa80f8d72a57705b833bcea7a82f7c3b98bd8909010001 \\x6632600162f2d946068f42033352a9c4bdf164d18d2d69fa05bf54391ff64e010452144cf826331969b034384dc04e90cb3181e15c496d11e86438d26ff3d00c 1668512989000000 1669117789000000 1732189789000000 1826797789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-148 \\x6561ab2a7e166b87d12c7187ff50214afba79309cf2e5cb9c165a9ec6ff6b266185b1d54a9a4690b30b4d717c2fcad60b4198ac881fac2623bc3caa6ef0e400d 1 0 \\x000000010000000000800003de3db2a17f98e2968a0620b672c255e4a2e904de5d01677a8fd13da4b5b802a3ba8e135bb3aaef04e0fcf4bd4e471bffa0cdd348f5680d37b0ff692d7f7593360f85562de03c1613b5d143c82eb5bf9032765ece385a70848600ee360a757ab10e78d5381cd9b19e71e7e7e0fc15930a56cf3ba48db3a6e9c7e68face464b39d010001 \\xd2cfb93cc4d8d528a3a4d03613f59434911f48643516ce157d15fa611c44ae93cac6a265f8ac64e96cb50ff29ee258c846612a27edb6da37e509aadcee606e0c 1673348989000000 1673953789000000 1737025789000000 1831633789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-149 \\x66ed5a3868e76becf7e35af3c6a2d15163e61d53194be7f1f8bf0a304937e65c5607fc7c3f3023e51aec3ce598912322c59a7349c10520e69b207d220188a0c7 1 0 \\x000000010000000000800003bd20dc8022936ad6ac58986a69c6073b04bb657b3d4985f262a21d50f2e31d2fe749fca8577ad7b9c7a3419436af90249da2b82615e99128de73a6ffc6ace4355519d0b841eaad9a9bb7efb42ab3e1f4a3e1e75d7b9da0c28af9eccacb2d2d18c4e96dc827e334836004bfab2ce1524b9858d39d28c761e55ceb902b0463734f010001 \\x7e8a7d002886e455595c64c607bd9e30563dab83cef648fa21ee6a51631e51b091ef35787ececf899a053db28b070a97b347b2452b74b9c6be4da811086d8e00 1681207489000000 1681812289000000 1744884289000000 1839492289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-150 \\x66c9fce491287303dc094463cf12f5f3bad6fbf7702342d5ec44e41182002a9194e3518d6dd8724f8e98d9b877fe04235cccbdfee0da5cdc0f15c371bba4d1db 1 0 \\x000000010000000000800003cc1947143722cc73c0118a5ee7e4b06358e3e2726e8e8f1b8c8b03cb39bb7d460224e82005fa000e994373aa37892a3807bee8c031b25c7ad85a49ddafa50d4b9792af96717c3366528fce76d39eab41fd0779b8d25494a7c09b322abeb987f13340e8ce2fd6ec8831f1c582a02b36f81b11723fb483181d5dbe92ac7dcf3bfd010001 \\x3af2cc9b3409be9474ac6e70789db149ca28202394a324ef89f41441f3163680b59f489dc2bf1a4804a3f2068ae5418bccec946bfe75246ad5f3808288510c04 1677580489000000 1678185289000000 1741257289000000 1835865289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-151 \\x6d09b95e99a9c9096e125d08eb22ca37c07744157bd03e3f8dfef35c9c904a334b687c4ed2bd83f06cbfda79a3ccef77a411c813768d8bfa7d92e5ff1ad03523 1 0 \\x000000010000000000800003c6dac7d2429f4cea52884f19fd36b823c363427edcbcd579e494e1a5eae99b77f3c7dbe651af8f4134cbf5e966907a2407e621bbe5c709784a77673a2bbf3c5993ab4c9308bcf4fe5afccdb9b064afaa5fdb9442b8bee9566e3a1c43f1437164c6100741c27f1f1b7b9374792ce7299e7fbfb8af8c44894e8cdc7120f180f49b010001 \\xbb656be49361d564da4209df22de8e66d9ab23b2dbbe836e52f27d8c90d276939ff2ccf447d8db7a2fbd6273addf7039615963a2dec855af76208db671d75701 1669117489000000 1669722289000000 1732794289000000 1827402289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-152 \\x6e8511fbdb26eb2199df877d8a0314bb2b033e1614bfc9a15ea8f34641dfde11b564857c92a528cff1a52dcf9ad244de3cf303980cfa24146f8f329b5498b35b 1 0 \\x000000010000000000800003ca5ea9721d23d9676fa3b5c513088d62da64cdecda10cd7af9e9c3fbda9d9eaa9cfb7d68090964b18b7f246421c5c703c67784f859208c5c0a0c5726dd61c2c7e19bc7e070f5442b63caf55716cc727e6b80883dc713f495549f6cc463c4d491d7811be35870df7c2dbab6c79ceaa4e822decf3772bbfe50672158372692abef010001 \\x1231d26c1987b3f7cc55310c1ae62fe7114f70e37153d40b5653bd67ffe35d81bde201bb92d8d3e18093bd98efe081f8171b26cc575387e9c1bb5b418192ab01 1672139989000000 1672744789000000 1735816789000000 1830424789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-153 \\x73a12a87bb1b5f8a068eedacb14034819b61d1682e0ca20afae755a7e60b55e15644abceedc8e35e34029c53b0889afa1ffe7bfd0b33da4b25db4931c81d8bae 1 0 \\x000000010000000000800003c00437c0916bd6e09c57a722f93bede5ea460fe056bad65ef25923605e293bbc58eb790c3d3aad33b4e9b0e32efc27778252b8c816beec7d89c7769a77cd6438eebbf70c38881e0ef040f5ef4d3018667700ac1919cc8a4427ac98c77cfc1a9e663fff94e062ba8d26a458dd89982dfc819c8d9d74ae0b2837c7d6a873e40f6b010001 \\x6bdf50ea4e379bd6c4ae2b65020a521f690a3a4ec670be481aa3de27f258f4f4f47c0eb9dd459134d498f534c7f9f37240fce90a9ef31d1155fa99461a772a0c 1679998489000000 1680603289000000 1743675289000000 1838283289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-154 \\x7525e3f1f904adc65e6ba15274caa8e332bdd74750b6e39f23ee2fdeffe778607d8acbb515ef670015b6375517738cad1f49b0d100242d6e8889f46734352004 1 0 \\x000000010000000000800003bcb457c4c51375883e5d184286e099c572e09f7e70155502065a930dc402d6d5d562691dfcc1e7d4ed8115f70f0be82709db574df4304c603a9aa5a6220df61009973d25639c8e1d4136fff9aa70405bf2598eacd74a2c3dc997c78924a63f2358dc7260ef6adf225fb320d854f3cb93c4e4fddb17702375735b7e7f2c12f797010001 \\x6cf4d8dc61f25614ac16e4ceafaee58574ec343a2af767e8cf2fb636a27af18b32a3734d9c954ff212164f2640c6782407da255e5184b7dd1aac52ee6d128806 1692088489000000 1692693289000000 1755765289000000 1850373289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-155 \\x7d75b3b7ecaa8bc0dd319de6c6764b2d7f620d63cc3276fcb152f9ac26a0b33ca8105e888473ec0b0ab0360e5cf40499dccd174a0eea1eae98a40576b3196cb3 1 0 \\x000000010000000000800003bcd2a384809043496e17f37a2b9d792c7c45283791327ba49006aa04b40baaed0acab5937564cbf10b22cb16795834026dd2ebe7fe6755511bf42184b63cd5dcf0e2d5415d4048811e386cd6dd5b7ca9374b0adedf753611e3223eeb09f049ddd21859adb0b9a71cbe3353fdadda1ef273fbce2c0f0007a87619b8de96068879010001 \\xe0304a6fa808bb74d5f64c356bca4e3b67437e1574f6ac0ae37faf67de2a6a67e1cf6b4d7184fb812896e8e64c19382a931072d7bcf7a80a364d05c5b319a307 1685438989000000 1686043789000000 1749115789000000 1843723789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-156 \\x7ea1a69d2f97219fecc889abed971037001567f4ba29abe0bb114db71d522b9a33530d99b66ebc0a9741cee5af2d4f1c57e379e9d174b8bb28b769704635dadd 1 0 \\x000000010000000000800003c1d93fc6be78a6a8b47f3cb96eaa8d7f3c5960a993a92cb27a0a1d3c35c40ea90eedbc1726e9a747dc7aa06db31e8d28e0f97d1ac1691fdd1d4ac99d7aaea7fde3540cd09e66fc32b138eec242947a58b8105e92f93770bb390777fc98731a1c58b21a57d4521044b131361d009c8c13d24fe3e4687c48974b0420c74b1ee507010001 \\x0d991d28449807d6e5ea1e9de16bca541d2f5ef5f5863883b43083adfbfbed9dd43fe78f0e118cdffbbbf9a068ad6d604f22bf5ec1db2c8c08907cb0279daf0f 1687252489000000 1687857289000000 1750929289000000 1845537289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-157 \\x857102122da26a523e7ba8666b532d9a58d05f83983a20305369e0f281be6aefe0a20fba34ced7ce4df549c48461463e2d31b1848b20040b6ea1cf263c8a2aac 1 0 \\x000000010000000000800003c25ab84620548c206c044c46b14ef0dab1a9a4759bd09422a5afd4c88e46f91f59b3d29293d103189342c6b95736e4304ff741c97bd9fd4ada4859169a5f1e8e23451108c00db0e28e136daf762129eb2b1cf898ab16727dd30beedf481cb414c5096048b394162271da581b3c24c69ac9b3ad22619df9e787bf63ebc0622e0b010001 \\xc81b6d2311f9f73a5ba4c3fc5acaaca4f8680fef05c04b000947fe97f1cbdbaf54d38ae63c354ac2ea3c55e4a169951281e5dfe91ec01481ce7f0117a28b0c0b 1666699489000000 1667304289000000 1730376289000000 1824984289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-158 \\x89c1927be33cc824082e98e512e31ef9ee2bcf3959b6227f254f9f5b4cc85ded5e2404028e54f3594e6aee69083599fe2af30e60b59b221b74d70f96cc8a1a7f 1 0 \\x000000010000000000800003cc3d77a9ab5e031d43cab881e87efba1317a8e8c61fde727241caa3bf61f52806d2829fde91fec93bc857ccb0e8e54ae5ba388aa11e92a3b643dc8240ece6451032f58b5d94a3ee89aada927d6cf99d9af49bc43250312138a9cecffe73209663ecc55d01cf071f282dbd901de82f933971f287128c60af1c39803920587cd41010001 \\x60d99f45008df0f97ae8da8e6e6b18ec7bcfa44f9d14e12478219819705c6fe9245fce2b7f5f9f58aaf52bae39678b766a8d23871453c7a45771fbda59171f0a 1678184989000000 1678789789000000 1741861789000000 1836469789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-159 \\x8ea51bee287471e8e9bf74cd93daa60c1afaa1c4f07e57ad53151044fecddeb284ea539d2db9ddb691ce2ceeb5eb58ab24f4bcb195fe47310ec4d8a88058698a 1 0 \\x000000010000000000800003aa8bbbfd52ad0080fd425576faf126db2361d86621632e96d34e30a5b98b6ac92e96b6ea5f1aca57c1bde76366ec5e28e539990d61d557aac446bba6431e9da444950bbf2a5e0fd361504a1fa35d174af8d9732a83f349c9ef45a8516c9141ded749b64d8ef3e7494612f3b72613fd574ae8b511436d43ea724f73d6de8162ef010001 \\x1732c157a5111aaace3c9b823e35d2085fe19598aa6358ab791dd1f318d24d87a560c94f203f384be0779d62ecb077c4bfe62a2d4180f139db270fb644cd3900 1666094989000000 1666699789000000 1729771789000000 1824379789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-160 \\x9809c4f9094afb896df7f2bca3d2a8279eb6096f81da326ed088b06680500ec944134ebfa841d26750e1113c1fe490e5932ba014fb4f07202aef64ead84cfcbd 1 0 \\x000000010000000000800003c643587b770f8315c62a8c8cb50a7c537de734f066b0789605602daa19ad17b479b6853b10238f03ffce2dd003bc5b1dcee1d921e1f8360723c98da2cd8a9f2863384f7c2f1ae6a77402921d37b34719d0c7915c2f4aec7990de189f5102abb0d9c303debc7587b538120ab621c571ffad9d71dc9f0a76a8d6b8852691be315f010001 \\x1158d2ea53d2c95dcbdb53e81e61255dd72c475fe13bfc4586949e9cdeb32dc5766b22f27ea20bb24a457be2a6e00de78a0eea698531cef17350705c2093730c 1667303989000000 1667908789000000 1730980789000000 1825588789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-161 \\x99e578f6f84b6b87903db041a5661269265f14bc33c36299d420170f8bf60705d560a2d05d931608dd5e5f097ec750542254c7b7df8309ab17ed0ea008851a91 1 0 \\x000000010000000000800003cf6ae11da447fb2d3091b361065423824f57f95d6faab7ed8b37a38ffb77d713c6bc0711a7000e084542f7466d388bd51e61cf6a005a04cc9dda9a29cee172a6f897d1bec350e1e2205e9fa3be8f695770279f6130641fda5cddc904165698a31ea32cae78cee40184c2d5784cc805447d41fdacbe2d9299c38640b528ef4bdf010001 \\x04dc4bf9a9b276f106d58166ea92dd379d8c0d42f8aa3af5e2133fcd2f0b75ce2757df00f1966d4dbfe489faabf420383adb2d7f7aa4286a498e86c11c1c2d09 1686647989000000 1687252789000000 1750324789000000 1844932789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-162 \\x9a8d54ed9c3ab691a37c9a7f07cd6024566e203cab2a07abc579d53137a53e9f177c63d1fd3952f73d9a5b81cf5816755aac5c15c0690e9149fb02e1c8f4788a 1 0 \\x00000001000000000080000399e594c63dcf0d14f6184e5c50ecf3c64d0e9abebf582fd316e61bf7b48e4a9a17d8db55bff0751a0afd9d72c782ea92a8bce33eabf09a7fc100e8aa62e14b99726b60d8c2e2a5d251ca9498d7cc825964e3073ca103eefe2b0a8034587662cdddf2eb29c89c675b1bab3ee54864a553e407c730b2a0233b9754ed5eaa213b6f010001 \\x3eb7ad81fe5c3d8ca4784ffbea963e06115ba377c0f767d731887e42efff9b02fe09d6623286be9f79055b99299c2ffaf3c199c056daae29bbe0b390cc2e200d 1663676989000000 1664281789000000 1727353789000000 1821961789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-163 \\x9ad55057fec085cc8878ddbbecfff09046c434b509200dc2ba74f93eaf19cd0cfab6bfb9a2fec6d7a1abe1be3a129f998f010cfe7644b6a4ea2aa94aa326354c 1 0 \\x000000010000000000800003ac264f591aa837820c52c5e71818ca8755e0249c2d807182497ae12abeaedb67ce360cfb0bd92cc7170bc37e02dfd90824276e1620d56f093715d294cc756bc6b7becee061f6d2b441cd95a05ad91de70f4d0e758a0735238d396a579f3f1123212e57f6518b056fb42621e169d57d5c9962e38efa9f33432d50f553d4fea371010001 \\xfab1ef4d3bfb6b3f3d38aeba464388c3ed1f32034bb50f87f4b6e1da8943d4aec7f0c195fc0e272b2318a3017d461d45e7767d7cb411c4413ce53b01d0b77505 1677580489000000 1678185289000000 1741257289000000 1835865289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-164 \\x9aa171ca35648e9a80fa73c1c8f2d0304ad9a9c4f8b81af95a9a7149e7fc9d9597a7b7caf102ad69689e598754349b6bc13dca114151278c8a3dbd741a42082b 1 0 \\x000000010000000000800003cc2f145a2721cdef29ca707381e7fa0dc617c55812403497f5b574f2d761e21b7d4dd02e4cd61b6594223845bc968b0b938f74e682302fb71c72d63578ca227a89e8127f6728dc3d6356ef5810b42a937dcf71d060b3989c5685a90e0905931cab4e21fce4567f3098943beba1d056374a2feea455334254c5ac205a7d92af51010001 \\xa3c7207d2baf59606867ab77eefadfc2a98b9ba03aefdc8cf6f4c050cec6365d8d74d7bac76b95cf7ebfbd1fba00556ae3fcac613bcff67399e1fa46d011a20a 1676371489000000 1676976289000000 1740048289000000 1834656289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-165 \\x9bb1ebd7c85c1a9f792b26ed20c4a9ddf73802d0756d6128c56491ebc5c50517fa1f34ebd99ba75c7f05657a1fcf948f52d55e9b2aa5f39359d1f9a94b162c8a 1 0 \\x000000010000000000800003aea6d3584d56a908b16d48675d3a9a08ab65fc42b9019cdf921096fd701cc7002b63526370a51a3e6c9c4fdabd196133369a6dd0b97c066f5434f5015193012d6b9679956cd39354b08c4b79e87a3d222e5977defddfb65913fe9dc65defe5e5720e732ea73606e1d984863bbce0e07b8f81b4a72239a9aa3d4b5fdd29f8fd95010001 \\x265f58f034339918b1cfdc388498a076657dfa35274e19a9f891a70997b2b25973a3d34b10c5ac9129e2f02229cfe4f3598ef5bb25e8d03d148d986d57395c0a 1670326489000000 1670931289000000 1734003289000000 1828611289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-166 \\x9b2d3bbbdae726a65b84d1290398a9c5c75cf837a7885741d0bb0226e10a83cec5a1f7bb119dec93d466195464cda309c8feca4d51d684f7e2f180423cfc8714 1 0 \\x000000010000000000800003dff996c8302d63802ba4a337c750e1536f9b7090988f7d1b85ebd5c52816c186d6742b7d0fe3b9e999d34868701eb0b4b76a8f8738345f7f2320675e3efb515c80c3fd2f8359834c3094abcf6f581f3fa622151ee3ec004554b3f18d29a9f971c04fe336ca3f87ee2edb7443b1a5d9ee769fa3882dface4abdef49b61b0353eb010001 \\x106643f3b7500018eb3c314755c3a570cc9d00f13e3904888a8ce5ecebd271f4f4c7128deb286a31e2120f0c66fe2862fb9460b28c3d0681b4ce1edb37059400 1684229989000000 1684834789000000 1747906789000000 1842514789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-167 \\x9d2d829c9f764decc00274ec48b298c938ce834bc5560b85eb3fceac4b6fd21554b7ed1397ad2e324ead34a7d6d0d1aa460196a2d2ac15bbc4e1e8a49a99ba24 1 0 \\x000000010000000000800003adf5ef28280bd7314ab7d73e443088d9e98c38716540fbc15a520dc09eca228ec6e95d8e7dd51f7ff3352a3e93e3a34b0deb2b6133d990f9d0229309652c0138de47675a2d7da24a2b1e2fbb26b25acf545cdd5f3f75c3be49ac30f5a73a9eaf367010b427e91e32a99a57391500bdfaccb3b8bb939915675fc7c9546c25aadd010001 \\x04aa8da8aec86f681945ae4396185ee0c8af47450dcce27a52368f5a79bef0dfad86e49176fe01d0fba58553d60b16ecdb09a25d0b7224a31c7f87fa07dda60e 1663072489000000 1663677289000000 1726749289000000 1821357289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-168 \\xa239cc0217143cc2271873f2b6083af91518f0975e565d44e0327f8a6dab6bf3b274e2e40837350f042b099a98b6dc198a8f72fa00c4dfb9af876d87c226f6b0 1 0 \\x000000010000000000800003d58e4c07955c76ba2cf6736fdc890a40f38b6532c2ab57306a64dd541fbf5a5409d3b0ae385e019bf5ab232a6d953482c1f538985e84ba3842ddffc6e5419674f2e12d0cab792a251eb717b570d1a1d4f005167e76a5bac0eb5be2521f6c38be8b4c519dac65590c7fabd418013add35d1c1a71a55c12e8d70a87ee75f762439010001 \\xb273c3a6be91db60c0d82eb96188c2aaccf1888e97c56ff1b861ffcae4a204a4f93ecb9249dab2c2c761646a3fc59d26a809d5b65803e436ce2b9056b653490a 1687856989000000 1688461789000000 1751533789000000 1846141789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-169 \\xa609fab5ce330fbb6c45ea07cbdbd59636fd132e36e3c9c3fba69147c3eadb84a0099353207595d9d3c5764826c1c7dfce5c516c1142d7b50a5a5f59ccd53516 1 0 \\x000000010000000000800003ea8e520f9724623c2c1bac9945f658cbae7d1b27d37cd001f0515d4c1a453041a7437e9dcb09472bff16b024fdbc5ee45c8e43321f4ba8062b990735a945bd4418c1bb88a05aeea02cda3baedfdafa99086cf8122bbb677f7e5f09ee3d2c3f19e7b3717658c4902355bab1e61ff670147e6582997bbe95805c895c8552ffc045010001 \\xc2680abd2a609d4cf90b2ae4a5c45b60d34bbf163c30a80d5b604502109c1b01795776aff4742125bcbfa38aa993ae33e761810563d50de4921505c07eb3960e 1673348989000000 1673953789000000 1737025789000000 1831633789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-170 \\xac519ba75e79539f02e53d1b184e25079293d42dbce7d3f7fdc9d9134a6b0ba242ae683772935c3db00e9f53b9d56c9c67fecfecc8a967aed09e47760d0b9365 1 0 \\x000000010000000000800003dd258e3b971a6e9368b7637325822f87afad42131f25ffd6c53b722a2b7c9fcb0aae403b97c477e5e409c37e70130fda857aff6ba9874e20b80894906fd701f235e9dd8e2e2dfe0d47612805e97feafc85b909f220d686369b9c87348c3d0f8dfee41b9edee7093008fe014847c80858cf71043ad9f6ddbf9053b5b722edda45010001 \\x97bd6bb21a9a86cdd287777b5b8be19085632118e666a7eb9acf8927ad626a5e19016f29a765a6f20dd26ff86e467d3efbab61ca618661cc43caaeec5175cb05 1678184989000000 1678789789000000 1741861789000000 1836469789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-171 \\xad312886b765c052252989535b4d2a07af7fca4bf046ba7b20349298670a029b951b3be7f84afc55f0978e2f3766f12b43d0558562090cdd939ca3a6a921094d 1 0 \\x000000010000000000800003eb9fad14d1322c60c10f24414ba686984d99406e704804ec7d1061eed8ff1b7419b1dd14e7f24aa9328d72a2a2a6e1cbea9d4b6efd54005fb5b932e10b35329d0e5607b8686a9e34f68a25dbe4dc95d6f89796bda8027670178016f50cc7c367ac8f39864cbf5725ae11809d0872650c815d009ab57d88b3fed6ba4a10b36369010001 \\x211e8758d7dce9ecc86ef4108e966c4c7d084afc23d3579c06475f6545686aca17ebe7ce7984f8149dc93dbd3aaaff44e63a6db155f52214299071a90fe6250a 1664885989000000 1665490789000000 1728562789000000 1823170789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-172 \\xb015fb1629ba5def49659ba101ef92498f3e7c33c6a052a3c0c28292d2671cc23f1a62be71be9e45eca842553ceaa270c1a080883fe3458e852b58374127a291 1 0 \\x000000010000000000800003d764d4683901a5f9cb9389d80ff06c791c3745b0d806accd4ecc84c28f1a8ed7335ff91921c820c7ffdbf843550c69bb9e31d6be24422872e8b65824be1e8f554f0cb8cf954dc068f77e3181727285aea6e2be32babc32dfff83dba7def4d55134e643d63e88c2919c578bfec41484f75835d2c7812c0b5e4580f4c6235fe2a7010001 \\x0dcb921741b62636bac6f1f1bc7a2c165aff01be9ff7213e741d4017bf86fbb4e6d8beca21d64242ae4f90328b88444a0b693b5a89d1192d90c34f9e8d576a06 1672744489000000 1673349289000000 1736421289000000 1831029289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-173 \\xb13d2764ddc4cfb4c76d443a693c338b153acfa391443e0587bdd6b4c2743618867074ec5245933d94f99e9d3efb0ebc39da8e4c0b425816617d49c0dfac0929 1 0 \\x0000000100000000008000039f2db593eccd2c676310f65a6c90d15644753df975f7b3936d239b3989acfe35dc2c52695ad0e5786a7fdfded8fb6c384bf9801a11dae5dc7f74d626b62449577dda0754ecbd7788219f035bd67ffc91d58fb134780e8480629aa4cb79bebb20a97ddfe7318e295907cd00dace28eb1950072e4de1e4aab9509f28f5700dbacb010001 \\xb3e6376f38e23ab93f3ba53a5e9ceb07d193afcbf1feb4ea9b1b7c02bf88fa91f8fb49c8fc51ee912047c9cefd21f183b5f62b4cf2d1287c2b28077bc317b701 1670930989000000 1671535789000000 1734607789000000 1829215789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-174 \\xb5f17758ee6cbb01fc7f9a532ac03600772d2d00d7df51844f9cbb72755e24414da1e16be61cff746dbaba66d9d70635428a467d39a496f3519f450e4fcb4f39 1 0 \\x000000010000000000800003bb876d0f851a44cfdcc284350a233e885c41fd458be025a0caa35ef9afd7a4794973eac0fd9ec34228716ac1fb302743004a578b54a5f61158641ad7ef598d2dbc95f4bf90359051ae692ae3ef4539b24df34af20b8a3ddf1d8417361b291d64a79adc499d518a9deea77ea865aea1ba52c5fe578b45f61d3dcf9b2116764d33010001 \\x53e33702b59720bd5236c3b6bd485f792a1b21bd5953e370a3d3f60dc0a443aa93e1365a7d824d17ea61bc4b74587fe3cc7f1243e9a216217d2bbd3c3fdae200 1664885989000000 1665490789000000 1728562789000000 1823170789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-175 \\xb6b99c56704769dee85b7bccdfd4ce3b7a45ffc9ae5596b046fb3fe756902ef986cb72c933e9b8e35c3dfed5d2a6cca445be609c3d2ea014c5898b68fbbb0f60 1 0 \\x000000010000000000800003d3df73b6283b2dec918312394ff538741a4ce98aae77bfe90a5da027c4e1446eb0b7c4c4d94eaedae9de9f137d19fa5bce0db65604d3ef0b141c24cd097a6a71d7e01b98612022ff070dec44fefb8d19ddef7ab4bf7d491e7f1e945cc30f2cc04372b91d70abcf47b5478e9a87aeee48755e718418bc445ff917e4914dab504b010001 \\x712261fbc0610a19c73860036b3f5a40b47d824a23464d93577c0fc2f752a06dc513bda276a6fcb10854b8e1b21484730e0037d9c0ab2fc167d58d692ff6870f 1667303989000000 1667908789000000 1730980789000000 1825588789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-176 \\xb6b1939314cabdab75df8fe22a1f358e49acb24709b6a21f72c5dec2e6c405f9ec82a4b91a659b1815615ecc4469bf7ec73ef8af60a955ffd687d028d51a9da6 1 0 \\x000000010000000000800003d7427aa3689eddba1ac67c7e7c6b6c730750dc46c8f4c6989808307801eee26133ba59f5e0f63662ea4263670948a2854df4e1c52358f7cd314d75eca63d6e1cbbe067fec044638d879dddb6b7e43b18360d3cf02455baeca1e0f610a0c51bc130038f845f02f2376ebf6ac7d3903e5052df00a8c3968d1b610963d546c865f5010001 \\x096b43cbbf98836b3fed7c283a0411270fdeef4ee9bc21be643dcd3c11f9789f95eabf7be7238a3768000f4706f050f387a83a96c59739b9bcc835216e80ee02 1681811989000000 1682416789000000 1745488789000000 1840096789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-177 \\xb775631417c3a07c8362f27ab64e364ef51cb79a4aa377d764370c3e8219a370118b519992a8c20cb53657be014d778e718e5e84995d6e1fac05827f7e49b391 1 0 \\x000000010000000000800003cbceee820542c1d88045c5846c54c6afc7532876ecc20661a0ee6da15b831cb535b0242300dec47d047d1d9dbcecd1b3dde5aa468e9fa12a6d7cbe9c0c6b1deaced6cd40406024586a8ccb8d77a68e935b334506a35ee2cbab964ae170bc8fa6fafd328b818994a81c51cfdd5746b3ff3908f159a4a0519455a13da9bcc83ba5010001 \\x141161ee3548675f021919a0ca1275fd53bfe1e47fa6c6f39cc9c18f9d8b65f226373453079fcbc5d42371e0380fc7dcd4e7287ec12d6b94343322df3091bc08 1690274989000000 1690879789000000 1753951789000000 1848559789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-178 \\xba99f20d38ed794f41615ab4c04478bc375cebb53d67a19b06d461e4f007b5d67768577a94864061f4952bd1a903abf4d1ff55604d22e7e7bce44ff494fabfef 1 0 \\x000000010000000000800003e1640d3ac9302591b485f3d6d2713a98923a9f32aad81e78a5486edc251b5e895b3d2f08e67f8fd04bb88819d2770e69ad487a4e3a8e6ad1998b39f8ab3cc9950323e736dd50300cc32a8d176d68d0baecdb1a84ae2cbd0df37e027af3271756332e3b3f1f028084b2f6798ec3e786d21f5b7606d0930181d4f1d97eacd47603010001 \\x8b7e8282e83063a00d0650e26be1b5384ac219b7e44d0cd4f187027ab1ab2c139868d44e673a639eba1e7192d7c90fbcef450020ecbc66f970e3b946b808dd0f 1661863489000000 1662468289000000 1725540289000000 1820148289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-179 \\xbcc9902dd74180f288254ea639b3c3186485a1fed2816a83c4e2e6b9ecc503d56c5a1c52d959d66944e527a5ec9f877aa0c7b407c4d0162f9542d866a0767127 1 0 \\x000000010000000000800003ab5d19030160f87c95e2815985a29a8317cfdbc8d60400097e05fdeedac399e2a6cbf2272cb238a62a8d3b63ed974cb54e38560dece88e4b5cc149aa7af3d4eaa679fa5a0026e9a7e885702ded2b6c3468c83c01358af7463444b285cdf5d334ad3afcd8f734a591e0a6d0a2e26e9e8ff52d581fb6498bbd62891e683ba8ad07010001 \\x0d2b047d2dde9fa645974fdc83bdcf1ae3c565d0c2d3a21858bbf629a75c77c97cdfee96c3627ed1335bcaff9c84bacaff90687c053af5f7811648b344a7b10c 1676371489000000 1676976289000000 1740048289000000 1834656289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-180 \\xc03de76ad5f3e95cfbb2214cca68ab113b5b68aa584453818da7d1659b79452810716130c29f2c06f2a06ed623bfa59c332fa37e858e866785b00d8aeeb03a96 1 0 \\x000000010000000000800003a763e885aab2a4cd91c42a5da6ea26b2adbca516e712b341d26852d3a9a66fbe431fe52371024b6b109bf75268bb120386f6ee9110cd41debe2c127cf90b9b1b0746cfc79ceb7ea00920fbc20e93c79a19684922b2fbf0cc34f4e0174cef148487e65e14f9ef704be61a68b059fef4779bcc66a62075b1bbf14d374b5ef40b67010001 \\x6c54aad5bbbbe147c6e723195338e799a0b94f169ad53efef27d1a2764b3ed407d06e054c60fecf2259f401eb21073573f65ad873064072df0c2919d9a50130d 1679393989000000 1679998789000000 1743070789000000 1837678789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-181 \\xc0c1ecd3077c9e8d970c22a4c433f03104ee5f5598cbe8ea070e57b5672a2e1be9a28b9b6b66aabfb14829f351c7a51ef31307243aaea2c8f28f9838ca084da9 1 0 \\x000000010000000000800003a9c407e91590a97a46b7e388603cc1856de913f1677cbd11ea4a4cdaf4240774ee03ac98df77bfd6e29255e8e242c8b8152fb5c22a9ed966f702be682de6762c203f1cca4e634dd0ea10542e36fb3985f87ffdcd48825dddf22dfa41f8d7f511d7d44db6eebaa6d50a5546b4d4356a8dbf3aa0831bdafb987aa694e5a9091b8b010001 \\x0b0a980496c56711b2a777f4d7443cd807101b71b831c16aa8712ada8c81acd98554b2bf5bc90c58dbe7f20b1ace292e2c3f4648ce3ef672be951e3cc4dc2101 1660654489000000 1661259289000000 1724331289000000 1818939289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-182 \\xc1e10b954410c5e1bc50168a5239d149e95522b0fd4785828bc7b9df36f70794343a476c7b58a5212c56bb6302d2966309263e6d152141e7964cfba28f9a511f 1 0 \\x000000010000000000800003cb053c909b2be20d2f7d593bb5a6e6044d8ab53d1821855a2ab7492e582a83448593cbc413bd8df58fc3cbfab7b240077780d75c5c9b3ae0e4666442b665ab9a980ce2273820125b55b179f9fd204e685cdc19b361ac7343c0f1c77fa024eace60f4cae44b64663099b6cc046000f6b21c8679016235b74d38ce1663a7248635010001 \\xbb3d2240d275cf8930b982097da751bfb30dac42033e3ab3dd060984a2129ae94dfc60bdd9fc73ab6f15c223eb0c82c8b204d5ed89efbfb8dc28f67abd6c3309 1668512989000000 1669117789000000 1732189789000000 1826797789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-183 \\xc219299a6e209d076131eaa5896b67edad3de4151d253bba75a4b479cb9f10ce3dda750001b232e3de7fba38fccd9d3521a7c4d0ef60804b9d02d54afa9d8572 1 0 \\x000000010000000000800003cc680300d677216381090f06b3d5b50f42cab019382da67856a1b86accb557f7df5878dbc218029f68295aee021afc917f043e79565c7160d35fe7cfb1ebfe4ed853c74e3786648cd332aae8bb13b9544a2dff45605fac7ab3e9d8b87ef63b2082a1758e1910fc555572a236d7d328a82c8af5e8637b68c6e339d25a9fa63c71010001 \\x990574cc27b3b5771d86e8a85e998a88ef5f070947869764e967253f0e4131fa58bf637c4225fd58e3f2f5a135604b11d2ee3ee6ac8059306d175e4d415e2e0c 1679393989000000 1679998789000000 1743070789000000 1837678789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-184 \\xcb753673280abef1d396179f15b9342cef4886391edb854699f3aaaae0edbb6cb71a394eace3fa750fe9f7628fe61ed6589ed0a06fa7b1bdffe7208f82f8f6e0 1 0 \\x0000000100000000008000039b151cfd886325bd191ba003a9bcec17d2226a885d92a3cb080604b54534da3a7416e526afe7d9f7105ee6e4c2b9983209d71ba791b9c3b3f8ba03f219dff93f7d5a6e8fcdf51494059ddde3d1913804d1f5303eb0659898aa8dd0dd22f5271bc0e924dd58155bc269efc55c7372ab16863bc940524f6bb207cc883b1eca1f27010001 \\x553ca0f634668bf8da2c50a16da71d27e9f9e2d4be5d0a4ffbb4972be1cb13895751755293faabce17787c6037797bf97e723740b71be31a7c97a1a300d24f00 1665490489000000 1666095289000000 1729167289000000 1823775289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-185 \\xd5f91223b6f18fcadfc3ede031ae46706ac947212264300bafb5ae1417a6f738606bb3c415c57012ab24ee2933abb68bcc5bbe2c5dc426e7f2ba33fd34bc0706 1 0 \\x000000010000000000800003d1092f783a3cf31a4d7e15bdd392c999da88936bc0f52c76f05c1eb2b0caa11ce80a9b18751a744feb85867fdd0cb634876eb17116e0815dc48d957ab320164dadede5fcb1dbd8d5ac0ead02704865a0b83e59528a66ea9d9657995261ad99cbc3309aabd322e2cb116266558dd208ea3ddfe169e6e144632db733c0bd891165010001 \\x36bdf33e9ecd3caf3484d32368aa797256def5541ff2d25cc0274f1d0f435629507497401a60d27f15b86f25eeb91a5c17a4f69254d5961a6c775d101c3fe409 1671535489000000 1672140289000000 1735212289000000 1829820289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-186 \\xdd259de9c096333ec1d92e5c539ebd700885949e9c7f06d50739a9a9a989eea4761b65dfa110ad33f33db41da0964a04b522c00eb9e85f2b23b97e1617d1b233 1 0 \\x000000010000000000800003be28254f5ee473ea66670ef1038c7cb85a6c295fc1cd47f44f8999d77f5166733704bdf5255c3f4af80d18e337fa8ff9602b3a60e7e859362c2e567286349b29a96f7161f901d7e48312638f728f00f10e7e6f8b4f0d2ca5749a1945b3986a384e8fe244a3d8682943cb63150fc0679e74055049eae2e3f1d6b53a00b9079fc9010001 \\xf9ac76db10fcbc5be5819a1b4b1e6d326d32b02cbd7d6b6b1f3ee2132a234322fce8e4a4137e2572eb99c439ef0958e9cecd7964b578ea5e70368acdd563da06 1670930989000000 1671535789000000 1734607789000000 1829215789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-187 \\xdef1ae8e0cc832d9cb08e3d578bc0ce77eef297b92d367dfad7df7629d37d68bb762bce44cee8f81af544fc6ff27f1ea4eaeae2c2ff44ecae37ab50d5e08dcf7 1 0 \\x000000010000000000800003b15c9b1504220b780da3980748fdeca8c0e1b64f2ccc6a066bf352c9d30c1c21c23eecec91e5784f73b11892c70f88a56d8c32bae90a3c7faff6efbe598067ffcb562022000078b5fcec971f065087a7b7f6db47bb8531fffa60923c5c02a88bfb7188511eedaef7c59490095cb2858dd7bcb1a420fd9a9aeb7699b70987d167010001 \\xf748ee3c40bdaf51c836db4b3235a707e64402db5af3d05ef6b948f5945f4407d6b7d65e4c60387387f78bdd55b1ff9d5852833309232c49a4298f49e277a804 1663072489000000 1663677289000000 1726749289000000 1821357289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-188 \\xde318f0b7743b3f794e89bc71ea71b96afb48e60c1b7c03d9cb862ec28eee8bc570289fa8c89018e10a1d62bb4d137be73e13ba0cb979bda77b918071e7c10c2 1 0 \\x000000010000000000800003ada44035f5091e39ed034042340804cf4535fdeca638748d3b17e20fcb9e5d632985d6189feb0dcdb7dbcb64c6dd9596adb6e91629a0856125ed436bc8126c83da02f712d9f4eb951603ccfb9e7e934e8d2a91872e8d6bda3ff6e35871bc1f7c615ca2ddd323f25824523e6cedf99acad9d9e22df88e9e17b7d4a0539b9bfd73010001 \\xec29ca8d0fc2336f2b5b8b92074b8941fa0a0f2e3a795ae23d72f8fe180ce588c020d41f92df51c4ab285e308b26a16d858102fa6b25acec223d4519be87bf00 1692088489000000 1692693289000000 1755765289000000 1850373289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-189 \\xe04dd2ab9d786897af835b48a3e61582e24b79bf4f8128f69f171f999ddfb060066549e62e8ea7a8e4dc9f193050d2649f06f82a8d0d823c498639cdaf7f6df3 1 0 \\x000000010000000000800003c49ac1af8b86f5b69408f52702e2bd86a5f3c36f786e45b97ecf71e35f4d8542e5ab42f8188745b30fb0adcd0dd13a5352efeb9db5c81bf2ff042f0137330fbee7f56839a3d316bd2656a0af2211984e6b1186f6ba003245b672d12c1de5d67c65f5e0d5d8a1d519673fbeb599aee37c424814be6de9e430c700f1626c04070f010001 \\x21993f4af31849cb1320762192d01b34f2945d3e2ae44ed4cc25cbb7c0feb38336536cfe8cf34be2a6de5568d875404de0427552a20eb0c33d1b5033bcb15900 1669721989000000 1670326789000000 1733398789000000 1828006789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-190 \\xe2297a3399b84ee0eff9082e3e234795246c7e51ac2452484deaa204cb5d81cc7c1a59c08d778e36f235dae334e58e4876e141fe8fa78aae0612fef5232f2434 1 0 \\x000000010000000000800003d0f72ce3ede2b5975febd094491a10d5117f0eb92b5045430ba45f87527bcebbe349662d2e7de8e3ee739f9d70c65cadaef73e5a95ff24df56b810e92e2978540c1f905001d88d9567b0f73e0e8607b6d1b8eb15c2d28fa0906c17ee22e96bf59dbce7802ee828cc5568dd6d006d7f1189beacfe0c9845d86d2115e5108cc7d7010001 \\x5775c62eac2baa12d68509ba409a3e75f529601ce9e8025a05ae2d163125de7057eeeccb07befbb20fa263e1155c56d9df6b609b10ba51fd584c0dc45a703805 1689670489000000 1690275289000000 1753347289000000 1847955289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-191 \\xe49953152d7d344f7ca812745b329ead89f563be640e8664d7a3ceb13b5773dae4149bae3836f8778b461593ca0fb7d73de34db117df72b31f052348b08d6759 1 0 \\x000000010000000000800003a427a5fdab8c25a31ed1ec5c0592da2bfe4b27489856311904d7057cfc1db9b635e03fdbeedf3fd8083b9426331c4191ef1570f9e7bfdc9c2b41c7ae86fba582957b293e93df247ee2561f3d40a5d7071e1e73e3fba9f50ce7fb6e7817ffe8bc9703754ba6500121d1218233c0400cfbb5e6840771680fff27e655bdfc888f63010001 \\xc7e6eeacfbcfb49e2d409d4fecb52bdb45f235bceff6924718fe032aca45b64cfaffe6a5d3a1dc47a9244bc2ed4252af4abb6cc1067243e03f2d3bdcf9406d0a 1670326489000000 1670931289000000 1734003289000000 1828611289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-192 \\xe4d9d21e9b07ffea6adcd99994926285f143f798726b48281bf7a5226442fda18a5c88b583e6aa78f332ea14aa8dcf3b19627f9bf40a32de7c8d46c5bd57e5a5 1 0 \\x000000010000000000800003d3f613680322c778ca4fc132e548c7ed21419b52ed605c323b8a1d1ee94e54de2c4aef8705c5728bdd2270fd6801f92fbd62d52c04180c0d473eb8b0b90ba0615f6dc4c5b21679768e381598b929e34328bccf1b2ab9a27e97c1ff72d177dbe8a617bb71c1a7b9c3ddce2527ed505f1a1d10c638f4fb8c1b93b3751c9d80739b010001 \\xb8db2f979f3affc7733afe743fe924277fec9dd1ad9e372c6ae96d82807abfc93ad9492fdbd2a6e50c147c883fc3a52af58c99169489f8d722ba425cb377a10b 1683020989000000 1683625789000000 1746697789000000 1841305789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-193 \\xe84d4af5520a55bff91584475f8e11bfaec0597f8e2e4d429498d97e57ef849a83e1a21cfd651a4bf280a0cbdfeea39416f5f964d1921dfdc32cba458e697bcd 1 0 \\x000000010000000000800003964b289a0c51f9c57afdc30adfb068b4cd0147bff8b55da5af66d91e5b4650a6e0b6d8f358f04f5f27722cb78d97d9c95edc41cb16fc51438c1af3d6138483b0c79e225991014d19c7803d7677e61458d3c5a3b158b83cf40138b3f690299970736c895ecddfea82e8ca104ab1101135cd6e0a4ece6cfc55b190b96e0bb5a4b7010001 \\x84dcf88385a789aa1876c982b323a4ee0ee6f69b9313c86de9bf5ade400ea9ccf5b349fc1ec585d087f525c78a6bac561dc1f8aeb1f60794177f2048ef3a7508 1661258989000000 1661863789000000 1724935789000000 1819543789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-194 \\xf259555f961283ff5fdb6c1d1703877b7b6dfa30ed639f8744e62b3893209c34d6253969a34ea1c53668b413a1922b1fe43157ca2d2669652850d7751a8afab1 1 0 \\x000000010000000000800003a7827723b9cb91a1a1f8cb31a75ec1869bcbc96ba3bd0d368b5b9de8be45138c160a2106329fd9a00ebd285af9469041603cbd8134fb0010bc40d7b4f430f882965e073d95521464085fea649f67e5b258496d805c6bbd9c357be6059e678e5b4460bef62bb7407d4b8f8c5b6cacfeb51ff5693cf8475d0a46e46b63c4d17ac9010001 \\x7ce3308eba9f8f74428b46ccb485eb3d269e1daaea1984300a698fb28707bf08a1c66e7779916b9be5bea95c14e63fa579a72db848f799026bb9419e1d73b60e 1667303989000000 1667908789000000 1730980789000000 1825588789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-195 \\xf81140623179e31c5f82ffe933a9181e3f9b06101601635c9da1978dcaf432021da4d9b53c9f2f79ea723a5fc849ef3db327c433f014a35f18da00ff8bf169c0 1 0 \\x000000010000000000800003ac9b8f7c5f31f8eac59b59076d271f68baa548fcbecf070607ca230ed0481130db3ea7e1e6b124bbe4746c954074eb600a611b0e6dc3fc193a1a9444396403d6755abfe0fe9fcbbf5ef039ef6063f3f7e9c09ec92c72fb8e39f1de469cd696984f2bafce0a532025b1405cfddbbc8ff56ea93148ae35fd5aed9e7fcb129ff7f9010001 \\x7b67c42cb5370ff21981a68242d09f20ab880a0bdaf16b1b808015960d5d2eb57946659e6d86a43a9bf8e34c3e1c29775039d3d5eb8c18bc7b2e4ca58eddcc02 1683020989000000 1683625789000000 1746697789000000 1841305789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-196 \\xfd7dfadab608b8b77e263a0590158bf9c6ff4f1cb67c46db36c41fa2d7171fe519a2eca247763c237e0364a5e33eeddc021562988895143423681b2bc2410a6f 1 0 \\x000000010000000000800003be31ac268af79bd15329334364f402b5dfcdb36106ffd5ef438384fa0ffd28d527e1fcf94179517641fd95a6acd08b0e7cf5e49838e298001dd772687ff8b587e943a52f55a9a95dfa1f3c9fa54a398f8268a8877b2ddd09232455c980330814fcf9f52dc3201d35be48f26b86d59d2f7beccc2cfdf28c7ee09a4bfe66cbf439010001 \\xda16e388506824a3f2def772b96d8804a8dbf7a992e64ef0149a457bcfdc1549574f3a62c3f93328b236a39ad4189dba043f84e987f671fe656b1d907c039a00 1673348989000000 1673953789000000 1737025789000000 1831633789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-197 \\xff61d4675fc4c46330cb1ff06fbbe9915826a86c06ccd7b9d83f8e29cc298c4469d9f043159a728c8309d2571e070808db82789d8c8e1bf61868807abef318c8 1 0 \\x000000010000000000800003e0eba8f3c9f082de42890de74fe4491d3cb5ef35198d8dcdd893957db62bd770c4629551f6ba7644e544ffe70f05ee284f0c9ab228d448f61a43d2a8f3ec6d790744143bf3d61b2f8f0559a1bcbd34d197d56ec97979514ab46c68268a2d51a1d5d0152458c5dddd043fbe47b8c5b56808ccff6c389a048dfe51303c9c175317010001 \\x7e3bc54bdca8eaa9f0a766d2d3a09ec611b77d69293b263a4827c838a9c9f2eb3467fb6d9dd3171a5131f94d67194d65c1609a58ce9f827ac8e6cd43cc8f0804 1669117489000000 1669722289000000 1732794289000000 1827402289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-198 \\x01ae0c39e4cb844d93f9be06c2fbc1cee79e24927a7e6d8de288018c2544ae51d0d572d8229bf78ffdbdd8cd1176df49607981c464672f255cc68db7b4a9f18a 1 0 \\x000000010000000000800003e95b3ec896fb91dbd38c9ad3cd6a6b8e12c3c472ee8ca5676ae206aa7cab36a286ff9cb11bfc72564f634f3da9274988d403f6651da79660f4525a125686cb09b79cdf197cb0914725654e8c58cb7e2495655e6033e70c7bcb356dbfe0a76975175a946c90a7936c416fadbd5314792c1375e9ad90f3544bff98c1624843de01010001 \\x50f4f7c0415af0361a00319d60fb77d0735814cc397d54303b448f6d28aa66d85078054a8256005e0c6a187e4f31fa1b9633c06d3378ca9ec9bc02977908ed0b 1677580489000000 1678185289000000 1741257289000000 1835865289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-199 \\x0682bc6bbdb9b65961e24a76d8daf9701c3d37e3d14d365c669621edc15bc2e5140364520a0c5237e3dabf2199632f793ddf829973aa3fcdba0460b852efe92a 1 0 \\x000000010000000000800003d529e58ecb8a4f069ce2fa2c38a07440f10b75a93154d1040be92f42599698a70e2167ee05d09b833884cac94e838dd884384e8ba733b371746eb679f6941fe43f6712d8b2b106ffc4b2b346507b96ff3d761ca016494c36f814d9662b508301dd5e468cdd12d3c2cbe0f06d223b92bde872dd15c7eef76309844e4f151e51c1010001 \\x9b332bf204bd465f6847677756d099e3a4a4de89d2c7f9237d0e193e61f472aa0526beea09b9b10f903aff7526938da262f4e68fc07e382ef76f3d1b081fe408 1687252489000000 1687857289000000 1750929289000000 1845537289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-200 \\x062ab33e15d7defe85e7ead97b72cf47f1bc74ae11beca4a5de4ea1db47022d9ff29285881a14efd94d2851fcc362c90d9f0ef2c4faa14954437f1b7fc8839a1 1 0 \\x000000010000000000800003e883793808c36af821a6213ca47c615752b3cc7348ea5cde821346455f428af24e5f170d59d9eb932e0aa55089136c567c8a14ea6d2aff99456e4f518832b0a3a602d6e6b72bb0a8f74c48468a22b43f547ecb8b0e56a24b1ff7060d92e2e13f8dcb772bcedfbb1a32de7af00b1818a83569d553344678832e93c465b05cecc9010001 \\x00ff59f926252af2511240e404ae8f38b24ea7be830797dea1a9e50f5268f3b89798d6d5e9e25918e1d493d1d4754d034da2bb1e7afa8a73b7378f1780f4e004 1680602989000000 1681207789000000 1744279789000000 1838887789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-201 \\x067a54a58b000f713764db57909f7d34aa3a98aca22754570b687a0b62ef1d13d31f34428fb2a63586eb6f7863a6f0345b302b2d39d28c2553a8b2392a0c9c22 1 0 \\x000000010000000000800003a8f0b277a34df5dc17ec0d7da38841acf8ba61ea9a16dc2b66c616682becdb6a696ae9e3a310269109818fdc62e4ac23d26f4b458e57e883c2d1fcd8567cd4196fccbad2340a1165d631d0f44ab23aa46f6a7f447558ea6f94b204f064a480a24a229ddb799c1bea7b153db473ffc5d228f62db4f2cf709df828186f22cb9767010001 \\x7dd4e0f3f5a8e6620e27cd9206376acfaa8a5456c0c9a98ccfe83d9d67c55824f94667d9d923bc5a111806246b1d09a24372832d378b022fdb6c0312a357340f 1669117489000000 1669722289000000 1732794289000000 1827402289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-202 \\x0a2eebd6d8f1fb2716cfe368297da97ce4fcdb381166bfc5999af98dfa005e9b6baaf6ac9171829188b4e556a224e40a95827a0bbf1e856bdea1b0986b546e06 1 0 \\x000000010000000000800003980f100fec9d95a9ce315f0d4a16f8a8074c66bbfdb16e6b31820fcb6f74465051839679bb40623d8cd0d4fe29f02fef0d74bbd05a9d97c89ac6af06cf085857499b9691604bae84f1149b4be6454129d894b2afacf73c4b5f3e8ea728ab1fa0c7c24c57446944cbaf189f4c54d5a10f5925042790b2182776fa246b4b091523010001 \\xfc28d84d004c296ed51d99f6394b7dba0c8823a60dc54d100f9c1b7721e21f12c0f71a1abc11b3340f6ee9e4f637cb046e16627fc0f2609d74034c2365daef0e 1690879489000000 1691484289000000 1754556289000000 1849164289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-203 \\x0fd63fbd7179598122e8ca4452961807e82c5a682b02a191c6600837061650a73c492dbd220d5879e8e2c90ae3be564471c2fb6cee11dff30f8e903a530a84ab 1 0 \\x000000010000000000800003bd08dc96c54fe7f7a43a3b6ac79c113e4f9d0b2d0da808535e0b625b0bfe48ecf498fdf683321356575602f83c2c32630ae065fe87eee73231f3f672a1c6f91e839e371e36daef752a5c3c1b5ca54432260734d784f1938bce337b8990a7f21a1ad675308da16ded4080c5d27b1827aadaeb92ca787084e88043e318b7fd2af1010001 \\x1cd17d686758fbf45bbb5d3d6e7d9aa32acfb0b9e314df63f74e9a532b72636ac0b49ca74dfe36938e162ecca11e076147b5d759823ac42512ccba5705396207 1668512989000000 1669117789000000 1732189789000000 1826797789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-204 \\x10fe56a70e4ad1d1f0ed2c1af39efaa283b6827be812daed94806ce0112e5273ca2d8170df975330be2c0ed0f754df0187999cf6f79d9079b4a23a0baa2ed8eb 1 0 \\x000000010000000000800003a4a3da544df487b8561224da248f0222eb8721659bdda2521fb8649d5695e0a2ea32c2870358e35b274ec1ae7868670b2993d0a73880acf399429bca29a48f7cb043a4ff787ea27266a304146854e39322587eb4f63313c38c9bbd7d5cec9a9135c64bcf2aab7f296affbdaf0c49301b0a90677f6e8ff17c217cc286fb08008d010001 \\xc100b843fd011bf2a3ec4d064e91aee9c9708206d2e495617995dedeeac59e57ffbdc088fb356162784b436b6d41365b247aa2315d950f0b6291440ea7ab5b0a 1669117489000000 1669722289000000 1732794289000000 1827402289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-205 \\x10fac7b8f69513632d5d28c5e3fc3b89aca5d50380aed07f97066d431a63164c7ab6e38dff6124a1a7f5e12ca27aeda56b5a2b4b70d2752774e72f3a7b506399 1 0 \\x00000001000000000080000397cc0dd71ec6a46a79e45d68bd59395ca935ef852b78107a6ca8539d3941248a3e4c7282c41425fa436e9439039656ddff755f95cdde901f2c629707b5f50c5d723a70a13b8b7f13c66089c137a3349c508a88caee70bc3f84856ad0503be2532f3d7b9bce0af47aa43c797a3d6ca421a0cd9486fcf166bba9b5984f59ccc345010001 \\xfd4eb553dd96bd7d71cd1ec5d57f38ae55f02e6ee1af87c1e70a717c52070607f8f4003254132b1f157e737c82d0d35c41eda7bbc6c00642a50983eb97f2f00b 1680602989000000 1681207789000000 1744279789000000 1838887789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-206 \\x1692ae0e79633dfc690282e0dd3427d70c34b2ca8001244c0b7b6b3367fd3450944221f3e78e3c5e46b2e8039f71ea827c9dcfd32541503a4a779173badb8716 1 0 \\x0000000100000000008000039bb8c3519da7175bd93f80f5cbf9f06adf83f9bd3483419360202fe61bfd01f698e080d8467a5f0857733197b97b9b728d99b2cf044034d0c1759c28b6a691f18693ca2c8ff1f0fe1fb6d3c037cdd73c478a7c7ac818e1003c31893ef70b5834b717cfb3af98d38021720a629402b2903036ce76899fdee8a90e6a9e976bbd31010001 \\x28eddc784db62461aaae68edc4edd4f78c8781f99cab136b10da0a19b4aaa65f8e2d0e7022816cbf3c8192d7ce2ef087e7895d96b32f3a804b189728a25a850d 1672744489000000 1673349289000000 1736421289000000 1831029289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-207 \\x1796fbd95c3d5d54b5da550f4fe38f53390d23f3aa27434a2252a14e769d30bbdafedad9ee6f6fd0e90ceed2b17a193322fc78b8763b962d386c157d31ef799d 1 0 \\x000000010000000000800003b9e23d765f410c155c3469f7f25cb2e7331593f1da914fdf6123f7cbc756097015483501a590ee923082ca13315125cd5281e815571bc545fa10581910a6397e92a1ec148ac078adec1592cb063d9e868aa9018f37e49a0fb39ee83ac9631b1d571946a12654eb0bc8f804a6710e6b00fd724f2e795e26bb0389c67fab6694b5010001 \\x3f6e075c1a5c88215f4726ea09d7b2d5df3a0348bc16e23755f1d4700fed3f9b8f118102837bee66f4b7e3cb6129e71198f17158c30626716513e6ea01887008 1677580489000000 1678185289000000 1741257289000000 1835865289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-208 \\x1b8e176694093b2464aed2fe42ac33728ed0a462a75b864939b1aba2cf3e97eebd5534e6b4eb3839a514c408025541f2b81abd5a33b3c09ecf3602cc8ff1efcc 1 0 \\x0000000100000000008000039b1fadf2204e30eaeaf66c3e0935d9d9b164682d680525cc995b21c7cfa1c1fe69a7b987066ae1d52f116e2d66445b4dd5bbfa14e987912f8ccfbf901e3011308b8e590d25cc03cd6564d21c9bf2673fd1c99a0b1bca59c369a29c4ff4d0e64a8410e684a7dd2beb36e1338fb6dafbae45777ab0298e74d0d114e9f1fff6e6f3010001 \\x212831c080a4e0e74512abd3134786b86e729d43e7bef0ea60dac45b1ed87e7e4565539773f7c03bf98129693ac209039021aaeff3258e87ae9ca9aff6d56303 1679998489000000 1680603289000000 1743675289000000 1838283289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-209 \\x1c96848f7366c993ccd281fe27a034978a14f6f6594530f807d713733a5dc23bd1bb73e82fcd88a69dc3fea7b11ff5cc9e57aa60b5b5fa5f84b9cb4719a3d31f 1 0 \\x000000010000000000800003ddae530282dad64bcf200b524200488aa99da049c75be1cbd4e1eefac5ef191307df810712d1f6a36318cc026a579a2f544d7b5a9aeb097aba5be636232768de401ce81680d2ecc5c30a4b685aa43f15994d395f75bade0c3a5c315b1b8a8f1c003330a240efbf9a441d2142dc8d3bfa9c821c4842e994016ea6d5796d775b21010001 \\x49e99686eb41de2954d3f14ae66fd0221c5bee6a485929511f11ef933ae2ffcfd5b8faa93ffe9e37b4e8fc0bd5c7956a001cc235b8637fd3422fb715b859b502 1687252489000000 1687857289000000 1750929289000000 1845537289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-210 \\x1e02ab7341ffa9cfd713124424c9cb56650437539f81b3412de50f7afbdc1d542d2314ac9fc6e0b7a8eeedce676879527669e2b9b04c1434a93cfdff1b00a2ce 1 0 \\x000000010000000000800003a99c2fce1a330c4180fc39bd8187538356d0169ae6af8e69e9c744eca08e2e8f7fa027212505a5e532ce99b7ced7684e5591344b69cbbcd1cbc0034ebc8bc0cfb8eb5c0bd3e35464056d7769fd1121e71cf1bca2bf0cedfeac79e3705e288742cc576bfc9ed1bc7eaeb0b0d3f11fca98b2eaaab47c7a95a7190a4a6b80df74bb010001 \\xfbf5da1ac559705e08f466aef845a103095c87e55cc4a91bc4587293cef5d9d11dc062c1f3d3e75aeef3436dc18de31f22b1008ae71057f2c55929bb10e6f702 1660654489000000 1661259289000000 1724331289000000 1818939289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-211 \\x1faad3bc6114840d17b358eacd07911e959fe34735f90197cd0113e247887ff614621ee6a93bc9cb4f74bf54418538bcd45b323766ce3ecaf8f029b8603a3ee2 1 0 \\x000000010000000000800003b7786da675b693d02abbb0c1a5c1cc91490ab51adc64ce295ba2c7e91f59c419c6eeeea9df67634a084c5d9ae23c29702a606e384e158c6d412a604de0504e9ad263b8bec148ddead2b7fbf05ac747d6892ea17840c80ca43f0c9fe91cb881d3200524ef6e0b5beccffe02f2ffbe50437152f2a6f4ddea122c6d5d8b2d301737010001 \\xd968a7cebc0c4e11f2c14ce91f0830086085252737cef9a3c163f6daf95bf6320e2aca8ac386fb6be95b6b2b094673b7fcce46bed95533d250a231f540eb7f0a 1685438989000000 1686043789000000 1749115789000000 1843723789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-212 \\x20ae619187bd6ebda5ce9f38a97d1e7a6ddec7bb4bfc0d72000333de4b7352a5b8c287c6ea3a00f3f5ae947fbaa56758409837ba31c9cefa865768acdb19e9c6 1 0 \\x000000010000000000800003a9a068635d3bae2641aded73b7b50182b7e9f7f2c4f8c49e7ff1aeed8c7b2f6b0e7f2df6415a440b65c82d3d3d3613673ea26e07126ff9923f142ca5442a3a3a86ec0c9d8efd18cc19e4ecb99c50acf97d997f69ada186e02f527649d77f213a8d288851de5b22c0ebf7880df751845419f22df85f5434b810482aa26da6b537010001 \\x0cb62ba966d5a5ac1db60097072db7a489a79183eedb772c0576df90b0d4aca36fcaba76e8803b5aaa489391d0a27c85fb97412550669d6cf509ad6737b22307 1678789489000000 1679394289000000 1742466289000000 1837074289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-213 \\x2136dc5224dc54e0ce5250ca8f2975dbc2773268464b83dabcde836c0e0de7ba01b74eed7ce63dda46b1ee614417719385e97cc9db638e826daa4337fb1eeb0c 1 0 \\x000000010000000000800003c65e3a28df2402750030cdd7662494202734574145fb503205a4813c083278d33e73337778ffa7fae03651e8a0aff129b9c2eb2af5fa41bc4cf3e45a078ea9939cef05de1258b7c685d89842cf54b6761270c0a177de279ce4fabf66d1014244b380939038df0b1e6a03be65a09136b43a29bc2a9cab74fb62812c4ba0c8e41d010001 \\x70ff25173e72414895bfbd41c8bde41ef288dd2e920722b65fe458502d5cc0508277db87a661f9e64c23394b1fcc1fc16d2e98072ebcf8180d30c391684d170f 1679998489000000 1680603289000000 1743675289000000 1838283289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-214 \\x2776f705fa0dd4c45c0b12d77148fb7fe4d281564b0b1230cdee7ed71c0d7ea48c7d5081c2c6dff9358fcc14d794af5f5d9e314691bd232d814fd38b6cbb0051 1 0 \\x000000010000000000800003b538d6417e2519c30c3428c13523d7b2c77fc123642d42c8f8e63ad240cde3ada8e55876cd21ed27d5d833fa2933f91a8354f05b54336c2dbf75d1f079927776b71a072909ec78ec9f81ba80329d6a5a7bce5d6dff4f5cf1d7c15961e889a1231462b85e07bb7000522ff6b798d8c9e9c87675349f51711822c6a6e9272dabdf010001 \\xce9a479f7120b656e4ef48b83eee7ca1a9f064d58fe979b1f36ad7d8db2e8998f1d8860ff22f2c4821ebe06c573d05e1f4f51c10d2bf5a429b37fe28ffddbf05 1679393989000000 1679998789000000 1743070789000000 1837678789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-215 \\x2a5e3b96ecf4ea210fedb38125cdda007bf157e9502ba410b34b3581adcca35b508e80639a26261d885b180b0a449aa8c57006047e6970e6e966a62d7bc566c3 1 0 \\x000000010000000000800003d618fe69b99d79b6ff41368ba935abaf2fe54795001249458a1745023be89040fa790bcbfa66517a005cdcf02f53d5f6e22a7d61862b6ea9afb87402c4c17631884f7bbadca7932b080a77913fc26e5756fe402ff335c4b42cc8d31d0ea48a48e74e811bce32dc77accf14bc03de17fbde16ab6db926f77a9132fe72a299545b010001 \\x45f2f7305dc17e5f887c2d7c0d87e4ef871f7e88457afc47e0637109c1cfe623881663d8baa09a7eebb33acb04c4eb9a6e1aec85bb12006b9f6b61822457890e 1675766989000000 1676371789000000 1739443789000000 1834051789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-216 \\x2b7e43958477c73efb3f03fd1b2c02305ea5d3eb6f261a76061cbd9a57ddd4a641045b36acd901c1eb64a9513af270e27b62ebe9f3ad7005d67c157d722e5264 1 0 \\x000000010000000000800003e6667c856c49cf8f27a4f32e806ed64793090204879fa2eb0bb6419e0e84af30d0d7838bc0f1d7073b6e8ad3a381d318428c0dc6c4a7e2c9103b90a4a37e599605db76fbfb9151df8d24e023ea919834fd19a5230e8139229fa6e2aaa2eb3bdf9041d3d1d40c00c63c3e06f5b79317ae60e61860a76b6a80f8f36ff4734e1fad010001 \\xd2ccafa6f772f4e9499aad5dc86c835bad859ba58f095836860f09736c440f1b2aed4d822aa2b363f68bda2985337245ffb5bf5e8ac250c1fefba101dfd56e0b 1689065989000000 1689670789000000 1752742789000000 1847350789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-217 \\x32060bce4abb1ad173e39f266e37e3667294c298a22cf039f78f94f508b41ce62a01a21a4ea6b9baa3485a0f2980743fcee100bb7e9fd9880e8ea20bd8d6882f 1 0 \\x000000010000000000800003cda08834f4f28f384ce25813f4a8d2c8f730ecb178d2bdef94d0f74685f3c51d4b0d8348a1eb6d905adc0045497e4dbbbe4d841c56b190264025b20f864b2c0e38c2c6cd0e9bf5ff1ca1bd49179ae02f2e50e33efb5adfa9c1e76fd890ed2c0a4bdc835147a8dc92b7453e38c2246e8a747cb069819e906e00f72ad6c21bee59010001 \\x375dc2508a1b6104471955c09d75ed91a947a9d2cd7af6fbf5189e4668c21895f4c6ba6a18df5c4ea474938fcd91595964bef74b5362319c5b8bd507e15d8a0c 1673348989000000 1673953789000000 1737025789000000 1831633789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-218 \\x343e23607bae5f9dfaeacd549ce67572ca97b707c7fca0eccdc637bdd620751ac6538deb508a5322b1917279d65b542cf7904afa3abbcfc33c745359ff610bce 1 0 \\x000000010000000000800003e99d208d92a370a6e068fce3ffb3509e3f02d56800083acf8430409bc8d19206ae44ff7aceadbf005b08f8930934e029f4e7a6a95f432361edaa9053bb3460c170063d2c95e602effc350ca0c28b890dc9d7f1cdb2af4464d2f45da4ee2f318e1e01f9dcf44ab171ebb4c8a75637c495799a17aadf5c1fe03ed647aac246dd49010001 \\x2ec2183f3c3f210becd80a321127fe08ef698dd4c0b4d6441c446f6e0534ef35a3970deca185cb06978fe33993da8da9cd4f3e7121cbf65a76032ed8ca54c006 1673953489000000 1674558289000000 1737630289000000 1832238289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-219 \\x3976ac50da84a983b388421f4cbc42596ad828163f025dc891815757e832acef1a8c69467625f93157a72f4ef7288de1610af21962d569d7293338ae6f3897f3 1 0 \\x000000010000000000800003e88346be9911c491375b8f3e7fded91c4df00227f9f910eaaee1c021f9292ecfc3e06236296b038a9cfa01bc625d84d251ce58d48c328caaaea9c62bdf9f0e81547c76c4184ea811580643028e05f3d2527b7afe9c49d9e622d272fbfb423803886467d45c3906a9a102ef3ea5e673bf093ddcd523c93c79405d6f6392e6519b010001 \\xee5c542b6548d3b90974396d5468e803317914af392c3d3df5daf95a3a103b73702a2d56cf5f1bc778cea3157e2d523f7ccbf629f2cf004f2306f1b8a52f4a09 1691483989000000 1692088789000000 1755160789000000 1849768789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-220 \\x3f52b9d3ce6c749b45b1187fac25165a757b68c619358c510bf4546496def0840b483e9a94ac8dac86e4f36ab12d1ddfe8f7cae1c091b7f5fa427850c0a445cf 1 0 \\x000000010000000000800003d81ee71679488d82135f236ec7fa06ea8fc8abee2d84b9d81c6fe482c49af08e3421d0c50a7c732e97579740209b6da83cb431d9e911e275e8c8241c654db2ef677d2c258e1a927771bbf684b8af256d4543c28b568745ec21f1a92e8bf42b390d185d21588fb55af54d4bac1f1d47a0f71f0863a4b809ff15e834413b120af3010001 \\x68bed5d7f76542977e2c8640ba6a77cc5d0293538dd6f77713a21982a035809a6050166a076474cb6b77fd0fd5ca9271172bf10682382e1a12178793e909950e 1689670489000000 1690275289000000 1753347289000000 1847955289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-221 \\x40f67b45a63f95b96e5ee2e4909a3f7b486d633cae11bc7f5e4b663ab8393000b272827edbe0ab3453363695aa7777831d814db364c656d7ec8167e2babc5567 1 0 \\x000000010000000000800003bc23b2d02bce34a850744b758c875a9f5b6a88c9f9a824b179fd17f577354470ed6b3b5e8721f52f9e2624f4afd001f20d24b5f4cb666b2c90c88f2aeab8ed13d0435f9e34e0909cce82fd961593d48b4153e8d82e9f9c7fbaa078d74223b51f94b2218e30c43f9588c37c8e07d63860b3f47a973a484053c83f37fbcf1a5a95010001 \\x7175a435c596a97733c2c8445663d52cc5dad0d9837be04c010fc18276061b4b67fbe23eaa8ad226ed03ce108bdfd48095d176ba274193a649df219e05e86803 1669117489000000 1669722289000000 1732794289000000 1827402289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-222 \\x40b6bebd9a1fc6b519f6ec0f19c7429db1251309a539b88867b6075022bd0d39cab125328c704fbc1db86fad041e32d2305339037aa54c7465ddb764e6664731 1 0 \\x000000010000000000800003ac54e2f9b01e25539e81bc78fc86c6d69403024378cf142b4453df938a45750b2dde61515a2ea3a5ec27f7b8fd3080da2855f7027890d88d505ff295b0c54834183d72c46ddd647ed51ec6ab9eab5a517c63bdcea755492e458a90d1c1c167a52c3801a312ec8c3716b67730499fc560e09cc70ee6cc9444f4ed00e450a62769010001 \\x46a43d1e121323c54fd6fcea04f3468ea444e1823a1dfa10d134818484ea43a86e7c2d88bdb94ff20f856c259baba60f535729e6ae9ff1b131e68e0416d4b30f 1685438989000000 1686043789000000 1749115789000000 1843723789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-223 \\x455a9166f3670121599a7bab7df72b9518f03b4c933960ed1014cf8017b4509f0dccf8b1d377152f47d47430a5471d485b8b4de6bf28c6381b340c2fb0ab9781 1 0 \\x000000010000000000800003d9bd58a421d47fbd3c52f59a45bf7838518499583b417198359d2322418c12ebfeaceb58f11e6a18ff90a84c3dce2800873fae0bd9262eabd699626294287220d4b18b50a6702529f0f20fff62549ec5de2847bdc0c11d9635430bf9f0200f926112a6d4a0ad4837f1d7dded1a1490c4488a5432b370101be87c852a36e0b3b9010001 \\x93d61a36dc8563f1810a85c445eea9ef4ae172f694d9b6ae57ae59a1a0d3143c1da20ff5a98c5105ad97ba78fb7a49d055236ea5bea12d9b533018ff35edd100 1665490489000000 1666095289000000 1729167289000000 1823775289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-224 \\x4ada44d26b4040cde77f361b9ee897672e3bc1a28ca14284d29fe5fdf199275018b43576e037536ab9dae26f074781b314575d4926afa320581a956d44b6bebe 1 0 \\x000000010000000000800003b90415aaac08661ff84caa645987026dd174278f1935ef64554f7847efca510c5983c0f2a4c6e1274bc29dc104d58b59c0a5bc43b76275d749f7f9f4eb25ce75a1f98299148a3d87347fce84ae38e5555a3655d5630eaee54da039c7ee32ca176309b01884ee28cbfb5c15d3c22e0ac2154b596797f96be6359f97d5c5680781010001 \\x17b3e1fb55898802f6642c9a7860409aab450f229981919a067375e37c0c8742f13aeba1ace7de73ecfad39f597eb40c9e08ab0cc1df67a98749dc2551ef330f 1672744489000000 1673349289000000 1736421289000000 1831029289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-225 \\x4e322b01eb2971ad22d78f37e4b89078a1fee8de474c6540ecbffbb0d48323f260d7d7499206c47d75ef805f149641ab8de5056da0486f4fcd7fac07fcc1c5cf 1 0 \\x000000010000000000800003d4ed49fba10a9012828d221f54d20c7667aaa9521145d08d44816278a5c0eff0d416f5d4d8ab5e21f2c2d5dd3627793192013691463fb12b4c113b565e88f8c876165958a2500819c1df4b34f7e3873f3aad8497cc1e40a9522642b9c3c8de66465bdd5e5d2b518ef5384d961154c227819b874f35dd6a640c9335fdf7ac5cfb010001 \\x30d511b07780d4ebd88b512982f394c385a5ec10edce192f0a0e685e9ab881bfe9901c926f43cd038a1048dc79ce653b3cd8383e43ce04eb9fadfce443fd360e 1681207489000000 1681812289000000 1744884289000000 1839492289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-226 \\x4ede90ce872844c0be7a018130f3e333283ac61d6a8f7ec76a26dac10ea197fd9dcb5071c3be7a546523bbe60b2a90ded00b2b770256d8a81e73eda037d932fe 1 0 \\x000000010000000000800003a80b9743d758a14f5ba592bb8e6af3b8fa47b738a83030037b250c2c955e3751076611c7c2c0a63b55ecd333ae0fc5465c2d8442e46c38d3c82ad96fb695c0e10b87dd649c801f47b5227d656b3456017ad6296ec4aad383cfe97c9c7522c7cf0b6f1a693b09aca5c45f939f9536efbf6d2085da06ba4ca62f5b4054adeef3f3010001 \\x7235d94c9f2aa26b16e654e286a4f7722cc5b9a2688a89ae2f948cb873f3d14637a2d8d310d0d27df8df7b36987fbb4626220c0fc0584e32f7d0d5fe03e1000c 1688461489000000 1689066289000000 1752138289000000 1846746289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-227 \\x51fea8332bb98644d3625edc70dbeb78e0456c7467247c01a349b3b25664df0359026052818bac3f0ca452c6dfbbd99e4c47e30a665523044187ad4d2376b399 1 0 \\x000000010000000000800003bc082eaecca6bcc631c47eab41c9aaeff1154bf75b1a0fe3796230b06064244e97d361e3af38009202f2dbb4571547896b2ab9fdeee1949d9a9ebb5516802ecc3f4fcb63525db66025c6bf7542987bf93d76a84fd57839a5251f12f0e8ea8e450a3fe316bb8b9c91bd6ab74b5aa476b1dbf1101d690ff09b081bb9cb1d14f871010001 \\x7d0218f44ad9e02428c855f83dfa1b6f3dc4ff365b7dbca183dfe246de6bb200fa80d86de646ffc828fd8c54a0141356dced2d465ce5d3a58e37262713f17504 1688461489000000 1689066289000000 1752138289000000 1846746289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-228 \\x52da17462799e559833f7f3ba7729f889976b3340c6fb921fa5d4153ddabb82a3cc38047f8906216554087417d55ad36a785a26b5e91824f8a4a301256e2fcb6 1 0 \\x000000010000000000800003d88c59128c08af1bdcff7bb3d312154333ca2558b8a75a76e9917868ae126390476cf65cbdd4ecee6fdc37eae30a73fec63b288868f2a08fc2f97dbc47f6005b36818c1935b93e06cfcfd1d0f232168b74e22dbd415855a563ac862d4d49c96e83e990023d17c4089812849079c5b7a9cb7e7c55f766dc886f75588e4e4280e3010001 \\xb646ff55c9768b742794c43077606d5b614675be14ca1265b7fd6765cbe266b710fcae8a6173bbd7cdeab4e12e3453254f845378b9ca3f6cd8c55a7cfc9d0a0f 1661258989000000 1661863789000000 1724935789000000 1819543789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-229 \\x52be6a6725e9c4d87ec6bf847637db5ec1e42b4c073c74a1f896911262577d9bdb91dd56310e20b0af3ce24f238c4d476300ceb8d28f87929cac16adf59d44d5 1 0 \\x000000010000000000800003baa7dca36d2e7d82352a75c1e888d2b4b4fb6d4fcb670b4a8f5020d67677d6f2d4c5e2256d2fc28e568241a728b0d1c86e199f22c03f3da653881994f9575dc0e58a8b08918cf01b5de69fb8759a0c2e8eb08e47cd62193ebd7eb340075ea8e2d65fdb5a07e2007bbd2e4eeec65cb22eee781217a7850474b78523e0c12032a3010001 \\xdaf498fb1d0f7b14c1e5582ddccc315968814ab3fc409a62cce93be345b46c7c3a2f95cb981a89cb29b2b19c433d35c838309f361ac29a10a01df96915d01a0e 1664885989000000 1665490789000000 1728562789000000 1823170789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-230 \\x54d2cd1ae059d603a4b7fa79257e58adce2a6d4481e3d463903185af74d587c7a5f998f08a8a20f3da650e47934767bca04a3100db845336845d87c3a908c000 1 0 \\x000000010000000000800003af7cfb86af0ca115c3430aa9c9fd9bcc618c888d9117e3c4ed36d06582cfbc07bff97764bc1da3dbbd793c0d5e87650fce6db84a9603f1cf3a2a478c4f1f4e2c98d9585ac1dd9ec8de1d2166ee129ae3711520c33b3fefbd336dd852fa061f54b717b0e844f03022a4ff34bfb0ba30c4e34af6336db627c5d86b27ddd2384a0f010001 \\x4f3d7587ee2fd996307c2496e3483223ed5c88f5aaafc63b6c98b8ef9170d312735273f9fa537ba8da07eafac244c126cecb7892982e0558297da6b59f88c604 1673953489000000 1674558289000000 1737630289000000 1832238289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-231 \\x564ee75efd6f0fd02e89d8e9af1cf2f7b9d51a24ba4738f3d8f2dd667e5aadfee6403a9f0471fc220c708774069dce347844a4e765bfabbe06d50bcaa5897e8a 1 0 \\x000000010000000000800003de8e89b819be205e87a0ab05585a8aa7ac8bbacc564ece1fec77e7c01fed051521d5de5bead4a438fb82df97f9ff82feaac534c60d4fa0f1a1aa87ecb6906e1dcfbaf5027b4a41c17a1d0bb9a2f8a0c13eaa574a09908d026b1aea8e153f1c7f50364b47ea9451dc7d5077ddfd95dffc06af3c4d933aea4cf371c91428bedaaf010001 \\x6aa9a17b1131710c46323d2fce0f4ea71d24ebee8713a652af69bfb203a68b49f9f0432c53a5c28ba3f7389b762808267f0ce330185261152fa28e45d1ac2d04 1669117489000000 1669722289000000 1732794289000000 1827402289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-232 \\x59421ffc1cd0864b59e5daa85ff8e7f3876f2beaf94b6fcb519f3f40dc7fe136461ccc594ef3a0c8d4b52dd1fe94fc30a4da095eed8984d640b9d639211be565 1 0 \\x000000010000000000800003c4e6b85bbec45dcb20f2f35ef98d214b861e4ee6b322b4f6d02cd7f115b90e2ea1d6ccf6fb6a5381b85021f8f01dbc1f42d95c1525b96b9f7b74bf6be369f6f29de8212a9610c46fbedff151c887e869858776473b9467aa8d834336c9b6e0077a1433eff9989aeb33e0885fe81359a04e0e301cbdcfb8a1cd839f506b06be37010001 \\x4d6655f4186c34300853468b6ef793d3f7e93919dcd60b5996e92e29970c1eac76db41bcb6f9014a90c1aecd0ca20bbb334af6e303fc3f718d203d5c50bd5a05 1689670489000000 1690275289000000 1753347289000000 1847955289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-233 \\x5ac232391ddd38b0e02b4a1a63d7add4c8d5beba3a37ef211bbd9eb72e851df9d4c8ff80c3663369337296b04a23d8efa56ed4d367e5cdb5d68b6a7446b6f0f8 1 0 \\x000000010000000000800003c1abe8742b8ec85487738a9e08e29e832972584499f4881e3a16877ea72edb70013857eab5aa1c7531a338556c7d65f834a4f0553e41829e777b76f1a5b6fee6fd05989e59a20b14d5c9bb228324c419de9099b0748028c07d6e11c2ceb25ff9e87fbdef0c371c83af0be2adba944d2773e8b19bf5dedec4fe4a01348a3044ad010001 \\x3b81ecf15dcea9220aae583ce7fdaf456d2b6362e21c4cb48a029de5a9b6d54f275768488411d7874414c594c00d3bdd80327f03c11e30d01d4b674a1a2dca0e 1673953489000000 1674558289000000 1737630289000000 1832238289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-234 \\x5b9e5a832553af5a91b79fc4ececf74e4f1b1a104bf7de7ddf287ff13a2f8341aeca333497026722da5e393730ecbd06b24a54cd987f1deb3d99d4e38b4fca01 1 0 \\x000000010000000000800003a921ac68cee9bd478a1998e65f1abbe67bb5f722b27269fa4428eeb2e2a72e8c7a6c8832f9dfb909306705c32644fe2273a0358dbb2ff4c36c1d8d422862114afea16e5e3f13f06fb0eb2ad595850bfa56e6718dacbd424a780ddb2e1212ccdca8782291b32b4f364f483a9881d8212e74897f5e7ff1417916aab1c76ae4c05f010001 \\xb4d953e80ae751e7458a983f0da4799c874fea8e0b692c6775f7cdf7a733aa6ecd5cb0e7fe19e7aedb8619b8a1f3210b381757295230f014db08b096df57a101 1664885989000000 1665490789000000 1728562789000000 1823170789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-235 \\x5faeb12ba4e1bdbc13a83551f661d743c63ee2502ed55880c16634a6f04fe9d5556248ad7a8d1b2a7961ea04643a1a929b380a550722a5619c8faddc11e5cd42 1 0 \\x000000010000000000800003d04cf7c411babe83a0115a4dfcc0a0737d199aa7c9cdaf9e68433abf699a52964e25b25e985803672d195ca87cc31da98b956a482983ca6294c6007a538f70eca027d3780202d542dc43521a26e5a5ca549ab573cac4e7c0123f9ebb574d4100f0b48e6082a8205528501dc95284ec8d42f67f84d4bddc64bf243cf4abca9e61010001 \\x2a9b41c5a4749f4837b5d81f8f8e577d8a03f9aeed13d8a76771b060ca5af11b08f68b5cb9d94681bc6d9a28609f96e67c40710c8b16310beabe9d4dc54c2a0e 1692088489000000 1692693289000000 1755765289000000 1850373289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-236 \\x6272d02290e3e6ffa44fb37536a15d20e3c326f16257dd38489a3d75b8cb99763fb5652c9aac7389da789ce4044e14feb76b3f50149c22292940d2daaea73de6 1 0 \\x000000010000000000800003b366e7dd8fb5344ed344dd2d1fb042a0fa0660d3c814e9a432af624d4606ba2906a7a2d118a4f96514cf0a5ba8e04dd9abc0332c6068ff5ea2e0d5834c3a5f5962bd1898194b14f2bcf85c4971b289984b2dff7a511e71cd85ed0e2139045cdeb75090975a489c08df39d0af0c05374ca3155c068670414c7006f09748b74a93010001 \\xe30520f26d9d22afc3033ce9acaa05b5fada049bdb59b1f18dc596fbd5b2063aa01b0ee21f94622f6a04bc75dd1decd9602ba245d84defd4265e689f6794c80c 1662467989000000 1663072789000000 1726144789000000 1820752789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-237 \\x64ca830e1e1e1b0b53dc293bc3b8d66295a6185e06871848a872c99f329e2a54ad4f8c84fed61d997407d6ec3e84bef41d72ad2c7ac54303e701a20896814863 1 0 \\x000000010000000000800003b25493e2dce996eabe67b4122bd813443cb829cb7d581a847e5eb7d4ee439fc62f9f2840a93a28120b0136ef7f822861ebce0871bb0a877399d65b67a153cfe780c5b05f579ea5669bc7d40b694769edfd5b7f225f750dc88f0d98391c7bf8e785d0fb4ccecc8902e03da5c766f54b7c708237663f633ee92f1cc65997c1e63b010001 \\xb17917a9cd63a4334df9e329e269cc8bd1908e1eee128b183b8f1665479f4259f727c0144b21532a3201cf40c768445e434f0070884f83d294264bafeb1b5c04 1686647989000000 1687252789000000 1750324789000000 1844932789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-238 \\x6592623bff43c2ff0f566449da61ee8b513b5645ada4e6fbe9f934708fa2ebc0491bf7778421aecf3fe2325ad8e5bdb68db3cfa60612633cfb02f99b38bfca90 1 0 \\x000000010000000000800003a24aa38b21b5a430aab3596a1d7b682eee201a3f6f7d4d8956a91097d4806a18dc7b62d477311a4ef6e3797c023bbe4db2cadba9e05a418d57a10f0fc0c63b97971e4e14ab1752592b88f54027246bed88c358143c5d964f7b83e1437d85a8dc2f9de65e3432157001bfa210406d725412b018c0752593047406e4248350d265010001 \\xe4da96ea8a28d3fb0e424ab777e223b4d6b25d81a99747e17da8c66cf0c5638e24086026e3baf093a05045580710f6ba5e14ab36171af29fd1c1f3f19b8e280d 1682416489000000 1683021289000000 1746093289000000 1840701289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-239 \\x6656df1fb2c008a705b4c05261f38f5dc37d18110ec8c633a284032e6b8926c4b342676e2c285aa4e2eb68f9f821285859c531f60c16867ac5c964637052b7d0 1 0 \\x000000010000000000800003dbbd72da5eca3aa710608ed31ce70ceae69244432a9437a3c3e483cc4d6dd7e8c1c4468d0240cc38acee7d2278b6193f57cd3a92eac8f9d1cd0d08e05d63c7da5efc6bb7dc47b3dbcc389697a000f31f6dc0cc2644fd5d1655caedf6c353d22dcc3733d2c2ef28aa9ab7e91b8aa09472b24394e4723b52cf964e24707586f6d3010001 \\x43f9597c43c98f715cc9c2e4c929f50e2cf058bccc8089fb55ef56e62f2e24eaa17bbd89edc5af22c6b3c4f34374cb2a1c5c2be8664a1a5b8ec7595621a1f40c 1666699489000000 1667304289000000 1730376289000000 1824984289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-240 \\x67668ef31d96d39a9d1be6cd8d9a9f0adabc70f7c4611dc5f0ca998983ff6a498e8aef564308bcd2915e9366008dd9862057098690cf2373fdda156307b32d2a 1 0 \\x000000010000000000800003b27c213da35154d5bf2159b45d94e6cd4b998198a7e59a429867adcdfa0ca59252a7b857cf22c64cc27d0c3c664178b63c948b0e799a1438b4906f3ca31aa109509f96b4ae5123458acbc2593f2ed139c47922180317e2dc6516b6cd6bb25a466efdd5b2b5c7ce5f26fd459463a8404ba9d34b52cf01c91dd8c66bd9e1017e23010001 \\x0c562baee3fa1ba18e3b147588a48aa0fc6130f44946524797c1c66823cf80341ceb80ac5da0c82ee406b3dd7a257fe4461315dead1ba2f2016c9b4888f2e50b 1690274989000000 1690879789000000 1753951789000000 1848559789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-241 \\x67d2d61f74464274eb54b0052ec68ca3335c295080eeed1e4f8f1fd94fa377e90eeaaf8e3c1613087e9712dc55e02982f8344efd4c123cb2953262d8f0bcaf1f 1 0 \\x000000010000000000800003da5fb029febeb9ea916b1efb873dac746958f95a0887b9cc111314c7c3229c5379ad79d3d069d9798b11b5f3f3e71693b759fa1ec3a26a93c6e22124739b504240c135df434d627d2ebd9ec77b1402beece66ab5e55f16d659131bce020e9e823a3db040b86320ee9745491a2bd42b3876d74c5df83088abe0d97bbad0077991010001 \\x271fb153be91baf1a46baa25eeb25e491d92071f1640110eaf9853cb1dee9864e93840bb8a5c6b8b4760746902a14327bef136374a5dd06654fa594ab31b8d04 1675766989000000 1676371789000000 1739443789000000 1834051789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-242 \\x69ba457283b75baa4912a2e23b0b536e61e76b9ed086d3cb0d07192a3962fe42f9bd32f5a6895da64923d4b4239c7997dfa2f9ea9eaeb42c5fff40477aedeca1 1 0 \\x0000000100000000008000039d9805b493cc6f5e3fe7d93fdc2c209529b1cea9931dbf3bed1d56bea7e3ad270d35de4e9e7a1d25eea4c600eeb40d4c654fabbeff0bdc6f6aee73e4dae6adecf756f182f3609d2496e6d5b3e7f7eb8703e891fac7a99af4dfe591db2e47af0bbe55916494f1c788b9228149fe728bc03972fd22249e4b69169156b32232a871010001 \\xb87a83859d9825f6ae47643005187519fb5a71d8ada6de53b732ec398db1b9d6cce95e70e47e8955b2450474840af7459e238791401b2c53c6bf61e9c489dd08 1675162489000000 1675767289000000 1738839289000000 1833447289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-243 \\x6f22feba482a503849f9c92922fd843941044630a465122889d23ccd4165ec2cd121ad176eb4bc2705d821be5b3c9aa1877977ba4e197c85cefc20e55b784758 1 0 \\x000000010000000000800003bc8dad8a806514e0d853ff103e97b686c14b611702616a7cbce71705f72daf3f11dff25cf861986bda5edb4d7d6f1ff91864244c76a1741fe3f1ae149de0aacf770fdcd60a4ac9dab3e586330e20458da710866b0d91f00b2b0c0f3de050696ebc96378098d4fa000e65b6d3254844afb22c47efe8e9e03879b5a2cbcb3bca93010001 \\x668b6d6659b065c70edd87d428d9293fc1e566cc80e15b8fba7397822deeabb50761a80fae9d12e67d01a92d661abc458a5a0376b1cb965f4e56a6a7ce6c1200 1672744489000000 1673349289000000 1736421289000000 1831029289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-244 \\x6fa63ad2a58601be73865f207269cb4f54981820e42514b398bca3d1855ad271cd719b87e75366bdecfcbc4c0b5154b705b91d6dce70ff9eca07af6f172c6a6d 1 0 \\x000000010000000000800003b9daf78dd11bef7f323d1f38f71e784fbf4ec457492b1f01d24e2be6746b5880844ba2074e0778ba98d3f072073a96f4a6954a0278b7226f43ce809e5229fab33c32e9facf446515fec5bbb61147062c4627e7a58690781398d3ee79dadec4be81bc474656bd80ec6b8fbad0cbbd5c9440cae1cc185e5aaafa582ff0b3afdefb010001 \\x77e6adda0eb3353ccec6d8c27fe6f805951649344ad238f64bcf8f2f26881dabec61a135b67108f9521082a3668b28747f103f2eb1d4a447f2e524af0383d808 1686647989000000 1687252789000000 1750324789000000 1844932789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-245 \\x7516dda4bfbb53d2b8930fec07e8f65ba8083b2f6a1d94b793e6983b7520a9bbd6277213de1fd2fc3a07194f3971913a735810ef8887f2587b51372f3773b948 1 0 \\x000000010000000000800003f0ddfb234855c6785aee62af66cb4946cdc293097bb2d4291120c16f0252a563217b540fa8559e099b18a6d3a4b86ead0288c361e5145bed197b3ea12b9b5d6c9eb0995c6d36335797dc77fe1740cade75bc866a593651b8136b9ea43d9d3b0815a33bf06a670149b9aa9594bda2ab135c3f8e7056fc28abf13ec9b93fbde867010001 \\x4720d1549f9138790e7fcf8fdafb2a781db80ab79d5b0605d2baf4619d9d403652b2ee17f68ac49b1c0a39d800e3322470ccca13e84c812990a1637e6cf53e0e 1690879489000000 1691484289000000 1754556289000000 1849164289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-246 \\x7986f3ebf1c80fe4d68bd6cb1e6a2d80150ddc350cf2768eb86154f2481683f579a7ff60a54ee6301f6a1fa9faf1ef54445e93671da3adfa4a790ab49a2d5263 1 0 \\x000000010000000000800003f12141a55261a80c698e2bf9b3cca4ec8e6a28a931a3b6781e058645996e185e6a033d7cac7bed31da4f2a120f4835c3b15fa01f8242622345e5f3d6babe0830a1f729a2f300e48b752cd945e98e9669c915615b714ad9aa22c5711a431a08a88721075937498ef15f6bc115fb79463996af0cc8601dfe13787c41d29429dce3010001 \\xb345d0e429d5257a82a61bec087ba395ab557ea2cf7d9884fdbe7fc9b212c778e8afedbbaa36204460ff6e97d5ada43c8a40538ae619c73e3d6d228303c82d06 1680602989000000 1681207789000000 1744279789000000 1838887789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-247 \\x7a8eafcfc8d2df7f3cde44d3808417e3d280c7e76960b8dc9361ed8b19829ccf999e269b1114ec71a8d337c9cd3e02e3639bfeae9622e0a9067b878736fb7f95 1 0 \\x000000010000000000800003d78f3fffa87a5bc60093c80b3420c294afa3e72fd988787190829e4e36a6704de47cd6413487beb4f0ab8911cadddab3cc3e144e7b958c43bfc619e6e05d67561d8f061ada94418d49234a4eae800cae5cbb57e102032dff5d5830290eb7e978f6d4753235c404c94a467e67bffcf3617f90d2d20eb0ea8b9af628e8c7443aef010001 \\x120e2f1713a6d0692b4b14d78c8ae67a26fddb190e0df3df38e1ffcecfd3cd25a2f8bac69ac3c50278bbca3571bf884d04e920cc87ae7287b91a17de8cbf7006 1681811989000000 1682416789000000 1745488789000000 1840096789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-248 \\x7bea6d55dfd95474d2bde518c89b8465574d0b917d990391a0151bbb02fa154ae47aafd745abe23929f15d716c09f618fbc47bd8cbd3a10e4513cae1b2f71433 1 0 \\x000000010000000000800003d41ffaf9ab250292471ca66c6dbdec7c36c9810e4431878ee7a90f5a573d6ac7e23dee4e46cd42711d025b691ac379e8f6b339804840e0b64a21b129b44a5c53cd0fdccef4e0c5514f20d36d28b23902e28457ee98614d1ca092bbd1875c6c70a991ba852b9799fe447457e4d115e8109880ba5fc42e5b2297e75dbac2ac96e9010001 \\xd908927d3f3a66226dd473bd0051e923ad376e2df68ed73b2e557cc584448f2fbfcd6696b6c9a97420ea551ce551118dd8d64c31edca6b400af699a60e4ee50c 1687856989000000 1688461789000000 1751533789000000 1846141789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-249 \\x7bd62ef4b53ceb3f254350bbba70a6d5cc3f58e02336e6e536af551006d442f6111560cdf52a856ce12f0030c8a61b9e3907ae817b1e468c262e49d14d3202cb 1 0 \\x000000010000000000800003c399ca1be975190338e2dfdd8ed483871000dd4b4bd01aa973de6d7c18368e8d2ae46ad0a00e85e4dca026af5a1f2da7edf8e5b6315a6a288021ededeb6968b50f944bbe4da39a9550bd14d0bca3e58ed6d0cbc46ea495bc570a9e3d8ba53260616083e51edbf9ae26b0f17b36808db639cac5a994417fa2ab9b2e576456576f010001 \\x421b1a3ba062173943406e942b669c90c726ba95e31f7459be82ee517173af71b7431cf2a4cd739f7e8c025342b6bda97159e25a95cf706e822f9f8a74429101 1678184989000000 1678789789000000 1741861789000000 1836469789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-250 \\x7c32b89592f1e80d6084952b3381b745fa055b5e010c402f9e92d8dff944a4b9c508321f7d9755477e5ebc3fa9741c9ed4c9ddbd153fa32c6ba7d95cdc9b9cd6 1 0 \\x000000010000000000800003c364f3a6ecb2244271b4ba2ef8b9d349fd0879f0b3e6a8a5af99f78931d64b27903cebf53e1be09e52cf0f8224e4b50a54d79cb4941f073585ab5399c8d50b49c37f6e760510fd1a9c040e34ba82b3f85367df09c70d7a0aedd00d7e25e54d783e722a117b2e19d053ebbc6584acdf732ab45699970418e77c29aaf344fb2f27010001 \\x5bc7ea92da272b996482abecaffa09654478028f48953efc3a249bbf33a24bd69fcee6e0583c7c4a8cb5cd2174fce3f7701d0a3f742446db18dd05057f588f03 1666094989000000 1666699789000000 1729771789000000 1824379789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-251 \\x7dfa729b2b558ea2cf66128d8e0d727ff79ec46b6c4712c2d4d6d38bc011388496e5910e2618b654394f9757ec148a7e79d5ae40b98226b9a0ea00e3fcb071ba 1 0 \\x000000010000000000800003bfa8bc719ac14425773e0886d2bb99a1bb33f824390594415fc238320bdfcc866cfe2c47b783ba0c939321b11021714a1f2e7f09db09ca873794a136445c78b102fc5985cba9d196e7057c0fd40df65906c60e7f6e632ff71c4965c38b0c68f96f36de9f3aa0c707e33b843191d87492aa3561121db27563f237de6bfb07cedb010001 \\x32766ca8f63e5e41e0eb37f44ced27f31cca1cc5e6937ba43741c84afa39bb7d2073f53c8dda406a81ec47753d38564f889620e2eeb6c14b275eb46b61a66600 1688461489000000 1689066289000000 1752138289000000 1846746289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-252 \\x7eb6fc0c0467b3bb5945ec8072597753c87c19f743749da090a79bb9ad29ce84f44e0559119cd4fd3b2a263414752fa8b8acb6f8c8ab03428c78331a15e0aeab 1 0 \\x000000010000000000800003c52c8d8429761351af6242dd9a735a5dc0237d6b188e0402b4f88971b0531f6dc188b8b7045189447c219b5212957d4b6ca5f26dd9a1f4e7005c829e20ca24628d024fc59119910a2a7fc806e7059ca17ef1337347e8fbdbf7df52ca34cdb26064877306578013614c5453bfb33e9a2adfe2c71810a6af510015b7531d45b141010001 \\x163c12639d9884b296daa8319bbb6a51cacac6818c0addcae3c8278059fcadfc5df097788e6ab7780eecf43b0c92acc8953cfd4f5981d58f91865d5372251600 1687252489000000 1687857289000000 1750929289000000 1845537289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-253 \\x81eabed9da07b46c574f08f206482679de29bfc499a68347fe8502a71f1f1d3e77322984948f1cf32345ca58fc893448a0b1efd3871089fc7d99dcf9487cc400 1 0 \\x000000010000000000800003c725708ef9376ec8d40e6c0c5386cf7ea25fa9cf7141db08c63eb60346b845becdd0625f07662ca1e7fe0090a6dda0f8f843e941afb4eda75efc9cbf0395fff2e686fafd15e42843da267faa5e97fb53a8651cf83c9e327cd0cfdf21fea9e90579c848184eb1884f6fbf29307a48ab3ad677e96d6cdea9e4dcf0ac95b548cbb5010001 \\xf111715e452f3fa35fd4c4c5fb55f6bd62f5debdefd2188cd3b9a4f8a2af06fd92b7be30c11473e548c121019f7dc365d4a81a0ed47eba1709af2a478d05c305 1687252489000000 1687857289000000 1750929289000000 1845537289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-254 \\x8156b5f353bca4441d8cca23553dbdfdac41917e43252e621f1584c005dbd0e95fbfc475955f4a066d80630f67e21cb19bf70e28bab3ee43ae95f015221861df 1 0 \\x000000010000000000800003cb4b2abcd80c85d0136d49df7e5cb4ddff6ec40eb5112db1eaed68521cd36afe142f2c8ac6a9993cb6a33c7c600a4bc58ced49c7e416d1282282660ffe2a5b9c40beaef73106668381cee4d1d640928f519f5acea9753eadd7c16503ada62392d235890feb597ffcaf3d557f90a5d14cf1534b83785e9838df0a149a130c8621010001 \\xd78291afb8029926c837072c9ece52a556e3a598056f50633991560828a73e76d22f6b22923064312ec8536fa7c5bad7416b41b83d86db0299169db554166705 1666699489000000 1667304289000000 1730376289000000 1824984289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-255 \\x83c6bd3fe4299da697af59574b153750868bc7b65d115418cd37f4946ca2ee08377dd6d21b897fcfe14ab6cc5a6f23346b90f9999c11b6ea5a63f1157407537a 1 0 \\x000000010000000000800003bf65c64d9fb8b87ca2f71c6f11de04ebcc0e8a26165b1b29fe21081cef4089fef48a35e1f0b79dc7142e03b173b513e0e52dbce08cd6492be11a533890bf53da31a53913d8f1f88f9fbdb95c3371c966bd5063acc049ed38f37f9ae3111440a266e80128f5694c06bce6570ff4c61123e385c2e7a747e17c19a2dff94dcb785f010001 \\xf76096f7ab7e3af36decf3d84307619ee954d61ad0e1f600be782f15700964ba0ae329e0e4020cd57f67cad1aa9d912a70fbf9358d577909e9657dcf38aef70d 1667908489000000 1668513289000000 1731585289000000 1826193289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-256 \\x86e2c6c6c5ab47909cbc39247cc86567a477bf4a6dfbc2c8a0569ebd7d9d47f03a41bd6b162fb83bc4867e6d366012c6dcca64e291599b849050d068c3266b9f 1 0 \\x000000010000000000800003dc3d3dfc429dc54661f2bcef510dd6493b7545d451c288e6060b9214a7502ad7a40ba0570ee4170e4a08f6b2f4bb4cfe148203fa8160af0cfe57f6430eb0eb14595ffd9f79545b72425ce4f872bf6736e7b51cd2438d99a040cf30d643e7228738559611f3e3f0b52f8028813ca78d5ffa6143b3f9142bcb9fcfb6a485ab92db010001 \\xfa67ccbfa09b02e72bbffa2271d64f4352af837e88aee38d7241a658f1059ec899fe6d901b10de1829355487bc007c61a0cb123264fe4adc57b786a4c9aa8905 1677580489000000 1678185289000000 1741257289000000 1835865289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-257 \\x87e24a8eebc4bac0e2e00338c6d98bcb03892d45c6a1d0f485c66da9843528704e647f70a62c5683db751ccf34a617644645906be7dd61a50a33a5513edae6f7 1 0 \\x000000010000000000800003a84b48081998600ebb2de53dd1259a31dbac767b960cce5b68858ddb67437ea858553feee415dded6d1437c52b555a63ec40ac739c1c4535618f971d9ca6fc2fe9daae3a42f0590e27aa91c7170abf2e341b4a209891d2e1a1e73a27b95323dfd9cb8b14026f08a70237b9462a858d9d0121e56feb3790a1fce5dcfdb157fc0f010001 \\x6595eaf02dacb6535a3ad205cff4e8fe218efafa0cc0ff6688cd71fce8db454f19f8f54405eb8ff73aea2250d3e025042866f073be7183b937c1ef8b5631a907 1685438989000000 1686043789000000 1749115789000000 1843723789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-258 \\x8956d41eb50420fd0280876a10c6b9d46abd2cacf04500a5eadadb1f5e9c9033e0e436c7151e69e3b7af897705f5d82e1b8a26d2dc6cc89060a67fe5a860afe6 1 0 \\x000000010000000000800003dcb8ca85827bb48c8feb9346900d2f24cdbf3505df86d5d04d7d17d16026fa8cfbbaa6ffcc27279a7958b10ecfcc15e19670d652d8cf620a08dac7a6ae155e8e9507287d957b14cc06602f5432d8677aefa771277c3c7f2531d202c028c92d9d64cf64df442ec0cb510be837099c4c4023d53ce6a8d1057bfbdffa4aceb0104b010001 \\xd606c21bb23d0e791f0290190e5db390c79fa0653a9f3f4105a9a714a01b15b1ba892a1c36d9aca1797d6aa06cbc8441e54bac60ada83d15bd8c99100adc2001 1664281489000000 1664886289000000 1727958289000000 1822566289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-259 \\x8a828d7e93bf1e1e2b8f46ec8ff672d3417f0be455a6079de895542a97fc35a6b8f8f266615c1929fa51a2f0783b4130e41754d2d77246ba352b06d43d36634d 1 0 \\x000000010000000000800003d1a1837c611fcbe2f99872a71a80ef6efe17a00751c6abde346a9f8aea27e58dcfebe60e70342c6fc24284cfa7046d0b7e0cd14b4e8c3e26ac900da4eddde6d904742cf2d54ebb0aadf196a238067756ea1d3c8ee7ef498b2aad3a76e354666397ebff089b32b42af7154ff4cb1225a75449431d75fe17433a88546155b014d7010001 \\x7fad1abb6d62f22291d6ef4c2e843d9d90b3331645226b87a405a892b035db8edcf79b2882c87ba4da47f729e4e55ce179496084968492c472321c4f12e65b04 1681207489000000 1681812289000000 1744884289000000 1839492289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-260 \\x8c1a9656f9a3f742915c87f2632da70e8943d1285badec4797a080f997a99e6feb167ff45e288c325c3f1e0ce96b039edced996f9884efd25f0e9fb0fec5b44c 1 0 \\x0000000100000000008000039b069627e29541ebc65aa925b852314fd4959deaea73185688fa6d23dd6bd140650a7df79f7843def9c20831b5fd69d0e037428eb34cd200b0b00d9338234496231c79876f612f625238b4490ddbb9bc813cab98a9181a3c13ef5e9bcd54c33bc58ebca8d01bbd36f2a2e51e49a61cbe53ef5f0b282cd774830f4339b132871d010001 \\xbb8ee45c06ff46d91771160d1aaf906efc89fc291d8c9933c590d1fb75b11eaebd29e0f767c0914aad574b50db05efe1e4326004e7d03df01f53fb2f7954520a 1672139989000000 1672744789000000 1735816789000000 1830424789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-261 \\x8d728665cfd3614aa4b70b4148bdc3263b6b5338b1ea521161af343bb51d530523f2dcaa3c3861f7550a9c91f94a414418851f1d624c30534edeeb8cbfa8f10c 1 0 \\x000000010000000000800003aefbac69af4b43e3940ba039f12005b740cc8b9ade86e9266d3b3fdb483806143bcf2426a5325ca140fa9465d6c81eb591bf541570a3d0af5e11f8bb893015018f61ef3785b62aee0483b529f7a9868fa728b7c016e01154aac1202fed1ace657216dc07688d2a5756178a77d19e16ecff7cb1b943d41242466e7adf2b2e84c1010001 \\x4f71a3c1c93cbcf89e60817068576605830a5f4ee48460a58462813c165e1208b045ed5511e13fa14e7006b45accd3c458819b6a1b591200c06a73daa4e5cc0d 1673348989000000 1673953789000000 1737025789000000 1831633789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-262 \\x8f42f3a425d02d6c4e6e27b8b107f74e957ec7c429c776bb678d26aa25fe9a70fa13d65a187519d9b34bc2b3370aac73be3d8dfda1b87efaa25830835e096c49 1 0 \\x00000001000000000080000394f6efbffd122901a99aa009b05b0624e26a6d8e4ffb7de719f8583c53a4e3ddc6bc22dc76ee653f5f3cb71a812b9302a83f1e733b2e8f9e152accecca47926f4121a7b6e516e9be70b928f5c931a3030f3990314c54727cb8ae89db7d60771d8ad08486f7f2b17a8c338c4dac6804543fd47e785cc734b27ad3f671aa34375f010001 \\x26426b4a762625d25f41313dd1053b369238364a5b652e2f174dcfdcb452f202babc6023f4757f2130f96b605cbaeaad12c9a4e0e945b3a24eb8854f4830f20e 1665490489000000 1666095289000000 1729167289000000 1823775289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-263 \\x905ed360383a2ea5b41edd0e6efe23c5f8fb3f15cc14b17c9ed2dd1a34ee568dc2ea51321cb93b3162b0246f39aae44bdbc80ad8e6f9d1856e3dee8df405fc82 1 0 \\x000000010000000000800003b23e884939f46cb5403eb7718a06bf724bbced3b5bc3503643d62c9771381cd657605d91abd791eee570b9e36124570bd280aad3d0323abb6c68e8c16b11ee3d925eb9dcd64fee70d06053148a792a56a4c9471a2b31aad1335fc00bef0f4cc8e33fb9226e954f25c2ebbc0024981a9f2726d7029e37a8fe2f3fe11f92871933010001 \\x32f84166223ceb9d822437e07423959f80a1834b8c3834684b01331c859ff82833966a076649c93c8cbd250a4ee24b7a88dc6cef1ebfca641ff3ad11bac59a00 1674557989000000 1675162789000000 1738234789000000 1832842789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-264 \\x9372083145889263b712fdf1cef692e71bbfde2b9b64afe8428c782b33338f12b90186d53765563a330b95edfd510664f2d9169fda36cce95f86d265daf5e6a2 1 0 \\x000000010000000000800003dbbbb3e2c2450eabb007b8dd0f7df43b1261982a6e2eea7f4380ca470b03b6f36cb624f165134d6a0765f6456a5cd67d160246781c9cacc17819d478f39fc79f0882ad1b878425cdaddef6bc5b08bdf0f61b894d32a0c88a9b863c5ebe9fcdc2636092205388b0025fce04e2ba2debcf844bd35c6611d50e6fd5ba2a23628075010001 \\x0c069c23e614a986001b012a0257233d66c431a63dac37cef5bf3054354d135334483096eb25a78c991375bbd40b7266a108b4a4e48cdbfcaa21ee098344fd04 1661258989000000 1661863789000000 1724935789000000 1819543789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-265 \\x9446c50d94032053dd5b5ffecd62f61ac51cb726133e76730a09dc7236cd6393c6e83d36026ebb2e3202a97decc77626fd149f45654d5a593c21df860200df8b 1 0 \\x000000010000000000800003aecab8b5f123c07b703796fb1d2b34f37ad49e9efdef7d67872babb42476d2bae4d5084babfc27a5a9354f37c745284b0e6f7b6ee87840f8a37bcb9cc26d523cac297a7c4939a2a45a24f67c362be026ec50513c8a5ead44b325f023edda9874fea8a8b7148b3e4621a7e94254ff13a7f7fa61099576011fdb4209265c1b86c9010001 \\xea0742a0d7f3b0fe875d4413fa83e527b133f7e6356b5964319a893673ffbfcb2cfef2794dea8434a0a6fc3172b326b7d34f8fe33771d1fbd4089e647a330c0c 1672744489000000 1673349289000000 1736421289000000 1831029289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-266 \\x94462e10397cadb87727dae2b16c628d27f96dc75c3d9b97e14a2a47c13a338b46614acf892cb56fe5e03bf9c3fa59cb60f352a54bc26796d78107876c1bdca4 1 0 \\x000000010000000000800003960ac253a478c1493e753f28bc6d16cf839112d4269a6a93a6d3a0b09c5d08db6f2877552f3bf0ca2fbcef85ecd73a6b19917aee7f8efc4812dfbfdd7c5ba85b44b05d89fdd1295993d84d71d0415110d3b37bc66c517d9fb9758eda48c62db5cdaddf61140203298a40bea21af068961c67bfcb627adb093bde68e788b34c6b010001 \\xe17cde44b1ea1a089056f62eb8ff26b5ba2a8e77e45284f8cedf1370bc0e421881ec061c09f9feb06defd65fcbb9993d5c6ae02a6896ec8373c403b189b0f600 1669721989000000 1670326789000000 1733398789000000 1828006789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-267 \\x987e6576889c4aa5745e8da2204afdce38df41b218859911e58074e7d49f810b95288655796a318acedfbb2eb93cb0806f8a36328d9a18690cf157a9e787c63a 1 0 \\x000000010000000000800003beece97babb0f12f9f539d4ffeaf5a85a3d3959a8f9ec07daf9a448553ddc34adf4a9be54b2e0dcd0708f86f97710a307fc13ba60fdfdf0af514e09ac035d4f1b6b9f0e9f4dc2b5dcbd861f97f6945b858cf3aaa3c2b2ec5eddac9835df3691069d1607fb3fb239f916f8e96ef76fbede086bf77d3fb4a829660bd0a79eda631010001 \\x27ba63b81a5d13b0f1c426e06489a730b8b2f4a9d09084c9cba6fa9353eb66fbe0e889fc7e20236cc6d6431d1b8c3b901092fb5c72c4080e69d745eda429f804 1667303989000000 1667908789000000 1730980789000000 1825588789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-268 \\x9af6b59fbca49ee8d76f0aafe853bb677ffabb7602260680b1b4711d92bf657b5eab6c822d1a54a69b28ebdf0499e9fe08a2daa77bf56ce1137ff4561420e6f6 1 0 \\x000000010000000000800003df908f8bc7a08d5e56629f8221d44a82daf0fb9da80ce82650ab5db748caa9153fe7033ef1072b232780483d0e776b37c6bad334b4357334b633dd8e3d12d3436f271474aea5223bb6a91e392f1422b62746f22e694f04d9e9d702e3633553e21afa8e1287495d166a3001b6ee32e7f6c1165e120731a5d0cf6eb96cb3868935010001 \\xcc0f969e68cea509a587b9a03c1d32e2b7a11768c3c4060eb03658eb25a2fb41acc8bf5c86b60f6a1f49d44feab2ffe342ebba61ea37497e136e2f0d9af82801 1671535489000000 1672140289000000 1735212289000000 1829820289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-269 \\x9b3efa1ac707fcf6d881c8b3adf1ad36f9b61a915a742d0f1e9b556e2a0337e1de587ec8c59ef4b1c10fe128cf127b6378332f4a61bab078b6e59d9cd18c01aa 1 0 \\x000000010000000000800003df85e2cd3545b773f98b12cc7de02b619a68f36182d2197d49634771f2718f6c5ef061fb27dda16db85ceb094e6b9ea25a36eaf142e84a8e4cd21fed8af38aa21e6cb8a37ee24a12752a53536216082bd9982b545e6d671b1208c47a012039dfa126634fc74843c9e2452e1ab03df7ff015cb5de6c81be054470583900a09915010001 \\x9a9ef842bd5ce01eb29d0825bffc3ebf5411a2c6b6d36100612d3f9bc64e677dfebbe3c73fa52855357b185530b084c0f0ecf5a67979756d2d280ff861dca80f 1666699489000000 1667304289000000 1730376289000000 1824984289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-270 \\x9e72c2cb58f27133763b4e56442dcbbae6a17dd183e1debd1f4ba126b0b2efd47b3db02e9dcb0bb02a90ec732d40bc8dc2557e099c002aed338fb9d7ad7979ec 1 0 \\x000000010000000000800003c3522301b5c87c11ba2017432c92da721df636648849af4dfef27e996337a88ccbdfb93e7f9e9553feea1889185703ac9a2e2a8ecaa5ad54a2692b0aab178f88fcdf8e7a0d02740b928f751e7b3d0baa8b1debefa24ca8ced1534776effd6bb3960a51bf681d0e1a0057910e358b60821a6e09ddee4502a172f8ee4c597eee91010001 \\xe7a4dda3ccdbe92922878a2812be238ee0b152dafda4cd8a60ad7833de5f99dd43ba6d1e63fe129015f1c192bbf2dd69f67759438ae7b098111911c59d87cc0d 1680602989000000 1681207789000000 1744279789000000 1838887789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-271 \\xa36e429ecbad2687bbf6c7fcecd657437c021033875de88d4acd08726a71ce03a4c7e49364706dd7fd54825bce225542171c5be102b95043dc2926740e4bb383 1 0 \\x000000010000000000800003c6d5d3f4fbf91b0068594801618eb75f900c1fc355f455386542ae875ba1a5bd1d1197d3d795193afa6d3874854f5fb3232172cf2b31f3d2039e942b3eda319236e3888b39af4b995a7b16ba634636a74f00e649b2e6f1d8ffdef73c2676b8b9561a08f975f0bc70eede4b15f7bc2e341343552e13f7d5b4ee98cd4e7270abed010001 \\x2a25d45294d5e934c6444ea67b25cf15d065beb2df7be45714c0e2d9fa6dcaeb48970680354753d632d540889e06d481c68c52f46f63e546f08a1f00256a2003 1683625489000000 1684230289000000 1747302289000000 1841910289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-272 \\xa6963e7443987a5d9701906628f0e6f3b623aaf66205d4bbc225a2d0f04d7be71c0b46a2fbe3cfc8067e0175a0a801678fd37f58f31589268707228798d0728c 1 0 \\x0000000100000000008000039d5bcad7cc380c5881ff1479211bcd65d387d9a6dcc2a2099def50a9557d5eec51cdfa0475b0a942b3cd158b0c222ddc2dcc5c06fadb521cdb5d75c9569e786fbd4d53ae147c71cd281a6e5382997bc819f0effc7f47b9b8492c902c6c420713842876125886c1a459a70e853a7763784ccdd6c28ee06cb2b0b3e5670a33cca7010001 \\xae5bf88ffe4631ffc698fc5d4d6e7ec8efdc3bdf7553584daace28e5a608fb9fd0247e99b21a68f6c0d9df1ca5dfd236bc0bcff93eaa92c826ea42c4b69fc206 1665490489000000 1666095289000000 1729167289000000 1823775289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-273 \\xafbe613f9f3673c0748fac88a2246af0774af714024f74bbd66fb01563c98261299241d1292769be499a9416e05a0c1a8e2655ab2d0df873106e63388bb7dbdf 1 0 \\x000000010000000000800003ce0cf13924bb4d6d516f772278afd9a1e53a32615cd545cafe128484bec702c12799e3caca5d369ba06d80d582e3e53c9ff2662279a36bb589923c8cdf204e7e4a5851d9cfde3fdda484cc9b6f0d169dd517acfa38d7cb37c04d76def6bd0ed9b8e1ffc23de21babe07c1c5221881709cf029136e90721b63235b0334526c845010001 \\xf7b6abdadb49fe3111e9bb9a29d7f93b545bebbb94857d582f1b437ad5381be75a8129d061c4447c6ffac3dc85a963bcf4f9115b92cebab9d9992f3e945f720a 1689670489000000 1690275289000000 1753347289000000 1847955289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-274 \\xb4aa247132444f6fef5dbcfb5b9d191133be79b1eedb0018efe887a9503e9d27087977530d03ec356057231967fa8c2498a41d1414dbf9ca33be19f11d28dae7 1 0 \\x000000010000000000800003e0bcaacf0530f63c16de2e89614a783fa52509e32f735a262bb6440e5bd9b50845ac43f593e0fbe97f42d2ee4d299b133f2a8a8e5dadac82fe11d7c498c435a47138fbf650aac2f88a1c31af4e09be21b868d2075b380edd50374852ccc283a24f4ad19e5e11cf5ad5ed3694747e14e0cc66acdd1d1833338ed753a2d4d0c2c1010001 \\x6a95f60c5a3ef24900a73e7d0408265a0d871b5e1d6ccac69694d60d8c6757bbdcdb787e7759f80a31d3e5d2a3f9d25e4aa35a3196e369f1e073435e8deb2607 1673953489000000 1674558289000000 1737630289000000 1832238289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-275 \\xb4fe682e072402e2b2cd0076da41219359b0ee2028f49f3623693b9f7a72f582f9fd67f3c42d31db32f4b2cb13354947f2a32ae19357e5c93ad1fc43ceb7d6ea 1 0 \\x000000010000000000800003f0451d4e19d70af8392ceab4c186256a790b247df590d0a0664e26364a3e61e50d54dc7b2363cee7dcbc8bbc7e9930a81531fb69564cdede65e4955cb229d202aef1fad7930030fb7da7e5b2b0dd7ea3eaf8e7ab490f18671017b99b601402c1b86c04bda4cce014b5d74a7aa6f8f482b108ee47d7ed7c70a1414052f82a6fc5010001 \\x5467815ade52e627ff4b206d8534fc1835db44773aacb62da381018e648de47c756197c4934ff4e2f81ec6cc0a5c6119a9ab0534daa1da204831d55adf1f610e 1681811989000000 1682416789000000 1745488789000000 1840096789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-276 \\xb45af6fbb20939d9b4dcfac70fd40910585a491641d4870559c12d7fc59f2cc23f70e3f3edc85eece973e01ddabc01ee72b5692eed5b8255cb04bbcdc5cd7ef5 1 0 \\x000000010000000000800003bbcbb88039f442300dd960c97d655b249e5e8b036a565e40e3ed36258e4dfdcc7a1668d185948f40c8d3fcf1f086a1525bf58fe8203c8153c25cde8575cd84f86946a2c72cda1f21f69a60e7c1e30aab4957865b670bea92ab9504d66ae1f652acb694d1f15d45411d7d74dac63bbc2d66a00e92e95c1357b616fcd307461a5b010001 \\x4688b5921399833ec6347d88094786846cf3a66375d1f67c67928578d029d4ad706225e42a6f2477b46eac15c364ff820361961579a4da69b5a159f1984b2e04 1684834489000000 1685439289000000 1748511289000000 1843119289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-277 \\xb74e44ccf4000507fb7138bfdd56418ea3ce5ed04e746ea37ebf7718615c779fadbe35582a14c06d72f436847e3d1c5c8a6ed4f518e922e09460fcdc3de507c8 1 0 \\x00000001000000000080000397edc2439baf7a091620326400aa7275d600ec517b25a9142879fd41cf1f91653969e28ee9868241d5ed5b34b2f5ebb55c5120740ddfaab7cb9296e4838dadc07ff9d0e15f53bc0c5dc33d931638eb3cabe53678592a7ad18fd5d2fc7b4b7d6e82c562ace4dcbdc54dadac355fc7a2e0eb1eb10a50bd6288fe5136d3e7283e03010001 \\x98d1f3ce3ba77bc0736866d4d657febc47407d052f578e33c8fd46902d214d2142c17d694d23f6cafc77a4a1205e44712d24d19051b964c8e16f36f9e1d3a50c 1688461489000000 1689066289000000 1752138289000000 1846746289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-278 \\xb932b5b2eff1b671ac98b0016ce1b18902c208f83e29866fa0596d9ade823bbfc75bb744b9dba927a8c636916e724e888824cf7c5a89d5a3a5a5e860320023fe 1 0 \\x000000010000000000800003c01fedc84603b5b1df9d3b7fb80602f9572e1f890600499720fe9bbdb31567d1b4c320e33b6cf61a94ec9bab679ab170a8b9756ac8ef032e0c960df92a2e0ff41cda7a8430c5b7af8072932222d12c8a342d3b4091585dda6f49a7e6271cbae45c1e841197f54e045efd027b8203dfc6aa8003c08beb5cb653ff2d131ac8d869010001 \\x949d4cb5392efcfaa11df25c6a211d23b89b556fb119a24b504d0624b6787a0ec65dc256424b36fabcb1ae1189a193f415180b1378713f08bae531d13b873704 1662467989000000 1663072789000000 1726144789000000 1820752789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-279 \\xbcaa79787332d50aec528a7c53139d912d19da153b908bbe204a722749456ae8583318ade8c5306eba814295a7fb757384d396f0c78847b02f4e347affbb2a72 1 0 \\x000000010000000000800003d6a815da56b5d9edb6e2453f0173d3f6852f487831237d70dae63ab4560a0377677c1f5d074ddccabf83383f01e64b0bf6e2f478b9ff978f47fa8cae8ee227c5070ad94852b682dca8982137e02d57319e62d141736de3de0c6cc48db2d72d26b79818cbc0ab4f9a9faebdcf64d9d951ce852ce1ba86d9d25c1593659c5abe43010001 \\x4c7c0df78e2170f8062cd8de4bfff7177a5e4a89989c8f5f0df3173c54a8e7dc98607dba120ed8cac79f5643699d8fbeb7d150a4744b1c454413a565ab75d20f 1690879489000000 1691484289000000 1754556289000000 1849164289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-280 \\xbecab4cc170e3a1da913421d58eccd30399fe7917f87dc61a620060911945a442aa190995cb587ae24dd863f26dc2beba97acb20bff147b46452c99110b86a8b 1 0 \\x000000010000000000800003af947788f6c022916cd0032fd556963f39e611d4d952bb258d00b37d8dd307e87e648d13ec4eaf55df20fa76574ee75ce134f77539ae575b466e87f700bde09feb618a3cdca028fcd2ca5b8282f61bfcf7f82b0a2befeb54ab6f9c8d7a8dc253feb8157e704f0525eab4529fabdac96b6544343438e6250014a1899290e2e167010001 \\x60ef9b60b045a7153b394b506c7690da91f6436fa8f20080416700cd37c4f1e56a262abb2498092a770cf2e2059b622e272e48220a87e2b38c928127ccc68704 1666094989000000 1666699789000000 1729771789000000 1824379789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-281 \\xc0626730ce5de0a50b11071dd7eb2d0b30299b4e9483350e145608afff9533d82a7affb032a2eba63097a00b83cec923044f03c38fa3ba73915c7dc58a785291 1 0 \\x000000010000000000800003ba922ae75233135ef56a7e2e043c6dd13f15f0f505dbaa45d3ea32e0e46a07b5b0d410899f740263f4b26f6e0e53e8d6804d09ede10babe0a366b51fa741082346a923b2a7af263289befc10e0c95c716eb026eaf3513fba5c2e13b19271e8881e4d4c13b4fa5382977ffde2ed9c4e063da08d779a1dcd1a2df4316b9bfaabb3010001 \\xdb1642e445420777ae4e69ea6892084938bef1672617482a20873842249fbb55b137abbfc0e03b15aa524ecac142d752ce80ac8f48d2ea0062edaf3ae6dce20b 1678789489000000 1679394289000000 1742466289000000 1837074289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-282 \\xc34a51faa3a05da48d2611e24bb5875d0e80693e708c5919ceab8ecc1970bce38cbf66191a6d7d3624379f037e7097234bc6e966439f962c4112ab168600689f 1 0 \\x000000010000000000800003d2bfcbca026eac1085f3598870bccf7f5156788527cc0d963551745c02fbdfa9e8dd4724360e241d523592176fd6d235495e05c3dc99661b82b7ae88d10a63fc472251a74f309b3d28c26632688133cd8550613defead4ecf945cf89a3339238867a3cec7a8abb838509b0828cde55e726107bff6aea089aa446de2000b6c3dd010001 \\x7033381cf6d49a785e7cf6e4348688e5a557af8a6f2feac671e3648ff34a4ae6adc30e29c3e033893fe830be763d4ce33249a945233d97f2e42f813f317f3a0f 1683020989000000 1683625789000000 1746697789000000 1841305789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-283 \\xc6ea31a4b700113f031e4ec3db4f29d9117b0c95d097702a35fa6d693afb830ea710c98bcc81c41b08b9c1e7e1cd042e74f542cf7e483ec6c02f8bde22460919 1 0 \\x000000010000000000800003986325005316837b48513f64741dd460c0cb6e73529a445ca88edb761894f4eecbead523d62fda0e6afd75525cded8a775293f6e9ebbe487b36a4850aeec74cac03cbe1ae05f6e6921dcc53774573022a648792460b5c3e9f94adbe782694105e3d5eafc4b724508967cc9b3047df4a37fd593ee297ec2fe06060489e29bcb45010001 \\xd13f395a06e17d1236c9c06b0de5f284debb65f729ffec03ba102ee7b1e610ac9c501e4394bb0df26ae0f6fe920550c65c623138c6d5371de7b208561b86d60c 1686043489000000 1686648289000000 1749720289000000 1844328289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-284 \\xc6061edb7dabc0f56bf22ebac1163e5a4e1f5c7de394372b4b0729142b87e2663a567d90fb4497a4cde046a9ec92daa7365399cec0690b8103bc38c7878c7ce2 1 0 \\x000000010000000000800003e7e46d8a9bc15032c1e3dee0feec63b81ee05ffaf0ea653d7102a089c9718e1fda2979c282df245cafee37964272ff748a629b5e9a8cbdcdf97e07dacb7a4fefd358ba7ee709b1bd659c13f7ec69f06120772af7232529264dc2a04c3b44db46b9d511f7882907343a826df953365388e8710542f06d058a74dc87ab0eb3a9a3010001 \\xbc4569ec9d1fe323fe58797d2701dafcff0900631260df3135cf1ae715c6893509cc3a029e053dbebb56e1abe14b7ff8e68829e06d538781136beeb23e64370b 1663072489000000 1663677289000000 1726749289000000 1821357289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-285 \\xca8aff94b6ecb5280569424dcd814f11f5113648c9dc975f41ad70236296af86d0a566186e4122b04510b472030976a255231d706e904d041b50fcfeb5ed445f 1 0 \\x000000010000000000800003ddb9a0757d870be2d32291cef3d3982669525c598180e13e2b4e1c9cd8a280cab4313ec107306a1dce814411dd0d1bf3a5e46d7d91d8abca8cc309d937ed93d183225373631a0095175625c48d2a95f500d65e9ca0273acdd29525281d5844eb0e1e1950bd4d42fa75ad2a9545953397dbb28582e0e327e8ff97113b0f7d5e6b010001 \\xed9f5a1f6f15ec597ca5b04268ba88ec8e20ba0954f4fead56558d6e38af0ead2af2c78a3239d3bacba94103b49d951fa380d680f0c4e87f97affbda69afae0a 1676975989000000 1677580789000000 1740652789000000 1835260789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-286 \\xca868414ace07b78a75062f0c38384dbe6aa9e681be5d46d47eda5b031ee39807664aab40afa487bd55bb8a50d527eae0ef2c56f936a8ca6203b1c9faf8d1184 1 0 \\x000000010000000000800003cd629607f6aa79b5b11e67258c4d1d9aae013463b7b6d7a5932ba60940e632b730cc272ed95197c0afc18a935f89c3ae82faf036710401491c00f480a5078ffd51923412961d3038fbe87a5d13889e97c9cd7b397d55e1a55c5fc1e015831653ed8e46e42debf542e7a35daa3cc8bc8e0360562c585395b2b505f926ac742989010001 \\xf4c918eb88ee252863b57ee8bc8353837d631174f70b204a5e40fb015eb4e4cd57df9a1881e0802077164a56a9b4d253c962241d8f3d29229ed45ad1f17a3a02 1674557989000000 1675162789000000 1738234789000000 1832842789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-287 \\xce865bbae90e33817dbfa5e442046eca0593bb7ece5a4349009cb821f20c6820f5091f7c4e05f5ec5bb61e6e24efd9c9007bf065bd13222af6b4df9ddb66304f 1 0 \\x000000010000000000800003bd97945ecd58a318b100a56b70cea8d0b363089d7d431141c17d15ba0351be6cc6d0ad89dcaa331cc18987f7b08b03b50ea5d2fde01b5d58c8264495d47bbd33d80bdaa1bbe5e4450c0f0769d0c8d865f842a9e6376bc02a59dc08ac011c5286a50905baab5299f7c2dba60cfbe7a51c022081a300e90d9c87ae0210cf742441010001 \\xff9473c124a45712f8a2528671cfef8513dd0453c6de3cf40aae881c9c5018c0436361b3d38792396d2005807619c0cdd0dee1d3bc0e276ad444ae137133b302 1667908489000000 1668513289000000 1731585289000000 1826193289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-288 \\xcfc6fd9d56a9a8a13f6766985e35eab85c2e171fd6c85d206d93289a9fea1e3308d748238a43348766d0376ea886067cade557dea6a1c2d2167fe271de47cd34 1 0 \\x000000010000000000800003ba311aff1f2e83c97202a0e0f2bd42228170ca549afbafa8a3b34a992338fcbb2cb8e42b630b9347c0bc17657a5aa05811124763a4ad5268f2162d4c10227ec1198edb50c3b825d48798a2aadba2371e09654cbd4da448e84151d5663ca32395dfb17651375172b5b9c193f13fddc2ac842d6324e071fa222d58ecfd6baf87c3010001 \\x0a33573a248179208c0f2c4c8a68096ffb08d12b537269a651f4a2216a679c4b9cbb66467d64b65ac9182da222a4e876072fae381c9490ff50fc0178786c810c 1686043489000000 1686648289000000 1749720289000000 1844328289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-289 \\xd0fe2f7cde9718c5040525736b47fa40665305fd591adc53974732a4d8230c59c6cb06ce17e50f0b9f6e9ed1818492c40305891bb6ad1612385f5aa06dca9417 1 0 \\x000000010000000000800003d4f45c65dd117972b4507f7cc56ad5f784cf5061327ef47109f57bb5ab1508ae4c71b7cc7637580640b0d249448000c9f78f823802db8178da43c5e14000bba07ecba010a448f6c0c7a7bd4a973e4e536eaa6ba8d93177439766253ef583dd087d9aeff4e3d7e15adf6531c3993915d93056f485537a836ced0547d8d482f6dd010001 \\x7605fbd01bb42ff1d9a915b4677cdc16e9eafd83085ec64f068b1f300d573f54f4d1e728db74c93f87768989e7c9de6320de8af169104cf09f782b1f3d60e70a 1684834489000000 1685439289000000 1748511289000000 1843119289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-290 \\xd4d6d2542e02edc832b08c1544447733fca976b26092ccd5ce235241656a519fba52c81d6a363a139f7816b3f04933b51e43c5d3c7a40adabea36256ef49c1be 1 0 \\x0000000100000000008000039a1a8ae91db2c42c0344bc523e1a93065a5a2ad0060b7c711ab2d7a9320b43126d88ad708b9ac6fb629012fa26947fd5efb010187ba92e0ced4d0e57dfc701adb0bd7caee6ff2bb3bf813edcb558841b22a3ed36fa995d66d12ba4c8191b764827e736794325f2741dd4573c05693df8145eb369b891483a9c2e3cd75b0aadb7010001 \\x40d27ea22166770c65d18da8e0cfb3f623d339f0d9c785fa5a5a9b14c8386bb4af30b852bcc94462e23551bb4cd5b5a3db534695712cd2972021e3c3d8b50708 1669117489000000 1669722289000000 1732794289000000 1827402289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-291 \\xd7a6ddd11169b72d249b5998116bd056703b32427b9197dce447665487556193f352ef7bb4a8dd9ecf9076a9c79302b11740916bd7f50d1c5e2abfb56248353e 1 0 \\x000000010000000000800003b7f05fbf4e3a3f30b695ff187859414e72c5c23629cd190d600887cb8c4f46bfe72d3bae50a7832f90e92db8e53b9da744afb91f4aa31bdfcc4bcd65d39a67e44fbca6b4469ae298b8371e18ac4748ca32eca1df5d6c9b04bb9e9d49ed023a115d88e4e68b8cafce6be581a8f2f7b8ecafd1f2c4eea5ec3aa87b5c64d8b69c43010001 \\xb6eb724bb2a948dece9aedc3ec42dbae5326096b70d509763a82b1bb36a0e963298a03e8c8b0ab5af32c7759632a3f86a9f46579ff69563d1fa49be8f506690c 1665490489000000 1666095289000000 1729167289000000 1823775289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-292 \\xdc2e4edf3e610cf2b7d1f98cbae924bde003b68090c29a8d43ca226948b344bdd6b3795415423777f420e6643a2c649781264f150728a4f6f64e3053f17e9087 1 0 \\x000000010000000000800003c4ca7ea2db9f8f07070a6b195858ce9a6bada44bce32e211ad7c5c5e31c62bb088dbfb3bde5f84aa53c49820c5fd30a1a77f681a50b57a6597f539378b702f3e63a73b35ce9daa60ea4f3f5fa2540e65d22981e4695107f53d8fb0b8743c67a34a67f9dde3061efe2226fba4612b84da0c7665719ee74bffd1f22a68b13be62f010001 \\xa91faa443b321b2cd736fa8c971315e59ca03f0d5a8e1ab1b7bc8c5095795c0b0ad93f3331de14588d6d7584ff1194594b24f813a0c872a98f3e13a2bf7ddb04 1678184989000000 1678789789000000 1741861789000000 1836469789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-293 \\xe1561456d3b3deab92bbf1d1c4d59d524ef23ab6f33b9fb3f6ab7d80bb9701bef3ea7caab93793b7269cd7ec3e67678fc21c2f3608d7ae2373fa4433a4a65c50 1 0 \\x000000010000000000800003a2c516cb2f85add45fc17c84040e5f003e81a1fbd3d3b3127feb0bbf0f49e64a589ef4b0b121f17a1bc3d2b6720be2bd1e9f140fc2794aba44a3c686087a4824ff1f4ed67d7812fd3239b6f01350e5a8dd2029d75f6122b9597a8d80f0ed4849f45a20cc0e351c0791481bdf24b5556d8838228fbacc7df6a14ab5ef9cc95db5010001 \\x153ee3c3c1066ed55ff7d3f24095d56292f3f0fad1df5568c9db863b227a2ee83069f980929b3a2a494358fec6d660b5aa0a9e123c0765e15fb89ff966b4dd03 1683625489000000 1684230289000000 1747302289000000 1841910289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-294 \\xe36a8feec18a1dc233fce8392761942760db4850d21ca917153acb67ab8652dbe74c3b6c02d96230d2972de2e5b3bf45933a521da152b766fe34cba715eee3fe 1 0 \\x000000010000000000800003ea490b411e6b21ca472e4c029754223480547ca97729e21aec61917875f7608108e84bee4675c2f43f9c9d2e1dff4f6cdaa32981463c678308ec6de8efabf4ce43c0a582a18d8ed9ee6fa8d963bdf3314d27aae0772995c5ddc9921c09d251c9f23d6282ddb9ff2c70c1287ca20506de4b37a8a6cde67dcb1b774e565718355d010001 \\xfc9592d56a4e4256c0028133774b32e6c3ab4768630a09722c5a18ed0e3e0e4a5a5673aab48ac3a423e1d94fcf14390e9de3f2585d544b72b15f0e7e7c14710e 1677580489000000 1678185289000000 1741257289000000 1835865289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-295 \\xe7c27ece2b76e5370f0f8891d7e0811054f4d6a527502fd1f4567be32e87343aafd0b9971a2591636b6919eb015332f7354e429ff90ff5e8eea7d35966f7677c 1 0 \\x000000010000000000800003ba5cd51991cd4ee282d762854c9c98487c765d42d10f47789b94a5df6a61de73b0a06ce2efaeadacf993147056554f508cff4b31823a4970151d4804730a42d21061093aca9a845b9576628776c0d587bef25892d81f044778247c47540ecebb94509efd5fd8fc2ff3c60a1699b23cdb69b32a3b12ced3a955a9859de495bc55010001 \\x35153ef47b809e929962b103ccca7f2a8cf0073c750d2f36ca3fde12972d72baba4999d315f1b8935b95ea692b95b1e1969cfa305be8cd6f1dc39d42a469a70b 1670326489000000 1670931289000000 1734003289000000 1828611289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-296 \\xe8023e53b0e5f9e8ff9de040cdbdce928da4c76cc166cc80684d51d4a6e99c8659974be4d0410a3a8160b4be1ab97b5386dd38bfa19ca06f4de931fdef62eedc 1 0 \\x000000010000000000800003f4caf0c7464b3177861a43331d175a281396e9481b7b6d87e555186888ac6be8210152f6fdbf35f5ecfced4b3f50737551840776394d2dee1c0c421b305c8697516171e0ef025bb615ef4a6e3d6c85f5023b0c461a4777878b08191994004d8534121f71de188177c895ff94663c2ef90e6cfadb6f2efe669cab3de924a05d89010001 \\xb4baf29a5d6f31cf90b6a99302ef112289946c428f06aa1405df8597f33a85dac8125dfedf4dd748a75ee37ea3e7889d54215ce4650158539a1ba0ad94c54702 1684834489000000 1685439289000000 1748511289000000 1843119289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-297 \\xe862b96f1e26607ceedc0b7da59875319add2b86855c5c8ec18595c386aba9984e6c159cc1a0a0ec7e30be19e9cad2c1e93d2384f980d4e489d05f641d4626d1 1 0 \\x0000000100000000008000039e81ac56a1bb4e0ec583e3691e87b968b94c396b7707ef9eed20b452d013c4b46d37852b5c1e29151977e560c73bb8fbc17be52c0aec81bcecf94e18527c9218e89aaa29c1b25a33b89cfae2ab1bcd50845dd12f849371a2e55048ea304b4dda22297f4e237bd8a5bcfc42204ebef70da685d81b199ad1b0379e64d790b58cbf010001 \\x4ece21a978dc30519c44713671d51a7b55b1a1df5426177bfff9efdee748cce8ee06bdcb9ca3ec67fa25265e198734ba6a0983517f72835a7fad8be14847ad05 1664281489000000 1664886289000000 1727958289000000 1822566289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-298 \\xe92e2569cb398be38328a9a71c9af98ed3a8a6bf77e42b253bb83c1e42e19ca1ff8615e891eb8ab219bd81195ed6b4ced86284a87a83a253ac76c39b4c0b7ac7 1 0 \\x000000010000000000800003d22798301ecc962e28bbd935c7c9613bd0060c72889f3cbf9c7ce231535095ce598c01358847cebcf055f14424f36343059f31b583c254ad949454fc88df5ab3c269c246cc597d2631395bc3a2c07bc86428f0c0485c660e7f55dbc04b141da6ebd62ab7bbff5887e111e11cef5e545f48dffd62a86cfccacb8722532c2d5a19010001 \\xaa827048d7a4444b2497ce69999906ceab9600a8928a2fbdd3cb2651e7bc4ee8950e2a77ff002e512e5b6582e5e8bc7cae8b1c2dad3174c7b1b22e9cb4066c0c 1663072489000000 1663677289000000 1726749289000000 1821357289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-299 \\xf07ace7fd29e500cc983339c742fac67e23eddc781411d09333faa7093484e3f5414197fa6462202425aa0f20f08626c07741a4a25a9aeb38220b186a8c1d5a2 1 0 \\x000000010000000000800003a87abea5970047bf2c6de511b6973563945cf47eb0bde47bbb457bba97c1b338005b1dda6967b3b9b72c60ed5e15c440d3a02de1a11606b74ff279866093c27ada6d3afa02e70ebe4076352a2a2e6010244bff27a48b2dbb86743df719fdbecc35c4da4e2cf1e924c5be3b00ce90d567f25699e58f1be6d778c8d8f92c14c733010001 \\x782d8820dc6b8a1a5c4bda70ceb86bc3446d17e762850198edf7c640f4cc0507419c1e3fe244ec3af18f8f9ea14b5613b4826d02e793dbbd05ec721e0fbe0203 1675766989000000 1676371789000000 1739443789000000 1834051789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-300 \\xf10a33d8ba0e514710941cfc2810e45ff85b7e2eb03b3972a0afac0bd19fa84c3c3e74571c6c3b3c753e885fe4a81028b602bae829b3963a26fea49a6c02d45d 1 0 \\x000000010000000000800003c069e11460b49cb5ee581d5ee1a43a1c13716dcfcb37326c687465470ff32f59ed84883dd216b00cd0049c43ccac528f2027c0999a08a1c0ef49811336dbaaba436bc22b2787ed856230d8fab931b23bb4557cd540b52623ae07721916b700995db7b6b12003f1652b8b893758d9509f7ee9a8e30bf5a99a1887a40ff8d168b1010001 \\x6681ca5950248917a3537fd0862296b0fd5003f8dcd7906856bbba42548f1805e35d85f9e50cb8e252dfe62d143d81a88db263d06c0b4cbb7736326a231c9904 1691483989000000 1692088789000000 1755160789000000 1849768789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-301 \\xf5a2720f96c8af1762beff543eafa0a33febb3888fae8ae28affc1f6f34feca92a94d267cbd951ec039b24785e6b8e415450dd7bca4c37f87a5a668f02e5ae96 1 0 \\x000000010000000000800003c4e65b2a5417cb623059ea93eff95cbd18860c92d7052784bb32d11d861280b478589950fa660313aed053ab296f1b0bb9f026b5783baebf9b25409c640b24e465b0fb72d6b3d804895f14708a7a87ef4226c38cd2dc1d680ddf06801519f5050e5c417e1ff4d89adec83073ec1c2ed62ec0d0dbd03cbe4523904512db3aff53010001 \\x5397e59448ca57fdb624206569816242d33ec325ebdd2b6bdc62ccc0404cefe59fd7115bdc0f79033e3a0a056fde3a55d93c3058062d7fc32b0a5f63b144510f 1675766989000000 1676371789000000 1739443789000000 1834051789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-302 \\xfc2e7628db79eae8624cc0ef2a7e03bb29ee8c9a9faf456b3fa98e51dac8f634c9f2d8cbb0423529dee70116cb80fc732522503f61508e8fe1273f64cf96f31f 1 0 \\x000000010000000000800003bcdd7edd49d8a0aea28796bd2b9f5470e6a0a565fbb7e27fb9b017aa1a3feeb8edc24c3ab83989ea0e9b0a2e7348ce18d935d37589e70e1d9ed8c0d629293c31e21bc9d6f1fad99a0cb8514724b5e1bbad787fa344557d0bbd06c29106a744edf07fe60046f3dbca09c1d4a29dcc1b8d5ca9d9848e45fa62884ac3630961eff1010001 \\x52a62ca19702ca2a81b8f8b69b53ed4166b9042047904fff664507967d23c35989a8f6f35eedec62d4eb9ebb8bbd484a36d5ce28c02013eb5592685abfa6900a 1678789489000000 1679394289000000 1742466289000000 1837074289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-303 \\xffe2a49abae85ed33dbbdf591a7c8e2ef848fab86e3c68ef4c7f25549a686d5b759ee1ff268f563a3bb3f487aed66f6f524d1998eb32aab65addb0213272b2a4 1 0 \\x000000010000000000800003aa4a26d845ececfad7cbc52177b0ee80a89d1fb01ce9118e4e6e662c19b7e689bc5dcbd6864fdac03ed2b62a403a9638a689d488f88b138fe3d7c698705f1095700ead65164c71d04557a735d01bb5b43b5dd85f3b5ef5b1865d554edfe46826379251c5faa9346b37d64afd367329944985465790c970d347d1f3f450c23535010001 \\xc9c2cf57dfb463f110f6e813dd789e8d7540e317c5d15e3cba947ef0858c04ab4d4743f1b948fd15f9dbfc2456b949e299482e00b2595c467c74b3efbfbca10d 1683625489000000 1684230289000000 1747302289000000 1841910289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-304 \\x008fed598bff6fd35526be5b08e3893755e36d205411b5f6b4083f840520241260ab83b042f4e1ad900a8ad1bd3f11448ed461db3134cd7b850d41cd5f23496a 1 0 \\x000000010000000000800003e239c89748c5ceeab4746dcbb98f3d1388041cb8c904a34805fa33d4888b9034b5dadcced7000c2bc05fb313cc3669e5be333874526faa6e0bf9e1d0ca70c3e7a01c89638ca135fbaeaa58dcc062f6f91f3dd6dadb09b0334d99cc75cfc1c7f693001f7c4e9513869374ab97a175d7f755c0d5c3c60b915c9ef60d76777f1081010001 \\x218ac5cb420c9a4709f40c7e393adb63bcc3610e7654d3cb7bcd30ff2078dab336333f305f8de66e421ea70d74ecfe8152ed757cd2443cfeeb4467b28efdb400 1675162489000000 1675767289000000 1738839289000000 1833447289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-305 \\x05ffe69e3d1f484481cae81b0b57e46e537e7b50f16153b3944a3a86e22ab3a0f65d670584b92f6b974f87ea4dc4fae7a379dc73034421fa9b2eace8c55690b8 1 0 \\x000000010000000000800003ba933f21f00b7fb02462ae66d30fcc40e26fff31f483dcb69fdaa4ade6a7048d35ef79af77ee58031883c7d3635312b5865e5848b1f3ed1980bbc9b4c19a2f022a6a4053a2861c456219519a67105d464a97ee3d72bc676224fb33ec803cfe6ca2c766dbf05c99a31f093b385b572e459a5c15f6396737d6ddc2e87284ae407f010001 \\x55d76274ba0a0bdb79ac5f34a7b91bd38060755c2b8272bbd7635020b5d029598dd3333fee8b228766d2317a01217cf39cf9a52a7b79a8fc02de88d507675800 1676975989000000 1677580789000000 1740652789000000 1835260789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-306 \\x074fbedb64500118fb1988e332f686165e73095da6e82cced085f87c5daa1931f40dbde3481a236262dcfb2c98cfa0b3ddce3978a0eed68a5b3cb2f353bcad11 1 0 \\x000000010000000000800003a44cc67202ed6139c31b0cafa6a93e09b9d7fd519d38424fc5bd624ae9b29b3cc6b3dce5cf8ff2ca1837ee4387a9f03f97428d43b72abc8726ab140d974c3af735fab6fe8ee3937ca38eac24c971198739091306023cf436c1e917e059f9349d13f8358c21990de6e4acc1c0431e8096a458227793d8e9748d82aed18bbb24cb010001 \\x2c6317090500ab3f09dadf17fc2a3d490e579474a8b9ab9d5c1a6f148a3974b27b2cccedc20e1163ee74a0ae5151fa5860c1356b891155d013d495d2c2d7d70e 1670326489000000 1670931289000000 1734003289000000 1828611289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-307 \\x070390e76f6e4193db745ee6763a20c39944ed474218ea0432f0281473381f162ed5dedc3406157ea5eb9b2893dac6ada7a7d6097e80b3d9e78f07f12a7346cd 1 0 \\x000000010000000000800003d136f8bd85a17fa1369daf370a7872d54d234bc7247869d8b1c2194e9bd51cf01e0b1c16abee297b170b357247d03e7c5bfa853be4ceeccb9df297dcf544bf269a66afcccf94108b7469c30ebe72df7c34e0824de204dd878f062b7153553a49880642781ed25ede9d6eeb2429ad49bafde5dadf224da85e95912206dce6871f010001 \\x0fc4865da524fbe7f6958710c0b6137072dfb5c5649ef22e0c1c899ac8d6aaf1354f2574110cee1fd8e978b465d3240250449a3e93a538e292fcdae06059b507 1692088489000000 1692693289000000 1755765289000000 1850373289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-308 \\x0eefa11161020271313e18d4cff1a795219a57be9d08de859a796c72bc439242abfac770de1c96bc191e3ad27f16db2c8ed3f81491669c3f60f40cc8fb3b6e2f 1 0 \\x000000010000000000800003d87f8e87d2d045dcc193d42800f9c71afbcb720a7ed357cd3a7ed59aaddaa4b7fcb3dff1ae1d40d209864fa037b159284e036389ad1db55582ec3d0954c9cbaa67c236c00ca550db8036bf96700ef75efc0a7106f07e4fc8aa17bbf9e8a53e78b0d1edf7f0863078c06fd28c1a48da1f8d634eb75c2b90f4cf0421594fa46033010001 \\xc435e59806b1af11a10b9104ebf87f3e7ad1d71557cbad83e053da611220e61c5ce4fbd565fb9cfd23f6aff94ae43f4bb2e85d78c6c76c1a392386053e025b08 1686043489000000 1686648289000000 1749720289000000 1844328289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-309 \\x0f7b605468c9fcc30f5fc2ee623a173f9b7d8952b295a3e93fc97be0e2bafeec916e1507f4d30743f5ca3376be560f1b565e2c1cc0388bf4806fda1b843f68c9 1 0 \\x0000000100000000008000039e1f83aae790d1525fc17a9b9a333276e6c2a0af5d21036056dce86b46c776bab0a571191f2d8d96f0ed0ef5c0e364d8b1dd80419967052763f81c71331770410abfa9e3f6285f52428c308dcbcee4f4decc6a32fb0f9c559fef5d888bea39ad08ec3abf272dd6a64e9245f1e62b6722d806cdd654c2e7544d3a3102522284a9010001 \\x8aa93a9bbe49d109e8c6b72ef639c226c4389fc57832d335c4a0d1ca137076f6d92176e33b40b07208a21bacfd1eaae743931a50cec5ce7b18e0f6448af3800e 1684229989000000 1684834789000000 1747906789000000 1842514789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-310 \\x0f5bea0749aeaf19b288797680946fe64351e03b09a2b26c2c92cfb54072af58f2a25311b340655edb5524c2ca3202a7241d68aca2fdffbdcf40183ac29b6718 1 0 \\x000000010000000000800003b206ebbdc3cc31b458bf6876b0577a4985e454d3a42ddf674ecb394d53e219b87855be48d0aec8ca2433951486d2609d7009e75b8754dd27031c43cc431516d555a8b5feeaea35720c2712f642817b94c0d7ee5a9eaeab5438059f9bfc9e9cc2de3da05a2519f47638d0dad6bd868f19879b68adc6745be00b4dc028c86bfa7b010001 \\xf371bb3a3b84a9c4e873a2fe9e3ac61946157e0b356695dc19a896541984a1f979dae82f3143588f7dc3cc50f09a0ba68846fdfdc4ceacf389ec4cf5ebf0e505 1682416489000000 1683021289000000 1746093289000000 1840701289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-311 \\x1073c1ccff7be61507a48b9ee21ae0dcf2dfbcec0a90bb4a692884d4388ace665335d64632ba3beda2b1c243f4bb8f88417dd3c22c6c39970707136bf0e1f359 1 0 \\x000000010000000000800003c0a87230a5247a4c9696fb69f95fc8fe004c8f4d1ba8e0bc581525ca6ae45ddc854300b93e909f45f9a84a3851be79ee4f22a781e0dc4471f34e1cfceff3baecf7eef2a30c1c305aab0ace47ef7c3ed0030da730bcade15d417e64b339b575143fdc4a56f52baeef7cdcbee7eba5032e59ea63e69f7552ff717f4fa314718407010001 \\xb8d4ecade075e17ceca177b4dcfdf6f130c1fb403dfba97f6e61d39935230e17faaa6a6fe8362f61f4ebddf2ae3ded24d5484fd330b184d11a78a494f5c9ae02 1679998489000000 1680603289000000 1743675289000000 1838283289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-312 \\x12bb0f26f60bfa1e4c1593496de80bc010bbfc950ad2d6d1b1afe0d7ae004a900eab2cbe51ba74468078fcfa8488ae66ed513ff0c72f28eba0195e89a11d7d11 1 0 \\x000000010000000000800003bedef47109112e29ca5a08c096769b8ca315f2bfe87b9f70fc9165e2676ec9e96908b3ec0b10ba09510e81e6ee8ffa6854c23826a87bc02389ea3e82478bca6e8720abe011a04b4fed63ff43b8d260f88ae43a3f65ab55733ee5c3928428fa94f6fe8ac0267138743fd3567993a0051490e75807154f6f6fb1d5f8a2aa35ffcf010001 \\x07376c9ac1b08758dcec9d8d006ad4a5a7911ee8a4927e1b54b316193da588295ee955e36925878c59140dce466d41e6bc30a1868d1fcb3de68e7e6a46065004 1672139989000000 1672744789000000 1735816789000000 1830424789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-313 \\x178b9b541ce3ff4833c1931c074433837df3345ce07023ac8c0f192947b945b89cd883c4964a7f7410e2ca37e453ab4b4ebc38d303fd1bbb9f2b4575203a850c 1 0 \\x000000010000000000800003e03198ec0979f56d9cf35b339512a7a522c1884b6a141144b84f4cb1e2790b0599d431c43bf06b4ee73d39f7aaaeb2b7c4c6b9612edde53cdbe3dbb367f3237270e2bdeea9d70f8a49138cdd7c783a08bb0085f6fad595fe65427ff19587a460109c4ab9bb4e0060c671c61f7d48210485bf2b9afa538df491c83931c1a77329010001 \\x6e230fb4dd454b41925cd0145e24dbb2a9c3256203c65bf0b8e94742d15af53ac7d008f8ab8bffe7375fd7ed6181d7f75ba06b6c6b6753c1916b9f3ec5a36a08 1690879489000000 1691484289000000 1754556289000000 1849164289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-314 \\x1dcbc28777322f4d1e1ccbb6ae70214af876d26fe72a2fe87452efcee4b903a91ea2fc654fb0c1c01ff51b577ecdd7b7d6c8751a908824c9dfded3d71e82d215 1 0 \\x000000010000000000800003bbc4b8c14e1ae6f0c99f33ff4c7848d8341dcebbfed6815ac9c1c530463c8ccc882d6606728e135af5132437ba609078df1dcda5ec343dce22c9941b26b9b91f2e07106e5301bcc344050d2c542b0696ad1b1d651505ccdd3c0f7579078232b29fb74ee24910cf8a1ba15f8a83029502d7f4a83672452fa629c6d5a8446b8065010001 \\x45703a59fe749323b132b10f91b18b3a15238ede33d80b3269560b84064cd5dd245771b69123ee1adf4d7b9cd4da6fc48d7f2478c63b184467004f3abd238305 1671535489000000 1672140289000000 1735212289000000 1829820289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-315 \\x1f17101ce49a7844f520bdc75fea24f62386a9a06c7cd5d08f9408f93ddacf41ee133abd289e95ff1efe586944b2b475be89ccce7485091e13c2da9023d24dc0 1 0 \\x000000010000000000800003c05ae886b306213421869214982a42187997acb1838762416bacb02005f05339ff76873f41405dfe6872d712450df6e1cb2d03e03b38cef5251b26001256400a51e03174d14a713a1ec88833cc18d435429f976336ad683417afe0111f12c692dda91274290eff0b73074f6939782d77564ece7da6004ca6f86f9af2f61c72bb010001 \\x6d4962a92f47318de2e4a867799d6410ab4e78630943968be43c66432db90015175d15c0a87b5b0214c8a9dc1cf2c519a477fd1da47e5cbf1ab24116881e1d06 1667908489000000 1668513289000000 1731585289000000 1826193289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-316 \\x2027469fcbbc95e40d0df7ae4403470f3abb58ff58f94b2adb69d5991434a682e521510ca20605d46ae815fb531ac263ff6a0345c119314037e873022d7d1404 1 0 \\x000000010000000000800003d7c02074e5f1cb9895cd5bc3eeed0f7de894c3f76e19e934fc4ede448c41466e22367a7f84504ef8d2c9fcb8295cde9a17b2201f63b185d47fefc4490ac7cdbe84599a8a1146efd6a1e6b28d09bef3a7c42ea6792b5eb6136817c497453583b30fb1b2f94bf3470be99fec0f89a942672a289db6146509b1d12ffebf605cabb5010001 \\xcda9cc3e0f254b1b1217a6eacc624f462f73d4eee07409d0c25765a601ea26a138faa81442188b57ee435f179ad0acf5aa357fcf5cd418da04a065762269ca09 1664281489000000 1664886289000000 1727958289000000 1822566289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-317 \\x20e307c8416a955bf1341972acf0a670da2b6ee32eb75441cfb47e0e6914dd511b048068a0c571d13060b50e34673b4a6972474b8d689170aab8a1c7203541d4 1 0 \\x000000010000000000800003cae1dc3b2c6228012fda440e0b1314e27a2f62c8225aa0f6da263ba8d169af473401c70ab1323d00eee3b0b87a46a2f17483302c123812d65d31f573c581108447402b36e75edcd734e59e75b66c19b073e4129c6c37c4fea53c9a0287a8f66f75fa74916e3311802aeca64d6a57afaee612d64ac214c265d126d4d953cb91c3010001 \\x59b9490a9f5fb805f2050bd919b63a13438d40493b1d9c75b511a14bc14f0fba903847a940b29be62bbb4595de8d3afa3042882ee989ca9088a95d5b8f4ba80b 1686043489000000 1686648289000000 1749720289000000 1844328289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-318 \\x248bec0e9ae357ea23467c45e54fb0dbfbf4ae3ac3ca352bf8c308848af96525b0a579b7a077f6ca70fe657489f660e2c1afe80657e405c2c060c504fc17a70c 1 0 \\x000000010000000000800003bb6f83c160a360aac75d9d4e517931965dc73e1c2b5edb3d07f4dd34ada1a9784312d9f1946fbeafe58532a681d8c89428be852c5f367563f2f7bf28bc31d8b12b8502f53c4ed95837734cb5d13da3bf8d66f7d631bc1e7351e237a41ffe55724ec45d3b5feb312b2acb1147c9d548ff0596fd45596ce56de10cde5048f8513f010001 \\x7565f68ac11f6e5610e4c4db9265c359c9d76b5f3b10ebe7b8a8d825ec74d922f1f1d61ea2237f765d1e92433435ce8c19e3699423f7d8a3e611745e9682d50b 1663676989000000 1664281789000000 1727353789000000 1821961789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-319 \\x25f7d6eeed4c65e4cb17f11a8639bc6725fc42caeed70c17decb91ba5e36f5c0c396ca3aef5f03e63d46a619a6495741a4c0e433f7c2f20af1c1f07059b170e3 1 0 \\x000000010000000000800003dbbeafe80385753eb23a05b9e6885421991e4321a1e495234410fc1e095c6026ecc0994a36e7e02f4fcdf2a2023b5ce99b86cbc4e995fe5799849060a4eb283f0466ebb478929c24c85817f4c2d2b6166c64a29c089f64cadddf56a4218385597ad535ef5a7b16a4720c4a6588debbcdc3ced366ccbcad47b012f99735d2d2b9010001 \\x141268241612948b97087fa76e7fdad1788ac87374014263a919ee854d4bee58f963585088838de3b99fb2c3a6c3d42e28e1d58f32a5f3565ef34fceb3da0909 1667303989000000 1667908789000000 1730980789000000 1825588789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-320 \\x26eb9b4b25b12842b9a721704ccf328e91856fb18963f0b928be0b11bdf858854687ff6b05c335643cac68b3a6e16adca83c78946e770496779a17ad2d8da689 1 0 \\x000000010000000000800003cb780e1d51e269de7688f9c1e083346231d067129d58c424f3ff04d9d3a5e5b29100d8bd6c3118a10abf2c4f2a257ee29451a74201d48966ff11cf4d6bf3257077383a72a9b34ee6dff7368c01508f41445f4fa560b7642ed5beb74b5f2660f0ccdc3b686af4c6af76900d61bfc62057cf7948cbff3f5d2b472cf53beab59f41010001 \\xbbc6afd7a84391bd4b7ddf45c03550a2da3ea7f380c64964196ea9a8af329447187959cbc8860ca471657eadb3110558450183ca80592879b23c4881099e250c 1690274989000000 1690879789000000 1753951789000000 1848559789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-321 \\x292b963b73efaf83b5d35a5e21cddbe238fd52216e9d6d5334ce01bb20d4a3ab88e02ad2fd00068a2502c77d042fff7aed422adf5009b2cb60954270cf4aa0e9 1 0 \\x000000010000000000800003c54e2d5d8b7ebed5417cef6fe1b29ca3fc739116fd70206139f8d27bb6de985dfc8538464aca402bbead467ac8fa20fc2aecfd72872eb241dc964c4833ccb2f37c98fd6fabd51dd71dc1c1925dd9b9665d97f7859157b663f4cc9a5c14d27e6b5470b376e25ff3e917b56aef36eef2af9189e0d7da7c3857ad8df831a7709e01010001 \\x4f9a08e1fe7ee416f8409843df3128f5f8b24fc08f3322f4aeedcc6d9623403ebd7391ed60cd29fdde11ffcf5b0086f1f01e01d98c94a36a9eb1a130ccb6090c 1690274989000000 1690879789000000 1753951789000000 1848559789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-322 \\x2a4ff1e6ba8e630a90d8e558540f2c4a8d341bfe421c3237ed47d86f2778eacbbd7a56f07fdcd9f6acbf21a87dad6eab6a64de51325f8b663494637de8778155 1 0 \\x000000010000000000800003cdf7e6d6d5845115c049b151210e9cf401bf9c744e3c93abb23f9935f45981158b1d64801d417e60ab49b8c4e784751267f7cdd792c565f53b15f5a02620a8b447619e93b7daa461d46ffdf4751ab95fccfb1afd89bdc275dab64c6f28c4092bc55de13c764306d069f8d8b765c17aa0d0e3255806194b8c2c6e3fe226fb3a49010001 \\x0e4bc2844b2df348f3edf9413ca380f5138e2290e64fe6281671bad37a2e8c37facff58c2c898e3e9b15d312b847e2cd72774e339a1dbcd29a2b285a99f2cf03 1680602989000000 1681207789000000 1744279789000000 1838887789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-323 \\x2cbbdfc75d73223b861ac701c62ba8f89c59106e5c45fb8a885eceba1606d4dfd2a4f278f4b45b859324c557cd72d43203c467d0bd50be6b07435d82f59e1df5 1 0 \\x000000010000000000800003ceb3d91dbd8881030fdc3b040a745e48756b27d57054c9ff8b47af9df2cf1f999d87d46cd4a6e5453cc9c748f40839595228009a6925b316abbc8d8f470a16a2f6e0c8e67377cfd64d1762d4ecec64ddea7267f4f9696f1ba4d3b2438eea0a4cb5a37e50784abab3d93f85f5b2f08f843d418afa978ee92d6cc6a17a31152a6d010001 \\x6045d2a2f1384ca92f33236a7b2713d6441b744a6369649d120dbd9688f216a5f4786e39a13460eb1c0a61720b76b99a0fcbe9e0e1c8c668e34a5da1ebd63207 1676371489000000 1676976289000000 1740048289000000 1834656289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-324 \\x2ce748c2573eda3430b501efd2ee6218b2f1b23c7cdc384f6f20b88a9f96b622aeff6b5b102667b3762feda3bec480eb9cd0f7b779718a9e357b3eaccbbc4ea8 1 0 \\x000000010000000000800003cecda04bbb33331420cbd37799695c0eccf1bcb06685218acba943a04c6343522510a096672fa69799d852d713bb2d72acba4f401390a4185ec37f818a4a90208fd658f04267b587d57a3bb2c3d73fe182110e5bfd71be7af7c26445ebe1c5d1c7f07e5cee8369f837cc8af61b5107c087c86108eec19cf12c29973107952469010001 \\x3814ef79bcb3bbe6c2e406bc30cef90e63a70ddfe53cd117ff695e8a9bcb2ac81b2bdc2d0b482308ab4ccb971b6326eadbf2af732e865c1c6235571a1ab45b00 1689065989000000 1689670789000000 1752742789000000 1847350789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-325 \\x305710539f2a34e4f85eaafece7923d31e436756590918e5bad4bbb61bd92d76469520621c88a8d369b4ccbd367f1323ae4039df7d36fd852230fe7293aa0e74 1 0 \\x000000010000000000800003f7fa4ae789a6d4eae617100ddc1374509d6aa3229e83bffd03f31a041870b71f3d24e3dbc77d7b795315418e40ec313b6bdbdb1a991323bf526baae9709ec58625d5128377b383a03b7e00796b5ba13147c4d21749ce186a41897f7f3fd6457e554f82b39e70c9572c7f0782d452a139820a1998e7196f7097065fd29e1cec03010001 \\xf9d9b0adb4ae8b062b0a3ea0b637955076d83eda6f40246e1cc457b5432b2f1b70a1b0ff1a0a339ac3bcb86141ad0dc48f54f1a5dc227bbf50dcb2215251e901 1665490489000000 1666095289000000 1729167289000000 1823775289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-326 \\x33538c0358c8f605b04dfd1fbd5d9901be20607a8074a41a2a0a35e03086469a77c7f77eebc0024d8206401937f1a6fb1214219b10c66f31d8dc050ce82c72ba 1 0 \\x000000010000000000800003db7077896f7fd91e851c491d2050e5cceed074cb2cd4d39b89af3948aff69f5d7e8b5cc0b08dabd6a80768c249ac2ed9b9ead235dd4783e3450016b9aabe2014666258e6778b48d86cbc678090e4cad0f144c86df511f7daa582b22949b993c35d825cf3a68bfcecc07fb63f1530cfe33922cf1f632c40abd3a629c2e6fb9759010001 \\x7d4015be77f55234318f5eb0783f8a5a99fab075315fff9e221d00f2d318676035dd6ad3a1cc451b8d51edcedeba703038f7bba3c8c3476fb9b291fb7c1de20b 1690274989000000 1690879789000000 1753951789000000 1848559789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-327 \\x36d35c1bb739a355d97a7394056723988e3cd30013a5d45d2d9776e6989deeabed317e401ff42045b05471e50c8dc2488445aec826efee24e0a06980d50e1577 1 0 \\x000000010000000000800003c8e15f95627bc25884afe2e58a483c9534573c6bf4d9762e62053aba6eabc7cb145de15261df72210af7409abb7836c5648564693724aeb47f029b66f4e4f52ed70eb3805bfec53ac05f159ebb8a48f37a113157c571aa4e17832b75df7387eb73ca24cbf01963fe38d35a73ec1a7728562c78dc15c96d14a10ba330c93f4f63010001 \\x5c29badb3e5732a7be171adec24d86724eeebe8522b41617394fbcc352ea14bb51297e592b162809652490dd0a9da118a3df0fefca8ff54d6797614dedad7802 1690879489000000 1691484289000000 1754556289000000 1849164289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-328 \\x36f78008eccee1b1eb07d95089718f8f9f223708025729ae2fd1b46407f40abfdd70374c271b17fb56c32cae20adb6f4b2fc0fa2eff8582ec93a7d865f1d301f 1 0 \\x000000010000000000800003bd118dd021e176b7b3d79fc7bf9d09c5f388d849ded1c19f28312a44cedc7e14ed7a3bcb0768f9f1e2948ecbf9654b4df54be315cf533683374fcf08a6cfa82665406af1416cb5758c84ee47eeb736ff1c6004fcf8366cb2976f5c6a582043b6761b7022ff0b3a5dd91c81ae2d4c101ead14ba6aa7274d82853b8bc181e95427010001 \\xd5f1c9049e0e81f793294d9325a90b870f6a8200cd3570c220e9a32379eeb447ea20f7bde131a850ef8a8cfba084ef4e229570e13fc86f05d601d1808fb6a203 1667303989000000 1667908789000000 1730980789000000 1825588789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-329 \\x3bc74614ed7fb5ee1baf55a03a7143fa003471ab14dc586cbd296bf7ec98b31faa00b438835c728c7f54754be75bb0fbf4b956ae1691980aa193744293fc30fb 1 0 \\x000000010000000000800003a3a0f59fcf2727cbde7c100acf559664385cc07afcbcf49ff2a180c37880b8450a7bbc7a4e3502b1df52e7794f58704ce8749b6faf1d6df446004b1f4c1e920e149c34bf10913752e8cfa2bc1eac113d1699a27cfa0154885d7e59d6f1a3b5fd2b79ad71b8a4a84ae1d9220947ca4378219a26c898ae1c79625631776dfb91cf010001 \\x8f384b4b5fe60e0f6491dd621b60ae8ffa2f4a4cb58811cbe8639b0e23425ed8d792817f6dd84176ffdf69e3c9405898b231c8eb663259fb9678f8d9290e9500 1661258989000000 1661863789000000 1724935789000000 1819543789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-330 \\x3ce3dd08b0287d6c26bc153f8f4bc4cb6305f0b91675d48b1cc62be3fb50d4cc2261a50cce5b48c810e54c49a7ee8032b165c0552edb6d0e41ec68aa59c51d2e 1 0 \\x000000010000000000800003de34ec1871b54b04fbae3d9efd628ec0169c7780cae39a58bf7a0d353306e54bdfe4a4dcb12a0b66292431af62a4149422eef825bb0396c85e383b955900fddfd7acd86f3d6bdcff3656c7b46b20c804a3aabdf739072b15d9f5607749d17c0d625b521b2fe7cc8e6fdbb9ea48754ca6e534557441b0800f421b26811a5fbee3010001 \\xd45aa21408a27ce59ced5b153dc09b83ce9780a3ceabc12f791894701cb4500f369f585be911410b410402aec56973b2b92af25a52389d32a0af348d44b8bf02 1670930989000000 1671535789000000 1734607789000000 1829215789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-331 \\x3cb7e1d9f7f5e6f482179670ef63ec0a2bcd78bf32bf87db214b707eb77fd76e1b8fb4323c77f3ea20e1dcc6264b7a911292f46e7868ed7ae05aea73390a31e9 1 0 \\x0000000100000000008000039d18049fd9ca665cb996b923ae6bc8ae7515b3419532e9e93271b37f4e9dca37a15bb6d31ef4a244af2ddc434639aad6d7f460e1699ebdb1b8a2764121caa59cc4bdfddcd77cd7e84cc4db32316ed6e087b7422136fd20decd3a23616f740089f2578bf581375eca831f886ca378f93bb4b7c72c1ae7356bf4937c5a10fac1f1010001 \\x89f39e1e2b95b163bd858cd65be5e2b3f6ac60ae1c41685bfea3754a67f6095790eb81d4c96401226f4ff7e0fae43ff89d7d4d6f84e73426b6a447405f789a05 1661863489000000 1662468289000000 1725540289000000 1820148289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-332 \\x3cc35c971089b3577a45c0680b4f99faab0894993f87af1051611437a1119aedf716575c390020cc7af682cd895a5272c06d312c0a9922bf234e41e87505d4a5 1 0 \\x000000010000000000800003cb5e013b0435e88ac9bd8fcdc14f6b81b9d1dc2bfd02599dadc0030216db891dcf8e5062db00a92dee8c46504d60a336a915928d044466ef883014ff61bcc189a0b69b3242de4d22a388a9d8c3218968ae93fa624289a76d29d673738d00742c8d2ea0328a741658cb18fdfa55316f50629b4f50123d68f3deb4d20bdfc33d2f010001 \\xcc7bb1a8927a01703f5861353f00b53e0b5776218a84ffd33fd8e96a00e9084e7a3874692ac6a8f5984f0596c0b08920bae805f0f009f3925503273599008109 1681207489000000 1681812289000000 1744884289000000 1839492289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-333 \\x3d63a91ce89892a205502806fb447a4d5d0a7ed57ed810c3fe2e32d9eda9e56015c9195e44e43015616ac69be4a745c3fdafef7ee03809f514f59118b3396b1a 1 0 \\x000000010000000000800003ca6ea90d0e7c9d3ab35bd376b21637e8558f9a5d83b3fdf07569f5b856868b56360a9b24385c466a96b548dc049c9e698b4549d67037924f29d354faaf2c2fe5b74de6015bbdc5d47e0e1d1b3898218382fd12a26906fcaf7f0dc0ba7c09557b009e295be04e629b7c058cb3d56645bd2cc1e11aa01d63810601da76b5ff71df010001 \\x726df66a9196b77daf59b007d91df1431139a38aa5d280886b3c87c52caaed199326753bcafe62e05636484fee8b2fafa60e46aedbf77c295b2ff9facbc8aa09 1680602989000000 1681207789000000 1744279789000000 1838887789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-334 \\x3ed7963a75af26d7e0cafeda1bfc77395a6d58b0629133bab125dce9a854aff15d434865df7d0774e4a28fe5dab5e05458fe330119760b4157771f79a27b5257 1 0 \\x000000010000000000800003ed884a67f0b2c72cbca77fd3685c0b3e932a7bb033c8b48362996ae79e8d431b9dd5a19abef2d707aaa251d335e3ccda2b185b94dfa6b12be7604c1f7d22cbfeb0bf7abcbf9cdbb33930545663316fe1239a432f9d24ab1c2a09aeef94ecebdfb3fe09d24f6fc0c9ca17e28ef4df4c4c96394823dabd93cf86ee1fac1bb3b0cf010001 \\x1cc3d9088239d57335e70e504d12cab3c512a195a7aae27f4f6a60824f4a5e14f8e2785c8381446912709f0d3a2a36481251cade142cfef0dc6ae30d6b89180b 1661258989000000 1661863789000000 1724935789000000 1819543789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-335 \\x3ffb390a5c9b2294d4b4a38653c72972d4495b0ccc3c7b04c3b082b8c6598565fa182730a79c13462c39550b1028c6a24da1508a2653451af57277c3dc107b06 1 0 \\x000000010000000000800003e2f8b893e40df9c1e4acefcee69f83fc829b02b24a666009652455a8bb10f3232749d98f02732a98072b56156e37df89cb9c9f1860770a6d96f3f3cbae9a72dfda77df5de0df69aaa6faf39a5eba315dde260ba6920c89d0d44cb06f52d507e2ca4d0a90418b7544fefbbe4f96715c1f7768a01571b87e9e13e398490c4c059b010001 \\xddd22a81383716080a3bec8039cf03e979bb2a5921980a9fa584fa0430a96fc89b68b9b1573ef0ea6f7ea3dcee87832295d0712e344cdfb23848b6eb39ced909 1687856989000000 1688461789000000 1751533789000000 1846141789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-336 \\x40737f6db6ae06e48d65aee09007f2fbf0ef49b623f9c9fa3e85caf7835b790f529191fb2038cf05a6c7dad24abb75791440bcb0296c14cdd6f30aed142a89ac 1 0 \\x000000010000000000800003d52c79e143c5f17861e3b5d4f2234fa935feeb3bea14fab2a6ff299b8ea22677edb4986fb05436051fa62ed092e36065874a997d671238bfa2d25960f79f7f5565780d0e3a64e77d78d7ad88c320730942bbd9e3416ea0a7059b711eb16265879ffd162fcf96dfeb654912409f4dbc6050ac328b80dff2f9d43c10eebff9de55010001 \\xc1e6420c2258c6d6e0c82316e42f7bd74141050d06c518a9268fe2b449d852e1f5f3a1c94a6dcb2725c4d0daa6a24fc70f59bd63059c25388813f656490db50f 1681207489000000 1681812289000000 1744884289000000 1839492289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-337 \\x41cb0bc268ef09f23d1c37911a4fe8f9c41fb5ff0dd339fdc962596fe7e7d8e933a12832c171333108c03cab14fcdda519d8344b31582e129c554a5f6a33ae04 1 0 \\x000000010000000000800003cc0ff69cf4e7dd7a9cc901c2a2089eed99fec18627024291d6dbe65626099809cffc0389c1f83fb8f1cbcfbd5b4475b63f0165794aa29ad54651328bd501a59fea27e1cee4a318b8a7cd3c37c93dd7ec7327761c81c8313e71ba2b7b70c9e782e707d29365f1fbf051e28e0e288721276054d5ac48c6aacf791a58d22bd5babb010001 \\x617fa47d19ff683644fdaf0679200ad1c20fe03edb7c5585a7f5ebf95d220dee20902cdbac71cfd7c4be9b925dcdd3cbeaaea69178f2367eafd5f305c208c909 1676371489000000 1676976289000000 1740048289000000 1834656289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-338 \\x42ab9d36a3b20e9a0b6927fa5fe53ed46393807a59b61655fbd6962483226e50efdd1c69a7d5092e93e81ac89aaef238cbe51f891e47918bc849b15bcc8b816f 1 0 \\x000000010000000000800003aee0adf0c74979f8b3f8446a71ff19f1cbafe672beb17fe7b763574272f36b60ef0caf34d5d7d1a8b99eae142281342364e852ec32b470eb96031b2dc6adeaf9ec921546d39bd48d19b2bcfb58c2441101d9002b7ae037088ca58d719c37c5000e2a7a8345460cd6a0a2d58dc7787a9b89f221593209f69f0138f96851a42041010001 \\x7971fbb519421dadcab8cf34e9bb6e3b7894646e4b57e815ec78297d78a83633c11772ff52eff53046c6f7becb100b84dbe9e1954d0a3e20941b294055d83f06 1674557989000000 1675162789000000 1738234789000000 1832842789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-339 \\x43d340f8f59517b0f8881a161024528224353f10dc5ed02546d06f74338a1372e8791f4cc25e52b06b54bc66f7f94d548000cfdbebe82c898ed626bc017936d7 1 0 \\x000000010000000000800003b7d0776b9430807bd9afe232af1440e9e863a35ea74ab8a253806a1cc3cb3ffae2766e311f44a1c348eaf0fd82b56f1516e6cf6c7482a79c2319210c68bc0327444a06953a46dbc99769b3433f04874f2c65534e82ce5c760c9bdbaf81dcf233dd5239077dba62b0060f5cabe2a2d0db3fff2caf9c8512a66e3cdd6076cc8831010001 \\xd6742f03d54a814edf658671fef898894a6327d046bf09692ae70bdb39f97aa0943da960e2d8c1ecf85b3496d68ad3a661a468b1a0e245c186d9a4f5dc670908 1666094989000000 1666699789000000 1729771789000000 1824379789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-340 \\x47e711baadbb542251ddd253b9eb7f59c946f3844cd8530b503e3e42b80ad08c966297b075df4b648424ea6890a7d4f6163e38168cffd8089de6dd8c14047613 1 0 \\x000000010000000000800003978678cc0ac423f424d863cd2fd77b1ba7553c41a26d4d58e7c3377079916bd7c59af47bcb0ccc8742f6f6f029cdbecffddf64a6de90fe05cbfa6357170debce05df08e4ff889d973a713ae4a18dcde26f3f6450ee8710bb29b4a844a3403a355e7af78ff5bbea404d3b02cd631c3b91220ff1ac76fe9d56f503aecb4691a8bd010001 \\x090194a2e3fd2189341971eca7444fec95c0ae4a7d12214e26787ca2c38c8f5741bab9b720b3d191e3afa87933b9d3c443ea634d75eefec91fe45c46bd13a209 1664885989000000 1665490789000000 1728562789000000 1823170789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-341 \\x475ba0527f394f9a2d78820cefef8665e8fea1b9c5752bbf5d2731d6dd2837330385d64aafd7373378475c3bea68971d9e687c51491d495595885840b9e0cb55 1 0 \\x000000010000000000800003f83c4b4dd83ffadf0bc2aa44d918806d4e0e7c2223ccebb64e8ba60084da458d383772ccc006325132d9bc1131894a9abd9c38010465d8bff8e53a4e5ee5badef3412d0c5d8c0e68a1f5bacab59b75543f0f12a056148d2598d801642c608c99283ebf9eff6c6e50a1851de28d78cf8426390595992c10e58746484d59cede09010001 \\xcde370e2e5f6cf7cfc0526b57846ba69f10e4f2a05098c93fa2c740a03f0b319e9a2ce85101a6a29ebaf07f4cd45f1f873de1cd0599071b650ed46a3d019df07 1687252489000000 1687857289000000 1750929289000000 1845537289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-342 \\x48fb3032f27cbe09e473c0ec9acf4a534e912187d9706c874f8f075cf9279e6f5ceca6388192e768f860bba9683b89b7dd22867cbbb0b0bf2968dc20985ab976 1 0 \\x000000010000000000800003e2c5a71c4894e4330820eb66f41e00c0736d2cb6a5181790283bde16e4f0eb220c57f23a99ba7856a2660a19e7269f3310599e8a94665efdd38a353a12e9c207562de729ab6541aa6408b0cc8bd7b0efe03800bdcc12575006612e3e5f89dd8b586a15079a0f28340ceba659cf892432a4fee3330df3e0f4d355f3fb81bb32d9010001 \\x540070de25975d3a335ffc2b80ca3eeac2e36c5ed1a8a831802d503c251d5a2792c407679d4262bceb53dcfbe8cc71c06403b73f5b2e5d2855e78198cd3e4d06 1689670489000000 1690275289000000 1753347289000000 1847955289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-343 \\x4f6760240da24152a330a82cdbfc330dd8c995e04402137c04e4f91cd829552ac1e0c2d38cb1ce1c31ac5154a5ffa3c6321d67788d9e4a9ee7d986a46705f3e2 1 0 \\x000000010000000000800003dba3612ff0c3d94b4a503d9a2f7cdcafd8f04d0ca88f8b4f5af13e728015b2e268d8261f646c86e2eaa8048fa1f978c9e0137164af99cf46ec41896b6ac0dc532d25b2469cef2fc7440643cdfab1dae43c4e3f0c390eba79aa44de83ebe4cc89f398dcf718157d730caa4178399d6ca9adeba0b007b0b0c6ec32d3c080409f51010001 \\xd74f8c27fda67bd4fc9d594ce3cc75fcd1969426ccb39d25f036c524dfa6639a6c10ce126e9fe6204e0efb949221af262190f8adb36df7b47a4718a6bf0fef0d 1675766989000000 1676371789000000 1739443789000000 1834051789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-344 \\x5087d2721709543a72a5327122e7d94bb2da9a84dea735caa3289bc3b67ef0b3808f33208738610b22f6eb1ea389dcda8e253f0e22fe3914d70f038168e44f9f 1 0 \\x000000010000000000800003c578ee71879615e432465474814646df70b6b7578734e16917c052994eea0b0c70bca311683724bf68d7d9f1f368ef8a03146ba8137985768746507e6ba78036fbcf90bbfa78de391b45a0c83b927b24c5980ad8d097d0826a8651d2f873e16dba7b2ad40d1866a483395998c77f40564bf52df61a4752044b0ea3b9702f3a11010001 \\xb91f703f58e6888ebcf08c7539e5995a48dea194272640b898cfb4e232e44ed7ce4d6a3b20c1178312f0fd09252d8728dccfcda4ad19877cc82e5517e0d6f206 1662467989000000 1663072789000000 1726144789000000 1820752789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-345 \\x528fc3734267ce3ecaca2984d5cc830126dc98e6e1fb7b26afa1ef742347b49a7acd3dbafd28a46b54662776bab2d58cb131631931729c00f2660d9851a52d7b 1 0 \\x000000010000000000800003b7d56eda74e42c085925530aa144d404d44446efe7ef6cb52c693779e09a3995ad943f419ea7dc1a9bd55fa9174cb5f9826a3833cd816419206a10bbe047dc2c863afdf0af668f5bda560253ffdfcbe3460fa3d1a938402641338ee9753e3eb7357d6c4fc971410657fe5074719a06e420f170b4178cd1348cd9e6c93a393cc3010001 \\xe67730affd5fda719efded47df3e968ab1512fe244c5f1aceef9a72c782323c53d4fc6171e7b3e1c25c143d9f8bcae175dbb23db9bfe3849778a33f61318ed0a 1686043489000000 1686648289000000 1749720289000000 1844328289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-346 \\x520b0402ddfc082cb200327084e5404d08efcd98107391ae1ce9416a280c8aaee2cc295fdf99e39f6edbc8e839c205b3fc07296ad07ef76f908dbeef946ef18e 1 0 \\x000000010000000000800003b933f29ac4f53007880ad89349ff7da8017f89a6e2d20e481417fd37d8b612df48764fe1260ec9af1690749b8f65a0a180a1021413b4fe87605f8aaab4ae980f0e7c5300bf8549b6d92828a604a40c9e8c557a94034b4033ed3535530bcb3be2bb1ab2f67250c61e767acf90a5b0000758b1091a519f1b768796f93ed787706b010001 \\xf9284541147fa88f5a58abf90216ed838ac1c73d9b625bc88da3708c600fda189a23acf2d1bc87cca251bebb703dbe36eedd329ff5dba0faa387d58c60546402 1661863489000000 1662468289000000 1725540289000000 1820148289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-347 \\x5b5772cc103dfcac073e9f2d1783db611896f3d7c6279d0d41a67d7a614d3ba95b4976d3d88d5190488faf00b7ef89d0021f097713e6a75cb5b9c185a65f449c 1 0 \\x000000010000000000800003a9d8bc834f3235740696fd622e25e76587deac01b8a89626830cbc5e771104965795c6be6607e65ef129a75574000a52403dbbbca1fbd9ff22bae6f2c0dfab3767c78745b456565a7e08e78bc872668ab63fa881627aa490371b945690f69fd124ca4e7a143c017b8a2f349a9f6159263a179303c502a4a8fda1949b5d9fa321010001 \\xca64e32278aaa220211666ebc5903aa534a0e0ce9746c6ae80c449556f5b4716dc3cc88e9628af4c75d1303dc09aefecf9fc6a6e97097941427c3635a04d6d0d 1689670489000000 1690275289000000 1753347289000000 1847955289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-348 \\x61a3f3c0d0983a6f2d09a4cc166d7ef0dceaede391c4c09e8697b2190cf6c9583fa6bfeb94506c7bf048c47e8a73eedefe6e89879b9205f54c1890343ad78e4f 1 0 \\x000000010000000000800003b2518b3c5fbd5f3d6532a42ee1ec43d604e2d7e782298df0ae504a9ec102a59d9307ef7391acddf3be7aac691534ade4ea05beb75a3dc9725fc2776f55bd79709846eea2462d4621eea83ea9bc5c4d5b9d47ca6dbc06c36c42a01218367400ebb11340e7671d9d9e3e58569cdb4f673269988dac6aefc49c31e83d9be7ecf5a9010001 \\xa5c644cf3d508bc4d04066b6f07fe78dab1ff3bac28e4163bd3eae47b075da0adb18320fa6daa5885320f027eb007ee7df12726b19dfd3ebb30ffed5feb1b402 1671535489000000 1672140289000000 1735212289000000 1829820289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-349 \\x64b39a0d8a96426554d9776b0e50c7d237b99757d24f89563cc2baf404204a0ec4c6bd2eb6efd5fb9565335224e00968d020e924f46afd61795a51d71605da68 1 0 \\x000000010000000000800003c2a0a7b61bc2f4eafcd99a9ed71424585de6b99d5961e2b3f56bc902c75b48b60e23c67cf1af7f0f52d0b6df9a1c2c8d051c5e21c9c5ace1f9ef7b1e8d46468add451bf3c65c0271426900e880dae089b4bd4ade8b15f6b56acf821a4beaae0a66019e764621149f5110350d274d1ae367815d6f3c0cea93dc2eb6846056fb1d010001 \\xbd123cc27bf8a8395f7692d632fba2c2d4422d9746aa8e84b04df9e2878b0400638561e2390a0a0edb49ccaa2230a503352f952588c6638e2e67e5633247500d 1666094989000000 1666699789000000 1729771789000000 1824379789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-350 \\x650b0b6f386af6971c656cfc42585203abee9380beb55e5401f4e9b7ef381f6ce3f3bf3fda29e741bca4f3d3aa9df605ddabc3a0661c764e2c5202bcd6727ea4 1 0 \\x000000010000000000800003bbe884189bf315e645092991e0ecae3979d78c8a4297cb233f42caf451f9b8c2e265bb9cbb4b9e17dc47cb93f2b29cd04a47fdca9b9b8597e5502705488024b97b67cac21a34a94000858e7ce3376b0ffc0a32b0251232299586a92565f961967aafbcfc91d1482c90640df8326eda0fd730361c8c771ae666b53d313b1dd2d1010001 \\xc7b280375f537b46a64b6ffbd02b2e6756363a9b533ffa7c05bafb999fece9adcedc00a7c65bddb61450781fd3f6fdf90bf2a27d1974e237a5e560568d7ea00f 1663676989000000 1664281789000000 1727353789000000 1821961789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-351 \\x65db16c8405396c489f5a83077539570958fd4d4ae8ccf952cb7a1daab91148c77b329f515d1fb0f4d413f70c67a3d9dbf49d06d90997aa038b38a8bfa40ba34 1 0 \\x000000010000000000800003ada7be330c98ed9167ee1698779ab1b770c8359d784239a7712df3674331e741c429ed1b0919ea520593f069a7e3add027ea6ffb0fbcdbd17a259cfece66625936f6192744454bdc2d15f1e8a926c840ec9b2d10d2ca83f776ee1c990c572967dbeb8c9fa200542ed7cbaf1e3c8deb2bc284d2f6104780d2610eb40814224c1d010001 \\xf63f19fd247f385d95cd45aafffdb6a1d6f248f2a248ddcaaa802ff2a4c57b8c70305417efd7bff9d1f50f92173f24fc24defed09d914a507d995e463776f306 1671535489000000 1672140289000000 1735212289000000 1829820289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-352 \\x6747b25026bcd226e248e14e8087ed33bfebf48a6fcd5896e96c57aa6a771360a78662513e0aae06a480e9ff900c1a9bd18cf46699528dd3047c3ced0d253971 1 0 \\x000000010000000000800003c76204faf781a6988963777cb313b33e2a6066c0b3bab4a5c961476d5d176e4d4bde0c0672c9db48be163486a4ff55fcbde16dc4a1dcc8db3a0eecd4cefafd72061d231245a579cc2d5091422344bb304517d39b0f8a13dfc16859545db94f71dac7f42d6eafb87b2a112e17cf31bd601ee2563f6cb371c6dfa134e21f3c4ea5010001 \\x0224eb3e2b5e5b3f60bea58a7c00ca833e2a3b585e5130d2939a2e7b4acb3badab54399e6110eb228f08757e91cbd82bcc4800960d5edbeeb8f514454eae5c0b 1664885989000000 1665490789000000 1728562789000000 1823170789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-353 \\x694f8885e57982cd7bca4bec2350e6839e90fe5e039d8c55553c5e8c40f59b90116d248414eb8dd696e9cb083f2cb17f96cdc0931f46785978ee34177e1f9e6e 1 0 \\x000000010000000000800003a54239630eb90c5c7a86f33c02a75e57534b98068de313a612e40b33105256ad22deea510dfa35080b338a995bac0817bd7b1de03bb0e2b7d37de5047077ac64c30b86a5ec9a321a57aa4910644c562add7007b5a3265f5cfcc4e342938fe6a1cf0adc6e225846e064267312a3b42ba7fc3786002f7530779bda0ec18844b3c1010001 \\xf90b7e0c30812fe2dfc911007b9250519ef9915e9aaf48b38d483d98f5daf810bb73cb79d5c3bed7bc490b834cec3fdb19b6228fadbcd0abd9fe41aa1f4bcf0b 1660654489000000 1661259289000000 1724331289000000 1818939289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-354 \\x6ccfdefb28cd9718dfdd8126241b683eba7e51bf88994f78d5da37f78a801eef19eeb7e510c5ca4aaf70b5403db8ba7615118dbd5ee0ed72ae22d0cc0fdf7a59 1 0 \\x000000010000000000800003c2140c08617247639a5458e7db79d9b3cb5c402d3028b96ae5475e08444d84b70658dc54805dd4126407dceac19ae23490f4820264a077b72704e3df04b4cebeb38ca835f972a31e04eda92cf0528292ad0572a4d72e53fe2eb6e43b123e0a5cadb05034b3395dff4fd9cdc372b860c5e7aefcdb0631c4656b84e9163ea84acb010001 \\xb208343a361ddf8e931ca7cd1a402ab8ee97480ca324b14f3c05fd7220593d414f14b29ebd4e6f238ac7dd8d5a0520dc4b92e8b2d3f01ce26b91cb5b31ab1508 1671535489000000 1672140289000000 1735212289000000 1829820289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-355 \\x6deb18b52679b8ff16280ea26819748b9452f67880dfced5f5335c68170b168efcd06f19249ecd544cac196e9f5a4db05742b46711582c6973981817507322e1 1 0 \\x000000010000000000800003bd42bdd43c989aa81b6de84953bee8a06de662972fe09807d1f0095b8412f92ce41163fdcfe390bb3fa1ec76fe89663f3419557875430190fdedef368b62bfa631cccf7965523b0c3a915309f8ff5de6ecb1ccb9cb95b8ba84408d8371dd1bc806ad56cb986aec0889ba899ab10390f0e8b5d294acd82a71226d855d21a8317f010001 \\x129bc0470f091739e8ad344b1cb3714c0090b72ca85dca4a4e5d20a1fbb4ee19ed8c979744338792aa4f74c7e5ea8c35d56c935e61e18e6aa551ea40032c1f01 1676371489000000 1676976289000000 1740048289000000 1834656289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-356 \\x6ecf3f677212eecaf7886541c79236c4dd3e515dbf4524c287dbf29cf8bbb133cfd23d5fb9b38a4f114d27cde38d8f329df98cae81a9c14b8b440f8fbfdcb088 1 0 \\x000000010000000000800003c237fa8067d41b2b371eca57d975239c5ee5cd9daaf655ef301872ad1a65418ae4fafe846f7a4973e3b6ab8cd4f067944d5f1c2c2de0e5aed6f828db27469797a8c96f5668464efd3375db79f362f9605243ba9ae75d3ac43ca27e4162e34f0b4c8f9d6e55a8a07c4b7fa72695cfc0f6d9f6b130e8bec5107e1db4ff142a1917010001 \\xcd620fe364c9c07ff072a3fe37ba8344a8de30b0af6ac94514c5e9c977415943d24802cc0dfd739c977a81b6b53e20f15f4a9ae261f26975f034d799c9a1f805 1663676989000000 1664281789000000 1727353789000000 1821961789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-357 \\x70afc7ac6cbbdaece25dd1d48d3ea60f07e490d9d73e4f008555480c5e3724275076d0878edb34a14bf2f181d9ab6f4ab5eed2556e26b949ce896f007fc91163 1 0 \\x000000010000000000800003d202e5dc6fe9c395407e3aea8b764b61db688d1fa51d0c38544b5fea8d0d179f8d46aa7b16ca2900442f8eeb7c2a5f42eb89b62ffba4dd4d734b9fc3cbcddfcfd8297a550e34f766bfdc383603432f7b09336d29325c71ead6c95cdf37770e45af3a08b40d1caa4dafd76568b919bd2cc2050aee344afbc54dc2f6effc97c71b010001 \\xccf14a62bd0d2ee6796270b43abcf583b7a8cb9730b9681af08bd65ba9587ed28c5b9c141c62547e25d13cf06f83c869e229494046c3877ea40b4ff77bc4010d 1674557989000000 1675162789000000 1738234789000000 1832842789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-358 \\x755f74c7881b94e9f154c43bdde40936c37072e495d3d43efd25d26f7c045e0488557920915eac3881b02da8573a39a44bc7800ef610c493adc5516ba40b11fc 1 0 \\x000000010000000000800003aa66acdb6ae854d6dc0557eb65cfe53df9eb4d10e3f0e35943569803557fde7f4f7ac04f05c1634bff6d8693f9919fa6fd35760e8ffc16817ea1d35ba55e7f921a1d43c986ae9dccfd881c0d8948e94e82d57f7bfde1ebf83b7bc55688eb3209cbcca4c0508f8bedd6393cba125c8ba765b5ee99421b8c8fd1c9e7d5983be83d010001 \\xb7a942a168dacc6f63e5c84b9d31f884139fdff8d3cb0f23449fdf57819b61ab9b5f380234f840d68d7baf50ab22cd45d7e47401211f547b3a81c570af1e310c 1670326489000000 1670931289000000 1734003289000000 1828611289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-359 \\x76d7638b5a29298001e05e9714abf345ac0f6bfa6171fea717d9f1b969fdd8f623890c01627230738c06ce83467e500a0bdb62fe16f5e477da2b307af3643085 1 0 \\x000000010000000000800003a9e94f802f4e1f08f3ed880f4e4afeab29932fd2443785c749a80e9cc4b7cb01006ada37f7360685521027c4d6479060ffd0dd8d6c661e79c0b4cfd84d0aaa65d1e17a10b590b78372a9d6dca434dabd11dc809cd87d94ee1a9fca1cc94d7d441b7195146874a32a10109c17d599997afcd9906321a652b304e7818d305d39bd010001 \\x1376e7df5a9506d7bb0fc642d77d2692020d8dd8a630a87041a90d5b9829c9fd150a4c42e7071960abfa2f77df27d4532c28116b45ec3c2170c361b29a38c007 1686043489000000 1686648289000000 1749720289000000 1844328289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-360 \\x76f74541ba11194b5ffe4713b3df7aaece19f6fc8feb8b13668469001c13155cc31657c97857692454cd61416fa9b761cb972d869c059fb0f40b9d3186621ae3 1 0 \\x000000010000000000800003e13db25f19f610a802deaf2291352955c99da4c8e6824760785d6368e982aa93b66980219b4bf242bdd7137d769a02ff8b4f21786aa619756a05636782b1163e02bae970b1021f5e8da90e6ba5b05097a7858bd15c4ba37bb585e08c6f7324f0ef57ff4f665363fa37db178ef2b296f4286e6cd9629bc212634f75781e0617d1010001 \\x3fee9641de767caae59855a8a2648ca90c205432ec8cfb9809cef4f2c442f74c099fa646ddb56342916bc0d5a9738c9c85894ee02cc1d338326e876106bdda00 1681811989000000 1682416789000000 1745488789000000 1840096789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-361 \\x7893cb7b628e126c0c2883bbd6a104aded6786a232811c150e3afc7886fc2799d3d6e5128e695e2117cdb1bfb80f1c3ec663f710e47eec22738aa02c6beb76e8 1 0 \\x000000010000000000800003c105a598af09faa41f82110f6d5f4ee7e4b0b07a3f1fe33cf73ed4ed1f598c7cfe5fc0d6bad9bd561bfe6e66ce046f040df102b19c8c5b3ab3abc73c6a1789478558bb708b7cdb9e46a40f2e4e5f9a72df17ff586658dcd0a628d96b085ce81b7fa62a34b6be2fe180ae3db6440742e9e0781e42627477243a01fb7e71c68ae9010001 \\xb57228e2738bcccf3246d4265eaad9a2bb54519116dd08caa0b6866411b59331ec61daaef2129b6d7348191b61f44b560380040ec1a475249e663e44b189d708 1662467989000000 1663072789000000 1726144789000000 1820752789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-362 \\x79dbf4617e9ddeca5b5f70963c4b39b75b4558cab3251d823b4a2571d59b61f9c4b767e7369ebe5d132eadba731042c069330de856358343e8a8e7b5add3525f 1 0 \\x000000010000000000800003dd1bb981dc2358c5cfc909e57459b74fa5628a919b6432390073c14939299e7b0184291abe2f935ac997e5e4d39c762648058cad990b3904372246853dcdbb6e1838a665dae638cf7b9771ae23ed676d05f1883620479228947ab20006e986b6549d2f4704482868d1cb6ec283142d1b60f90ce27a50b1561e232d72d546140d010001 \\x72770917d82526aae90c50f16a29f68c75a744df1bb37306bb58c868b2f112b194753780dfab092af9007ccdd43ea566abf24ac03368b3d72e2def14a5b6fe0b 1672139989000000 1672744789000000 1735816789000000 1830424789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-363 \\x80ebf7bdfa1743bb2f6777f4ad96ca6fccc1127fc35b7aa127afbfa6c7995237b171c2efe676281d3912b8cd52b51f52d4821de14c1ff73e7545776b76989186 1 0 \\x000000010000000000800003bd29f9868cc1b871a2d48ab0d7d8bd2732e1f3ed6f5f5fd2a8649ea12cc8d04045010d3567c9f369187553b003e690e1a7c8870b8736c5ce90810dd47f76086a7c5c90578ae8fa6f6dc633e497e4323d16f6b29568bb389e1a06ce5b1f7e168b01e0d6ec36ab47f5d28ecd9fad787c686ff92a10929fb86fe7ff1ca4e3da1c6b010001 \\x5947fc356997afd5e1a231c5ca44eda007b7616afbcaf6205adda61295d5f32ca97a3529d103a80f8f6004c222378e97dd20dd164c4ae2244fd9dcececeb8f0f 1681811989000000 1682416789000000 1745488789000000 1840096789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-364 \\x828733b8170dd7e0225b08861e0c88a4312a5edb8c3e865a0be2d66e878072ffac5c01f7dff995648715319974902cd204b00356895da9999c06e7e1dd47fb4a 1 0 \\x000000010000000000800003c6bb38da7e1e34f2bda2c06ef23bb1d3d504f134d52c1f1a4af31042d16a5fd75bdde94846ef54cb6c2d78446a2fddfc84416db249a57414143b0e7e4b5ab505b5150f22808aea0270955b0c70c592a6affa79af7920410c05561f3abd0daab02334a138d4c4d6776cbfd4251c44c41736c3fdc26fcbe96186a0bf26b88e5917010001 \\x41b0c6963e56cb75da77644ad1771c8b8e91d67d47e6c5f1a5b3d4f7d8baf33bb6f6c46773c9212c6602e393ceeb0447d303d981fce9ee15667626a905e7690b 1666094989000000 1666699789000000 1729771789000000 1824379789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-365 \\x849bca82d50c7168cdbba5a07e480e9e305884549c63fe394cc2a147d3925ebbd51a48883c4e89e07fa8c1f5baba3a443b41a8a51fc1243ed888f66130af19e7 1 0 \\x000000010000000000800003cb6cd87a840d15ce0473f380c7582adb3a3841cee01cbb001d7d58684c8b41582a08568627c1d626bfb94a632600191ef0a5e3f324ae3e18536eb6437e372436a38e725f5059dfafd9406a448e6b3949a3191dba35b84806a1ee94f97a5b9f3aab4e66a8701241cf312e26bc95ddedaf6f8b8e9d051ab37868223bf279fe18c9010001 \\xb824836058c237b87f78fb3709ea14dbb964d1ccdcc9d8dd9041fec17caff5c980a43415bd0d236a6ba42733eb49bc8f38fb9a781846e69cd4fe3f179e67950c 1676975989000000 1677580789000000 1740652789000000 1835260789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-366 \\x8407b503db94257fc076da90260715eac00506db81374aa1aa42c268dff06def74fdbf65da7ef91d7211a26773f555f737370c0538c72d13f36117e33217b1b8 1 0 \\x000000010000000000800003ce3c13999bcaeb7d136ea036d47541bfedabe63285d4df7a885919a8dbaee1254a78a722c252e2ebd9275e8408be59876780c47c2b6dfc629f8892daa6c869dfb5ed12fb653f2eab7268fe62e46e58fa6232287271182784a202580320df72d0d1e46ee5d2ec18a1a1dce99e723108fd9942004117f503a4626f060e653b16e7010001 \\xf3530765d8eab3f5d99d5f13cafa83ccd0509b04e1008e76ba50f1e953e98b81fc3ac48a6d005c6516622cb8ae86dd564218b235ed5a171268f9a21da5147208 1671535489000000 1672140289000000 1735212289000000 1829820289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-367 \\x86ef6ef52699ac74539ed5907173dc8ef2f259fee71c054ebfa561f4bb483ff8cb4c39f6696ca7ff0a68a58bab71043e28a71ae7324389459f5aea31f5e63f2a 1 0 \\x000000010000000000800003dcf3644e7d2b0ecb731cc6e723ed0874bf9378cef0fd61ecf410e36af7b4e18e0ea8e5dbd8187c5b2e8fecee461917d8ac642fec0cc5278a315578dc25f883eafc75bd95f37d65ccb5d2b580d5892e95b7b65edcde9fca2f5ff5251351aac3716728d1ef427facd3729ab740470fe27fd262db944e7b9088779d25ce551f327f010001 \\x206c2a5c90a2b7191cda6da6b2b3b723b77cf4436641615fcc82537e5e7690d35d7636092392737a66ca021bf4a049f58aa818d5fd3cebf853b81ffb975f2a0a 1682416489000000 1683021289000000 1746093289000000 1840701289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-368 \\x863b645fe761c5927cfc254fba879467710960829e2a55eeb0a7733eebe413ba61b30cb1907195ed5caf1ed00ebe3fdc2cf6166d221a76d0d7507b5beb727443 1 0 \\x000000010000000000800003c353a034f7cf2459f4e3161e189230403a110041c0494d41fc5256573b3df6b365bdcb2179f6514ca642d46221c70ff19042c30efa73b36aa2d321e055fe1ec01de7ef32eaedf858dc2d8d1425da0478021d9415561cd5e0eedb18b578d790915a252bc24e22c7f442e01e7ff24ae9a3b90531fd21a7554bcd9a71274d6c17a1010001 \\x36b54628e7f39dda1df87510db41981d70089117acbf81a05c089c69cfcd72181adae15bb0904ad2639c518d8bf2c651219e44103234c1d84f8ebbd76a786a0c 1688461489000000 1689066289000000 1752138289000000 1846746289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-369 \\x87a337bdc75e9cca00672209b572235d32b03d8d761ac5fa578c7296653474190877dcdae37ac8d03cc751706e1d371a7d3f4b1e75f024ad7f3343285743c970 1 0 \\x000000010000000000800003cc4c6d5764b20fd5d440551f43441a657b64c07aaddca797e01d820e862d9382a02d5e7add481ecb92ef920cbc247fe76af20da06868b065c7086fea9afa84b3b77eb767c85c17b9aa13be00618f85921206c2a1f0e2a36b1b13d382bd27f27875309b5f7077063ab647909e80735962a422e250bb3d3e5bfd4fec1ed44addbf010001 \\x2654f2b7c0d8721d4fa1f9d44431ccfad99c9a35bee44ee7e27658c4f0f2b262eeffb6b663c9372c219b90f32a971edd274b01d254f1d48d70d3db9c87e62800 1683625489000000 1684230289000000 1747302289000000 1841910289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-370 \\x8877fa64267f7631c79a01b3e770253f432a097c18810dbf5455cd768aad0bdb969265209ff954ed57904b6cf676750ad620db9b18d48363174ca74f8601166f 1 0 \\x000000010000000000800003d259b730f76e8e64a2185c0f354a5211317c5f11f3770f7f047b03934e5b47b637a8a8bc08653a447a582400f3f480b86a5766ced6de205c8b881c566aca195870dd8ec503cec3f929c9287af475aa0092eb8cd50f0f12d93b00b62c579a99370f103bd898d676e207242e7bddb1a03b50f7d259fa87384e09ec9e61afbd1041010001 \\xdaab740c1fa1ca76fe15d762a7bfc7ed3c6b5eaf594d8d0e8db1e3b5b9c3ad5d7839a1d477cba72a5f898393c7b62e9d2b0e985e58939666c98e92b699cd610e 1687856989000000 1688461789000000 1751533789000000 1846141789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-371 \\x8cd77288a23ea5210da4f89f16d5fa18e25849e336ac13f5c49067b30a66374471a84e5f0af1c9783f00a5776d336fc7aa72775259e888322f49fd99d75a001a 1 0 \\x000000010000000000800003ce797deb6dc041104122b2bb8ee81d68e5610a1945745da9181158c652ca4eb77cb01f4da4de19e1f2f9870e4694e33cfe9e0ab48d76c0d1aaf878cb3932f0b317de797e368789719507b0818dd2e7c5f5331555f0d19428751560e043e401761414755b358249d3e6c4c98070071530783b7c010011b16bb2eb4d3ac3c1e559010001 \\x1c858a203096de4b2de5e7bcf3d5f882e6b9dcd3b0701a4a7b0ed4449d4c605a6b7c0e94c6b58ebb66a582ba9d72608c8a982f35a038f4642e917dd18b01cf07 1661863489000000 1662468289000000 1725540289000000 1820148289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-372 \\x8c4bb810e0a251a0070eb6f762c70ab2450245bfeeeda49523b83f88d8ba07141edb3a8ba338e0fbb4e34fca9b125cff19678db758a1ddcf22d78001dfc736a5 1 0 \\x000000010000000000800003c14ae889d62931dc8dd6fc4b6e55173e758ed922f90daf62dbfb8aeea2f77203b8a7f35ce5ac9520db9eb09fedce5142395fd102dc6757f7d08c35bbca40a535f861c552a4107f482fde6141cf224bb5e68f6207dd0017e25efb93cc7380860983d3fb78ad3b012c27b53d8a742f1f5e9cbd9e33a88b749d9ded3dbc03a51a95010001 \\xb655f55789fc4597e1a9342a709f44d145da44c723bb50ffa11a2ccd1382ea54df5a7c20e15a7e7c5a99f1d0e937a156813ef9781b68eb1a4499e975f0fc110c 1661863489000000 1662468289000000 1725540289000000 1820148289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-373 \\x8c6f43e328c1905644ad088322f8e00aa6712db4f44d152b541cde0b1b36b19cc96f5dd6c6dd28a69c9c8ead674e140f18dae5a45b77a159d96cc78fcab993ed 1 0 \\x000000010000000000800003a154760c8de37558883aa2d617a5a7a1ff41ae14395ac0376ac2f594f269bbd5b10eeaf66ddc772bb309ebdc037b9740137ce54cd337d8cd26a72bfd31f867746ecbf9393f5d5733cae91c07eb895704c1be13748d387df88d96d7bd5871a928425c9059125e7a542034400c4ebc9e64c80b806e2011094b82aa58113b2f2443010001 \\xcdf0e12b47747b64e0006cf898866514f2f9a7e60b2b5398868ec4d65e01114816dcbb2ac107a72eea8ab01e54531dba2992aed4a0096a3a8be3bfef011b5f04 1679393989000000 1679998789000000 1743070789000000 1837678789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-374 \\x8cf7ad417bd3fd62ff5134003517194ff046933f31d0414aeda53d0f57644329731e88c18a7b14b87b4fcf3cdd80878505d45ebae408a1dfb79bb4a85cd1a9f9 1 0 \\x000000010000000000800003c17bef01b923e94d15971d0a22717cc2ecdca7f4db6d6d9a1afa0221918d3ef59583d4c01beada8793ba63aed111921c62ccada116ca8c93126a2771d1d40e3960913869f1a6e8d8eb83455951569136f4fe36d9d617b09d227690b07d60599ac0e4f567eda2fb7bd987bb4367f4d8a361b7ebb43a6a85690732a74fd5e2b015010001 \\x141a0bda938c267775fa6a3b54387c4d0748a411d9ca1cee23f11123602ad9fcb85cab97ccecb105c8ca7756308a87cc76f3ac0f73fd131ab89d9e48ee0bab06 1678789489000000 1679394289000000 1742466289000000 1837074289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-375 \\x8f03a54bdd6c316a7b91592ef398937f4dabc08c55c95b76e09a2e6a3cf46a0571e5715a9dddfbf5c553aad5af2e6171081159f16baef867f67457617e9ab8e9 1 0 \\x000000010000000000800003cdc01ce2fbf04985f18a619b91e24f9526e1a2d4307223812f8becb1c70173c099a8a575a3e5899d627a6213c45491d9ea31f0d500a1f3149bf7e3086194175b81e6ea794355df3e1a4a8303ab3ae0ef537c211d392bb74d63e7eecbade61e0ac179cff4ed09f81a6b59163c402b06fbdc07df4617ab2a68a5672acc6096f0bd010001 \\x24abbc70972ba81da0ce4669e262c7df9e2855e4534e4fcb19f1e6cdc0d0cd06325557146934dcec6b7b989ffdc5fb025e709f1b4c7aeec11c0663521dd94a07 1678184989000000 1678789789000000 1741861789000000 1836469789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-376 \\x94073432cc2c791370a7a84535be9c7210fe0c8da8db7aec1e704020ce2e2b7d57019b4f9424613be1c6effd9969f2798e2a15055e96fd6ba285477e73387218 1 0 \\x000000010000000000800003be22b100987263c387c6d7b5295ea96a4f2dc1dcf8f8cad0df84f4af385c93caecbf9b317c59b43e58c44ceb126451dab4c99038c360c04b56a8a199411929911ec420f5175cc36a9d478e61c976303436b93b243cf38cbc081488c69e92475b897eb589fe93125bc45fb109734041d4541cdbff6cdd663f28e36247cf759ec7010001 \\x31e148e5457692207744bee8eb49a12fd98c9b128ed41d3ca096565b93845468e691116c09f5a57d708c65e2069ab0e695ad139b66e181221e51f12a1dec2e04 1677580489000000 1678185289000000 1741257289000000 1835865289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-377 \\x9a433b76ccbfce64a693680029c737ad740dd2f78bc84f954d9a26793512775a22c7ff3b0252036b1e13d5e7d83b4013d869b3a5b5c3fb01391b0f100c467b1f 1 0 \\x000000010000000000800003e28b2dac0eb4d9cc33f8bdad662c72b99bc5f912b5b5e921ae925ccbf1e9133e21b4a9ddac639bf0c892fe91b37e58a5096da8b8f8c9d2386270e35f70ad684a7f4ff9be253df1347a168c96cdb9368f3aabf0a49e6779273e3826268348e58c5600c9f067bb5a66bea8fb33a40ef5c4876895ae62774b377d35d4b545abc381010001 \\x919d5f634a6a076f79aa537c4a8ac051a1b0fa0263b183d84d86355a48b23c7736358d2be6a5264e21c969d43140d99dff160b369e92de25ac102439cb9cb708 1668512989000000 1669117789000000 1732189789000000 1826797789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-378 \\x9e8b6da794bca65fa9c1bb95a22960e2835f97a40609e80340f035168f46dedfafd067f4c93f80b3244d9f344f251ddeab954fc8c801a1eaea2506cbb0277b8d 1 0 \\x000000010000000000800003bf3eec96e5502ffa55218e9985a480b8e3a2d959fea45ead02ccaa77c15cce0d9f86478c2d74900a6b7b2bec81d3f133a48510ed5f92bdd98f290725714fc30b85790e46ba4f1d122d8db6f6bdc9a923f9e925a50eff59d54568beb81ca8c9d031a77d197e5752ad9d45229dace78a9db452da12ad6f1dce9a8b404cb37489c7010001 \\x65c40c67d7cc3aac21447751fe96267587680ecb468e5ad2846c7b7d6c62045513f2a76881c22450e192739e310075690f263d1f5f5069c9eb6869254a60890b 1669721989000000 1670326789000000 1733398789000000 1828006789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-379 \\x9fb3a6697e804ac6499be473d9ccd2de22377442781b1710c6fe995b7f9011d2a1c62ce5d428f08b6035865799d0f52a76254b392283ada738f870f3f30e6aaf 1 0 \\x000000010000000000800003a1c7ed96a40457593289dceea44990087e6f78ba2792a82d271a309acce7182d8667d6b93fcad00ce010b4154935a11bc7afdc820fa638d11f6f11d607789612ba8c681bbe1c1ece4bea6d24f3c6c2fb22fd57e685e6b37bdca1641167af528373ff28d8d81ad4116287e70340aa764b0ea9ec929f807442de6efdeb979ee87f010001 \\x80f26441f26a24c4e6d3c123c17915c9f094f2683e17e6688fe55d7468ddcb17c41015546a31544d03e320e646a826d8fc6117e6c0c76a5ec31d797abe42af0e 1670326489000000 1670931289000000 1734003289000000 1828611289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-380 \\xa2f7c0d0d24e5253ac6c440f29bf3f0c4ddccf30ff71fcba7ed8e0272ef3ed9c0aff04f1a0cf0a252dd9d9533ee5f4ac642ba3d5262003c945c4890160a913e1 1 0 \\x000000010000000000800003da60dea85859c0580ca76db874957411a20d9b97577617d6e1c5a0d575413a597050b3bbd7121a0d70f1ebef8056f54049c3f3236d8037f221ea5743031d52317d222cdc09ed97f0bc1378a95f62829a04e04c1d9651ad82f0b8c1f4169802fcbbe5934089cb7b5b499b2259c8141f36d419c2d45a161bce3c1209d3710cfd29010001 \\x518f421862a389c4e8fece1c70a51ba6f9cef28e2ce58595817f99db98afb8ed20a98ae63901aa20f4790ed5dc667ce6dfa8240e3859e6a0d085b1981c3ad109 1690879489000000 1691484289000000 1754556289000000 1849164289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-381 \\xa35b794ba20ecf9f6773de13fee390315c2c98106a8959c3405bf1343cf9b3716bb501012ed726945f251eb3cfdffd1ed85d85b10c6e102661ba1b41488f5a45 1 0 \\x000000010000000000800003bcbbe7090ac2d795139c80518d92442ad30f205d95f27515e79c5147a62417711a71a20fc84fe10eac3a42fc525c9a286eb9ad257e732855bce2337d0f7ce8072ed368f174fd55d41a636c5ffcf8e3766b7256ca415a02798603547ffa416e55ab52b0071313a23255a2bdaa727a8f1d9f62e425fde82f21783b7073cf748e9d010001 \\x566f65e3337beddb2a11cb186178c171540ea1dcc1bbe169b3c7f18f119ff41a87dbaf6a4515f9622002ea5f4c36d5974790ed66c7f2ea4347a2975158210904 1676975989000000 1677580789000000 1740652789000000 1835260789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-382 \\xa433d4b4152d52978383aded3139ca97b13b914a25a25beb210b4905a26d490d918a19a180150373e6db4f31b16f8f9e2b8d46bbabbba877448da9ba37786ac5 1 0 \\x000000010000000000800003e16d7601bdba5d3c0c70b293b5d863e66fe94ea5875544d7f3bf2d43e9974919cfbe494fba7e6b572033ee98dd907bbb37580c7bb5528b938ab93e8c8abb9dea9de7ee8894b90ed2ce28db58a8f1298a0218871a5f1fa5354a446ec4359dae696d4aac5b9479e304a76dd815a57433172b44b5992af30e23931f92374f25a5b5010001 \\xf0da5347ec85bf7be585845afb2cb5df35c727b735ffc4673915787a9f4dbc19a3e6d92867358074215045103792eb8cdf2e9db3f15f5abb9c2e02f1f41df204 1676371489000000 1676976289000000 1740048289000000 1834656289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-383 \\xa7ef97c237be3f8f4fdac7c8a69f44c91cb9c3ee3a039c158427fae08a6fa633ac383856e47276193964bc0617d98c9d7b2cf728ad25818ea6a441f76f68fb12 1 0 \\x000000010000000000800003d107824847f416af5ad6aabf847e7e415b4c177fdb7a7273bf160366f9aeed283e2f30f87f2909c3842778c45db1b6181406d5472840706d25df5f2d71d8a900adb44055c71f5797b3f05c775b469a6f6396c9b952ec74cd0b6d44554d205120bf08cdd112d7b5ac9c6de624195c7ce360f475214b184206466ae9baa71894f3010001 \\xa58d9e80c80cc4b026c6ff310a1c44bd665c9bd208c1acaea5f7c658df51421bebf7173ff28766ae543ad44b9e43c120305e798768f9c97a58a900189af2d503 1676975989000000 1677580789000000 1740652789000000 1835260789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-384 \\xaa077bb176aab233452ad7c37ab3242a25ba006884819c1b916f27aa2d087db7f2cc37fccb63934020cd69e73ae8638d414642d9a43cd967b2fc045d4c73c335 1 0 \\x000000010000000000800003adc4985ee0f7d5aa77470686b021590fbc8f8b3854522213376830c57011cb6d0b765cc0062ffded82d17a4f2608b49b926a1894b45312b77888ec5b1a83985849c7e022cf7b92af61f8e61075d115992392171575b981b66248d9d496089c60552d8eb1239fa70bf2fe06e94c55ab574bd5ef81fa4421382ae20a290035a39f010001 \\x6fee54548a96c2ead4fd8f787e46d9b8e9bda4142922c7181a909905d4f2b2c4fd810a1c7079af5670ed5ec4216a5ca0ab535f2abec4cdb0b1b9383ee13a0e0b 1660654489000000 1661259289000000 1724331289000000 1818939289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-385 \\xab0bbdcd6b331b906800a9f931466bf021b614790e96923e9afbee6f84b7bc5d5cf8096486a313fc45558f66f69e9072b2cde89bb1a89010a9ecac8da0c78df9 1 0 \\x000000010000000000800003aeb56217ddbbe252b4437735aad7b30f7432cefcbf51a3c695e73cc3f1a55ca17bdd3e5a9085c6fbbf15f090967b7065c174327359f7f055b01707dc0967f6e0cf49f70d25cf05b974e3dbef2979ec6f3a64000ead1bb954216bc4af3ddc6aefdcf81e3acc0a316667aa4298dfc9d56a15c0076bda07473c28a6445924eb540d010001 \\x789e1d8c0789066df17f99ffdb5f1b4a13bd62e86663efff1f3ac9778748b53a5fdd5f229672e6624f9123ae784eb23cf9be2051a1238bf0b37b8b77127cde07 1667908489000000 1668513289000000 1731585289000000 1826193289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-386 \\xad83422ee4f1c565998b793596a7c47dd333cbf424621933e44f9540cfd89cbdacbc8173f288e625905353740377df698f4e018e4b038f21e7d3172a01eb13d7 1 0 \\x000000010000000000800003cc45d62448dedbeb9493dc3c287defe3c9990d038d62f9365f86daef6b31faaf1a4050a2e250afb51e7db4c1a6ef864c30cc6be968f59f181c83ad28acfcded3e608ece0aa86dd468a507d0a4501e9a2ccedfdc772aebf42489670a7e454ff14df7138581a5350917721c29cec0b8cbb96458b55d468cd6f188c5b1ba160df35010001 \\x05911163b0bb64eed6458423e68f32d92032f115eaf29daa39029537060aba62769c118aac4bc77dddd3d0c24eeccd47b2e3d4c7861cd79294d60809ea68d30a 1679998489000000 1680603289000000 1743675289000000 1838283289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-387 \\xb2878327c70b74525fd1f0114b1d7e3addb7251371e51dae43e212004ff79ae6fdbc0095f60006e4ca3b32ac0996ee9d0926a8fe6204eea96ebc1a5dcaf0bc63 1 0 \\x000000010000000000800003b7b3fc3d0e4ad9f458100ca2c7ecbb7747d7f203faac13af46de461675cea3167467115bdb5c6eb8488cb57d2ca59b576871511213e6138ab75171b44dedfccae00d151b545f9bb9a6f7c5038c7fd6a8c6a0e48036cb47499f6250094d3d6a48cd322dd49675d7204fae175a9dcd61f3f9292d24a647a016e9a336577c454553010001 \\x8818051e54a99517dd4ee6a038fc930e93c4f1c88f498085a5df330c7dc9635abfde6e3ac2607fd4deb2325c013ecaad61c885040e41bfbe0c4573bf14c66308 1686647989000000 1687252789000000 1750324789000000 1844932789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-388 \\xb2f72833712af812e7e27f1409995cc9addeb9c9508d45770858d442b9ae815bb5beb17b23c4e452c1fe78daadca7e03efdd0efd3da139b6d18656f2fdbab9cf 1 0 \\x000000010000000000800003cf98fbbed4d9209f8e40fd629bb8bb16e20b1494f1056bb252d5b71a86d7f33ac5933a6585efe88a3023650fff0c4368332efcc1e0a3717eaa4280d2ca4e10461376003222214a3bb1bac8fa6431daee07da5ce52e3dd2967681ec9a46ca1ee333d4ab99743ba25acea00b0cac01ef3c6656ea855b99df23a8b9ba0146aa8681010001 \\xc9f4258b0db0c9176ec3e5ea0c01695b111e062f40de13067d16bb854166dee5aded7422400694a1338c4a09b78dca135042721b8a5eebde20e2e2d4ba87190b 1669117489000000 1669722289000000 1732794289000000 1827402289000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-389 \\xb4cfc9c2e6773080d6f781e7238d55a1f5911282f9774b2385f13c96316236856e8cd1d63b95dcc0fcff2fa706d8e43fccd08a21e295a972fd807ce34cb8cc99 1 0 \\x000000010000000000800003c3ea652e4a78e65355cf16411ed995b386b23e5150f7d8f17fdc7ba84586fd1be87377083581e1710610bee44c412eabe3bb78d379cf8a91169150f87daa613aa0e67ede3deb9da60166de7a09d1bd7987c19945fa19bc0b2eb045b2dfa47fc3db29fa10653f39f92204a81f5ea9880e3a9781a90dee87bdd24919db64940bcb010001 \\x28e4bee33f4d0955a9d1635babdb2fd6fa9c74d6ee971e81124a37b845c2e61dc66d6c5993eb4ba97c47f9c3722808f21f4653d8b1b77e55f7fa97a420c9740f 1688461489000000 1689066289000000 1752138289000000 1846746289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-390 \\xb79728d94b215522ad5868972c36193f3125c7bc6335c7697cce38c5fcf26c86e2bd672d020cdacbef6def89e1f29f0d04ebcf708afeec8f94025ce5ca68f708 1 0 \\x000000010000000000800003b2bf86d631b6e166da6230281fc1515cc5bbceea6df50ab845aba09bca6c21d57a4e70d9f0e73fa00b5ffb32e4c546778a7b065ed1a2519f85cb4781456124d51a9dbcc56d57ef0a30124f6dc2c291cae6ee3d74755dfc58f6d07ae38f79ef88b0821bce42fc2cf926397a0cb0c213464bb2033ba9d278936644f8ee63f307a7010001 \\x5a716f7642828a39efc18a3884d9857f46bf5924e7f3ecc2bf5a1a22223a56a3402c14a986f703da9ea322185efcbf8c126449b46bce0361036807d38304fa0d 1685438989000000 1686043789000000 1749115789000000 1843723789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-391 \\xb87bf4ba9548976de41d728be2d852f365bcd7fb610b7987070226b11faf2f2f8a24ad7680a5ac809c40780332e2f837e65900fc219dd004efd7be54c43f7583 1 0 \\x000000010000000000800003b1ae548eb3cd9d95076289bc53e7a7d51981679138cea507ae2a0d6808afd2cc1579ec5d4126264805dbd7a096a62014228bcca05967731caab2cd37e3d9cb13c67635659665300bde2765a16ef2b38cb32c1b55ad572f90be44aca895ce51635e2e8811dcbd98399e4938c93900ee61f60a2e81bb3cc09946ac648825fdc143010001 \\x65c0fe48eb3be9adce4adb5b4b563d7f038a18f16ec8a7cc16ea0cf3018797501b5a690e9bbd26ad152f207c8fbb9b5bc7fcb53cc2f91e1a2f05ab456143e206 1669721989000000 1670326789000000 1733398789000000 1828006789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-392 \\xb8af15fdd2de88e3bf48df04ebb0511dc8547aca7e59963ba2c0949551d398bad60b4ba7c3e9a783cd4bb631b1e7fb3b8d23317418c05ffaec3336166b4e889c 1 0 \\x000000010000000000800003aa35f4c7059304967da7a7c5c6ce44e2894926afe89303b90cb84f0bbc5e8adab5201741521f42abeab9f29b107671fb4cb841213daabc33a72ebdab11f557ead0ef54f35006a93ada052d182c249b03d013528f45373a84a58887a675c104d53ae7030eb725660342ce940e5df9760b4dd6df5eac453229b9ebc26c91ae08fd010001 \\xf1e18a1bfe96cccc0408e86aa0c3b5cf08cc230869ce4ff4848742012fb0fd2ef400e334ec79dc6e85cb16a7370a98c027934790fafaaa5021af7912816ed401 1689065989000000 1689670789000000 1752742789000000 1847350789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-393 \\xbdf7a5c74e45af8aebd2c3782337d9eaac70f5fbdc3f29106183cd00135651ff1a61ce2bcbb9e0a12c529edbad2861a9bcf5201847babc622ab8b0714ea863eb 1 0 \\x000000010000000000800003e22559ccfa1f3fdc98e0d08483cc5d4fbe6c5c764b0efe70f4097d985dae05fcca5c34c34f965b20c313b3cc0e899269c4e9e6274068d971669699ed1c537cd4f4f5ddfd1e2a5d300abe33e2c399566c2ef62fdabb2a52d5b4e816793bd48ddf0cdd930a445851ec42b7cc498366c9938a2706e08e49aa2aa66372cb9e8ad4af010001 \\x04e9adb3bf820e896e3c734cae17b758bb22d48cac973c9c09de22354a65c055e921b1f16d77c6dc29d79a69a4485d410d4c558bacc2a13885588e1d0362010a 1662467989000000 1663072789000000 1726144789000000 1820752789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-394 \\xbe73f5a2a5d8abd5de773969b556048f251bb122ad1806ea4eb570d8b5d9af4ae5e0a68b0fa06e3d3a820306a5aeaca31088813f03d92635827b52a5655d34a1 1 0 \\x000000010000000000800003e2c10f704ccff556602e10e4ee3405037e04c9173802a6245f16d3142c1beb234447d809489c6a4aef2ce0452ed688d731a852b16f9474516bef83d82e0e839c29cc13a65a438ca2a5e7473b63f3fc1dd84d59fc1110e45746780083b45b94cf4de431a2b6bf7bd00f88633d010f090a3e3225fc6304cfd2a411d6759ee65847010001 \\x8e29a088ab9858a5392d9ca0ce531629591d15ec5b937c21f659785e2c8cc45065b67185bd8a7aef539a739eed569e61af2c9fc8509f4435719319b8593ba00d 1669721989000000 1670326789000000 1733398789000000 1828006789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-395 \\xc17734577a48c1eb0233412d56c48c4a50067d67a08b46c5318034d11004d9c39859ff783f778445fc960098edd0eddf5a7729e3923f3e10b1c7d626e1c66a6a 1 0 \\x000000010000000000800003ba21dd057d43414f294592a3fe3a875bd4c69839dad00f1c39f24d06f833b795931334176fdafe92f1cc669fa41df331a096f2c7acbeb05afea4b2768e4d5c95fa36fc2194fa26f8f64a0dbd88d2de8ea5765b9b5da12b3e2e87ebccb3481a346eec6af2b450268fff62b50acecdc159edd419e4a7174f1efee1964e8e443393010001 \\x93970c0936e1bbdec1eaeadf8f5cfe956e6cbcb01b3ff7cc106fa27f19f727d8589758f1548e4b769ad3249d2423978af5685485ef35996baa879dc089324109 1681811989000000 1682416789000000 1745488789000000 1840096789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-396 \\xc21bb8cc58e1fd52beb685de9cf255c6aac6a5c723ec9ea1b3a264777883d0cb2c049134cdf4829ad8d5d7ed7bb298f8a1c143beabd81a6714714dd964f1a8f5 1 0 \\x000000010000000000800003c098678088e15b022b503af10e838c577c868f3b7b7a373d9910170bf52fba60fee6c4954f2e603cf7f05d4863d759672f9a71cf2f357a5667bee5d607f370115b37b989622bcd2e5199afdd50560e99c251ea905b3a04843a5bc86b59651fef71b67bd86adb9738c63419c39818179181c747bd413d2d84a4ac9a626dc9066f010001 \\xcf0ccac8460835b179a2e729be9d8b587480b86969effb3d380a36e5534d0c1dbb92ba9bc25573c86499fdee9ae277102234f96be3031d6b5f2c5eb39f1ad302 1681207489000000 1681812289000000 1744884289000000 1839492289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-397 \\xc98ff2a87e255862152a79c293dcd2fbd0f38fd7f87af2dd9a69b070d3d19611e549428250b53112307db65bda920556e5d76f228a6d6ead9786ee94c9eb1c35 1 0 \\x000000010000000000800003d0ac027078ce45f342c28c7aa1b473077c6e4945438c7cba42abe383d208c2d59cb2cd5cc084b9788832483a3a88a4eb292915fed2be7516ecaab6379470165a718336d67e61b91b4c79f54e79d97eec52a747635f7900d11e77a31c2dfee673375e34478ebdbafb8776011517dacb80857a24d00b7b0e3e47a7b3db5882260d010001 \\x174aba72d84ded1e1e4dbd0808669ed699e7107998d3092f8ba6e514d2b37cbda3c314d3517fcca0f911be8ec33ee6843657d54aecb061e5514262f0c91c5606 1675162489000000 1675767289000000 1738839289000000 1833447289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-398 \\xc923f14535e4022c8c1eb48f8b79c05edc14631defcd2ff26d4d038476488ca9f6ab66c6f0e14166d7bb84d49b0b0e0b4d3bde37bb4d736678bb11d5e8f4b25c 1 0 \\x000000010000000000800003b83f2e1ec2fd0163b1a16eaa408380b8cd21d4c9359202878adab817b26978e72a5e6f7fa344388d9dad87b3dc46f0dd2c317c89ed6fc54b43ecff8b8429ec0855f366af0d24ccbd65a2e5af9c6ca422939e5fbeaabc4631cc695cde6700f882c40ab257188145072496e4d51f76bfb88f9f372e6a2b763191a2a8922fe769e9010001 \\x5adb72c5e5a975f0768520f7ad4d73df48bc1098eddc01ef180b4751641192ab9c4357d01d0956173ab1c1e3952dca66df6d533c690fb2ab1257b06f9be3f70d 1678184989000000 1678789789000000 1741861789000000 1836469789000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-399 \\xcaabeb630653d248c5f68550221eefdf5ada11b9626b31a230501cea3abeecac2b61eb2c30ff74ff819fb008555d6c23a3490efe01671afbbf7e911d5e1917b3 1 0 \\x000000010000000000800003c8719d37d3416365a718854a5c40b8315d22d64de6adad0eae147abcb6808304bd6bca0eef181f3c11b5489aac98bab2b278f720064bc97c0517c3dacd9b96fd209784ec22dc3e1fdbc43691d8c71d0fe2742015ae3b09afe10094267eff25fe0dc150c144ab49fed6efcc9de03428e5371c44251dbbb8d1a54d501e2a4f5935010001 \\xc39b979175b9b8bcde4656e2fd0a3477a47c7c844a971215b9caea513e34eeb0e8445427ebc4cd3ecd852523339aa1ddf47e5c949dd1712c42c040188832d90f 1689670489000000 1690275289000000 1753347289000000 1847955289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-400 \\xccbf38aa6eff3e3e2cbe7e59f96e0f143c1bef426639a2a2b87209f4ff280645b06ad55cf0b4eff407a0edbb972ba17d60325c750c453f65b61e2117fc6b3f3e 1 0 \\x000000010000000000800003b38ed97a9d4fdb071baa6feccc81933f924d992dd91f843221ddbbd99b515f0f32e16970b13069b9568169dd3094e25c6c64c8c982d94644e6e2144f917d6559886b5f281879ec3efacc759438d0d41da381b05d33a5f6e2eb1474354cd90965b3202d4fea73f35667a7f7dd9bb638f2a2396ce1fdb5dfdfb492072c1c15b68b010001 \\x0628ffe46c712d24931bd82a71063a4e67cb6b094c4640b11c72f510cf2af1662c9f1a5efce2fb31ca6ff0a7db7e4492b7c067e42646abb38a10523581a23b00 1679998489000000 1680603289000000 1743675289000000 1838283289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-401 \\xced750421ca6b72a1f0226ce06b4d816db19b369897b4a53a0a599e47ffe79a1ce8bf0f445cb36171275e289341ad4a010968c5b9021d1019810180a035babc4 1 0 \\x000000010000000000800003d71d0bc0fe7a98cedce5bea9fef031fe2910413448227f8ead3bc0acb031fdd690fbc3e711bdc43a6e3b11c60d9f5859856657abb77e32b3e1ebb8b1c8659245493b509ad5709ce6d19fa967ceb5b359776d3dcab62bd2b68c59c16d34e8040e9a308e2515958ea6b6ae160fd60023f2954b40e00012027c546aae9d4b1ceacb010001 \\x36b59cb5fc7134be556b5d80f6c257884e697beae78773b1ef81a39d0a0d5bb0f990a78de60a9606dd02fe5dfbe5a586fc17de90a98cbe351554e7fa62790303 1688461489000000 1689066289000000 1752138289000000 1846746289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-402 \\xce5f19f9e5cf8e3be91e2f23ea018c431d77d44a5d9bfc94f9007a0480bbde2ada474418da15167eeb6f58aa380b3c374124cf5110849ce061b9f1d28b79cd7c 1 0 \\x00000001000000000080000398ae71daf2989a0846091b2646522c625fdd8ecbf46fff18276f2250e138c45ad23523572a4f0c6ba6a3e087b727087513821c5b6b0b03f0313bfeb560c19ef87c411ea2649237f2b39d7c1e0dd9d799c430f554759ee47910ef3c32d327a6c805e586316304c411759f101e94536b54e4f4cdf09cc1f009e615a5c9c04877dd010001 \\x289c93103158f4c147569109beda1994f818247f157a64dbda44e12d7565dc2ddf22766790f1b67ab8a845906143e439ed6dcda9d127c2f217e6aab4e5deb40e 1675766989000000 1676371789000000 1739443789000000 1834051789000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-403 \\xd03f891394241eed12b12eca284f0179ef76165f3a97bc2551c9deb2f0d4b25a00ad3ab63347a3d24598ebb76d64e7142960843abbdb95e14c9b5585e890609f 1 0 \\x000000010000000000800003d384dfd4af8768321b665aa07527469897d7eb48bac485c98674c6edd2d4010700ff5a696e4ec0eb76b9fb2d6e7c082ca82f3aa3960b40c642ae178fb4fabf5c3b912af15e7c17181523978803c3c7d3802bfde8a0e77a83d6fa28db05b69b3a462d2fb26ddf6bf851b80cd3bd3ca09e14bbbc5438d73cca0c3183a23948bd71010001 \\xd509fce5db1759890bcb238e5f3b40f036665e29a85a51d1a076c6962140ff93310fa88413712278b3bcef74783acf7b664e4078d5d200c3a1ab93382248070a 1686647989000000 1687252789000000 1750324789000000 1844932789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-404 \\xd75bb1bf2813d8ffe3cec9f6cd9d58f26220b31fa0999f97ca3d02c86390f0612d309583379c60b7ff3bc6bc8bc42afbe7c297e3e83301dc67617e5325ec4873 1 0 \\x000000010000000000800003da2cda908d2c01feeae779403b7d5424d1e0c50636d9b09daec40e25d74e9fb7050093524071505e8c14042438a8065e97309d335fd6e7b6b5b4ea6a86b922de0e7db47e83089d4398ef4862abc0f3353d160afcf750f0a91f76dc2f76a82df8d44d16ff1869daa88cca9bbeb4008b467b4bcc94595daa9075eee77ad422447d010001 \\xc067306b1d8e1ab145d5f11b6c4ee78a578b7c35529afe4f8fb717ac493b228ff25d20a5a8c6d27a053df2b335be50dcbba68022ded2d3255ce08e4e2a79fd0c 1675162489000000 1675767289000000 1738839289000000 1833447289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-405 \\xda8f1f404415f0fab653f9ee5e52370661560bc839e18b4537d490561bb4db5ad956cf3b6403a55f9908ce37db3f2b23fc31341579408d2de3956be8cb7c689a 1 0 \\x000000010000000000800003b9a5dd6122901b9a9630f8ca979d228179591b76acc787e76827c8db50eee6b7916e1c76f22bf594c259754fd8a1da26fd5e5ebe3fcad974da0f67f6b542a3bdb8d41440a759accb0abf12e2f7d01443c3bbe992a2e010cdb5a61c0774f6babf4ff7cdc0350128174d47830af30fb92aa951461b01a5937d25d6020448f9092b010001 \\xfcb4d9cab7671fc97837d7cf22c901af757ee2a7c8affe73bf392f75bc76aee4433a206f74023240b642da4d88cc2654c046e4207165ca2565651d521a56af08 1661258989000000 1661863789000000 1724935789000000 1819543789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-406 \\xdd5748678302f85cfc284772d38561adefb84f1f6ab38fdd0644de2f95b8fb91edf1a4fdbab788fba2998f3bb85f17f07fd93a141231432ece779e1c95c2ed8c 1 0 \\x000000010000000000800003bfde48d1c3a20b6c1c0fed24ef9b09d6981c0adb70c48da4607b11f24109748bf5955eee9f61fa8a65b82aeee6c8e5c26d2c6b613542c7e7730fc38315487b4684e035e08ab6615fd54b3f56e661bd35dcea04b32f6f92a24bd7fe9067359feeeb4f44dea59228c7fb2100cb46ff2819e6e9ddc3abef065f7f5acd91360dad83010001 \\x7c5c52a73a2cae0adcd52ab04c3f44cb008bc304e6ad0276d5ded917ca85071827b643eb3375699a17b1f26ae4dc72e49c643228ae9face6e66eb79d2033be07 1675162489000000 1675767289000000 1738839289000000 1833447289000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-407 \\xe30fb6ce11d70ab8f5c936ac40dd46671fe6fdbd4621917d3d1503207a68ea5b60d9e3bf390d5cda366f701254cbda1375a329138de8d576c96b2c33e0519154 1 0 \\x000000010000000000800003aa192f11bc1b3341b3193e757bdc7a671db4dc836a0d5b8be836dd1bc7ae7d85018006a802ab2c10f442afd7de6cde9fc19cd5bdfb79b1e376f2a6ade9b0136aeb75095d271b61f5b568ccd0a4b15ff0dfb5fa52e655d013cb8b32e875764a12aa77af9c866f26d9662da169c61591e23321f8828bd5f250890f7b78adead211010001 \\x799b7bce285251934cabb470a074e58e6eb409fcf953f41f4ae2b3aa65c1317944ade7fd323fd837c3b7a2fec4dae5384e93442bae74a5ea3e7fbcc3336eb407 1676975989000000 1677580789000000 1740652789000000 1835260789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-408 \\xe5bfb46526093d9df8f01a75b430855058d90e71c20577f18c33d30b4f7c20f633b9445b1db22fd5e33ee09e0fcf12b3923b492653682c96f0b0b8a127de343c 1 0 \\x000000010000000000800003ca858d3edbcffd77885a2891cd79cd60e98e918b6de58380281028fb1651bcf66f56c3f1b49f2cfe95880235b729d2c936d20e00f64468db58ee087b656a9f2710489adf97a21354f5e3f5fbdd6862a46b60c8f1bacb92ba1bec75a165cc176b9e7718ef6bfbdcf8bfcc2b6bcfba9069cff56a0c077be13be77e7556bba5452d010001 \\x7a320e7cafe3210291fa21074dfdb18f01748c19e6a5dbad5ee65505e3eeb164ce003098a749670a847f072f0dac61316a82489e48383810edfe1daea824cf07 1690879489000000 1691484289000000 1754556289000000 1849164289000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-409 \\xe6871793ffe80d5cfce9ea19dded3ca01ec23e95cc0d7373acfa850d9f21f59884b896191ae5c83ae5c772a7fabdc3d83a9409c2c02500408e68db595b62ef94 1 0 \\x000000010000000000800003f2c3dc38df6c124a76f79aecd53d87d8a37ddcd98b580a977b87b21fd1202ca95beca2de13790d9d47b84f928610d85d46d6407e48fd7a219381bcf3e51fbd1c39c2f111aaf5679ddd8916ee95f6db5740e2a5064e3ee5dbcd2fe22dc13c8916975407f46b87546be982cc46b9dea2fb6ab9ce3df1dec96c24f0092d716669cf010001 \\x96a8b1e53a0c9b35cf28acdc24f0a929e06e54cc8eb520498e74f1628eca458dc0dd1818d07dd4ca27e8c42311cb36d88dbf17b59240c574e21d31fd0767ab0b 1667908489000000 1668513289000000 1731585289000000 1826193289000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-410 \\xe6d7eeab9af49214d16d911ceabaee06e3668ff0d6f9141d7621541032537b195800a163587a6bde35d4ad5147681f20946fa72d73fcdf5c212e3056e30672a7 1 0 \\x000000010000000000800003b10ffade5855437445b647e896ce5ff17361b89c8aa289313ccc7eef5803ba5cc53061fa085f0c17b427a0fc1cf3b3102a6c00c9ce4b2521b46fc7f790b67d87a4ec92171e3f29d7b0f572a8bcb6bf284eeeb6a180e983667a4914cf9a7c3237dd4b73d1bd7746966964e21c4f56b4b4996fa0d61c2d1cae79838d792d72f803010001 \\x4a6c14fa5d1eebc96bf940d8e7d74e49b970d3bd1c71b5df794f3fcacf302d4118684da3511db77e276ec957afd40cad0b801aa203bc4bc8914164c716bb7d00 1682416489000000 1683021289000000 1746093289000000 1840701289000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-411 \\xe79f57339151e1e4a64dc73b1899eb51f5a3e35216437c44d6681332a4157fb9b62f37b752bd5f818c59ffac70c0e32b08601d69463b1c7d715370978611d56b 1 0 \\x000000010000000000800003d9a62db951d9f2c7138c5ee6ed47e280f85779211a9ee63084c914e98c02f7905e9cb2eea5c81d1ea2b3ccd681b5f2a53138973c1fd53e0f18d196ebb6576dab861678fc789d89e42bd2dd3af210d9becb837861aebf9eb18273bbc11f4ec133433cce59fe9ce67a3b9d50f38aff911fb2a2b42f2d259325b0416b9127191cd7010001 \\x47c4b69d75e22434d3d26b1ca34f1725fe55aa4b35b316b154ffc8df8400c27586dae5bef013a83b011956e68084b8f13ed6406e2bd0cc7a12d1345b533b2904 1666699489000000 1667304289000000 1730376289000000 1824984289000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-412 \\xe8e7260f08116ae3154ca3ca698206e9bf736a14ce53b855a63f266ec529cf75bb1f8a3dad4251d02d5b8c3d6609136a8bd691ae7c53f1e1c8486a41ab91600f 1 0 \\x000000010000000000800003e76a9acb6fc16afeb14552eff8cdab7256294560d7067f96ea96e87857d4c48e7512f4cfa8b06de7253aa90ce23d8c4f40b15d34168894479090532734aa306f417da4c526340fd0ec2d325c3b18b643fab97df1b0eb694121d6654de78581f1a80b7dda3b55c9803bc7a0def85de4cc096ae95348a80eb9e3b983e05fbbe13f010001 \\x1ae413a6c9f360c62a15e3bffadb9a89c0a1e5e18a0acd746965c83401be0150c3f1dff290ca6046aa3f40da5853fed399515bf3bc0eba90f13c129b64a27906 1675766989000000 1676371789000000 1739443789000000 1834051789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-413 \\xec1f5f2efb4e2b8d44e03adcfd3c229a17fa6c5447c53859e884cdee84a1d5c83b14dad49adbd1324a4979c7ebec2edb9059ef8f5613adb9275cfdaf201a0098 1 0 \\x000000010000000000800003d5396beaae87bc0564a9463f3748f4e15f755e3943f7f841d450b9d25e2d7b065764c4426b8e1c08aa458b36e6dc3a18030f0e13f9dd037057cf122308b96fc31e404cfa0989f83b277179f9d6049dcefa239fe55a20eaa78b88540d66183cb9bbd007b2a9c2e936b5def898e51f1e63acfd02a1ca8317f2edeb9edcc28fc427010001 \\x693b44ac621ce68da56bd0e2146f3a084f582592f5db4f30a73e4b2b63dc8ca322174f957c0f98d43929927a5493f6c6a3ea23587e391ffbeafd0f0a15d39a02 1687856989000000 1688461789000000 1751533789000000 1846141789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-414 \\xeeeb6e7de5178032a4fd8215324e0d6dc0e1d1c67de80c93a875c1c953cda0d51bba48b9c8053c227363e256651ec4a5e1b693fbaa82269a7665f19cf5c08ac6 1 0 \\x000000010000000000800003c7a96fca0a95e79bef38574ebe95caf203b927a89f5ad33a2e30f1d1e562d4b02b6495dc92891bfb9c148e935a07c6cb6be124e7da6f3783614fe27459d48e5d4e8ec28bb204462b6569c56c79689ac496cdd9de681773d4511a7ff58d72f6572ed4b13ad8f08d87692d212a270f4ea1b7d8b10cf0d65f964dd8d71a5c759907010001 \\x962276d335b986d5e7e7e1ff58eda174b07c2796cf5ce78e4407035ef72ab1c3d3c6aadbbe3b24e36cbe9c891eae2775983ceea3621f6432d93b23e68d366407 1683020989000000 1683625789000000 1746697789000000 1841305789000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-415 \\xeef7885d12ea6bd13593239b85de796499a149cdb70823d2f5e8497cbcc74c9fde6a7525cd7887c2a935f53d9219752559e7e2feaeaeb5da2ad962a074f6aaa5 1 0 \\x000000010000000000800003a6d333e6558976397f720161848041ea0cbb47e75e300e1f051cdf1a6143f5ea1699018e7cb82f67ea664938aada4362767b3704006bff667af948a0a898e6e5b445b53cb026589284b7d3e4b615a3b84259dc64646677947412c0343820e73f9e94d77e23dd7d7d42c045be1dd47645d54b602d4b498beda41b3f75364be183010001 \\x7c8942682ec3c75653a8b99a3cb27bc85b3a65e0cac19f206e466d2cde2bcb55e0cd4e2e1cde554522fe4d4dfb3b0643a16f93ff23b8e83898dfe0f76dfa0503 1672139989000000 1672744789000000 1735816789000000 1830424789000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-416 \\xef6340c6a696b5969bce507f0fbe123e0ad44b9e08b5512026e811368a87807342fde1d99e667cee1df571157e70aa7cb420fedc03a8d7403e0baf82ed209fff 1 0 \\x000000010000000000800003b71689cde19128e9abd909ea11e0f4b8aa01539ee45e3dbf75a5fff722949009804f0fd3df94fcb23efe2f0996c49b389530c5ae2d5b1ffaa1fd50693d9a2a4b687591c3baccdfed8f9035ab42d860efa4cce45c2100af44722cfeba2a0dade6f420ed5481b1e8c15cfbf4986b6ee05d8ee821bf4b120f43cb970f6fd2a559cd010001 \\xac13d6b3394a32c64ca3080ba37193d055b38a571cc6b573d55b11e3aa4b75fe83fb7a60da50eb8f2e3e834482788e1b575acc88003325bbefeeea1b7c58bd0d 1691483989000000 1692088789000000 1755160789000000 1849768789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-417 \\xf1a37222fd8d4e84b1d24d14efd945acfd0624370dd0c81d8389a742f359a15ca5a8a0e065013ce9c0e1e285927b76ee56ccc19d42441bdb90306b8130a22633 1 0 \\x000000010000000000800003aebcb99991844c3f95f54ba167603df4b8122921b8c86695ee4cb4db1b61951797f92618b05f0738b8421b1137f8b70da290fbb9eabfe8ed4b9afb8b191f5d0e92f407923b475705633ff1068c273f55772899b538aa66a4ec50ee3b5a42c23560945b79307caf35d0d73c2021c93d40f8bb8c832a852c773cc1e45c655c61bb010001 \\x84644086d89242221871ff1dd33aea8741ea737c96c1876252b2075b79e4fcb75e7be5062b20505e09b4fd254a3e2809b3aabbbcb2e833b71cc7790ff78d2c0b 1673953489000000 1674558289000000 1737630289000000 1832238289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-418 \\xf2b333023b3ce79ed1deb60f9f58df2e6401ba01af22af070b42e0babff82a916bd6256e54173478e4c25da036943eb5260fb5424dbf929d7636494f3ab904a9 1 0 \\x000000010000000000800003b5706539afb5133fdc5c7023621a1527bdddb8aa53da2bf8abc21b96fc947411f085b4b8a61a2c3271d4eb65479126afe4fb9b1dbce84c57d110a905d0e4febe7b34e4ec0e13e6cf056db805853b5e6b0f83638da5a1659e83019ec14dab79d6af6820d3c0fb32a9e5517893af1a124f5205654747f9a9ff451da080dfb6d429010001 \\x06d000297c73a4912e7d7e7f95eefa965004afa6469a13c404c26173ed848227af3ae9f4919c1402a795a2c4ca0c90f70fd5c98b717232fb1a9ff30a9a6de404 1669721989000000 1670326789000000 1733398789000000 1828006789000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-419 \\xf6e75de99e0047b919477952a5a0fbad2779b958c14adbaf6a0a2fa057cbdbb29999043c1d83b901ae8ff5a3822ea3c23f7b23edff90722fd32af8077a9ccacd 1 0 \\x000000010000000000800003b0f71ee891427fdbe8ff6088376ae28420471abcccea02a234d428a978d55bcc23b1111dfdfa7a11dd1fb0da75ba9975818a992361b453185643d627f4ddf42d4f195ce8e930fc0e1af845880f8318f85cacddfe898b6e47f41126c549603da1fb5159a1c8f60a50564f20bba68b3fc9301dc4def9cabc1599a35048809c2429010001 \\x69fe4a31b252d33a392e8e57528cafd3b272c3048be4a04024d579497958842a250c947d6c16b86877e3f462f656e7193a3c994a20a5920d4d8401861039110d 1667908489000000 1668513289000000 1731585289000000 1826193289000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-420 \\xf723bc3d3c0754ccdc976bd34a48b7a4da1c96290ed1eff61b49dafaa3c0b09a8cd3bb45b1af0c6b6fe3e31acc3dc34248ce6912079657365c37ca4e78f1f3f7 1 0 \\x000000010000000000800003b0294c568f7f33162fafa9e3d71be42615a5cb45a20464600a5c288253051546fe56f0ffe20483135bb2aecf8c8bf11925f597b96ff6ead022b3e45e4c7b6459dc916f9f0814e279bd753568e3a378bc50244e982044ee8ead2fea7a830cfbce5e36554f82ddb0a7082657bed01a40437791b79e87ae72492c8994f9500577df010001 \\xb7aa7c5081408c98f7306739758421a9923fc9e3fc73de84379647e70dd9e36a4014efc141886da0ce7aaf81553cd3af65a16d04ccf41186cd76096cb4fefb00 1664281489000000 1664886289000000 1727958289000000 1822566289000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-421 \\xf87b10d117daba6cbf20f3d980130234d322141e505a8426c55b328d02896c14b024505a7a3cfbe5b7711ead87bce48291dd5e3ea5d1c2df93442e80bf150672 1 0 \\x000000010000000000800003b346c5169b5400023a73f948f88fdffeac7853301c4ae3c54fc286bf117f7e957443bab79c7c1d030e0378411724d0fa455eb71587dee235b64cfca6b57039f898098113cbdbf68096eef445c309255dd14ccf1f75834be52592cc20b5b4415859d4a828626a1dc9eaab2016dec870d484e76f21222c615e80f62e44f7262d8b010001 \\x0b2faedbd78eec96a5414fea2553d62fe96cd3001a5297f60902ae83ce4cc80b2be3c4dba69267d4a79d03ee92481be324a3367914715881ee3eac5d25b31905 1668512989000000 1669117789000000 1732189789000000 1826797789000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-422 \\xfadf36733a826837a775b9b2a3d3aaccc958d2659f95b264c4505dd17425487cf4cbbf18173177e3ebc67da8d7105886aace28e573b311fbaa56c6d058bd5594 1 0 \\x000000010000000000800003abdec24cd2d664f9847ae99b988df7674ad98f49b1f8117702fb19dc3bb6c7324c68c0b154eaf754297980901eda5d8ad52d2bb7f3e1bde1469622af4375530bca13bf44809cd1c4283d71bc6ef798b61f0ffa23fc25395c42fdfd60c95bcf171cf04cc849db21097c2e31c5209a50151d56545c1420fe877154d21b4db407ad010001 \\x17d31c2dc44c9d55641f067f8a185fd1e0446cd1e148586303a3e4bb0499a64374518b3da361b5253d8cd1e5ac22b9c6a36b7e241f1987f96554ce9aff1de208 1689065989000000 1689670789000000 1752742789000000 1847350789000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-423 \\xfc5b3e069a61da03a68e76d8be66849ec4861baac04d3dcc9daecfeb8cdaecc59d1ae8c822d3342948f5043e689cef1029920ec47c0a9178e4294f21318fcfcc 1 0 \\x000000010000000000800003ca6875dcd07652196c8155356c7f632ec93b89f0f10f4bcc67fcfc47dc5f0e5dbd36c6cc327b821adaa4ad81591edd52dad0b77cc677e79773fd35096e02baf6c81b53d366c5eec25b57a136f81c5f31683c089a5107f441120bcd38864051eca42622312af616c247fc283e5e025d0f1ad846fd1afb418200e725af618c4b57010001 \\x4ff18d7ab7c05aa6b3497c9babbf1c2fc7e96d873df79c12e96e1d4a926b036b65b2689c22c213cfc09d6114d30e2881e74ac72f24085089f8a77393f118bc04 1678184989000000 1678789789000000 1741861789000000 1836469789000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-424 \\xffd723d689efc566fbebed594a21a06a5fde22826598d92c175a36a3323ac9a131d52e54b7ba8688b4c7b5f8007f5727c6b0aa5927a24560cf86ec46289be94e 1 0 \\x000000010000000000800003a769252d8d8411e8b021db5705c47bcca1f4f40a5b7d2c7bc3c7c4b48d57ea695e7e341dd1b0986dbb04df64b728d5feaef62cdb42166b9e8b9477c69fb0eb3af1dac305d15c38885522aa5ee91901e14d47669e93c18594f58621445873d82c0119764778c53caa8983011c295f4fb89049eed7384c1a42c19593e7d4df4de3010001 \\xec7c1a702185e06e5ea994a715f28fbbfc59038f8b4b2165db373b4335880d6235b1d2da26ece0fad4359ed790860e1bef5ae2f926364240d7d66c03db848908 1686647989000000 1687252789000000 1750324789000000 1844932789000000 0 10000000 0 1000000 0 1000000 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;
-1660655418000000 1286140963 \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c 1
-1660655450000000 1286140963 \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c 2
-1660655450000000 1286140963 \\x08cbb6eb28062d0ee4ea289196cd77b6fbc825bc6972624b88c5512be2e55fbf 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 1286140963 \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c 2 1 0 1660654518000000 1660654520000000 1660655418000000 1660655418000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x00cdc96040fdb55b71f39af7132cb8d53a818197207e1160a403edf2de1588e579dd07e454b85706ec6df8f07fcfe773dfc1a5861f8eaa7b90e20ada26986c50 \\x507bc5d978ee1b4a2c0c032b05aa91ddebbd8eaae1c26f8e53d02c5f685ea9322ba2547c930ae4e627ba91229ae9e363ec7b594900cdb1db004b4475da13520c \\x08d3af20dd4f3192c2b79040c703b7d2 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-2 1286140963 \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c 13 0 1000000 1660654550000000 1661259354000000 1660655450000000 1660655450000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\xc322b4ebdf16614d1c5a72ba91989486cda1e26b02ef26d105f71bd952f2f22b9f798dab19b98bf191c662338f571a6c295caf24ef961390262b67f697a5c7c7 \\xfee8fc92bdd8d0f189f27d7978ebc2219642563e0af5856095d7f4b7a15cd14b264d389a58006fc52c8ab6fc85d59828b9a3f9ec0ee2016bf8bc4a9228262d05 \\x08d3af20dd4f3192c2b79040c703b7d2 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 f f \N
-3 1286140963 \\x08cbb6eb28062d0ee4ea289196cd77b6fbc825bc6972624b88c5512be2e55fbf 14 0 1000000 1660654550000000 1661259354000000 1660655450000000 1660655450000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\xc322b4ebdf16614d1c5a72ba91989486cda1e26b02ef26d105f71bd952f2f22b9f798dab19b98bf191c662338f571a6c295caf24ef961390262b67f697a5c7c7 \\xd7a6346c5d0ce0e6b1cac5534bd7d98c025b2efb5ae6a35505ed54d4c7e53784f267478feac143ee5feb629a2f7ac1bb2a85b6d75753fb92b91976311efd680b \\x08d3af20dd4f3192c2b79040c703b7d2 \\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;
-1660655418000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c 1
-1660655450000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c 2
-1660655450000000 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\x08cbb6eb28062d0ee4ea289196cd77b6fbc825bc6972624b88c5512be2e55fbf 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 \\x811bca6bcbe1bfd86f768d8f5917a0119f9006bac645b532ac39076b6e540453 \\x2a5114e54b06bca1ac06f218b69dd18c418d0b09dc73db5f44c61c195515d6554b5ee765c4ff151aa9421a2b0b13e934c6f26ba2fe11fe12bc823a4f640f5c06 1675169089000000 1682426689000000 1684845889000000
-2 \\xc32561194b4b6682cb7029e149cb59c85de1968e440502f57040754b2a678892 \\x7264213ac164de65e186b021d57d7cb94ec27245ce25c0caf460ff9dad3463d213f644235699fd4cd0a4150f5f3d92c99da5d6d4d873ae93dac4407775bb6d03 1660654489000000 1667912089000000 1670331289000000
-3 \\x50c01d5134ad469925ad877b9d6866ae23b0655c41705b44880b2ad4e69f946d \\x08c294b061c552a32f348aaba6b55d03f0d1c188be276e8f3cdc0e4599fd714730e25b91a785110240e5fa9e8cfc6b2432d27fc68d1d84f5ab2e083a42fa5a09 1682426389000000 1689683989000000 1692103189000000
-4 \\x70dccf9873559849a59c15a45dc39949ab2b6432936a14148d0a8426b4ef4230 \\x9a155de882455e0bdb4f8dc71954a88eb6e8c318f3fc2a4015a33dd682c23211fd7877544e5b72cb4e1cce17fcff876abbf34cbc1720ce869ec9d159d02cb900 1667911789000000 1675169389000000 1677588589000000
-5 \\x92b6657d3608b9e13fa32373bce1aed54098deb20f173765179fd32b3e7aac71 \\xd10e81652ef36461c2a69d6cf00a2d4628eaee995b63aab78147a163e76e609ccca4cb28637b76e87f7b2f2a0309bbd87e093b9e7e39a0a264e237ad52d0570b 1689683689000000 1696941289000000 1699360489000000
-\.
-
-
---
--- 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 \\x52c2ed8fda0bf03a86a1289c1a2d3a30f591b3f97bdcc68fb0d7b7c82614af9d20b998478bcff9ce16d70960df7d971d6a413db287b7db6f0725244478b2d805
-\.
-
-
---
--- 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 3 \\x81e52922cda56c38827286da06915f63d0680b91eec0d8562c692c484879e1e9 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x0000000100000000af4329dbb51890fad6fc5fb289d6980ea59725a245d2f5b75bcd001b84b45b6ff14f63899abcf8e4d0f8973986e38f54c7c167a19cac9bcf323ac4d2706ef66f757af1c6d247960ed4cc5344490c985da9500de54865c9799294b117688f1fc58d0fb8fe916b48fa4d70e698666aaa4244149512f5e52fccc2e254959d123365 0 0
-2 384 \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000002003eea973fe7d507355431568a07060c4801081c2bcac30ac171661fa2ee1e8061fc649c59afddf02471c0164ca9f4f4ea40909571ea81ddb0ea0f041e2adf505cacd9a89b788392b32c215fb7a12d91a96a434ba47eda9bf2d665e4b13a3c8f6a1c6ee6ee4129a5156d4b229f551c5d80006e90550d28ddd2abf87ccc79d90 0 0
-11 228 \\xd4ad63ec6d13117d9af8e2b35950d334bdcff9bc2299a1af23837eb81624d4b6 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x0000000100000000333823b7dc9dc8bbba63e1d4508c402239121b75e7bf421bceba01bc7dc947becbc1285d6025351cfb5e64b50c8e0f6bb74472d316b86ba3b43fb76f8e2df8e28daa7a851f3c2b8cc0ccca4a2e9dd7e08f1ecdd182f096d4be255605916c54edeeee2656449c4228d620e5e71ae497e294144cb189fe907b7c41c40c75db110a 0 0
-4 228 \\x3e1bbd733c5d49f118fa8e1f37200e469f903282520956f8f2e1dbaa38536b94 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000035b038e0001022ec54b9249309487742793351e642446517949c1e4d19e32bce74c470b88c87e5f35469b8ad907746a3711365898ff5e34f8190d22a2b422db26c3ca75e7b3da792f180ab0c55aaad8d024d9c428cb03a5aeb2b6ec1fa6b6c2b96cea79746fefe17eb38d21a49cb5f6326798eebcf2fa24dee96b730e27d381e 0 0
-5 228 \\xf12e19044b7c6c87ca6e2c2d29d4e032863aed6e5344ba2cfca87c2a4955a90a \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000061f84c655f893d126e0a17c5cf49f27aae622a9319db3e6d0ef78912920f76927f320f06b36a2dd40519901bfe566c308f69dac16cd3dd2e4d8fdc505ceb886f86c43192a5a8a22be9c0852b244fa313d3a96a07060e25adcabcbe92bd4ee49ded86c6f142bcccedf6db011115a3afb5be654d96de79f0acc6a3328f9b46c3b9 0 0
-3 104 \\x13f3da5dada4e71d1d2705680f0949426d5729b6746c3fb9297ae081706dd2eb \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000073c13ad622193ee1f20bd6fccbd75db4f145502e13ce648d13f60041ff21cfd3bb868994e46c497d52a8ac576d450ee05b5bbdc974be286289adf6568dc0a1bd434a6e4dece2fffa5082b7942f2d22a29725cb60ba08f24d3480bf08f82e360c8ebbb190d9502fba630862e2fbddffb21c447dad4e6a244331328282f12d0310 0 1000000
-6 228 \\x461655a76851395e6af54470944918c03004e5e0ac6c9b2eacc43a513ca37e8b \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004be2a747e83cf48adabc27e2807fd0fdceea81c972981eb969ab1b714b6e3a3b47175306db5468de7857d160116eec5a5cdbb78d2548ac151270009421858395e779684be65b605c0155b56c463f8421ebf26d53f6b8866ad3514aa890aede01f64b3fb82cc79b396ff31f645d1cc222c75fd58eb948db9fb9f11871dac65d5f 0 0
-7 228 \\xc149761685a06e3c38e9cf97e352f98891130157e7d960e5ed82c525585b4abe \\x0000000000000000000000000000000000000000000000000000000000000000 \\x0000000100000000d104b9ce01193f5d63376d944d1807283ec5929750df99a6dd19f803ab6f012b1b884c930d9d9d4e8c406423155b4704a87d8f4816dc15ce90f1c087492ed9879c5268f17e44e61399f9cb81ef1fc5a20898622fe5b0df98f5ce2a046f55aa365d36e64db9da0d0f5a5486e19b36c2bddfcf3ecd95fb9f715d38738440e8161f 0 0
-13 193 \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000006fc9be5adeadd985672c46dfe75095bed8687dc79680287b832adcd9c18fe9fa7d25be2abd9123587027b88833a687dd2d5cc8b229339d86daa894d9c4c7ec6a2fad493e6f65843b8c50965feeebb71b562ae4a4db0250d2f09c3e91c8167dccdc6090918e2b21c2159ce3e131de2f22a4e8d9ce3ecb620c2317008cab1ec2d2 0 0
-8 228 \\x72597e88734b124f2b6898f990dfe4968372e066a71455f0886f141c219abfdd \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000057cbe2cbebfaefa3532514705b8acc58c0101966a63cd1ff8a8bad8002b58b389225e6c11c20711afa7536a302fdd648094381a50baea6f8dfed47d44f26d96c0dcb19eb27f202a181a9dd3387dda8bb6bd1877dd31978bf4c370c3e3e67d46eccf430e9ddb0e7461a4129a0828e5a7f80b58bc10ee8fda061986fd072ea528d 0 0
-9 228 \\xc0e2f5a7fb0b4b8c461c50b95e995bf3e0e7928b4f725c8cd94d1244d8a9b1fe \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000004c579eb7084325a99b9000d5106843e59c58bbdef6f145745e3a23814238add0f4fa16bf19833f33b703b9e8ad25bddaf6efbc791bd60000bedc337544e67a8fbc9c862c321bd016923e32de3163b69187dd469f985872929fabe182b9906441de85a308c95ef31d566652e1da753e210c15507c1543998d92b74ed0a3eae35 0 0
-14 193 \\x08cbb6eb28062d0ee4ea289196cd77b6fbc825bc6972624b88c5512be2e55fbf \\x0000000000000000000000000000000000000000000000000000000000000000 \\x00000001000000004af6bfe50cb21de99e4adac02c1befb9b0946dfa791da29abb456ab14f9da509ff0149ca250a762ed67867f5a8e932e97ac5801fe20e05cb2dc5dea283c49845bb4e8552df26adf222254a0c765ea287880721d9d2156426c47f9b9b34a88f6ca37011f16b08100449a50adbab27d7b313fe35ff58b91bbbbe89dbfae8876162 0 0
-10 228 \\xd27fe1d9072c9f90945819c6facac13c61841e64dcd18022fc0bfb7dee6b8f31 \\x0000000000000000000000000000000000000000000000000000000000000000 \\x000000010000000010c13b9b59e63a779cb920e344c412ff9d1e50d3de37d66a5dec54c8e24f358464e501367c52b0969caa4924d2bc2b6d4b1f0b2613f36395363bbd1fe9a33e3116ce5f89a6e4c9b7917bf927abf7210c01859a4d5afad045fe8b25c64b45b43fe75f720adc6e2116ed095f3cd7f38b6938289a3f7abb6ecaf5824aab98aa2800 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 \\x81e52922cda56c38827286da06915f63d0680b91eec0d8562c692c484879e1e9
-\.
-
-
---
--- 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 \\x81e52922cda56c38827286da06915f63d0680b91eec0d8562c692c484879e1e9 \\xcf5d423ea05618c32afca2ea30bfc2fde08880a1a9982c2de1015f9cbdf621ae1689ed6fa98a22200acab26842c3eda03b13b532f17ffd48b7b5d01d270f9405 \\xa3860210e63cba08d0a291e8957dbff4a47ad39198ed020e1bab7f51bfc1c393 2 0 1660654515000000 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 \\x3e1bbd733c5d49f118fa8e1f37200e469f903282520956f8f2e1dbaa38536b94 4 \\x3e1f3b1b70d397cb7fe954e2f5a16cef376e1fca3d4cdcb2b792a315039f39b0bd72b75ea5bb56cebeea8eb4ac2f84977eeaf40137deb947046d4ad93cef8f07 \\x236abb5510936674b9ab58fcd355ef9538bf0e3f5e0440acf0d440af63c27ac5 0 10000000 1661259340000000 6
-2 \\xf12e19044b7c6c87ca6e2c2d29d4e032863aed6e5344ba2cfca87c2a4955a90a 5 \\xa7464eb62afbfe5b1a5831ba3afa2b61adfd5fbe8743cdbe052ad22c09fb4d90f820460d77ac5614325cc2b4b23629041607c091a2b04c572958fd72e842050f \\x50a6315c8c31cf90efbc033fdea6573f67b2616444bd932934f0336bd2d73217 0 10000000 1661259340000000 5
-3 \\x461655a76851395e6af54470944918c03004e5e0ac6c9b2eacc43a513ca37e8b 6 \\x000d053af630cb59f07e948223382401012622d5b0b57ba42ffc8df75ee1514eeb0c0532ce9b3af21059a0b2b50fd1fa39b6d7c1f4fe5c0dc82528fcdd70c900 \\x1b43bb106fed812305df958b0e0132eebf58b3604b7cd1a7ab0563aa84d70343 0 10000000 1661259340000000 4
-4 \\xc149761685a06e3c38e9cf97e352f98891130157e7d960e5ed82c525585b4abe 7 \\xcecdff48850521f110f59cfb1535c5eb814b783df31ad65e9187d4196f70567a7d05a1a8009395761e4c00a3c750b7f4d26ab9ba9748039f9ce1db6592de140b \\xae60a14e98e263c0d3acc7863a3ed91ba954d407f2703f5d96ff929aa54532b9 0 10000000 1661259340000000 9
-5 \\x72597e88734b124f2b6898f990dfe4968372e066a71455f0886f141c219abfdd 8 \\x4a88d44bc054648e32b26a2436223e3724b131b1e98daae7b198a942a1d6a172f1451d8be7175207e5a53782d94ee248f82678753be64ed4a270ca18a3086509 \\xd782724e11a4807f322e1634ce8973c51e58ed896f77b96ee65d93a17ec1f455 0 10000000 1661259340000000 2
-6 \\xc0e2f5a7fb0b4b8c461c50b95e995bf3e0e7928b4f725c8cd94d1244d8a9b1fe 9 \\x11b522fc4cf99d2cefad528e56f768c02b14ea831d6ddc1b9a2cdfbe789cdaf9514386d086e95f6f5891e807cdb580ed175b3b241acae30cc171e0d82b2dd907 \\x0fcfed597c34fdb287c396ddb1b2823255e57b7b29d9dc5b779532d9c136da48 0 10000000 1661259340000000 7
-7 \\xd27fe1d9072c9f90945819c6facac13c61841e64dcd18022fc0bfb7dee6b8f31 10 \\x37da6cf6b7771593a121320db1f094090b74bd3cac7317232c60bdee598a90c0f8e2c6c309fc18a4cd6bed05abcd868af0133b0f2a0a36a9a6fc037deaa77904 \\xe8d9b8f6bd77071a7744ac00156541eed9be4639ecf6962ac5dfe18f328934fc 0 10000000 1661259340000000 8
-8 \\xd4ad63ec6d13117d9af8e2b35950d334bdcff9bc2299a1af23837eb81624d4b6 11 \\x3b0a5fac6e708fc77a688db27cdb719a7c8a68f435c100db1bc7779bdb587e00b9e514b33692466e188ed3960701aceaab944c1c6924004d668fc3a062c38307 \\x748cb06c2b7b640978f2573a0925ae78013988b6cdaf5e6702df675a442593a6 0 10000000 1661259340000000 3
-\.
-
-
---
--- 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 \\x7dfa61890630c1563d825da2270b79dca235253b0665551fa53828df09ebbd915f47fcea2be19305ca4b9cf84a6300866a846b80f67efbdedac1d1a512ea4542 \\x13f3da5dada4e71d1d2705680f0949426d5729b6746c3fb9297ae081706dd2eb \\x6653f438ca7596dc178d56bd8de798ebc65fae25f0c4aff641d8ced762c1d2de8237fc28b2ad12e1a8562e639c8fad30200988aa1331d2a2ad030435492d690b 5 0 1
-2 \\xf971a58369c49dda2c7fc11f7bb5ceae71e920adc7806fb45acff8dcaadc5f94855a881071e677362824cc24cfc92d6e0da65b6860d53d19174f65246dde33e7 \\x13f3da5dada4e71d1d2705680f0949426d5729b6746c3fb9297ae081706dd2eb \\xf05a319098d99b1e80ed37d99f4df9399d105b4f02e2c202261982ff6eb5ef77072faedfeaa0b854edb4ab8efe75da338f035a1a50f7d35721495c98b5da4b07 0 79000000 2
-\.
-
-
---
--- 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 \\xc2595d50a864d0863559c6f2b1e7796856dfd36d42d4e4524721b5397bef68e8059289f2ee51cbb4a0a3d030b7481c8d5243e7fbfe8c4368efaa600c8a92c30b 334 \\x0000000100000100182df2646043677f447aaba089625a7889e68564a442e4307c543a7d87444a3e5a5e1b32e1351ec18a3db5a8998c5c7f673668e4c06b02892fb20f43026b5d8bbb20744e8ba83317813e896e5a0695a4e9509302322b9047c1efd64a97a06500e94c029997f21ef3f2f97bbe1ec234e5c6dc6c70c6343dcd322e0385baea7dc2 \\x7176da8346a1bf580dbbddaea019655d51ef56698b461ecf4f187e938a1c45ee37f128fb12b6eb2b96c96c6232cde5367da460419b89fa571d71661828655f9f \\x00000001000000013d23068316985355e5b8fd8263e2d6483412c11c87143a3b24a2f556c8ec0169f31c5d0e4c2afb62d5efdfd0e2a25b380dc9e8f83304555dbd33b37bd212c9c3681782ec984120fa814b5680bdbc89aa4f449adc605e98627bdb72433d0bb772be9787bc15a6045d778a0dec84b6a8ce3f977f240655572057a2e7b696d8b1e9 \\x0000000100010000
-2 1 1 \\x72cc0b2df77b5309cfbec4ad17287bed2271debbd23842b0e8a670415c186197122add58eb0b7a07d58c5251adeab56ba5cd2f4fbff11457ad66a522d76f9b04 228 \\x0000000100000100d14d300dfd9d0590d1c355e7fefe3a9fbfcf808fa8a6bc2433deff6f04ffe8a60e38cb91ddec61bbaaa5fd05b9be67b93d28d9cb13559dd8983846c3860e598c354496e1cfe01e6371026fe24ab3c3baebd2e09b045dfc973046a5ae00bc3a21ccad9ae1f69cb777d0038486e66d881804370b2adfbc28f4ceb2a11bd1b47c1d \\x63db95eeb0108b05566e62296cf1cc40c6cdb456033e5c4db8e15965d8b06b7fbc2c1daa2b24181adb16cd9850429525c57bb69bb3469e2afa56983b5b6ff51f \\x0000000100000001917ef0b85e1482b6f3a7a74d9cfbfd692c7ebe24fd68039fc4c69079cbc239f5498ba5a993a7c52fa15058b1ebc33403605b9bf46ebb1c71a9bd0b47a0709227071c75c4ab55da83306644d87ded8c0e48b5ebbb7640407cd62194b4b7a86bfe3f099d23328cf9efbca1b41509860676eb82f3a430276c37c9486a319ee2bb26 \\x0000000100010000
-3 1 2 \\xf77b9a9c09eaa18c0850fa578a84617adaf1e49502ab2fcffdc45bfd641dbed21e7396b4421f79c6eacb2ce732f50af0638eb2e61c626d1cc576c631231cd604 228 \\x0000000100000100c40c09a2d38b0a30924a86fe67e1c5a0c4351867ed41bbb76e9a5e4f1454aefad647d49113a11730b731463686c7ccf87746a17d1a495000b84f82b53199044b92ba37fdc515795d5c0c6deb091dd50eb6c71175a1027de81ef39d2f6b225e93ec75a63fd8e79244fe09fb8d77e53b8f3f6dc0633cebd00a136b7d2300d11abf \\x166dcbe65af0a6337e16ff58f5a73d3bec4dbfee3dd74d052e27748c1b4843ee8415fff245a4731d76009554fbe9d3ef5a53a54e13b93fc3f28f8f35f497a4b7 \\x0000000100000001313faeaf74b82494eb48b1c48fd3928d018d1116cab1ec9e5d687311b39c902ab6871bf5fd5d82a1dc7ac09004d9d5c7c8c08246a8ca0120fe63ccb4d75449f32aef7b7cc643dde1582d346ff807036be25514dde7d2eac3540c2d37cc928844544c3dd2704c2345ba3759126c94292ddf91aa2caa955d4f041babc171430872 \\x0000000100010000
-4 1 3 \\xd0afd1ae45146278319ab2505db10f1bbfba0adc17df32c29536e04a0a41e7a289df59ae04778c97ab1ff06b7de69ed0849891129c1bb90fe535a6a9f045720d 228 \\x0000000100000100193693da45837bec75908f7a580136c932c490c6d92c51da9d40dcfd3a5a21a0dd1b2c55ea85cb06e43031ab41db75e806bbac00eb9e881cc864e234444f7734c9aad4aaa4eb9a164105af74044fd48631ca273164769cea6eee898b58305005392531d5ecf6322ada8c2123ae179f22e98af020aa6853a2f1b07a217d8b7e2e \\x02dd3dafcc858f32e8fec3af05ed50a27994a2e8148db0877f0e90ddc544bbaf312d30825bb7691e96172f6837386a17ac4a86a5c9cf235f7d5bc874a4742957 \\x00000001000000014517ad5406ec677bca9e913ffa294a141d29af1614178f5b351cc67604401053588565a89ad842bd6651dc1d2a5d90710cffa3c9287f055d6016fe377d89bed014561e40b9842052a21ed79e9f2e7aa71d96bc9d33a84bf72be0fe5e61e525092c6710361dc4b8bd9696d416ed17cdf19938995c5e3c026d12bbc68a03bcd82c \\x0000000100010000
-5 1 4 \\x647fe96c4784d3324fcac4041e1455518be7aaae403130be73c9ce3e23f9172bd724addaf358e3313a6a2f04c8e6349f94e06eb9bc0f5f9f728ee6599f3b6407 228 \\x00000001000001003dda6ffea5f9b5685d7c53fc6f0afbf16f635785f68f9a0ebac37e06666e168eb500220735c4cd408649dcaf774cf0f18f7e2469679ede92ef57a86b36bbd9bd1bbefe0d079047a412a5a872a8bf604bb6ca53b46647ed588a35e610eb793acadb5b9bc0766647729cc962d2c9cb0f5e18e60c71abc92638548e5e29076a9502 \\x098c0122a9f8d99bf2230abbb716cd0cf276144eb6d627ca285032b14e45c61d9d64c3bd9dcae1ae3d72601c555bd67acd387ca67ca38a9ecc673227d3730f80 \\x00000001000000019cf59e9e2384d52c63167d29c5412ce8e28722650c2edce0a889a21e11d0bc7c11135853f3e6d703f4dd3f3a9f101981241134c2c75500dc242a36907db72d459d4e147ff1cc4222a4af9bec97f04989298bcb2e24450529143308d2d4e65cd29416cbd63c3c9f175b80746d561f4c641387d7137d0456bf8f166cc98ced444a \\x0000000100010000
-6 1 5 \\x54dec43d6dd6ad0b815d66297c3e282c1953384d163cff4b673b859fbec8f195439f4de8c2c427689a3d59da0633d1b6914de4e6df669dea1fa4aac9b5416f04 228 \\x00000001000001000822e69c35523fad484f2bd4fff0e197ec74a5b50a0846ab8130b415bfb5f970d4584a8efaaeec03950c48a32a005d6be83da5fe5199de20cf4263d9091e8353cae8d4f79d7266ef908b94abfe6a7b8ca92402f7b87f1645af4a7a9d01f3cab77fafded31627e7a4f07263825973bbb93827b5a2b87939c716afe79fec76e4b3 \\x0eb36463fb1dab97c81493c2c491bdec5e52bd85791d1f96dd04be50759a558708eca0c29fc607e0f0a0f0b728a1a97f07b9ceb797791c930fe901bcaa02edc3 \\x00000001000000010c6f0e54f06e277d676492d0ee20c46681d7c04db58beaa04c18b69d0c70c5dd8e5dc55ed3e7edb0489a0c7ff02d1088c039945974ef27502e2029dd7ff9c94e001132a8b9dfe4deba769763a51788b925375a280073e0626ffed2c1f70630db8b5932f6206870794441e582ee89a21902fb27883e63a4921aba51591b3febaf \\x0000000100010000
-7 1 6 \\xb6af1992384bed07833370e22b68ff6c388d0c2ceac150f54cd7b9310897e901dfff4cb7df931531c9f7e930362576b0a665cab2cd156756327a2c3c86ee0405 228 \\x00000001000001004846b59b530a6b8fe083d99b632da487087053fa97bfedf81a8941ebc206725a505d6b41fcb97254fedef6754d4b1470b657263f01270a8ffa359358bc27b15bcbefa7ef52faabdc2987721f9dde98800fd07a0a6d9f3ae936df21290ad2e6c776f3ea80902a84ba372cf5de8d5c1e34c26d4d441a97cc00fd71ad938c73023e \\xf9d847faf04f38e801d746e07156b0741ae66b880676599d03c0fcc99e6d9ff92658bd406549e672c7d753ae10622a329a1401415faf337af7a36c8040877f8e \\x00000001000000018c346ca92e48455d2378977210093077a03953243e34025bcc49ef154b773145125dc03c51dc975526f3e0cbb89eba75d98399d555786c8b59a2b2febcc078111b4e7cd7eaec30b25da36cc9e73d72dc0e758b51f9c6f7dedd5fab68fbf7674c13c5a15ec261de159f8efe4690434d4c5b1141031d634b58a6d994a6b11eee60 \\x0000000100010000
-8 1 7 \\x8d15b24ca56189d29e3942e30d41d13bf325942d0616351456247082abfa625d99fc4550259ea0b3361d1df77f9b7ea60350ee8acee56b80d72bfeb441a3fd03 228 \\x00000001000001001a88f3563133a22cad804600db0eb0df1957f3b7476a8e7a1770a46e10301191c7814016d87e21d6c75113160e72022a27a0166b9b70ee07c682112faabad0c1b2927a4e7f39e21f97ba33824cda715067df59f1650c7582741488164d7c2d5b8710947c235894d4bd9f1a27b9c0613d327d0d139e924f273c14ac199d45bd45 \\x887bddcd4c407a74450efcb653cc37d9b48945b25207004513cc5fe79eefe8a08976f0f24369b4e373c44ad89172c8c7326cf8d4b9e6b62c17f0b0cdf2a270a8 \\x000000010000000130b9b12ef803a5535944e149054e0c28f32279ae5048d74999623d0380862e95447fd7745d9a9272b268c31862e8789842c91e59b6ec67bcb1d729a0c621ec0749a9a498e7fc2ed2a19c9396458ca098104a9c7dfcf9c024435c7dc9ae3d9b3d07a63d3bdedc9ef162079ac67af3329876d7b8e11633031fae0a032a8a677fc8 \\x0000000100010000
-9 1 8 \\xd6a9ac66deb4e84e00a09df369d931b8379f84ef189d5ce4d9dcae6d15174c5cd413f2151f012d6b6a3cf9e63890137bde13569ae73f14ec5e223a2f86369302 228 \\x00000001000001007c199513323b92a73bdb9026cf6fb77efa4cf976f8f23c6f608df9bb700bcbe7e010057b268c2aec1735c2da974d22656c350e0ab21bc1ed42902e9f15aba6c32a8d83dc4deb0ed541ade428052cc58fb2bf0fbc396698adf420b0ec018134dab4980568dd9c465b16d4b9b0057ed7b44f3ae900ef8c6555e4ea63a6adfab864 \\xaa67e85a0c93d2dd5b5712c3e871feb99514914f96a0752286aa4ee0f9a5de35e29bcbb2a7f976a218d5dac506e82c30b7a482298d431945ce16100ed96455b6 \\x000000010000000155f345c5a2749ff451093e2d285a632ec1b95080622972aa5d98eb505a964c97b9e66caa8b0faf08d940ab267821224cab5317c401c2c4896fc7b85b318bbd84e8faf232ebc1266c982df1dffd72273889f6a9426ba41e75ea6eff84fd8db29704ceb71a56b2e5ef5a18e0a160b9e30007a71fa189fe2f94b2627ecdaf8f9930 \\x0000000100010000
-10 1 9 \\x8437f8bb642ebb088c48dd9ddbd3efeddeb81d3a132c38051a4de6f7eb8896610a15a94cdcaa379e3df0c7c9e8530590bc7e6df8c4619e5091b31b116096c502 193 \\x00000001000001006fbffb85bf9da92c8698e3994cfb9bdb450371866821aa11f5972ed3579580683876126116d9eb613123871c7204b6d33e33837e376281f43b06ac2c93b88c3d9b0367157ad675688c832ba37f865dacf90f7bcb3e321e39ae6f57b458fe22599f078b279866ed5f054e95108111357b73108ca3e62f6426fc52a998c873f9e8 \\xb96c98d2d2b1ffb22f66b48e65ed357c17e313e33ac0e21bf90f9f18bfd9a1273a34d36c8dd0df0683d5c830604ad45fd11e17308de1b29a87cf884adf4f7456 \\x000000010000000117c4bbfd535268589d3cf98877c4b233a0c28677d2199e80d4bf605f912f4b7734412f3468985c3941f9bba419ff486858f10b8e69a4d451ba0e10e3b812105160094fc167aa1a26769fd79fdbfe3404754c587c2985a40f982bf6d502622b9b7e04dbbb30946525d3d5dd03dc3fbe4cb12ae5b09848201d1b5656778105cfc8 \\x0000000100010000
-11 1 10 \\xf1c12764382cc1f273984f35e426d612c844ccc88387d8130d30b2e1b6565c247ee6cd650b672ade5e8afc2b7ae2d9c75e283e3d5401ab49f23b5897e040ab06 193 \\x00000001000001008e88539381e8d4d07765f8aa84ad36510570e33b42276604701e296e3c96c3bfdb55cfcfc97ae99877a952f831384452669406bd17c2b441004043f19fcc945c839682f6ec5b2f7cdb2309ee28abd9f9a5ff99615a6afc7c1aadc6a61fb66145441ec44f9869d340913f8ec94554f9e9bd342bf68a0eb498a45e6057e404cabf \\x787d14ebc12b74d97cf929e1d27e038fc700c7c7ca3f1d26dfd05da0e8831ebd321306165d0fab9adf721f858ad1bb00185bffc88ec1d2f89fe3540dd0f63d19 \\x00000001000000011bbd00a0e30a0b6784fae4ad857d9d77bbfd4872d745d7c8a9c2517bb97360bfacdcf7e612824a856b31dee391ca2676e628f53cd51cf3456a3019bf635b23ea65343aa4fb560aad3e0473945482f77f02878ae8a90aeab80cbf387a139536d1109186255d5e1911e90bdaf06f14a0706218a4ae6a9db372d15391fa1c6a0da9 \\x0000000100010000
-12 1 11 \\x5f677da19b9569addbc9e984c8c969fbc1ac51e6d87b59fcbe9dff7e9d981d2e91a4280f32fd3076fc1c6a398ef29ebef9e8b26a6f4ff3a68c9c71a8eb3ccb0f 193 \\x000000010000010021358f9ffbf6b34193c4bf17f2365e3a97b444cfe38e647aa4df0efd95e495c731dc589d625c3fa9952dd995b055ed7675708f2585daf16512bc60a8d36cd2e3c3eed66502c0fb4575f2b151b0497d70b6dd366f558077efd8f1b67eef46168824e401e1ffe5705e70a91fa25b97a5f7e21a47dc2fb8eb2eb9601882adfa2d4b \\xb1cfcbeacb214a7a3cfc3ad14182d2cc9c3755d120dbb01d727a2cf0a3e413bd957d12f7b9826cf3abc0eacad75469c90b8bd6769cccfe21baef875d35fc4e75 \\x000000010000000169710a94aaf1881ded9c405143d7d0ebc7be76ef5ade7ee417295419b94cf50922cf9ebc272812fdd9f36a48077055e92ae55e2771221e53bfa16d79907962ccb1ecdae5d43edfbfe31cb1e7faaae50eb3bfea522fb2d16a371609e5ac891dddf18eba01fcadc2438f81e259435b97bb3093d3220c4d13c0aa073675db6ed22b \\x0000000100010000
-13 2 0 \\x7dd0b9c0452b13e2dfcde3ecf3f8ff50ef4f390df48d7a31037c3bce293f43acb567be09304409acce2f2102b8ff60758af70c27c622e5ccab90927bbce1ca0d 193 \\x000000010000010065b00082d0e32ceb9f7cbc29b6df3d188f7fd12d7f9e6be4cd0a748b203fddb4c8795dc0cb0db43d8c8ed764dd78ac211bd33d98f8b035fcacc51246c070e66264ccfe9ade60382819a325c42d6101fd61a157cef54aeaa338c4b89938eb883115fac140c6b7956c74b7c9728e9496c6c95897c8f758c6091750cda45d238f17 \\x4646049b74e6689337d192bd09567f29edfd4edc42f3cf2f865bda4dace3f11790893480458b868fdded6115879b1428d58cd9149dd1b09218559cd3a2e54f7f \\x000000010000000191650a572269100e24f5ab4f9e6b6c709ea6acada72f8283ec4465cdd0f9ac3d2074c96cf6ff00b161ea0870d56b2b27a536fee64ef0c6c1db548aacb11f7d45037cbab82d566e71ecaff6b8114f08de6ba3e4cfaff7d261cd62f776cb98e8f3f605b734e737cc49c74129e4000707895f184a328a45921d0438b933ba616c3b \\x0000000100010000
-14 2 1 \\x1a350893bab0452e951c4862f5aa3a76a5e079c81937366a98f0056f4a902e6494ea8cb0f1628a3f4f16e9db89c6e03b1f25f3603c3f7833f19ea5d7f9ad910d 193 \\x0000000100000100524be79104fb3b5d1208d0b1e418d0822c83578c7233a4d4851a64d02b43ad9bb612f550f890aa6e1538842fc1a0201e8b3f729d779663c8e21af3450cf0ca8d987d6cf21b796d442bd8cc16b8c2bd5e1472fa10a773754f27b927c977fcd8921ec9c20d38684a069788a8e14e74d218a71a65f93ea4ff51d69e24f954d71f92 \\xa7d4ad7fef69ef766c899c22c8395e3a410f998e9caf4c4fb9791d05b19d327ac12c41f8eec35036bdd10273facd3baef9b36ecebd142e76cd2d04a387230e08 \\x00000001000000014af013d009ea4f622fd67adc1f0e4e6f050f3f7ffe4234f2fafb2e7c7940bfa88597a161b925324c4fcde4a3a7a7b8b5c9facc3e7fc3461b9693c40cd341a9106f73c70dce751a348f51aa93053201f87651a28bea26046ac0e072336215399f973362edf1942937ebddfd7ad0a0c871571a0eb0c92bf56c559df040e90c05cc \\x0000000100010000
-15 2 2 \\xe1cbab5c82b3a0fdd78302674ad972565bb10173fe71d2fc6b49391de521535512a72f66de509cf109c376bb9e78baacef7bae1dff5e1616a6deca584433a20d 193 \\x0000000100000100813bd7534b935e6ecd7666583aa73f29cd4824a371799b6b780a931c453b8645df0ebd0c675c20fa680a13edcf965c8dc3fd480cdfddd2714e47226fcb74f466d8e52d12a0caef2d63b5c2e6bda3f69f3f29464682a2fd332d56a89e8db89d4a21c67b7d724c967cafada6122847fec768304f123c63edf6794deb7f0eef4928 \\xc0a1da7c68e32d69202b6e2f8bc2c98f971f828ea2709bcf26cf2b8ac6e473d6a113bf137760aab57c1f60543929be176004555c809c43f4e27761839c71655f \\x000000010000000106a3a716931d7548e04bba437bfd197de39db8bf92b1373f72aca93f16d4cb808fb6ef6ef0d449562662097381d518fe6ae749cc93d855a83dfe51d70ea62da71df33e65e24753a3a7e5679dcd83ea614c89bfe002e00ce6d34f1b975ea5f4d5f6f035214b363c6f0f8f83f122e7d916b208476c670fa6f070ae79f29b24f534 \\x0000000100010000
-16 2 3 \\x28f8ab37e32b83a2d7a7b51ef6fb3e3d3ecce2fbd40fba9131f757e4056867b9dc5077e090584b2202b3f24714baa97bfa630f82ee2ce165797c067a3f2e0b01 193 \\x00000001000001000803590418bab2db14997afb43eccb2001f3ee4f6b3489b4cbbd5ae57f7fce6056fd76c8573480d8c3bf96578ee94de1ec417a85ab6efd03ba3d1324624731a78a1abbd3baf1735a5543aa95e4168da1b26dd001bf3f7ab32a837acb68c9212f468c97999042de833f63e2c5e9055e9247a266b23fad751e0939e044a4422ded \\x350dc06501349dd93afee4386cff50bab1a2f367c2cb1bef0bb2aa7d3b813e4f570190fc64c45dc23e717e72e5760baf0059530c847496b1c39320b73ab54e66 \\x00000001000000011f11c108dc3c45defd358b97a8b08d0dacb61054cd86e244f464b23dbfb484cbd28a7cb075fa2752a514decd2de8f81ebfaac9ab3bd55cde12da6c00ee1b3305a1789d240bbde29eec5a5d0c46219c1b8897f42ef5eed1f51b95d2ca12affc8d52d450f7eb676d465b6552ccde1ac03b21529ab00f0a9ed6d2197b4a721e0b88 \\x0000000100010000
-17 2 4 \\x2dab387837f43dd3fc6a4f84e53f846616c54da31120aac44fbb1dad4828d93b7ef3d30726d47e3b047eff6fa9884c54ec50d4eed81ca38a03477efb56442704 193 \\x00000001000001002afdc5f074e232d7fc1e90fdcc5a5526e31a4abb5f1a84def151178af285ea9bd05d4622d95e37d32f9fbea4bc9d85590adf8911ced13b693b109655d3d39717346c5fe1bd2e563b49456705017501f8b42350a5db0017d8800609d98b09fc4f61e15de2aa296c89f3bc0ca10d9768786016f575219db93690cbae7027e6e6ff \\xf4574f52a817146a7743e3d1b4777cc4f8015241f67f918cb388c3825e928a7a81676930d19654c0360f72beabebb5bb2ee86d05c2f4ae4749d88776563d27a3 \\x000000010000000165a9c02a4409c446a006c48cd928f1f4c0c443c793d48e15c9204cb4b9988be5518f7a6b4dbdc71bcbf861b9d992e2c7b2cec55ddf1fe4b30f9f390f2b7fe6bc73772355508002c4e827c76b8706066bdfa68ec4be58b44b8cef5a42df45d1f9aab03c3400694f862fb4618d10178dc92e77ba1d9f680d5664de13cc842866f5 \\x0000000100010000
-18 2 5 \\xd7ba624d04ddd3d80066bd96145fc3506f6aa0751053b28bd5fb70197133f611f406667b981e9426250ae82af96c3ee5101d2f5aa7aec50d82351c1c9901cb06 193 \\x00000001000001006a03db8d8dbddf42a5a02d1687cb9a3dd166507de70ede4ffcd63eda959b60b937a8a70cfd931755f750d2dec8faaf9a4ffcb25777a0c28801e339167c904d206f1d9d7ddb0fb8955203ecbfc459a0538a659e0921b65f07a363bb51026d37c47c5359f2007f23b08e98d7e00a75dc1a778b570491f762b7b28da7f1c657d0b4 \\x20d0b9d521235f128b9764bf072c88c5e05905cb4db7f76302ffd6d35d8af223e76d4697c06a54cac2320c0806d5772cd56926eed558be9157b7b103bd252467 \\x0000000100000001323c5010860365019a47d12459ef1303bfc65f12782a9eb3cc2e88e8ce3d6e6349baf11fc92e9052c53b323fdc6d72879fce8a83ffc6c64c9885b1e914aa5357d6dc7ef4c2aa4c522a847bd4c78e316067a7c2cfb2e7b41a48865528cec83545830511f979e412017c2c8b668981a75efc0c3f4ce9b03d6f511add7f03d19b11 \\x0000000100010000
-19 2 6 \\xbc89055d431a5033d1da1d16eac3582a523d786c46ff904a2538747037241aa3b7ec3fc78e652d348c275d026f91abcf4bc1f467c0eb3565e475175c85686801 193 \\x0000000100000100790393b291a1f441730a7d113a9699e5bee1796840f64a66e667f52800d6489e4612446bf896b7f5d3fce038794564ce8d1250540a4e15da5d652429a841942e734a962ff62d569c51a6ef9904dc30bbae16532c6eb0ae0249e115c45463b029dddb6f89df3bd44c8fb697e612f1ab97a37d71daf64f132c299c75815de7fcd3 \\x385e80a528dd40c138a95c0575fae0c467e1a86c626d8fe0aa77ff881af255f7b9e13a7f25e9539035d3544dd57c3a7b12311df79f3e859f726f3e82dd7b8191 \\x00000001000000015bc0116c13ec60bb1d4a9926ebba85aa8c804701b824be4cf8d7779e1349b462fe9e0ae0f802a2788a01b93abd990567f85b766315926de1a5db70f809d5bc6b31fccf90119b742c50dd06554127f76d210f5136f98a9a18ebbcf231c7fc8bc6577692da1c9c50c2ebdbead6452d0d91d4b6e01eeed1be66ea434bd4672428a7 \\x0000000100010000
-20 2 7 \\x29499a821230091bc189e5c45a1c7f4f7882948975a6c29e06b487ab8d2bb8b22878c3aae7fba749f1c07837ea0aebbe700c31a6fbf156884d13055ad8fa350d 193 \\x00000001000001008f288bb298e08b67c6f022000c90b519250c7cc4e53a3aabb896600622dbbea368035ff892d6bdffaa5b395de5447a308264aafdc2005d0569f930e39f5138d78afe40d95e8d90f6299c64270ea4f746fab3489a7950e4fd7574e857318338813d710c2d3e5d0f333b910dce6312b754cb0842a401be0516d413a76547aaf4ca \\x7829d664f38f14911d2b2e0385519e113a7b4668a9957db4a4de3ceec497b9c41773903d3eaac7caeed3d3a66c327e138b997cec4ceef2635877a7f9da4ea7c2 \\x000000010000000112dccb323fc40a66d6813966099dece4d544fb758076ec6093ba5677baab1a1ba4631e31f7ea984286d19de5c9a71f8f89900b0301257180c95ecbf3fdcc336bac464373f7634ab2467777683b33f2e79f74e418e02a7c3eff41cdbb54ae563dfe2669599d4be7a30df184ac95b27a955afa7d6f3d943e9250e5d4f9cf1b0b01 \\x0000000100010000
-21 2 8 \\x02341758cb977d693aed94098594ecae7c511f909651bbd865b2b4c6ea4f8f86f171f67d20f85039088f20e0bc742b228a958d90d3bccaafc660a084e8813e01 193 \\x00000001000001000687b7d552edca13be96e2cdbbcd525048e46a063c1d948a7cd37b8d0700cae73d0630eda6125966c1ce1577581f4f63015c7bf73adbe493581049004a10a23666ba593409c76f389d5843b49ca643acbe4540d1aac2248bb164ae5b6b3c0647126a48e938e2385bee2762c45fb19dd13c17aa2e523cf1b7c3688b1445636a2d \\x6bf9537d76622d5c2d837f72002bd80bcb818dbf153c8eb31dfecde284496ec8d2a97eec852f1960a578ed9feab9f264496ba7f9e8ac57896f3017e7c722e0bf \\x00000001000000012d7a8c4427b858a8fec015e9cbc80e2e79539bf504ae415e4d3ba128717d8aa28bd67c13dcfd951b5a8ed6f8bb9fae56eeae631733817417c93ef22ddde6fbbfc19adee84395a3b8baa14af2c59e3f945bf7050bcfb779d68fbf3bc10d556fa2981b40323680d4570cccaab77d5a0ba953131e1648cbc978b5346bf034ef12ef \\x0000000100010000
-22 2 9 \\x9a3413a3ffdafe35916bf0066d3a6b5d39e56b6725c5dbf1099168371f4a17f43846babdca86a4822816d64491a7124c60c92089b3019f2b18248fb91ea81202 193 \\x0000000100000100651c8fac01ac5cf9c6bd41e5ebd480de8b673f70c535b1febe848c8c3de290babb99b678c96cc671c5a4ca3e463c6641a619a32a18511adda5e80953d5881287c1fc3e767c7177c7f463071561398fe83605cfa55ea790ef47fe7f2fea73296b1c1c984510e547a9ca5dc2acc838d91432314ff29ef0371977d057350d34031e \\x689f0bc058fe521961a6ded930dd34f948ef2e9331ee58deddecb97e0d6368219eaa98674d00d0ea7e7b0b8e2cb446ff5c6756bba7a0ccd9bc4bc5ea4e53a03f \\x00000001000000010e9037be5839ca75b461f259bcddab067b7a95fddb7b51ec9c6ed272f1f1911c925d8598a24d0918d7d19b11ab70785c868932bfba6c0e329eadcff431e3844af16849da93fcdcfe6f40ac903f1999a9796b1b16c04df8b50818f6445847d93783d296b8f92b8f2f4ad69d0aadc2199743ab2db1c21f544c0b4e634469b9bc9e \\x0000000100010000
-23 2 10 \\xe959f3fcf396970b35cbd3b0e92c705a942a91575bf0cf01804a4b3a9568ce69cd09b0d0870feae008e3ac53a76f3aeae04eebca531145b2d6c140bfab7d940d 193 \\x00000001000001003f521a3b369f84f699f281ecbb53f5e33b4a9f4202f01852b7b32e556c45b58506eb7b309e53607dd6afd0c26b15cb0840f65e8f178105cfb8946f7c2b6b740ee1802323eef9be50bb0294f2c5cdd14646b87669a27f1af7020573943a0b3d7afd4746787b2b965ccd4be5fd8c446e949612472a8fec6784cadaacec9150a2b5 \\xd65cecf58fba700275b50d89d2105862da6332c25b3fa32460139e9f97cd39a0bd8a5fa0b4fdc7a5edbef99950e4e376905cdc5a89e7d451b958d660a1391cdb \\x00000001000000018b82845eea1e24319051f868bb3c96c855083ab9cf64d758dc2e9e25e23c505b3afc91516579f80fabb7cb3b0a4bbf0cd3f83666cda2349f999cf202ce5e09b57b87137b4ceedbade13e1cb12abb54e1eb2b6c58fc2f8e4400ba1387c37f4971819d7535cc080efe2835f5e1ee64a600cc22870ad0dd920cf77608bb21382652 \\x0000000100010000
-24 2 11 \\xf17eb238a32a078e26ff2d6ada340994f10011cad1573b12e2dad5dc504e2b9a30e2f57628e2c505f29f0e89a474437ad452e9276b12237d7a56b2d8cc554e00 193 \\x000000010000010011294f73e40f18fbd3dba37129a593f94506520fea96c664c4429076ba479f1cf13bb78896ee28f51caac3a88bb5bfee923b75716243879d2f04364e09de1b1da25841d4bc9b0d25551383dce3b5fa88de4642e16ac3b289e974fd60754a7c707fb21812e0af63ba6cda282b79acc35b40720f62f5be30339bdaf4ee86c7c1be \\x37c0bc6efe52207b38e5fb386c426dd8b2fc261794c2b73035591bf7f0404f2e46d059d8e900a288d37296c71fa6babed02fb9fd1af39aa33f38e8ca43408377 \\x00000001000000013c8b5f5b0bcf9b6a8894a3f3845080af1c34a038fd1e23027d2182b950d00fda8520a26339d74cf00654ef90a794169f3ad2d7fe144a180766a8f4626d7a4bec48b2b7f6585ab81c397a9a9769ef95ccd76cee558dfed543c41ca0ec08d90b495956cdc435f00bf74a396a5f28bee59959d046f2adab1c4dd51d33a5d39d643c \\x0000000100010000
-25 2 12 \\xada71c5ac36257b1c34321eacbe28c85a9359a95c900dde6854ca2679113e58ad58a8df9faa6d6b1bca9e3881271bb9ce27558f326404e9a759bf00d97fb980b 193 \\x0000000100000100181b696f37f622abf80b7b158d4d9b7b36f2fc2b7e0f6be0f3422d37316be28366c0d50b36559d04bdce152b938bbcaa10662a776cae47d4662d8e62206d62276f88b701a1c32178cf53713f02db219e8b573fc28cd039c32f5a707274dfe2bd62613f5e95109e5484008143de311e7ce59e02bf9d1c65a948b2ba4fc2ce64f8 \\x5b57a545c437b6f88484f288875e5a45f79e27d6d0743fb849a7855840b1416b252ec87385d6173c243bae7edaccf48d007793ab873c6b99912296385c7e18ee \\x00000001000000016c87791ee16784d3698070096244688f37e91bb6ae7f9376ecebe43fb8e201f46701ee6964ca9125cb5884d95f259d8af301c3b8fd1dcfd77a771fc0b5c83a86321222550ccbb59c62a1e2c9d57975de35dc2d991b050fab95b7d3d5ccb59893b1ccee16559361c798932dc85dca47b9e49353890e8c1ca42444ec2fed86a3fc \\x0000000100010000
-26 2 13 \\x1957924af2fce317653269df5f00dc329d513d612a88246f13f21bad87d84768e40d8f2f2146c4cc06be2c6cf59671899fa00b3fd9f031a698a192ebeabd8e03 193 \\x000000010000010028a59546fcace3d707f9ee634cc0316a16272d53cdfd8fc95a07b63fd0d2d75b6432c4150ee70a57bcd343c732f974d494c444f7bfb389facf7dfb57b6993f38c1870ad362ff38033ee7d2c4daf6808fba600ea82184467c23132b0c58bad267723f338b3993c9e3c32d0d90db88a8790a78114d91f4648835e1f50de644f16e \\x99f0077bdd79a17fa8bf3c30bedbff5ae1b13b6ceaa144f57650eee9618a34990f9a35a03584b98ea9058cdf86fcd75d61455bf882e9c63ebd3d18978c9ae2f8 \\x00000001000000015af4652d87de3b795e1608eac36bf70bc0208378f216a9a65c377357002f922598cc68eb0ab27cbde44ec356c88bfe87ad84c91c802c7879adfaef10baa3982ac7236b4892329c529070110d4ffd74e148b0980da0600a46e1d67b82aaccc5446ad5aafdb02facb8709bcec2a5010a6ddb40b39c196e54dc3f013a1529664a81 \\x0000000100010000
-27 2 14 \\x64c319f655660503074ab2388492c57920ee5e3ddd9d2f951e1b68bbd740b1f4178665762d8420168facfc93c257567882ab12c3cd8b563d60add6272a49ea09 193 \\x00000001000001006e8e496a84921861fa5a93a646d6fa5ccab521fda67856c93936c32dcc7744b76ceba00ddd94792bc1afb37bf2a2c7e4fef6502f370d0e819b15c289d367027648cd2dd776799068092f74733a39acc18809eff743173a6adec62ccc1be7b603714e3be5877fff7256748c3485ac1f70be28972134805c14ee676b55002aef90 \\x045dc24f5337749c3a2df36a5dedbe446d718174cabf452e2467d9ce9644d33133a5a116ce813b7f87a2911582e72e8991a09c78167a7cf5969607275b93a3fa \\x00000001000000017351617fa1d63f07538792dd1524cb6042bf9260f0a1e04566d3a84d47705ae979186b34ea197a10ccf151934c40fdfa86d2e628c29416f9259c2914c6424e1ca5b6e6b138474875cdc5d83593d91717a1eac91a33a47df2096bf2197641f69ef049c81b5c4fb53d3c7d7e8e92198b5449aa453abefc3410cf6685c9d769c9f3 \\x0000000100010000
-28 2 15 \\xf7dbbe1b3c4d6b5ad973f8ca834adf5bc2f073f9f4985858cfc251855caaf1b430c416f536d0c985ea1fdc2ae26089212072952de026515f928a2a0a9903ff06 193 \\x0000000100000100869fb3c02d54795e98d108de5e662bbc88eb714970fbf60f847028fdebf969b45eea4cc3610bd2a62b27754463c1e6b7c81ced406ff9b5d58555dc61e64852ee2c7b1beff28264399d6a4c6e1d75cd96ef64daf9619bf61c9897451a90bd64c759377278dca0a63f7f3eab2552da331299eb86c7d3bf93398f15ce9a545ba7a4 \\x77e0ce1e3e9673f439abd53a4f1dd624ab71368f87bfa56475655c55d7ef9c450a9e1df391801da07c4a8b114685d8bf4043e91f0a8281c6fa4333433ab000f0 \\x00000001000000010824de93c6b169ceb6fecd52f24923b884f70c662363af91e0aeef87d0698b78c67a0c2c707e375a38c65136833e0d9f9492696b29cfc9b9cad227e661f18469a65b94fc409b5349cd23784485abdebab80d89c74fbb7d5a920afaca1066f9466583905560803963b1b48425c676b28058c728c546356c408dfc7a68e18ad6b9 \\x0000000100010000
-29 2 16 \\xb4029da544edef50015d0ef65e4dad6ddab4ee5ab4d951ff83583ad6be2b16e8bd7f94d81c1f814909f7621342ff2656eb5bb89a60ad0bbd55d31d187a12270a 193 \\x00000001000001002664ada183230dbd556df4315dab00ee3ec6a9515409ebcd679a884bead0891dc62dacc776fb11c6a7bd725375c3de6f60601f6ba2b3700f8bd19404422ceb685c7008dc04cc2dd80bfc48a2d3f1d64449e17b2115dd0f5b53fd28bc481a122e8f53e7fcf0a1375a6a18a6ef86400567e3eec0dd56843eab85f3ee65b856719b \\x4c7eea31119110479d9117495566a382c23879c739b04e1eb405ef1b35535b6aa96d0f6ae80100bd873cca711b66efe90717e70bd41a97d6fcc3d0f6e6c31cbe \\x0000000100000001432ae001408cc190713c19c5e1fe48f7809741d4e0405da83eb12a4b90809a6655ae193eda0d2bfb83f14103c2b91c1d58dbb3d07b5a82b08d9215b32b817bbaa7f51a0f666ee6a4a4b0783acec6a29d13b98294f0deccc5a5883789534ba1260b0ccdbeebf8a97bbf53c537e0cb17c0481f9c2d6b7cf92528215ec1dd04cc5d \\x0000000100010000
-30 2 17 \\x50b052d95f556d228ffcb2ccd1176108e2ac32cd3cfd6c7824fa02c8a75279e54ba4abbface53a4aa0ab7f5d4f19562b05ef359e80635a6b54aff4a4dd71a00c 193 \\x0000000100000100886d3bea7dc9be82de68707b6c0ad603eefad944a357fa2ebbf3f2a38e8761dcaeb9d68c6f77dcdb8ebfc22ea1cb52c61b07a483f0c745a5cb29c6daf457c6453cfb4411dc751242b38b88b8985c1d27fc2717e707b79fe7dd8908ae7fc5263d939766ba96e79e4817b2f5dae5f459350f65af83c5b3c107861d60693690d659 \\xd94390347ef4ba4f72199aad4967d8721f3f6ca5438713c696c667d44738758784c1b1604107b33703fc4d5a770722c008f2c1ab0bad6a14956abf66a9967eb8 \\x000000010000000145223d93051603a6e9cdc7dd4ddd25753203c6fb597535d62589875ace72cfc99d3dcdbffe6146aa9acbf60cac01b33388d0a88f7af0d27de670de4184c40c46cf09f85c51564b9609aaea1562b8cce5292b77b69f8aaa3cd76b0a2b313536d0e92b002da5a297562bb4ab49444ac58e6be21582d57897d97a1716352d175cc6 \\x0000000100010000
-31 2 18 \\xa53c8158d5d5c11745b034d7400f44da4420cb84dc4d2569d9f16823ced4b120be87dd989e0924ab7718e98ca1079ca69cf4f697b0404f2f0b7a14bab63f6103 193 \\x0000000100000100859d0c5cf2171f7fbd0f858d9979c15b4a2db3dbfe5ef55175c308d041cccfc3cc22033d028ed6a0210dfd750c58e12a3cf10774e5d8fde9d9eb2233750ff5c89eafa78cf6a9d0e62d1f33e8046d017eb92585b3338664d8cfad80dc6b86ce5d4b9f4954e987ce8cb7c3ab54f013047990549c113416553e6abfa9d719ff5abf \\x963dc532f7237b0df22a92099ed72e23ae5ff3580a4a92e017a0abc8ed30104b56dda9a4bb05b00ad896a735d736fc79dab7ebd7900bdac911830f10c4f79f10 \\x00000001000000013739f7d02e71e1040ec40cec6da6401a2b5d0b8d9720ad010dc1357d0d3df1b9de23c39845303501fd1bf021cbb9ff9d6516770552fc5ce0567f4f444fa238134de0bcb2ebf12f36cd595339928302355e9d68e7a2bac02b78b6d4ad80ed3859db548a4592310a4d653532eed23500cecc5a3adfc8c5341e8a133a67f0015c66 \\x0000000100010000
-32 2 19 \\x16f4bc3acda90c50f93fd2ceef15c0f943564292e1890a51853069f309785538a8d0e827da92671d6c711186574ac5f4f9ef3150c61c73fdc77ba1e6237a3d04 193 \\x00000001000001001ef9d17d60c1da738f7284332ad533e1b4cb70f5c26a816b3eeadf63a40d3d316f1eb382e8995f3e22a250fccd68c64055505470ecc4fd0566a5129703f4cd2b04d8a5e5d8080481fbb97cf67cead478986a55a477d7e981f44213c6e161a95f4fb82854fd1920465a97bedc165475d06ea6ca7528b95e490f4cb5f22d45080a \\xf1f9e5a579dfb434b8c1c2e62c959edbfbff3da1265cc2026211a4b9ba1f39b0f7a7bb1d0d36b343e574177dd1b8e5a5d982355c6c30eef3dd83ee138255b115 \\x0000000100000001120c1b868e28b5df6f3d5a0431ff54b54d766bada9fd4b04ac63d8dde1b0c621fe50aa27ff8d52deb90fc62ccf5790722095a4020793a8f50af330b1bff06de7b8e5289fea33ff0ff83056a88e354c058129a333a473f73b74f068e6ce57aba96c422689825710b67ca52fdc17523586b3577548e470ef49f0bb1f9a982fab8c \\x0000000100010000
-33 2 20 \\xa74ec6bf072dde82abb1efc1c54a60a3d7501e5ad424a31bce0937d12da550949cb13f53419b1d6851d8c66b7793f39f1c12849d780f1d2f95994f202a956505 193 \\x00000001000001003ca71efe805c5ffb2c9ce33f3424259e2f04db4c4a67bb76cfc4486833067785bae9aa000cfb3c7c48ca256bd15511384cb2ce6bb5472860199a25037d2a2760d89d3f9fd8348da5aefe0edacd77604ca12ec29c303d9bb5ceadc4fe7d0b23ccb25c2033066ad10c3ed26a4c2d528bf1fbdfaaf6df0bb33d0726162382b40b1f \\xc08a986964a8985943ae987ef8a61bd60b1f2adea89336cb7d3c020d03897a60e68283603e959dc99b873ccdb9eb70497b0fd0d249f36d633390d51d9a0340a5 \\x000000010000000171fb9ef9871b09cca03640063402a1b5d1f2450326247410f4ee3b6a64aed0aa0de3d85153d49f404e61e7560089a51ee4c1ad45294d22ab4e78fb3fa02dd1ed6ad27faf110bef09fa84d2edf6ece544d16ea7416091af1737e498d721d6c68bc9ccc330a45d0f9a00bb5f7191d0893976da87ac181034f29a1a14521afe46db \\x0000000100010000
-34 2 21 \\x27a1014cf7c26e2fabe33af852248fbba85da613b6f797522e10abb8070492c96d11216018c2437c371ad1f0afb4586588c98651725c7b245faea39b022d2709 193 \\x000000010000010020abd5dc5b4a13951407817fef3d3beb1518f7e99422ee91c97d788192bd9d4f31ad80b7a754c0c957e3d11151755b3a0ae6aaac0ea85eeb1db27d28338d2f0dc6e58822b5bc830456ce069910e3834efc0b7d950f6875f1b1d69fac727fe3885e6dea84ab8f4d9e5ac1cc26b3b8f5da07663e5099c1ee3d52cd6f8ae579473b \\xbc504f3443c65623480406ab9c5c83ed299825227b1c7a1bb97d9765740733ef1d2a15190c29eae886e5716c07c32701795fa426f0b0c5801eb3c1e2e283cfdc \\x0000000100000001709d85906140bece9a22b71a896b4da2e639095d67a3063837625406a5cacb653c7835bcfe5b48b874cb3151b5d904914c324f2876e54fbe27e1e378e08e7f886f918fbf66f02ad19fff954892078b8b7f2ab557eb38fdd110ce28dec3814763728f71ca088d8d388611445233e9b803d228fc3a19fa22cb0178cbb514fe1204 \\x0000000100010000
-35 2 22 \\x3770d63d879aff91fe17ffbd4f79487ac875f1b1f755a43631168fbfa5181b139cb35ff313983a0158a8cc2814e5e3181b325ec18678bc9d81b76d0c6a14d301 193 \\x0000000100000100386d534321d39891f0cbb6cc8dc9520ffb168fdab0696fd618ef08c21d10ef2fc01f2a6ff6f3d2777aea40689d44af7a58bdd9907c6d4bda8228a76209ae06b6f2b381d3c8c024b7d92c8e21ba3306779f7eea1239cea8e560303abb6298b0259f978799947c6ed631dfb36d7f836aca36427b4c9652ee84f7e1085b40e3cad5 \\xba9452b2f59f7b31af7c2ae3d8e550a696c0f7a1f4067f8e06b2d4b1e94c126e148d5ed3a0b762024e7e13ff34c29389584588c1d57df768d94daf851bb0615e \\x0000000100000001739dc484cd73bfcec9e5a208f23020d9f7e5830e3051cff8f8602ae67960de73094eabf124b0995c0f8f1e5fbc7fada679dc3f15597d53344bf8b8489bbb884a394be7d74fc939d3f2dca8a127bfe9221e02a463385bdc6346cd68e54595c710fecf39303ff7f968ff2c5afc5457205fef3639df8064bb2d5aff3a89cedcfa39 \\x0000000100010000
-36 2 23 \\xf3c52140fc7e71aefc902849888120867a081f157909349b250f7dc1c8cc434ab94172a584e180b2d4a07c01b1e2b06aad0a1fd4f3e40a161d758d922867050b 193 \\x00000001000001003c3b1835ab22e133430d373f0fe2b2f8f1eacbcc154163f8dc0e52700416ab8d5428fe9b1a63cbd24c9bac04fda2c4b3d769b5396ee3c25be92f598cd5fe619f9c746d504b3521f24830f0d3f410b9981da1c62c58ede3441b11bd6106b300810ef72bd7c22eaac845a93f0d0b9fe60a4032c3f8b690119e2cface51ca363dcd \\x0782863a93e5afc8db33ed45f8dd3ca73ddcecb4e7a6a07d4d0beda5bfa67f2e0b29ecfb3afd49ccbd7bfeb12813aa5b24fab644bd85d2a85b78755ebc9a16b9 \\x000000010000000171d37b556200f615a3c1e8459a85f18b2b0c2b977b306f24b6b2f55809fce6748ad951323d3c395da8fbf8b200f629f992426e71f7d4f5073db9c74da9e259f3e3e22919177ce91dfcada4581885b07881057ae7832e80eab33571f56a2e967258ad3c7e0286e1ca9ab0a7e5055d2f2ab9081769f3e873c3770f2f88a1bac970 \\x0000000100010000
-37 2 24 \\x7711b601b4d478c0fe47afa44c589f91370b4c78b4bcf44718a7b95c0c9d1d64854f6638beecd8a99ef543a6f31b27ec41f0573536e84496726730f9bdf88a02 193 \\x00000001000001001d095ac651c8016c4a03a012ee63fd533c67e8beecef00d4970cdf53a41fc731bda7e78d8f83b9379e888d3b1c06ca8edc0dd9ca45dafc278ee0e9353f2e39797d6ba0620e434249f802817a97ed1729bcf4bd2dbb65888e8e7538886f8d105856a80006a8c55b6d25ef22eb4bf159f27ab8cfea2f02a0f8bf4d331e21177a20 \\xa90c991d63ae7858c24413bf71afb7844913f6aba9d8848664bd3e9c5b13b7680cc30bc32bef65d782ae4b97acfda9e76add075f3033de03dadefcda2f26cc95 \\x00000001000000014c1fc00f3cb97c69754db7b3e45b93d9455a074adb607a7b45cf692245eb64be1831701bed7b573a974fc4c616a84b061de1ed9c0e48e03004f669a6732960830df0ce1a7dd304918378ef5195335b41e75c501430b4c091ced64285acbf5505fc70202c5fe4eed3179b07d6d5b71437ead528c5f65747e4a0cf2711f42c2e3d \\x0000000100010000
-38 2 25 \\x961aedff0d927d5e59284043c5fc5acbdbd18fe2b14ce415ff0658ae696d233d68e1dcbb0c49e2254fb787a3f2a2dc9fcc192b43c66af899b9f46ef54eb26f0d 193 \\x0000000100000100305534ec9e4cc070cd5face7ad7b569c3519ffbc5baa933ba9704c97c10b837845748c4203c97d284ed575abc2bec693d2ba300ae004c0bb5156e5caf8b5d6b12eda602eb141858c2dfd739f1e6545292b8a5303b372d38e5c7c919a747e8f5b674fa0a2535c7518d2efb55ee7e7ec628034b5461d78896dfed12e7c275c8b2d \\x852e7c13f3f80dbc5e0cd648b7be2881394949d86d8c11d8d4f45ce4176c50acf97cd4153481479d53e2b155752bfe15ef7753ebd5435e8d7d5704f62ab1225b \\x000000010000000163e0a5c1daf533c2f6d4120bc24c7e445a1687e83ae4f96889c90c272f8791fd179fbab4649d7e573bc6c412028ee674dde991be56abe66de523c4984396b433f0ca369059b112da5b450bcd3039a503bfa40ce76f09ebda60755f1c64a5e03b52927c909177f92c4dfd9f99815eb181ce9482f5d23871fc51eec253b7045096 \\x0000000100010000
-39 2 26 \\xe14b76fd6da69a8036a2eb8885c931720a0fa929f6e0117aa08ba41406a0dff6e72ab326e0c6611781b4ae7a31de860384bdfddece576f6e1def4fa0baec8109 193 \\x00000001000001005e0aad7f63a33ec1fa6233c9f8b1536a87bae787b6e97fbb3a5ea77167918df6ad252345f2eab9776836016ca4683151146796d0ff094c2b98193be48d9684e612e15c50cd73519413cf85e15f10e62cdf32e62e9fb979af67c965f766241f9f3c7dbdd48984161f257015cb3e89253d06f4ef9cc9fbcef56c42955b45f5d98d \\xebd7a0a57920d7597bc18268015334c1b07e88f3c567998425dc87219dee34dc8c88d72982f9613e7381384c3f71af025fa1b85f390906a7c879af54bbb6dbe4 \\x000000010000000109a9245731fd25b24031a818f66339a787b95de1f2b888bba685d42d92cd824db3260109d63d9068b18a7be207b93ce87c292de2b7dfc1efb96ac131c6017ce09f8ff4c12116d52d0d61c622ed1701ed15e104a18c529b9f652775daff6ef454aede309867c75625caf8885f5dc3886dd455e11c275e5d498644e003761a78c0 \\x0000000100010000
-40 2 27 \\x02fab3166d7347342db6162aab11b9cc969a5d25aff741a0badc59487c44b315b848db145eaa2b389e4c14b27b0376710ea4e6846441ae073da5d08513dc6f0a 193 \\x00000001000001001d22a6c7cfe1ce3ca00ff246daede623f00e87ab9b1a50cfc56c386253691a8757f6e719cc5ddd1c4f696c70e8f67c2268797ce35df535fe256265f0a5886a8b84f6d1e521b7167d7c3b18ed55bc7277324c4f73d2afc444a1c44c9c048829913486364ee4f12d89122215695356eaa3cc81d6bdcfb3ff243a075eb33c5e11f1 \\x2c056a7fece6a291b6f60a121057eb8770c1d6b8721e2f2c8de05b00f02a3ffd97657ef4e6354c7df9c5418f8b5a465feec332e1cedff40c59bfc93384d1bce2 \\x00000001000000015978697139b9e71a86f910bfa5176b03232ad5594cf473697e773f281803a1b77a5f58f352be57649cbcbd6243606b1514284a1de94a125d7660055337936b988c78592d1ad67888d5fc372576e256762271c69818b8a552552a6b3cc034b5beb414a1b1a900d5150c3d1a22494b36ab8c416aa959a69c38b3366329e760d7ca \\x0000000100010000
-41 2 28 \\x82d5a47527253abf019033a3c9858ea5a772f786c0612440d2085a5177accee835ff34f67a87d20569f9ab11fd5302c1c9a2589f0b9d822e7b177abeabdb7a0d 193 \\x000000010000010082a21f6511308aa6d18a12eca761d53bfd44e0c7c33201313a51ded97bfda5f0f7d71331ba0d6d11da75710331f87fe1a48c33c9450f58e02a3ecebec1d562a2cd4ce972792a2c970a8f0aced72049b774f51c82abb3e6249a0da7d288d2accd8b8171a09eadb3b30613234eefe0f5bee8dd376ca5df8a528925ed7a2de6fd38 \\xfd2ef57b530b59bb9db3a67f342a12f2b4553acc9a220e969d5a656fd25501ad48c9aac6769e4c8ab64cb16acbdc4748587cf7349f36c1f09c1da184d81c9de5 \\x0000000100000001068272d5a32a218fa6cb4ed55d693fa97724f5d210101700ed27bd08dc8f482d6be2bdafc787d165d229b40ea11dc1c11a83f0480a6e822c432ad02a269ea7b4fac3d5713cc42fc241058714ecfabc376c3932ea278e8f93ff7cac7e2bc81ad00796e8bf20205dfd2cc4e313ae188d996b0de0a689180247261325980d019e04 \\x0000000100010000
-42 2 29 \\x1bf7fabc5e6ad35c201969f0361b28cd699ff7475f9d88c81aea347c47e581cb3fafce4c9e26991902e1fe9599aeebbb31642c551be9209cb03015ca34eb6501 193 \\x00000001000001007d4fc1c2a52987279c6e7ea0b6c2418456575d0ae90299a5f1f3ae297b3159913c9ccc3f84913447fd4bc2a9079fde9bd76d1b4a8cd6b3b879445c90c22f6a3cb0ca69ba2eef14ab8644bef3a0a6a37c2bdee3e580797c2d7c944d6c5c050f494da6d4a6ab1249422db7e24338e2fecdc37add60913729a17573e7bf24d6eaad \\x354acb980fe554f40233c7e86bdda6e8e8fdce6926e0fb96ff8a4937a6241d9d2f1c08e0ae1eb3b0ea99274741689f9d24151614f8aec89a3bf74b0dc75f642d \\x000000010000000130578d7c039e39c3d80de7abefda20d375a77906c1a7ae1342a678f3d462bf7a511a6e1aa6d026a6587361234e18c1c9d2d37c3b0514d81af8aeaf6313ec1c26c7ae0b663c109e0ff1d45835d242c905098656632ce73a240134f2c8a9d48e4b62eb2258bbf235a9aca40a8b459ccc2d701d2c65d819bcb92818f933b5791b86 \\x0000000100010000
-43 2 30 \\xcc036535309dc8e2a91ecf05cf86c0ff0f3d0e0fcfc7a0b22c8eb28cb5e03a540eb55eff8fbe376b665e5774bf720c30f29ce55d4259b33d74f0bccba99af30b 193 \\x00000001000001008b8f77b0f9ba55fe463a93ed408d4716184021bf1edbfe0f6b966a88b008a8deab619f8de16701e2c2d6ce0af9b65e7a9aa1c87d4f804d92bd05c3c16e3c94e4ba63fa9626afb3df6ea2f50e70e443e1abcd14a5f669fc482d791fa72dc5ea08758aa509307917d0fa5651335ae5f652325c4105afb9fc8c0911c9b5b9e3b175 \\x2d35c5a410989beecd749ad9e3450d86c9a562cc381dd7ab8cf44a4e6f3757d230b74e383da7079d85c5017a617dde13ede5f89de3331c8d741910b06e88817f \\x0000000100000001258d6b6c38a5c5c049760c706b5e3cb2afebd87144a9a6685070edacc1b6885d4179d3696f96804f00f8b56ae9270bf5aab650c5287de41b97f0354b9ec6e3c228c44aff06815a21fcd1103e6eb7167befef7e339e1b8cae6cbcec47afa4d324adaf530bfa92dc7084875687f2365669f5d0344d6e2d619308d2690ff5226b33 \\x0000000100010000
-44 2 31 \\x112ff1f7a2bc83e5f3e375a2864fa2d9aec851bfdd5430af5d187e2b20f5b14a56074b970ebbb68676dfcf9bfd2fb3bf5c770374a69b19825c8585fa8734db07 193 \\x00000001000001001bf265fb74eec598cc897c331ebbeff23dde1e1cb1098205eaa480f892a12d4eb6ea6afbdfe38620bcf09b05f432934e418c069f22e8b4296c1df5157d9d13a6cb45d8da9143540446b46a4d547c88328650aee5be03e5e3b52a021d67127874622059a117fd847ac9364b738110319caf7dee61a46a4e2eec62fc47b4dbbdef \\xed11df4d684dc8484fe5e66e85234560719aa6982237cf55474ef787bf208fc4e08b61ea2b8c0a7bc38cf727730bffa91e6abc993618cf8ebce4ffabcdceee25 \\x00000001000000011f412ec88eeee6fcffb428f507bce0194e514bc43d0d6908537597f3d9549dc181ca29c52a203d1c6ea7a448aa0a017afb5ce23038f2486dcf4fcde4fb28b6eb8811f45d882c224f992f8c5e0c667874afad1810745bd7952b29ce0abb3cd31c15f4ab1623b4c746b855edfe9e9b6325b8ce486df537d646c97af7ded17381c5 \\x0000000100010000
-45 2 32 \\x8d6e8886940733ce9ff3cefaf4a971d59294fea57d91bf4df9f1313b9aff51bb55880411a742b521d797c2727c60aa34fa48334a27641128734b02cdb250a702 193 \\x00000001000001004d94672334fcf26fed05af12e5b78b3de8a4aebc3ef8285556c0899400a42443d34529e6c2d94a6099993647b65c7ab10eadf79fa61fc08a43d326e844d5fef7d26d770919fd587ee4ae078282bff5216fa446cbd3a225b607a46735e787b665c35d20157227e57e64db1761960af0ab17d20f5fe7a285f32763cef595e7ab5e \\xcabeea29a25c1e817714f8ef8e538cc1f8d3a89829d6e6986acb166dde8dd67880edf25efd214458bdc9c945284ae22f95ef811689a610fe71b5e07e2905a9d9 \\x00000001000000012864b38c972855000e849ffcbe60d7052b17ef9d3864de6219765f8753894740af35ce63fe034d957ed659b7aab7f4106044ddb6285ec29c82136b4d1e3c9bfd1854439f922632cb9f4b4fbc9adcd8cea017f53c00987cd1486aebe921883ff36e0c7d99b67cf0bedcf023fe247b82a0504493ad50702281bbfa666cd91ad5a3 \\x0000000100010000
-46 2 33 \\x8ed5a057bb9b24d92ae2deb6927c9cc2243af008088489517ca9eafe96d7acedafab0d8f4996730da0ff6b21fdd9f85c6ecfac1e6551314a0d0ff1262188cc04 193 \\x000000010000010082d357be44c053b5fedd6a37df0dd77076e3c8b9f4255eb54ade53b0671935c0f4d38bc0919d9bdafa0e7a75903376faca7feb4beb18b7099a5cd34fd31be984df780cb4e99722cdf945d454c67a814e3dfdc334b881f7201df9f064253d8572f374cdb51082fcee59812d5d4e8b13575d1d2b748089315acdc334abf68c11ed \\x00ee3dc5dd84948b74b7994fc273c3c11ec4ba5ae517e8c34a6ce7be0680308ed2402ea5c178c9f10cd00cf138fc632a362a33a305f9b73f1c6dcf4a7139a18e \\x00000001000000017120c437a092dc3d01138665b527a6ade27a409596b882b6f7060b14943f2de2ef68c644800086114056719f8429769cf1554e8dab1eca6aeb6c7be6bff9f769868df266ea1fb7158701faa8a08b5c02e7a610932d44c7271701a1347c074bbb94f714cd2f421b4fb4888dca2bc98d09daa19b30676e75dbe8e9c7114eb3cd90 \\x0000000100010000
-47 2 34 \\xbd3b9e60e05cf29c32ac98d0ecde204a9231b528b5c85ac01724d2188630a33a2c2ba63852cd9512581899792ffd6ce822ffa36dbc44b658b8168f940963320d 193 \\x00000001000001003691308377a5fe547c1d2754003943e6537ff8789a9f059a7e3633f1fa970079704195aeaffb459379fe2b398c257166bf407d29b358bb80edc2a9242585e900bd5e9c6c7e2ef50ce01f4e4fc417d1df7d2365330c6bca43c877409b3c9dd3215c3896e7df43a05b39d7a147ed7a7e891c8d4c9d853360b9da3358f889a10d2a \\x756c6ac0a8e6459b0909d270eefd8dbfe52dd4e2cb6309d589ded31310664bd4914a84796fc0840b569685c11119dc9afde75c7e8ad52865437c5a7d3a1a97cc \\x000000010000000142ef88794c9db47df2c4cabb35e8948bf7bc2c240c236c13d1efa5f40b1ab3e8767d747e28f200dccb8456fcc997d6f9ce59faa88a2a39a51ae386475912b5cff37de226c21a38163b8147684285d367b965baf33e134dbf029b535358339bdf70a93bfb8e25a7be0b3efe2468891fbf255475ae9b775d2c274d06e655b0c8bc \\x0000000100010000
-48 2 35 \\x6c7c5e734a9775fed52f7b906829cc8b61b5051ee1736a26631ecb3167515129b7c99f10e0aa29d67a2038d290d5b50757980844e8c601982414880b91b82e0a 193 \\x0000000100000100484a23d1ee56bdc46768c5b49543ddafc0fad3d44173e5d46ab5e280f8257e01e9105c9d2596fba89e9530152d92aed4490f0c561bc17435cdda081c2b1d5ea65314d968cf747f4ae07efb37de2eb141d0108ad2abc74968895ba406082c04a25e445add82ef1ef894b9364e870452036c2e4d8ba57a409a108445c6955162fa \\x4692a28b642a43f374f8178d1b0317e8fa1ce4aca21421843e2f94147a32b5d0ed8ef5b743e038e9a89de614459c9369fcfa938a05ec1256d23c83487a974b4c \\x0000000100000001689bd9ede290e3f709724dafd92f104f90a46d6844b8a51bd224e06012ae34b70314a86090fc724d4ed777b24c3f2799944404f10c068acbc23dbb89e4f6fd369dbb10ffe53385592fdecaa4b7c5c65e2af65806e4bfe41f531a0bc022397d17211a7968dd79f63d3d2bb96439908f6f0b0f0d7800c0968e9ba4795670ff9525 \\x0000000100010000
-49 2 36 \\x91bd0be8239ed1bb19ea85bcdd60f83c21bba291999d95e9078230bb73a0a871928ec05298ef4c2117562ae8e8acb538b944d4d33dbd2028abbcefd6d30e120c 193 \\x000000010000010056905c945712690bfb7fa49b86df5f5652e2eb633e7e25130eb2207fc4d557dbf97ca162c83532616c6737feb36d14ed2269786feedf96ff19e0a78497b140ad3df3e74b06a80eb664efa401d6d74f2eb932b678d2975f254fd3fa3caad1bbe1595aa9d3856a8edd32988bb65c4245041c26e2111d6bf80287f36202d91691f7 \\xd31b6c8232a51b1c92b0854afaf88d5d7f1c27b66be65be838c51589dd41559567b71889dd8ae63c15808f830852e7dd6cac12e6a95ba1edde0eecc07f09e59e \\x000000010000000121b2065c26873e413a98d1bf74dae59d7f3d3244b4542cd836736471d8ee893ad15f714e209458aa2e559578fef85c58fdf740f6ab058f78f6c744132bf4721f352890c08d5f576a220f95ea91e8ad4e162b5fb1839611b7d6c8bff72131a9c5de4d58403b0f8335dfa6abaeede4dbef6cea26fb64b3a8b8593711ea77a8d14b \\x0000000100010000
-50 2 37 \\x0fc4984701700fe1381e1cb0aacd8fdf8cdd6ceadd2e6e492ebcecdbcb0bf0ca0247fdf6bfb72aa5456ef949e07dbfb9a1ddebf708876a9df4573e7424d8a001 193 \\x0000000100000100555dc6f7665b96639ec5ee7f1d1af81142638494367ebd6e77ffb1ab408c5de90fbaa997c886cf015cbf4eb86dbd667583134d538d45e9f7a3d3aba53b72fd9d6f05d3edf841d4f46497cafab576e244bf46f9a55ef7730040c78ee470573a90be112e728752ab3bfab2a634d3f5d2740159d13daf35fd9d2c49a1ad82054d49 \\xf906cafe98bc9396b0bd6201e3ec47a5b821dba38128bdfad53576d3021c3bf60c89092a77ccbe17c9f8a60235e2fe422d10652c8b386e82fdf53a938254174a \\x000000010000000142b0c3fd76cafe4c8b23f0b2ee9674a444b8f6855771d763ea602de2ca8673357535bfb471063bad9032b0a1b40753a155ac2956be3423ff4b593df3f33f3e2b4bfec08ce31de86aef39aa823bf7fbcda3664058b73a2ffa939e2d494c372178ca3d63edfd57763778faeeb9d53f4d66c2fbd1fc525ef15a40b14d69bf8efe3c \\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 \\x68c4d95084c6e6b102c44421e4f55920a251c51bc69023efa718b4525d4a3459 \\x6e44aa480cf37e533054b62baca5cbcde075816fc9c452b94ff518aaf3f340cb0b1328908761c5587c55f5ac1f38ec190c7c9831a1c84277a9eace90d90b7045
-2 2 \\xb41c0282b7068ca252daa74122072f90d279872d3f4dbd211810a9fec38d920f \\x37053d6e739545adb81b681baf1ed53c790cd2c863d24a8b9d7b628bf182e5712783303bc89a13f5f6e65de4ddb28c084451807919cc7515204478b34b606f30
-\.
-
-
---
--- 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, max_age, expiration_date, gc_date) FROM stdin;
-1 \\xb9c28a718cc5abdedeb7188a00523252945905d1d33765de3e045e7944eacd4f 0 0 0 0 120 1663073715000000 1881406517000000
-\.
-
-
---
--- 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 \\xb9c28a718cc5abdedeb7188a00523252945905d1d33765de3e045e7944eacd4f 1 8 0 \\x3c942b03609b3cd8e4fcb95abf92bcf62aba6303da0902b5974643a4369fef08 exchange-account-1 1660654502000000
-\.
-
-
---
--- 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 \\xfb7df559cd80eefe8e0eeb2d543cbf5452ad8813eaddec8729298237a7630a58e8e005e2b6886a50bdab4ea45af5f03109a36407aa95dc45290339ae9e25a778
-1 \\x82f34489ab9bd7cc9b0aea11f482fee85e5b7117a9d08fb40d17d38daa232583bbd8de38a793d9534bce1bc947f2269dc21e48548d5d738ced886d5747b76e5a
-1 \\xf217ddd93dd5e5b56e9053b592b7074163f5dcfd201fbeb6448ccc960412c695e65d80878501d1211c2a0236fc11c70e26c2297ddd1fa6425ba8e7c5739b13fe
-1 \\xe95bfa18c21740bc74ba58f7bac783757bfcf2bcfabc12c079df315f581043687adf8a0df22a0600cc87350c8c980d2e8de3a36f167580e6fc8276bb2f4120db
-1 \\xd9bc709aa6244f558086fa9a7c8c9a9b298da53a8446a5ef603bd8a0cc23ae8c57c2c9ede64453fca1456bb0e4b8ed903ff730b68bec8a9a8614aff8b91acb90
-1 \\x04b54ea86784d13d36e8f8bb3bd3350e3a60c8d48dcb85da194ecff705105a312e9fa4cc3ce700dffe6ff48470a6318064a91c6bced22697d2709192656a6f22
-1 \\x19517ea7372037addd0b41d65809be55437e59acf707523ba6a5480999e5c42dc144be0d01dc4e406c765ce2aed43f914fd79b0384da7a39be283578a286da1e
-1 \\xbcdbd9a12a731df1453a7ce34260d3352de6bd35a8546b9b70e6aca54fdb17f9dec0aab3d5df1cc9c767ad16084309d4128952ef34e8f483c6943f44bac313c4
-1 \\x670be3fd9f5390aee57dd22c90602adfabd29b0247e34a83805d4fe79163ed73f1a337bad3a96b133de8ab99bd4977338da3f637e072fb3ea18d15e43bbd2aa0
-1 \\x99f8955c7978aaec80539014d32a0f07a3cbadf51e16c4e9bdf486e6fc9424894ed69d06acaaf46840469531be26a757ee574f90e37db976444954710bec1efd
-1 \\x6ab80708d1a6c1a96f1aa4dfe00c497e06f9d99814c472d2404a65a1af0469d8558f628ffc68d9e339915183e9d3d4def1ff74cbaaede65a05767f04da94fdcb
-1 \\xa0a0673431d0815b330b37b0ea1940655ae0d61126b11d2c357df35a8af90277c6e9d381febb4d02f859d8b67a8de9847a7680073c33da9d8f94f701894435ed
-1 \\x2f9009c32b821a2c0ac6060d90d8c708e7a1cdc33ab418e15e88ab8010991957764961ba8f6e7317d4b89bb1bebe8387a9084c0d343213f70d2f5dc2539a0770
-1 \\x0fdd9bc851a1de06068d9b854855fdee5b723493941f5ffa2f47a27fea8138fdc5a9ba496172f309b8aa47d1a5a9ed173389316fe2bd981cdf858eb26bc9b515
-1 \\x5c54df85f84c61053e53ae959bea3b4212713cb87277099ecb38bbd30824f3f9d50b9c272a44b0338a384a790b669326262f518b977746fefa93aba09ca45f3f
-1 \\x000246cc7711cbd4a3b1e061c5bf4de97b2f15c79a6a74d97911b5d7291e9fab367ef534f7b051a0e057769a1f14be1180f435b9937fd4a379dbd3e6293a3931
-1 \\xc1f27507c1e6498b9bb361b280d1435d88537dc7b373db13d414fddb4a63d4a3184c83d04215ef19f9c88158f2d7938031e925859713d33470e39a977be5fc37
-1 \\x85bb10f5fe500ee33f9c1d59eb370508fe3d8f875ca9876a7f61f48b4c401b2ac8ea96aec9ed3b010b2727d6e30b221c0d6f7321e003afbb12377f603342777b
-1 \\x707bb93db6451b111f5dde3e791f0320cc95e74ec30da07688d56a2c22bb5b278f1f84309bf7ce92394b9cd53650a90cea042afa9f6bdc3c997d659e919d3b92
-1 \\x3ead69a4c8ce2232470eeee25d88a4c7bc88946794d6b3d20abcd56f5aa22cbbb9cd29494e4a94f81f2cb990fe7d00a09750b70f55d6a52395c762129a5b6514
-1 \\x8f3ec6eca08775f517d9adfeb334fdd52ff7b49a42b4210dda3f6b6da286731bd8a88ec9420c11c311b90b164c85f92f64775c8f39ae3d4eb55d10326642037c
-1 \\xeb2d4a22e4d8537b8a7557617fcf9f85b54e204ac7f34eb2b0dbf521a35d92c2fb6e7641603446f7ba4522a7ecc0015df8a3f555d18681014cb61aeec891fca2
-1 \\x20281e845c405ba48f4b5e64f7bfd8c48c9a84c046f517a39472939fe386f942cb2b961ef5b7b49710fb5ac9d5769d0310ab7cbd903976ca0ec3335af5f1b7c5
-1 \\xf2ed97bfc10b7ab297c28ef06c8086dc217fa9a1e775f05b2c5583c119d8ec77ad89bec0d457febe9b21d718d89f70dceea6aa0b5967ed08fad6ff8927e12232
-1 \\x6e36686d7b83bb8332d9e8eed6ada2224dea7e8ab8593dd2ee1dd0614b2e0820edf4fbce91efe6a95d7ab08e25517b4e6a51245117240ff6a35135f77c363854
-1 \\xd96e6421db4885471054d373878cdfe6199a8a607b19552df66ca8331bc2dcd1107af728077e35f54622f6c63a04c4874badaa78e7dec89cd93de274f5145af0
-1 \\xa72488712f26d754f26b2f1b7070ff09c67199939d7f76abe3eac354ca0adce78695d05f0806b2103108c0726372d1eef95a3c72bf3b7141c661f731cda78ea0
-1 \\x97ae4f6b79269b256a12262167428ccbd0822bc6cacd5bb937fbaa5f16b9ba3f3d8e3d622422f3b0077be3c84872c22cfd61d35346c254c45924ae8eef55876b
-\.
-
-
---
--- 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 \\xfb7df559cd80eefe8e0eeb2d543cbf5452ad8813eaddec8729298237a7630a58e8e005e2b6886a50bdab4ea45af5f03109a36407aa95dc45290339ae9e25a778 104 \\x000000010000000104a6c293e6f27b6c2d1ede04f04cf1630854f0200a5a1fea3c35d6ffb1931431c869d1cfc2876e4af3a051e2b034acfaaaefe33882f15ba35de5ddfa0fbe8bd103b25d97117c59ce0642d15cfbee13e6b8f3a532812a8d53baed9eb7434a90c4ef9afa9967bdace136c19bf0cbe3098c0e63879a23ec3c3755467feca1f557f8 1 \\x5deb764cfedb946a2e49dad70c9af08988b8a94871a2fcd3d500e8641f25bd32034e692f7b12a8060ad3ddd3985f648b9a5a616f6da5ce79760e8e33a21f000d 1660654505000000 5 1000000
-2 \\x82f34489ab9bd7cc9b0aea11f482fee85e5b7117a9d08fb40d17d38daa232583bbd8de38a793d9534bce1bc947f2269dc21e48548d5d738ced886d5747b76e5a 3 \\x00000001000000016c2f4f2571bbd9c24c034b97231654a8ce3e0adb893fa5d0cc0a83fed3c819db14695920b7ea722a5ed80844cec6e20d6aadf45abeb500581c3a8cf02f07e35f54fb8ee253ff443dbe365d4a75a7cbb69195a37910c98696dd18f8baf8495073866e35e25c0a1da16c1a284a4a6e7ed909a421745db3c141f06c7872901b858a 1 \\x5be36f6ddb1630aa8d3689bde73ae3a15bc0a47bb3c9e55405abe4e45cdd7db9bf7c6551ef88aa0fbcd21783b2f8dec5c5a65feccbdb62d51a46a55a3423aa05 1660654505000000 2 3000000
-3 \\xf217ddd93dd5e5b56e9053b592b7074163f5dcfd201fbeb6448ccc960412c695e65d80878501d1211c2a0236fc11c70e26c2297ddd1fa6425ba8e7c5739b13fe 353 \\x00000001000000019c590b88e7150d2b635ab7a92b6929b19916d5fdbec626e57beded4088b67d84c676e7a4bf088ebb75cb2bd307cce826fef8563247f5bcb5b731435baca8827c9595cc3e27239bfab7914ea95209c8090340c3faa88173c0811602b2d84e32cc8c5733da6a1c488a89fe5f5e76c69a755f413c149aaee8534c96764a8518ba13 1 \\x08ee00edc19858c652665bb0ad54f7ff3f7303c4eae994e21e43bc774e14ce43f6760e47fad2ff80dbb3d7e13128409c0bb5533e2cb3029a7ecdfb2b1d8d2507 1660654505000000 0 11000000
-4 \\xe95bfa18c21740bc74ba58f7bac783757bfcf2bcfabc12c079df315f581043687adf8a0df22a0600cc87350c8c980d2e8de3a36f167580e6fc8276bb2f4120db 353 \\x00000001000000012e22fd15882f8d2a36f1172b87efdcbb026a1c7291e74d3a3e673e335f441e0989cbcc76a6eb249ab6d6ffd7b76b5d0b370b188341a6d4c3781858dd7cd96f48105c041b8a0d734cb1c45948a32b209af71cca42f307c8a0c1a787499827987c6f724186570165208f068173d12df4d2e386b373966ac1745687d49609c85813 1 \\x327732f2d6869b4ee3f3d608b34a1b4e9a28ba2d91533a1dccbb3e93216fd042f0ef2332efc78040b2c4a51530211e5b0ea9f6f9ef9fee151e03f7570f8d6a08 1660654505000000 0 11000000
-5 \\xd9bc709aa6244f558086fa9a7c8c9a9b298da53a8446a5ef603bd8a0cc23ae8c57c2c9ede64453fca1456bb0e4b8ed903ff730b68bec8a9a8614aff8b91acb90 353 \\x000000010000000123527a395b725bfef6a9d1f526702ec39273c538483757b522611c0c95fb92b8b8c630328602820eaf54b1fad88a49fa1f6ed4a6e0bd8f45cdff00ce499c8f6290e8d917091d340f2a4ad50a701ad449be1b01e934a20ad66371fe37e86e76db15bed9742928c26a679e3137bf6f16af115d7ba96ce5f2dbdedcfa9f2ac2fefc 1 \\x38dca2b165359584f6c7a43252744b9c7930cb5c4972ce41adaee9baeb75c7f114be5c398c0850ac076b8fa0905cfe68fbdf8833b4d9ff5104de80664dca5c04 1660654505000000 0 11000000
-6 \\x04b54ea86784d13d36e8f8bb3bd3350e3a60c8d48dcb85da194ecff705105a312e9fa4cc3ce700dffe6ff48470a6318064a91c6bced22697d2709192656a6f22 353 \\x0000000100000001505002c602d566bbdf56d72b405bf0fc092e064eebfaee033ddeb0471f251bfcbd157dab4b45f34588c2dcab3b01e8908c79f00899c920cc16c0f064b22f63b6d7a4ccd7e46d6f6156d6f6da1f51fdf815491c18083c723a94c4433086b466b7f07d6e8f95829422ddc2958b5142c3088cc95b4f1b5fd62b205b50f341f47696 1 \\x3e485fab3d21c903d5d406c2bb1046fcb99915c6faeefbe66c6df266b363bd736a8c31bd7437987107f0288e79b465be47774c2acd2e86362a3261b702999404 1660654505000000 0 11000000
-7 \\x19517ea7372037addd0b41d65809be55437e59acf707523ba6a5480999e5c42dc144be0d01dc4e406c765ce2aed43f914fd79b0384da7a39be283578a286da1e 353 \\x0000000100000001846290ac8c45c3738d7eb004b7a1e8ca362455248b347a0148089b2c8bc597a5c5dff0d0a26f1d3141b150b913b36762f2f68e64a12713b7ebe68b3f51fa9b7805a3c4af38acabd5104a946ecaee27d6c5ee9fe6c343e6b3725ac21deca0ed1b3b944ee8a4d55d4434bcb013b87058ab67eb13658f94a9887f610da7febb4ba1 1 \\x451999a9dfb0212dc25620571bc96ccb65980926c065098ddfdcb43428170baf0c758034bf243d5bd8c4059217f7235aab11eb13e6e965d008d3b0b3f1b55303 1660654505000000 0 11000000
-8 \\xbcdbd9a12a731df1453a7ce34260d3352de6bd35a8546b9b70e6aca54fdb17f9dec0aab3d5df1cc9c767ad16084309d4128952ef34e8f483c6943f44bac313c4 353 \\x00000001000000019a90f58b285f2979004238cb439dfe11d41a1a744867e378ab776370006a8ae1af236e291ec54489f3fba1f1f961ee1333d794974e6085661dbd80d85a950864bee3cfdec9a61dab1c991767d4df2f989142d29a8c7a23eb7f0c11c188b9f371f245664a1b104284104a3df504b7b182f91d7a43287f8714ad714c8de5c135a4 1 \\x2f375e6ec69f29bba33913174df3c64031983039cd6ba9710c82fa48294a97905ab0ba6d0dd4a0272fdc31d1068b1a4ad971baf8a5fc7821b1d23983af6b9608 1660654505000000 0 11000000
-9 \\x670be3fd9f5390aee57dd22c90602adfabd29b0247e34a83805d4fe79163ed73f1a337bad3a96b133de8ab99bd4977338da3f637e072fb3ea18d15e43bbd2aa0 353 \\x00000001000000015a52ceddd227f2379d31eb87c6716bd1fc51822b33db177c2fff270d3de8244a09da7a7417be2974c8935c6f720e5f1d0a6c4f4a8b53d950b97e9608a4338c2aecd490a8d6f5b28699d9d88a1422d477ce6021e949969b8a1610aa748b60fde0206f39764625d14563d838ad92372a8a9ed6c513dea68c1dc041bb8b3a9940ea 1 \\xdd884503eb9d3ec92c68345ef5fd1fb2ba3e6ded677c46bf14e3a25bef8c88608e451a605900c3763643f0eee57a946f8d7d640096aa07e2231529880a8df80b 1660654505000000 0 11000000
-10 \\x99f8955c7978aaec80539014d32a0f07a3cbadf51e16c4e9bdf486e6fc9424894ed69d06acaaf46840469531be26a757ee574f90e37db976444954710bec1efd 353 \\x000000010000000190ad8dbc0167bf88cc25a626a6188c09693f5aec237ea223428390f3b8c68839568c0a429dc2fbcbb0963ab1a0937fcfc25357f203163c1b3a0f9ec77f8aeac1a1e8ee8e936dbdaa5687f4993c1476a6f77e1e5a00f44009f9cf24d18a8ac266abc5d30bb0c609f53754573a2312d7a8e560d8e199cccdf3f995a65dff2dd269 1 \\xaa1a5ade138e350226ea2e03176a22c88e9a270a5f6536cbe7ac9f016cde0f1b71cddc1ca7d8b1307a808af0be9edfcb58fd3e39f1ba7cd3c59b1bc3e487c804 1660654505000000 0 11000000
-11 \\x6ab80708d1a6c1a96f1aa4dfe00c497e06f9d99814c472d2404a65a1af0469d8558f628ffc68d9e339915183e9d3d4def1ff74cbaaede65a05767f04da94fdcb 70 \\x0000000100000001d008e73ce266080b0a2b5b137cad8f75c75e9cace0925652db4376f70f3ff9dff664da9852e3702629c6cce7345c62614db94cec0633471c0a54eb5dbbb53c6e63448dce51854207db2bd3e8cf4333dbb23b06a7a59256a04e97310146db1e525ed4e0803d14f74f3dac36c8654e211038c8340f31486cd4c824614b2f98d8aa 1 \\x4a151b22d0b16f2b6a77093786bd42385034f0f917975839dbe2648232ff8f6bb9b3f3614c202e40f0209271d86062ca83748038e5f2fb041f9434d6fe2ec008 1660654505000000 0 2000000
-12 \\xa0a0673431d0815b330b37b0ea1940655ae0d61126b11d2c357df35a8af90277c6e9d381febb4d02f859d8b67a8de9847a7680073c33da9d8f94f701894435ed 70 \\x0000000100000001643399cabbd76f7152d22942bcebda1290564a8f91f8a20284e95e94443ca88bcf3c73d67247cc44c4fbbc9c491052ca19684ab65427a042e2e7a646bf75b823f44ab8b6f4a4cf14b1064d3f978ac4c2b7de7f1024b236b92d965650b47f022626657086f46d9584a1b501ead6881d90ee87de074a0cb55a7355bdbd5a0bbe13 1 \\x13d385b081837cff465685341ff2ab4f87f909e1daca2354d6cd1e5b6558a3556b006aa74a1ea6ec524c737a8fb36f7753f3b888b2f07cc8baad35ffa4d3b109 1660654505000000 0 2000000
-13 \\x2f9009c32b821a2c0ac6060d90d8c708e7a1cdc33ab418e15e88ab8010991957764961ba8f6e7317d4b89bb1bebe8387a9084c0d343213f70d2f5dc2539a0770 70 \\x0000000100000001d223fd8de7ba306a396e62645fae205ad701858510c9b5325ce6989a2594af2bcb245d5af622ddbdd35a78f25871853b078f948b8628a72c73baca195ccc447a9cffb76dd9e910869535bb6cb1c87509868f8de4b43a95c975fbfe1fbe95511d3d9b318992732a0c7b8620e77b19d0d488981a7acd02c0562459e3594f3a285b 1 \\x0d8b6da0dfa58224685b3fbea583f7e3c059b2cbf44c1e437f68b7675e5dd9467795a1843cb5c229e81fc7ec3b99651cf08319a8d0f5fe89d8a31a47e66bfa0f 1660654505000000 0 2000000
-14 \\x0fdd9bc851a1de06068d9b854855fdee5b723493941f5ffa2f47a27fea8138fdc5a9ba496172f309b8aa47d1a5a9ed173389316fe2bd981cdf858eb26bc9b515 70 \\x00000001000000019f8b86d68a5937c3caa4290bab54ae893a8b47bb8977faebd40b63f16a0fa533bb64c7752b15b9994ce6451ec588d3d6077c6ff5199a416d029906b40a53245b4238405288fc016fe35cb483b44bd588466971868f3c625423cb366735cda1aac2a3694d8ca78e2dbf2997db3a9daa9fdd2fdd95d5b2b4651f3b8b9e616bde46 1 \\xdfc820525c0e1924cf3d71b3972a54b4ea3c0aae999f8c3fdab8bc4c7236555e5ef20f249ea159545355ad83ea8fad48ee92661d7e2f9e0ce8d50d4f32cbde02 1660654505000000 0 2000000
-15 \\x5c54df85f84c61053e53ae959bea3b4212713cb87277099ecb38bbd30824f3f9d50b9c272a44b0338a384a790b669326262f518b977746fefa93aba09ca45f3f 384 \\x00000001000000018eb318688b93097f1c28b6bc36ea56aecf0dd57e89ed8ba777d674c462983662d74d1d47d67547d5e25eda04f84ec2510e987f0b9b8b345b54c0916578744cac1d8dc29c3b815746c321d420c7979941c1a33c64f523820bd314b25dca01b1be218a2e76c553d63133658ac465c0425edc0befd93c55107488d08c765ace664c 1 \\xe703c6b6ba80bdaa9f63a6e85b0bb2d2351e0ba976512570f0aae0ecbf5077f8ff7dbf11452fced7da5fcaec6943f6d7073f8fff0200ff496712864a753d690e 1660654516000000 1 2000000
-16 \\x000246cc7711cbd4a3b1e061c5bf4de97b2f15c79a6a74d97911b5d7291e9fab367ef534f7b051a0e057769a1f14be1180f435b9937fd4a379dbd3e6293a3931 353 \\x00000001000000018cfc4e6242ace0d546147e8836a4e4c64db03bbfd2ae65d6c2a1b04cce10caa0cd96f70f89020a4f44466e0095b61659f7fe82f385e03c4f64fe2e128af9903168e18be6679579de43bc050a7945b001a5ebd565f7495a3045b947771100b40bc01c8545cee906780afe6eb2d526a8a3fcbf2332ff6be5b3b88ab1b2ac63c850 1 \\xecc07706c7d3748005d371d63096b2a3b2fc12d6c390beed2bec84d6ace71d6dce476b18279d31b6d202f1f1bb223ad24b689c9f5ba7cac65fb0994b9a94b402 1660654516000000 0 11000000
-17 \\xc1f27507c1e6498b9bb361b280d1435d88537dc7b373db13d414fddb4a63d4a3184c83d04215ef19f9c88158f2d7938031e925859713d33470e39a977be5fc37 353 \\x000000010000000157df5ebc5c4fbf109665bea6284ef124c336012bf75404526b35e69aaabd7fa57859bf8a832adf37da1f4ada1f9e014eea39b6c74702942bcb278c1c24dc0996c44da0291a40167b4483b78a495ff9abd37e11e84da553692fe0ba75dbf3aefe140a9eb59eb96676e1a7389ae0b60346df511cf88f050f6f92d12590422a0d01 1 \\xf1181f4d1e4abc505560e167361101fd7345ff151a6935f8a67818477dbda3ed7849942d5ecb087462aca37b7025e54661f2db7e80e7369cbefe64666860bf09 1660654516000000 0 11000000
-18 \\x85bb10f5fe500ee33f9c1d59eb370508fe3d8f875ca9876a7f61f48b4c401b2ac8ea96aec9ed3b010b2727d6e30b221c0d6f7321e003afbb12377f603342777b 353 \\x00000001000000015ed6d8e28f441e4692090479717ee0829e68ea537daa9e24e7b04105a2d524012f86d76de93cfc090ec0702906118d2f41073f7b00fc037123c597cd66932769f3ce8694a6cb7c9d4097cd5d8c337a011197e5ec49e8a062721924bcd16eaa3e350a095d5c9ec05b45f8c726755ccb93d3b61cc18c5648ed46d664740f67f873 1 \\x4bcb5c8a86ccdcbde5ed21f5ce88c8e428504d1dcef21d5eb7c712e7be762582af66abd99237cbacfb6800efa0ab8f56c8caa42c968724b42dcd46b858e5fb0a 1660654516000000 0 11000000
-19 \\x707bb93db6451b111f5dde3e791f0320cc95e74ec30da07688d56a2c22bb5b278f1f84309bf7ce92394b9cd53650a90cea042afa9f6bdc3c997d659e919d3b92 353 \\x00000001000000012b0c23c559b0b95a8b2ba8f4f34c36270390f29dfe0adc0670d1535be3d12a662a7de8761681e4864213550e9d6b1b3f44979592f77c0c307fe0ba0f7e4ea7a0fcfa6af20ab6ecf809b8ee69f36896112608f075078ffe1d354ed100ee1deb12c5b0278ac68202ab8221e9d504fe93d0ff1a37ff53c7e2b439b96a315d37611a 1 \\x1054231bb98fe474bad40455f5008e0fa551fa88bb8dc867ab115042b082810d002f4587abf98b92383aff1918c96dc83d384952ebd9c92cc941e8ddbcb41b03 1660654516000000 0 11000000
-20 \\x3ead69a4c8ce2232470eeee25d88a4c7bc88946794d6b3d20abcd56f5aa22cbbb9cd29494e4a94f81f2cb990fe7d00a09750b70f55d6a52395c762129a5b6514 353 \\x0000000100000001121df9f3a4bed74d52ab486e00124a0ac3a1ea59b0f9dd5cd79dd865c95e871bbcc8aa424cac63e81ec0fdbe92d64a578d04df26c4c0b9b3f3e1edfcb821eaac90403d392bf790c79fd1d285576d60d23c3ee9052dd3288a93042076fe3d3d58d048a31d7a15e8ce99042823809f90b3276f2fb63a6f7e207b36a3388bc119d6 1 \\x59e57a09f1c46875b2bc1fccb4a355e5d046982fd91994a8efcc8ea8b59e3faf39d2880f4b445129515b43a1e6121da7be93cde1cd49ad6380a85f004330a808 1660654516000000 0 11000000
-21 \\x8f3ec6eca08775f517d9adfeb334fdd52ff7b49a42b4210dda3f6b6da286731bd8a88ec9420c11c311b90b164c85f92f64775c8f39ae3d4eb55d10326642037c 353 \\x000000010000000172573c14a05e17c5c173ccee255c4220fa6e8c04eb7e2e3f6393cc3518a00c5386c0ce41751c746f91b41d28f6f413746d45df606b50d561cf2d5fe6f4f3a06b0ad547ea18c7f00d5d0556428543d31dc1540bb249a03aea42049ccafeac7e49d81c39f2fef401c8838893f20b84e620ce2f790743d28aebaf4a932b33aba60c 1 \\xa4334a7c19e0bd01b16f07e147c6515bbec259f21535aa38c0ec8997886c78b33848cccc049e52986787a6ab99e630fad1cb4acac283790694ca6979dbd06904 1660654516000000 0 11000000
-22 \\xeb2d4a22e4d8537b8a7557617fcf9f85b54e204ac7f34eb2b0dbf521a35d92c2fb6e7641603446f7ba4522a7ecc0015df8a3f555d18681014cb61aeec891fca2 353 \\x000000010000000166a3d5e3f33b77d9458204aeef1be4986c2bfd9f1b6e9abe250281a021ad6642a6f06cc167e7c915774c2abb9a632525f304b955425422e529d124fdc3d42b19b2e633de6f9a5f30ad21b8bdcbc6e09712f5d73d437f286d84048dc1f079f519fe4bddf038fe780554df2d41d21029d3a297b94aeb0c72f5502dd6d9a2529427 1 \\x787f85417e11d37b3f282ff6a689b5f9ac2b63a26d75df56098610ded0a8cefcb8352c8be66766782b4b1d0e779a327baa52dddc6696415d01698f0e3b108400 1660654516000000 0 11000000
-23 \\x20281e845c405ba48f4b5e64f7bfd8c48c9a84c046f517a39472939fe386f942cb2b961ef5b7b49710fb5ac9d5769d0310ab7cbd903976ca0ec3335af5f1b7c5 353 \\x00000001000000012fa0543ca4e283c78c7f796a1bc274f8c4e169ce4ef1262e791a3bdb03b6c839e080290aee053711dd904dda73c06085198580c0296e1bda4be11cf0e3d04ec068b029cb222a62a1e64a996552cc22b7c8d7981dd429f9be547e61ec839aa37138c620fba1269f9a706af3c9a6a45e017cc812f1b641da4b51a2fda7d129e5df 1 \\x20d3aaec576e704731db67c8cb12217d01c5b948c642666b3bf9da7125a13bdc9bd4f5cabdd2516c0c687b03ae2a2044431b38836332972b934c754706e05e07 1660654517000000 0 11000000
-24 \\xf2ed97bfc10b7ab297c28ef06c8086dc217fa9a1e775f05b2c5583c119d8ec77ad89bec0d457febe9b21d718d89f70dceea6aa0b5967ed08fad6ff8927e12232 70 \\x00000001000000014787bd8284b950055a29fdd9e51c22cdd6401fdc077b0237b1982f94df11385e6465da71115b2d0b45c9a284709ea5d85a336047911728866e042a6fadd91c8ad876a21f67e604b49bacd5683005f3706a4932761ee67711b79fe8ca83c8ea3ac59876365d9799ea0d8fce3b627db85bf46bfeaa2eb9d3b4aaea9dc9668b34d4 1 \\xaa8d1e67b1a8822fd0e7a0038213534c02f24ceff5c281f583a7c3fa8448855420171125560ba93205275f786bf1a5a4010cc18b094fbd79270b8e39d445a108 1660654517000000 0 2000000
-25 \\x6e36686d7b83bb8332d9e8eed6ada2224dea7e8ab8593dd2ee1dd0614b2e0820edf4fbce91efe6a95d7ab08e25517b4e6a51245117240ff6a35135f77c363854 70 \\x00000001000000017c0d3f3890619ed9d34cf0658c16b2b32549d0add4bcb71bd5c5a7c4e2ad2bcd2bcf6e9a3807e1a4d6f2818d6889e8e2d2b424fc19b051b2449dc1e46b1097820bd6a8b32768ba59c6cc28abaf4436934b53345dc898f8df89f3ae22d77473c631bd525240c012826be14a9a5f20d2e85ef4f84642e3c1ca68c0f509e8d2a583 1 \\x5a6aa0bb98a2804c773fdcdcf0bc1a4721c41ec50756f664e19532dfd9d00062405db273ee9ebf804c83fcd48669f4a390494b1b75f925262539e8aa6f6c0c00 1660654517000000 0 2000000
-26 \\xd96e6421db4885471054d373878cdfe6199a8a607b19552df66ca8331bc2dcd1107af728077e35f54622f6c63a04c4874badaa78e7dec89cd93de274f5145af0 70 \\x000000010000000145e591b5a9988ab84537e98f1b5094da1de58fcb8abc935ac1c39790a168054c28074a029de59c8cd0e97e5e63809590e51890260897bc4009c119de376d1ea4a7eb14cd17e05eafd238ae76706fa6b2cbc23c5f572177958b596a9f146b87bcb764f25b165c89ae60e05ed8dc3539a46e76f77b2d079905cedee3a10340c5a1 1 \\xb799dcd744f5884582c18ef8c7fcd58168b29b9c237c0cc0f03dd205876cefdf0ace2f4e3f64798896f5e625955dc468a70810bf305d6944797ffc390bb7d203 1660654517000000 0 2000000
-27 \\xa72488712f26d754f26b2f1b7070ff09c67199939d7f76abe3eac354ca0adce78695d05f0806b2103108c0726372d1eef95a3c72bf3b7141c661f731cda78ea0 70 \\x00000001000000012aad4806582910070478dd77779ad8a18d95867ba1e6f8c521a8391e48b6869d68e54498e9780d77e886f5a4a805af633f6df5229008a0c96b494cdaea06fbbf6deca51bdad860e09e15119542193e454b67fcf3b881f3e707bedcccbbb46416bb0f5bff7274703b17e410c9498d89260c6defbbabcd6ad70e49d4c1660c831a 1 \\x7f4d7a8a6fc8a2a71b29fc8cfe7268f6f5f387de219294e948a322cf1280ef039dd9874c6038f94446f2861c932800620db2202167e2c215c6c07acb0b6ddc09 1660654517000000 0 2000000
-28 \\x97ae4f6b79269b256a12262167428ccbd0822bc6cacd5bb937fbaa5f16b9ba3f3d8e3d622422f3b0077be3c84872c22cfd61d35346c254c45924ae8eef55876b 70 \\x0000000100000001ce7d58dfcbc25f33dd7b19ae21d427b3f9129faed751a205d9b3dfb690575f4e341e078a1eee7fa04a11049ad8b62f363c24d679f14fbc8e4220d3725e9641f6ce4aaa84336dfed36e6198ab5d86c44617760daff3638ef147c33fd9715afff81e0af1dc1d393b828c92ac66468f8479f335542cb8ea7cacc6c2c323e197afd6 1 \\xd732a53bd0ed1f202e74f0871b65020d66f1ac3d4a9bceb1d83f5d291a12a26118d1081175e4b7077f52891ae02193043eb5ade36f9903ec3131876f6bfe560c 1660654517000000 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/DE870149?receiver-name=Exchange+Company \\x1c64d6c284876958e0a5b6c1612b8353bdc06a84b4b598dcfa534b88576801f4fbcf29fccb4e2f55d53ddd20681a6e5b92c9a2caa25f99f4736d0f65b012d507 t 1660654496000000
-\.
-
-
---
--- 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 \\xa44fc10beadfe76054b7ce38d899df6269da7e291fe99b668d57165b9e50400f02d9a62ec0dc11c85b685604e20d0352fdca034e2ed0e1e700afd23c57ef6c09
-\.
-
-
---
--- 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) FROM stdin;
-1 \\x3c942b03609b3cd8e4fcb95abf92bcf62aba6303da0902b5974643a4369fef08 payto://iban/SANDBOXX/DE886824?receiver-name=Name+unknown
-8 \\xd31e3f48cb5318906dbbb7948326362f41604c7a728323230ae82aa995f27400 payto://iban/SANDBOXX/DE474361?receiver-name=Merchant43
-\.
-
-
---
--- 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 \\x4e5560fd6aaedc6a128debf56db7f43664b46eaf7a1707c518d899179a3d7cd4d3c7da4e984a05978144f9d14943fa4a1ededd44e4be39ef34a1d81afea70050 \\x08d3af20dd4f3192c2b79040c703b7d2 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.228-00C4509K1JGW0 \\x7b22616d6f756e74223a22544553544b55444f533a31222c2273756d6d617279223a22666f6f222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f7468616e6b2b796f75222c22726566756e645f646561646c696e65223a7b22745f73223a313636303635353431387d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303635353431387d2c2270726f6475637473223a5b5d2c22685f77697265223a2239534150315a42414e5645364d344d445846545056445a4d36534a4238564e4646384247464838525632434846364858464b414437485954395443344d314351473532464b4d4139384658344d375059564e32453946485358575441335030545a544b47304d30222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232382d303043343530394b314a475730222c2274696d657374616d70223a7b22745f73223a313636303635343531387d2c227061795f646561646c696e65223a7b22745f73223a313636303635383131387d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a2233315234354a54474430354734444d443048515344564a344e424d5153564642434d424656563532594b394a3443344d43395a47227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22365a475a4a5254353159514531503535444235504e565a39414d56465753454348444443534a4753344b33304a454a3059563630222c226e6f6e6365223a22433053544d33413746564e4a4a383545564b565148373035393548534e475030384b46344143313733475232454439414e4d5047227d \\x00cdc96040fdb55b71f39af7132cb8d53a818197207e1160a403edf2de1588e579dd07e454b85706ec6df8f07fcfe773dfc1a5861f8eaa7b90e20ada26986c50 1660654518000000 1660658118000000 1660655418000000 t f taler://fulfillment-success/thank+you \\x2ab6dd3d3015a474e9342c0db4bffaa7
-2 1 2022.228-02W6JYRQVATBT \\x7b22616d6f756e74223a22544553544b55444f533a302e3032222c2273756d6d617279223a22626172222c2266756c66696c6c6d656e745f75726c223a2274616c65723a2f2f66756c66696c6c6d656e742d737563636573732f7468616e6b2b796f75222c22726566756e645f646561646c696e65223a7b22745f73223a313636303635353435307d2c22776972655f7472616e736665725f646561646c696e65223a7b22745f73223a313636303635353435307d2c2270726f6475637473223a5b5d2c22685f77697265223a2239534150315a42414e5645364d344d445846545056445a4d36534a4238564e4646384247464838525632434846364858464b414437485954395443344d314351473532464b4d4139384658344d375059564e32453946485358575441335030545a544b47304d30222c22776972655f6d6574686f64223a226962616e222c226f726465725f6964223a22323032322e3232382d303257364a5952515641544254222c2274696d657374616d70223a7b22745f73223a313636303635343535307d2c227061795f646561646c696e65223a7b22745f73223a313636303635383135307d2c226d61785f776972655f666565223a22544553544b55444f533a31222c226d61785f666565223a22544553544b55444f533a31222c22776972655f6665655f616d6f7274697a6174696f6e223a312c226d65726368616e745f626173655f75726c223a22687474703a2f2f6c6f63616c686f73743a393936362f222c226d65726368616e74223a7b226e616d65223a2264656661756c74222c2261646472657373223a7b7d2c226a7572697364696374696f6e223a7b7d7d2c2265786368616e676573223a5b7b2275726c223a22687474703a2f2f6c6f63616c686f73743a383038312f222c226d61737465725f707562223a2233315234354a54474430354734444d443048515344564a344e424d5153564642434d424656563532594b394a3443344d43395a47227d5d2c2261756469746f7273223a5b5d2c226d65726368616e745f707562223a22365a475a4a5254353159514531503535444235504e565a39414d56465753454348444443534a4753344b33304a454a3059563630222c226e6f6e6365223a22514d4235454a57593446584a46504b41335841594846465757374b39454853483734374a41334b475147414b544b4b5931363730227d \\xc322b4ebdf16614d1c5a72ba91989486cda1e26b02ef26d105f71bd952f2f22b9f798dab19b98bf191c662338f571a6c295caf24ef961390262b67f697a5c7c7 1660654550000000 1660658150000000 1660655450000000 t f taler://fulfillment-success/thank+you \\x855908c98bc7a7905ff2ccb317ad6503
-\.
-
-
---
--- 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 1660654520000000 \\x00482e972a0e5c2d91efad58eb2f298fa5604f7879e9be37657061e6fdd5e53c http://localhost:8081/ 1 0 0 2000000 0 1000000 0 1000000 2 \\x81494bb48a83f0f03d5d0c86d1e6cae6b2b3713275415be99e113d1ff4eadfe4529cc7fc87e739ab13f1e0c9f0d1b8c709dcbe5b11bbc0f2626a5e8ce6d4a202 1
-2 2 1661259354000000 \\x00ffd8756285c382ec9c7cbbea48a2d0daa35ac810a8d23f126ed758eca99b8c http://localhost:8081/ 0 1000000 0 1000000 0 1000000 0 1000000 2 \\x585af5eda8b3f8b06ba72dac11f599f6cdeb4996814c59096b018dfff955571aa2bb3366c4fdf4a92e56b9f97f92db2483d5b6ecae4b8eec1e4d4a767147b20d 1
-3 2 1661259354000000 \\x08cbb6eb28062d0ee4ea289196cd77b6fbc825bc6972624b88c5512be2e55fbf http://localhost:8081/ 0 1000000 0 1000000 0 1000000 0 1000000 2 \\x2bfa4363fc9ef8a7ce881760f335892bdcbac802c028b8ce4ca78c8cc153b38fd9d6638cda334c0b3f411c0c717f897eed6f0b3c0370e8655bf3e47aec765305 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 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\x811bca6bcbe1bfd86f768d8f5917a0119f9006bac645b532ac39076b6e540453 1675169089000000 1682426689000000 1684845889000000 \\x2a5114e54b06bca1ac06f218b69dd18c418d0b09dc73db5f44c61c195515d6554b5ee765c4ff151aa9421a2b0b13e934c6f26ba2fe11fe12bc823a4f640f5c06
-2 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\xc32561194b4b6682cb7029e149cb59c85de1968e440502f57040754b2a678892 1660654489000000 1667912089000000 1670331289000000 \\x7264213ac164de65e186b021d57d7cb94ec27245ce25c0caf460ff9dad3463d213f644235699fd4cd0a4150f5f3d92c99da5d6d4d873ae93dac4407775bb6d03
-3 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\x70dccf9873559849a59c15a45dc39949ab2b6432936a14148d0a8426b4ef4230 1667911789000000 1675169389000000 1677588589000000 \\x9a155de882455e0bdb4f8dc71954a88eb6e8c318f3fc2a4015a33dd682c23211fd7877544e5b72cb4e1cce17fcff876abbf34cbc1720ce869ec9d159d02cb900
-4 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\x50c01d5134ad469925ad877b9d6866ae23b0655c41705b44880b2ad4e69f946d 1682426389000000 1689683989000000 1692103189000000 \\x08c294b061c552a32f348aaba6b55d03f0d1c188be276e8f3cdc0e4599fd714730e25b91a785110240e5fa9e8cfc6b2432d27fc68d1d84f5ab2e083a42fa5a09
-5 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\x92b6657d3608b9e13fa32373bce1aed54098deb20f173765179fd32b3e7aac71 1689683689000000 1696941289000000 1699360489000000 \\xd10e81652ef36461c2a69d6cf00a2d4628eaee995b63aab78147a163e76e609ccca4cb28637b76e87f7b2f2a0309bbd87e093b9e7e39a0a264e237ad52d0570b
-\.
-
-
---
--- 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 \\x187042cb50680b02368d046f96ee44aae97cedeb6516fdeca2f4d3223094627f \\x21e4a5e9d5d17432fa0b1f7a02f8047c7634c1053d6aa1f6456ac134caa8bbf3da7776a78f85636af980472afd166b4edad654979a89d92c49a4ba992a7e3571 1640995200000000 1672531200000000 0 1000000 0 1000000 0 1000000 \\xa44fc10beadfe76054b7ce38d899df6269da7e291fe99b668d57165b9e50400f02d9a62ec0dc11c85b685604e20d0352fdca034e2ed0e1e700afd23c57ef6c09
-\.
-
-
---
--- 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 \\x37e1f963450faee0d8a56acb6aefe95536fe65cc8b5accca1924c6093a40f6cc \\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;
-\\x5953e7ddd7430ba42c1a9f121365e500b5314d8bc2813046338abab6475a9cc9 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 1660654520000000 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', 22, 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', 22, 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', 25, 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 331dfab77..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)
@@ -1048,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,
@@ -1069,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);
@@ -1081,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) */
@@ -1141,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 (!)
@@ -1168,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);
@@ -1206,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
@@ -1217,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)
@@ -1240,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,
@@ -1252,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
@@ -1688,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);
@@ -1703,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);
@@ -1732,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)
@@ -1745,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)
@@ -1755,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)
@@ -1763,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);
@@ -1836,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)
{
@@ -1864,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,
@@ -1879,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;
}
@@ -1934,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));
@@ -1968,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 !=
@@ -1999,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",
@@ -2016,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),
@@ -2045,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))));
}
@@ -2100,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 9aa15b53c..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 33`
+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,46 +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 ..."
- cp "${CONF}" "${CONF}.tmp"
- taler-config -c "${CONF}.tmp" -s exchange-offline -o MASTER_PRIV_FILE -V ${DB}.mpriv
echo -n "Starting exchange..."
- taler-exchange-httpd -c "${CONF}.tmp" -L INFO 2> exchange-httpd-drain.err &
+ 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`
+ 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
+ wget "http://localhost:8081/seed" \
+ -o /dev/null \
+ -O /dev/null \
+ >/dev/null \
+ || continue
OK=1
break
done
echo "... DONE."
- # FIXME-MS: need to make sure here that the target IBAN exists!
- taler-exchange-offline -L DEBUG -c "${CONF}.tmp" \
- drain TESTKUDOS:0.1 exchange-account-1 payto://iban/SANDBOXX/DE360679?receiver-name=Exchange+Drain \
- upload \
- 2> taler-exchange-offline-drain.log || exit_fail "offline draining failed"
- kill -TERM $EPID
- wait $EPID
- rm -f "${CONF}.tmp"
+ 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"
- # FIXME-MS: transfer tool is happy here, but
- # the wire transfer triggered here does NOT
- # show up during the audit. Do we have to
- # trigger some libeufin/sandbox job first?
fi
audit_only
post_audit
@@ -254,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
-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 "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 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 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
+ # cannot easily undo aggregator, hence full reload
+ full_reload
}
@@ -392,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)
+
+ echo "PASS"
+
+ echo -n "Check for lag detection... "
- LAG=`jq -r .total_amount_lag < test-audit-wire.json`
- if test $LAG = "TESTKUDOS:0"
+ # 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"
}
@@ -515,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"
}
@@ -578,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) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b');" | 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"
}
@@ -626,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"
}
@@ -669,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"
}
@@ -710,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"
}
@@ -762,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
}
@@ -831,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
}
@@ -890,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
-
}
@@ -1231,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 -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 "===========18: emergency================="
-echo PASS
+ echo "DELETE FROM exchange.reserves_out;" \
+ | psql -Aqt "$DB" -q
-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
@@ -1306,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
@@ -1396,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"
}
@@ -1432,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
@@ -1485,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
}
@@ -1515,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) VALUES ('payto://x-taler-bank/localhost/testuser-xxlargtp', '\x1e8f31936b3cee8f8afd3aac9e38b5db42d45b721ffc4eb1e5b9ddaf1565660b');" | 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
+ 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"
-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
-
-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
-
}
@@ -1697,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
@@ -1739,10 +1833,6 @@ then
echo "OK"
# cannot easily undo aggregator, hence full reload
full_reload
-
-else
- echo "Test skipped (database too new)"
-fi
}
@@ -1750,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"
}
@@ -1778,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"
}
@@ -1808,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"
}
@@ -1850,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
@@ -1881,176 +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 drain
+ 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 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
+ 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 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 "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 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
+ 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
-DRAINED=`jq -r .total_drained < test-audit-wire.json`
-if test $DRAINED != "TESTKUDOS:0.1"
-then
- exit_fail "Wrong amount drained, got unexpected drain of $DRAINED"
-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
}
@@ -2060,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
@@ -2083,7 +2122,7 @@ check_with_database()
fail=0
for i in $TESTS
do
- test_$i
+ "test_$i"
if test 0 != $fail
then
break
@@ -2096,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