-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathredis_plus_utils.cpp
124 lines (111 loc) · 6.02 KB
/
redis_plus_utils.cpp
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include "mod_redis_plus.h"
std::vector<std::string> get_commands(char *data) {
std::vector<std::string> commands;
bool flag = data != NULL && strlen(data) > 0;
while(flag) {
char *command = NULL;
if ((command = strchr(data, ' '))) {
*command = '\0';
command++;
} else {
flag = false;
}
commands.push_back(std::string(data));
data = command;
}
return commands;
}
switch_status_t mod_redis_plus_do_config()
{
const char *conf = "redis_plus.conf";
switch_xml_t xml, cfg, profiles, profile, connections, connection, params, param;
if (!(xml = switch_xml_open_cfg(conf, &cfg, NULL))) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "open of %s failed\n", conf);
goto err;
}
if ( (profiles = switch_xml_child(cfg, "profiles")) != NULL) {
for (profile = switch_xml_child(profiles, "profile"); profile; profile = profile->next) {
redis_plus_profile_t *new_profile = NULL;
uint8_t ignore_connect_fail = 0;
uint8_t ignore_error = 0;
int max_pipelined_requests = 0;
char *name = (char *) switch_xml_attr_soft(profile, "name");
// Load params
if ( (params = switch_xml_child(profile, "params")) != NULL) {
for (param = switch_xml_child(params, "param"); param; param = param->next) {
char *var = (char *) switch_xml_attr_soft(param, "name");
if ( !strncmp(var, "ignore-connect-fail", 19) ) {
ignore_connect_fail = switch_true(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "ignore-error", 12) ) {
ignore_error = switch_true(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "max-pipelined-requests", 22) ) {
max_pipelined_requests = atoi(switch_xml_attr_soft(param, "value"));
}
}
}
if (max_pipelined_requests <= 0) {
max_pipelined_requests = 20;
}
if ( redis_plus_profile_create(&new_profile, name, ignore_connect_fail, ignore_error, max_pipelined_requests) == SWITCH_STATUS_SUCCESS ) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Created profile[%s]\n", name);
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to create profile[%s]\n", name);
}
/* Add connection to profile */
if ( (connection = switch_xml_child(profile, "connection")) != NULL) {
char *host = NULL, *password = NULL, *master_name = NULL;
uint32_t port = 0, timeout_ms = 0, max_connections = 0,
redis_type = 0, pool_size = 0, sync_flag = 0, sentinel_timeout_ms = 0;
for (param = switch_xml_child(connection, "param"); param; param = param->next) {
char *var = (char *) switch_xml_attr_soft(param, "name");
if ( !strncmp(var, "hostname", 8) ) {
host = (char *) switch_xml_attr_soft(param, "value");
} else if ( !strncmp(var, "port", 4) ) {
port = atoi(switch_xml_attr_soft(param, "value"));
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "hiredis: adding conn[%u == %s]\n", port, switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "timeout-ms", 10) || !strncmp(var, "timeout_ms", 10) ) {
timeout_ms = atoi(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "sentinel-timeout-ms", 19) || !strncmp(var, "sentinel_timeout_ms", 19) ) {
sentinel_timeout_ms = atoi(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "password", 8) ) {
password = (char *) switch_xml_attr_soft(param, "value");
} else if ( !strncmp(var, "max-connections", 15) ) {
max_connections = atoi(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "redis-type", 10)) {
redis_type = atoi(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "pool-size", 9)) {
pool_size = atoi(switch_xml_attr_soft(param, "value"));
} else if ( !strncmp(var, "master-name", 11)) {
master_name = (char *) switch_xml_attr_soft(param, "value");
}
}
if (timeout_ms <= 0) {
timeout_ms = 100;
}
if (sentinel_timeout_ms <= 0) {
sentinel_timeout_ms = 200;
}
if ( redis_plus_profile_connection_add(new_profile, host, password, port, timeout_ms, max_connections,
redis_type, pool_size, master_name, sentinel_timeout_ms) == SWITCH_STATUS_SUCCESS) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Created profile[%s]\n", name);
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to create profile[%s]\n", name);
}
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Profile->connections config is missing\n");
goto err;
}
}
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Profiles config is missing\n");
goto err;
}
switch_xml_free(xml);
return SWITCH_STATUS_SUCCESS;
err:
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Configuration failed\n");
if (xml) {
switch_xml_free(xml);
}
return SWITCH_STATUS_GENERR;
}