-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathwsrep_connection_monitor_service.h
134 lines (119 loc) · 4.26 KB
/
wsrep_connection_monitor_service.h
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
125
126
127
128
129
130
131
132
133
134
/*
* Copyright (C) 2024-2025 Codership Oy <[email protected]>
*
* This file is part of wsrep-API.
*
* Wsrep-API is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* Wsrep-API is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with wsrep-API. If not, see <https://www.gnu.org/licenses/>.
*/
/** @file wsrep_connection_monitor_service.h
*
* This file defines interface for connection monitor service
*
* The provider which is capable of using the service interface v1 must
* export the following functions.
*
* int wsrep_init_connection_monitor_service_v1(wsrep_connection_monitor_service_v1_t*)
* void wsrep_deinit_connection_monitor_service_v1()
*
* which can be probed by the application.
*
* The application must initialize the service via above init function
* before the provider is initialized via wsrep->init(). The deinit
* function must be called after the provider side resources have been
* released via wsrep->free().
*/
#ifndef WSREP_CONNECTION_MONITOR_SERVICE_H
#define WSREP_CONNECTION_MONITOR_SERVICE_H
#include "wsrep_api.h"
#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */
/**
* Type tag for application defined connection monitoring processing context.
*
* Application may pass pointer to the context when initializing
* the connection monitor service. This pointer is passed a first parameter for
* each service call.
*/
typedef struct wsrep_connection_monitor_context wsrep_connection_monitor_context_t;
typedef const void* wsrep_connection_key_t;
/*
* Connection monitor connection update callbacks.
*
*/
/*
* Connection connect callback.
*
* @param id connection identifier
* @param scheme connection scheme (tcp, ssl)
* @param local_address local address string
* @param remote_address remote address string
*/
typedef void (*wsrep_connection_monitor_connect_cb_t)(
wsrep_connection_monitor_context_t*,
wsrep_connection_key_t id,
const wsrep_buf_t* scheme,
const wsrep_buf_t* local_address,
const wsrep_buf_t* remote_address);
/*
* Connection disconnect callback.
*
* @param id connection identifier
*/
typedef void (*wsrep_connection_monitor_disconnect_cb_t)(
wsrep_connection_monitor_context_t*,
wsrep_connection_key_t id);
/*
* Connection SSL/TLS info callback.
*
* @param id connection identifier
* @param cipher cipher suite name
* @param certificate_subject certificate subject name
* @param certificate_issuer certificate issuer name
* @param version SSL/TLS version string
*/
typedef void (*wsrep_connection_monitor_ssl_info_cb_t)(
wsrep_connection_monitor_context_t*,
wsrep_connection_key_t id,
const wsrep_buf_t* cipher,
const wsrep_buf_t* certificate_subject,
const wsrep_buf_t* certificate_issuer,
const wsrep_buf_t* version);
/**
* Connection monitor service struct.
*
* A pointer to this struct must be passed to the call to
* wsrep_init_connection_monitor_service_v1.
*
* The application must provide implementation to all functions defined
* in this struct.
*/
typedef struct wsrep_connection_monitor_service_v1_st
{
/* Connection monitor connect callback */
wsrep_connection_monitor_connect_cb_t connection_monitor_connect_cb;
/* Connection monitor disconnect callback */
wsrep_connection_monitor_disconnect_cb_t connection_monitor_disconnect_cb;
/* Connection monitor ssl info callback */
wsrep_connection_monitor_ssl_info_cb_t connection_monitor_ssl_info_cb;
/* Pointer to application defined connection monitor context. */
wsrep_connection_monitor_context_t* context;
} wsrep_connection_monitor_service_v1_t;
#ifdef __cplusplus
}
#endif /* __cplusplus */
#define WSREP_CONNECTION_MONITOR_SERVICE_INIT_FUNC_V1 "wsrep_init_connection_monitor_service_v1"
#define WSREP_CONNECTION_MONITOR_SERVICE_DEINIT_FUNC_V1 "wsrep_deinit_connection_monitor_service_v1"
#endif /* WSREP_CONNECTION_MONITOR_SERVICE_H */