-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcluster-async-tls.c
106 lines (87 loc) · 3.02 KB
/
cluster-async-tls.c
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
#include <valkey/cluster.h>
#include <valkey/tls.h>
#include <valkey/adapters/libevent.h>
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#define CLUSTER_NODE_TLS "127.0.0.1:7300"
void getCallback(valkeyClusterAsyncContext *cc, void *r, void *privdata) {
valkeyReply *reply = (valkeyReply *)r;
if (reply == NULL) {
if (cc->err) {
printf("errstr: %s\n", cc->errstr);
}
return;
}
printf("privdata: %s reply: %s\n", (char *)privdata, reply->str);
/* Disconnect after receiving the reply to GET */
valkeyClusterAsyncDisconnect(cc);
}
void setCallback(valkeyClusterAsyncContext *cc, void *r, void *privdata) {
valkeyReply *reply = (valkeyReply *)r;
if (reply == NULL) {
if (cc->err) {
printf("errstr: %s\n", cc->errstr);
}
return;
}
printf("privdata: %s reply: %s\n", (char *)privdata, reply->str);
}
void connectCallback(valkeyAsyncContext *ac, int status) {
if (status != VALKEY_OK) {
printf("Error: %s\n", ac->errstr);
return;
}
printf("Connected to %s:%d\n", ac->c.tcp.host, ac->c.tcp.port);
}
void disconnectCallback(const valkeyAsyncContext *ac, int status) {
if (status != VALKEY_OK) {
printf("Error: %s\n", ac->errstr);
return;
}
printf("Disconnected from %s:%d\n", ac->c.tcp.host, ac->c.tcp.port);
}
int main(int argc, char **argv) {
UNUSED(argc);
UNUSED(argv);
valkeyTLSContext *tls;
valkeyTLSContextError tls_error;
valkeyInitOpenSSL();
tls = valkeyCreateTLSContext("ca.crt", NULL, "client.crt", "client.key",
NULL, &tls_error);
if (!tls) {
printf("TLS Context error: %s\n", valkeyTLSContextGetError(tls_error));
exit(1);
}
struct event_base *base = event_base_new();
valkeyClusterOptions options = {0};
options.initial_nodes = CLUSTER_NODE_TLS;
options.async_connect_callback = connectCallback;
options.async_disconnect_callback = disconnectCallback;
options.tls = tls;
options.tls_init_fn = &valkeyInitiateTLSWithContext;
valkeyClusterOptionsUseLibevent(&options, base);
valkeyClusterAsyncContext *acc = valkeyClusterAsyncConnectWithOptions(&options);
if (acc == NULL || acc->err != 0) {
printf("Error: %s\n", acc ? acc->errstr : "OOM");
exit(-1);
}
int status;
status = valkeyClusterAsyncCommand(acc, setCallback, (char *)"THE_ID",
"SET %s %s", "key", "value");
if (status != VALKEY_OK) {
printf("error: err=%d errstr=%s\n", acc->err, acc->errstr);
}
status = valkeyClusterAsyncCommand(acc, getCallback, (char *)"THE_ID",
"GET %s", "key");
if (status != VALKEY_OK) {
printf("error: err=%d errstr=%s\n", acc->err, acc->errstr);
}
printf("Dispatch..\n");
event_base_dispatch(base);
printf("Done..\n");
valkeyClusterAsyncFree(acc);
valkeyFreeTLSContext(tls);
event_base_free(base);
return 0;
}