summaryrefslogtreecommitdiff
path: root/src/backend/taler-merchant-httpd_track-transaction.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend/taler-merchant-httpd_track-transaction.c')
-rw-r--r--src/backend/taler-merchant-httpd_track-transaction.c20
1 files changed, 19 insertions, 1 deletions
diff --git a/src/backend/taler-merchant-httpd_track-transaction.c b/src/backend/taler-merchant-httpd_track-transaction.c
index ed1eea19..472960ae 100644
--- a/src/backend/taler-merchant-httpd_track-transaction.c
+++ b/src/backend/taler-merchant-httpd_track-transaction.c
@@ -43,6 +43,10 @@
*/
struct TrackTransactionContext;
+/**
+ * Merchant instance being tracked
+ */
+struct MerchantInstance;
/**
* Information we keep for each coin in a /track/transaction operation.
@@ -205,6 +209,11 @@ struct TrackTransactionContext
*/
unsigned int response_code;
+ /**
+ * Which merchant instance is being tracked
+ */
+ struct MerchantInstance *mi;
+
};
@@ -591,7 +600,7 @@ trace_coins (struct TrackTransactionContext *tctx)
return;
}
tcc->dwh = TALER_EXCHANGE_track_transaction (tctx->eh,
- &privkey,
+ &tctx->mi->privkey,
&tctx->h_wire,
&tctx->h_contract,
&tcc->coin_pub,
@@ -752,6 +761,7 @@ coin_cb (void *cls,
tcc));
}
+extern struct MerchantInstance **instances;
/**
* Handle a "/track/transaction" request.
@@ -774,6 +784,7 @@ MH_handler_track_transaction (struct TMH_RequestHandler *rh,
unsigned long long transaction_id;
const char *str;
const char *receiver;
+ unsigned int i;
int ret;
if (NULL == *connection_cls)
@@ -831,6 +842,13 @@ MH_handler_track_transaction (struct TMH_RequestHandler *rh,
if (NULL == receiver)
return TMH_RESPONSE_reply_bad_request (connection,
"receiver argument missing");
+ tctx->mi = NULL;
+ for (i=0; NULL != instances[i]; i++)
+ if (0 == strcmp (receiver, instances[i]->id))
+ tctx->mi = instances[i];
+ if (NULL == tctx->mi)
+ return TMH_RESPONSE_reply_bad_request (connection,
+ "unknown receiver");
if (1 !=
sscanf (str,
"%llu",