-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathaw_message.c
More file actions
98 lines (80 loc) · 2.49 KB
/
aw_message.c
File metadata and controls
98 lines (80 loc) · 2.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
* Description:
* History: yang@haipo.me, 2017/04/28, create
*/
# include "aw_config.h"
# include "aw_message.h"
# include "aw_asset.h"
# include "aw_order.h"
static kafka_consumer_t *kafka_orders;
static kafka_consumer_t *kafka_balances;
static int process_orders_message(json_t *msg)
{
int event = json_integer_value(json_object_get(msg, "event"));
if (event == 0)
return -__LINE__;
json_t *order = json_object_get(msg, "order");
if (order == NULL)
return -__LINE__;
uint32_t user_id = json_integer_value(json_object_get(order, "user"));
const char *stock = json_string_value(json_object_get(msg, "stock"));
const char *money = json_string_value(json_object_get(msg, "money"));
if (user_id == 0 || stock == NULL || money == NULL)
return -__LINE__;
asset_on_update(user_id, stock);
asset_on_update(user_id, money);
order_on_update(user_id, event, order);
return 0;
}
static void on_orders_message(sds message, int64_t offset)
{
log_trace("order message: %s", message);
json_t *msg = json_loads(message, 0, NULL);
if (!msg) {
log_error("invalid balance message: %s", message);
return;
}
int ret = process_orders_message(msg);
if (ret < 0) {
log_error("process_orders_message: %s fail: %d", message, ret);
}
json_decref(msg);
}
static int process_balances_message(json_t *msg)
{
uint32_t user_id = json_integer_value(json_array_get(msg, 1));
const char *asset = json_string_value(json_array_get(msg, 2));
if (user_id == 0 || asset == NULL) {
return -__LINE__;
}
asset_on_update(user_id, asset);
return 0;
}
static void on_balances_message(sds message, int64_t offset)
{
log_trace("balance message: %s", message);
json_t *msg = json_loads(message, 0, NULL);
if (!msg) {
log_error("invalid balance message: %s", message);
return;
}
int ret = process_balances_message(msg);
if (ret < 0) {
log_error("process_balances_message: %s fail: %d", message, ret);
}
json_decref(msg);
}
int init_message(void)
{
settings.orders.offset = RD_KAFKA_OFFSET_END;
kafka_orders = kafka_consumer_create(&settings.orders, on_orders_message);
if (kafka_orders == NULL) {
return -__LINE__;
}
settings.balances.offset = RD_KAFKA_OFFSET_END;
kafka_balances = kafka_consumer_create(&settings.balances, on_balances_message);
if (kafka_balances == NULL) {
return -__LINE__;
}
return 0;
}