first draft implementation of new bank account balance in history logic (untested)
This commit is contained in:
parent
3ad698d018
commit
c25b805f62
@ -973,6 +973,7 @@ handle_debit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
{
|
{
|
||||||
struct HistoryArgs ha;
|
struct HistoryArgs ha;
|
||||||
const struct Transaction *pos;
|
const struct Transaction *pos;
|
||||||
|
const struct Transaction *spos;
|
||||||
json_t *history;
|
json_t *history;
|
||||||
struct TALER_Amount total_incoming;
|
struct TALER_Amount total_incoming;
|
||||||
struct TALER_Amount start_outgoing;
|
struct TALER_Amount start_outgoing;
|
||||||
@ -1019,10 +1020,7 @@ handle_debit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
/* list is empty */
|
/* list is empty */
|
||||||
pos = NULL;
|
pos = NULL;
|
||||||
}
|
}
|
||||||
if (0 > ha.delta)
|
spos = pos;
|
||||||
end_pos = pos;
|
|
||||||
else
|
|
||||||
start_pos = pos;
|
|
||||||
|
|
||||||
history = json_array ();
|
history = json_array ();
|
||||||
while ( (0 != ha.delta) &&
|
while ( (0 != ha.delta) &&
|
||||||
@ -1076,18 +1074,80 @@ handle_debit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
pos = pos->next;
|
pos = pos->next;
|
||||||
}
|
}
|
||||||
if (0 > ha.delta)
|
if (0 > ha.delta)
|
||||||
|
{
|
||||||
start_pos = pos;
|
start_pos = pos;
|
||||||
|
end_pos = spos;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
start_pos = spos;
|
||||||
|
if (NULL == pos)
|
||||||
|
end_pos = h->transactions_tail;
|
||||||
else
|
else
|
||||||
end_pos = pos;
|
end_pos = pos;
|
||||||
|
}
|
||||||
|
/* now calculate balances at beginning end end of
|
||||||
|
transaction history */
|
||||||
GNUNET_assert (GNUNET_OK ==
|
GNUNET_assert (GNUNET_OK ==
|
||||||
TALER_amount_get_zero (fb->currency,
|
TALER_amount_get_zero (h->currency,
|
||||||
&));
|
&total_incoming));
|
||||||
|
GNUNET_assert (GNUNET_OK ==
|
||||||
|
TALER_amount_get_zero (h->currency,
|
||||||
|
&start_outgoing));
|
||||||
|
GNUNET_assert (GNUNET_OK ==
|
||||||
|
TALER_amount_get_zero (h->currency,
|
||||||
|
&end_outgoing));
|
||||||
|
for (pos = h->transactions_head;
|
||||||
|
NULL != pos;
|
||||||
|
pos = pos->next)
|
||||||
|
{
|
||||||
|
if ( (0 == strcasecmp (pos->debit_account,
|
||||||
|
account)) &&
|
||||||
|
(T_DEBIT == pos->type) )
|
||||||
|
{
|
||||||
|
if (pos == start_pos)
|
||||||
|
start_pos = NULL;
|
||||||
|
if (NULL != start_pos)
|
||||||
|
{
|
||||||
|
/* we are *before* the start position (exclusive), add to balances */
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&start_outgoing,
|
||||||
|
&start_outgoing,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
if (NULL != end_pos)
|
||||||
|
{
|
||||||
|
/* we are *before* the end position (inclusive),
|
||||||
|
add to balances */
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&end_outgoing,
|
||||||
|
&end_outgoing,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
if (pos == end_pos)
|
||||||
|
end_pos = NULL;
|
||||||
|
}
|
||||||
|
if ( (0 == strcasecmp (pos->credit_account,
|
||||||
|
account)) &&
|
||||||
|
(T_CREDIT == pos->type) )
|
||||||
|
{
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&total_incoming,
|
||||||
|
&total_incoming,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
}
|
||||||
return TALER_MHD_reply_json_pack (connection,
|
return TALER_MHD_reply_json_pack (connection,
|
||||||
MHD_HTTP_OK,
|
MHD_HTTP_OK,
|
||||||
"{s:o}",
|
"{s:o, s:o, s:o, s:o}",
|
||||||
"outgoing_transactions",
|
"outgoing_transactions",
|
||||||
history);
|
history,
|
||||||
|
"current_incoming",
|
||||||
|
TALER_JSON_from_amount (&total_incoming),
|
||||||
|
"total_incoming_start",
|
||||||
|
TALER_JSON_from_amount (&start_outgoing),
|
||||||
|
"total_incoming_end",
|
||||||
|
TALER_JSON_from_amount (&end_outgoing));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1105,8 +1165,14 @@ handle_credit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
const char *account)
|
const char *account)
|
||||||
{
|
{
|
||||||
struct HistoryArgs ha;
|
struct HistoryArgs ha;
|
||||||
struct Transaction *pos;
|
const struct Transaction *pos;
|
||||||
|
const struct Transaction *spos;
|
||||||
json_t *history;
|
json_t *history;
|
||||||
|
struct TALER_Amount end_incoming;
|
||||||
|
struct TALER_Amount start_incoming;
|
||||||
|
struct TALER_Amount total_outgoing;
|
||||||
|
const struct Transaction *start_pos;
|
||||||
|
const struct Transaction *end_pos;
|
||||||
|
|
||||||
if (GNUNET_OK !=
|
if (GNUNET_OK !=
|
||||||
parse_history_common_args (connection,
|
parse_history_common_args (connection,
|
||||||
@ -1161,6 +1227,8 @@ handle_credit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
/* list is empty */
|
/* list is empty */
|
||||||
pos = NULL;
|
pos = NULL;
|
||||||
}
|
}
|
||||||
|
spos = pos;
|
||||||
|
|
||||||
history = json_array ();
|
history = json_array ();
|
||||||
while ( (0 != ha.delta) &&
|
while ( (0 != ha.delta) &&
|
||||||
(NULL != pos) )
|
(NULL != pos) )
|
||||||
@ -1225,11 +1293,82 @@ handle_credit_history (struct TALER_FAKEBANK_Handle *h,
|
|||||||
if (0 < ha.delta)
|
if (0 < ha.delta)
|
||||||
pos = pos->next;
|
pos = pos->next;
|
||||||
}
|
}
|
||||||
|
if (0 > ha.delta)
|
||||||
|
{
|
||||||
|
start_pos = pos;
|
||||||
|
end_pos = spos;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
start_pos = spos;
|
||||||
|
if (NULL == pos)
|
||||||
|
end_pos = h->transactions_tail;
|
||||||
|
else
|
||||||
|
end_pos = pos;
|
||||||
|
}
|
||||||
|
/* now calculate balances at beginning end end of
|
||||||
|
transaction history */
|
||||||
|
GNUNET_assert (GNUNET_OK ==
|
||||||
|
TALER_amount_get_zero (h->currency,
|
||||||
|
&total_outgoing));
|
||||||
|
GNUNET_assert (GNUNET_OK ==
|
||||||
|
TALER_amount_get_zero (h->currency,
|
||||||
|
&start_incoming));
|
||||||
|
GNUNET_assert (GNUNET_OK ==
|
||||||
|
TALER_amount_get_zero (h->currency,
|
||||||
|
&end_incoming));
|
||||||
|
for (pos = h->transactions_head;
|
||||||
|
NULL != pos;
|
||||||
|
pos = pos->next)
|
||||||
|
{
|
||||||
|
if ( (0 == strcasecmp (pos->credit_account,
|
||||||
|
account)) &&
|
||||||
|
(T_CREDIT == pos->type) )
|
||||||
|
{
|
||||||
|
if (pos == start_pos)
|
||||||
|
start_pos = NULL;
|
||||||
|
if (NULL != start_pos)
|
||||||
|
{
|
||||||
|
/* we are *before* the start position (exclusive), add to balances */
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&start_incoming,
|
||||||
|
&start_incoming,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
if (NULL != end_pos)
|
||||||
|
{
|
||||||
|
/* we are *before* the end position (inclusive),
|
||||||
|
add to balances */
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&end_incoming,
|
||||||
|
&end_incoming,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
if (pos == end_pos)
|
||||||
|
end_pos = NULL;
|
||||||
|
}
|
||||||
|
if ( (0 == strcasecmp (pos->debit_account,
|
||||||
|
account)) &&
|
||||||
|
(T_DEBIT == pos->type) )
|
||||||
|
{
|
||||||
|
GNUNET_break (GNUNET_OK ==
|
||||||
|
TALER_amount_add (&total_outgoing,
|
||||||
|
&total_outgoing,
|
||||||
|
&pos->amount));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return TALER_MHD_reply_json_pack (connection,
|
return TALER_MHD_reply_json_pack (connection,
|
||||||
MHD_HTTP_OK,
|
MHD_HTTP_OK,
|
||||||
"{s:o}",
|
"{s:o, s:o, s:o, s:o}",
|
||||||
"incoming_transactions",
|
"incoming_transactions",
|
||||||
history);
|
history,
|
||||||
|
"current_outgoing",
|
||||||
|
TALER_JSON_from_amount (&total_outgoing),
|
||||||
|
"total_incoming_start",
|
||||||
|
TALER_JSON_from_amount (&start_incoming),
|
||||||
|
"total_incoming_end",
|
||||||
|
TALER_JSON_from_amount (&end_incoming));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user