1 /* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
2
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License, version 2.0,
5 as published by the Free Software Foundation.
6
7 This program is also distributed with certain software (including
8 but not limited to OpenSSL) that is licensed under separate terms,
9 as designated in a particular file or component or in included license
10 documentation. The authors of MySQL hereby grant you an additional
11 permission to link the program and your derivative works with the
12 separately licensed software that they have included with MySQL.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License, version 2.0, for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
22
23 #include "my_global.h"
24 #include "xpl_performance_schema.h"
25 #include "replication.h"
26 #ifdef HAVE_ARPA_INET_H
27 #include <arpa/inet.h>
28 #endif
29 #ifdef HAVE_SYS_UN_H
30 #include <sys/un.h>
31 #endif
32 #if !defined(_WIN32)
33 #include <sys/utsname.h>
34 #endif
35
36 PSI_thread_key KEY_thread_x_worker = PSI_NOT_INSTRUMENTED;
37 PSI_thread_key KEY_thread_x_acceptor = PSI_NOT_INSTRUMENTED;
38
39 PSI_mutex_key KEY_mutex_x_client_session = PSI_NOT_INSTRUMENTED;
40 PSI_mutex_key KEY_mutex_x_obuffer = PSI_NOT_INSTRUMENTED;
41 PSI_mutex_key KEY_mutex_x_lock_list_access = PSI_NOT_INSTRUMENTED;
42 PSI_mutex_key KEY_mutex_x_scheduler_dynamic_worker_pending = PSI_NOT_INSTRUMENTED;
43 PSI_mutex_key KEY_mutex_x_scheduler_dynamic_thread_exit = PSI_NOT_INSTRUMENTED;
44 PSI_mutex_key KEY_mutex_x_queue = PSI_NOT_INSTRUMENTED;
45
46 PSI_cond_key KEY_cond_x_scheduler_dynamic_worker_pending = PSI_NOT_INSTRUMENTED;
47 PSI_cond_key KEY_cond_x_scheduler_dynamic_thread_exit = PSI_NOT_INSTRUMENTED;
48 PSI_cond_key KEY_cond_x_queue = PSI_NOT_INSTRUMENTED;
49
50 PSI_rwlock_key KEY_rwlock_x_client_list_clients = PSI_NOT_INSTRUMENTED;
51
52 PSI_memory_key KEY_memory_x_recv_buffer = PSI_NOT_INSTRUMENTED;
53 PSI_memory_key KEY_memory_x_send_buffer = PSI_NOT_INSTRUMENTED;
54
55 PSI_socket_key KEY_socket_x_tcpip = PSI_NOT_INSTRUMENTED;
56 PSI_socket_key KEY_socket_x_unix = PSI_NOT_INSTRUMENTED;
57 PSI_socket_key KEY_socket_x_client_connection = PSI_NOT_INSTRUMENTED;
58
59 const char *my_localhost;
60 bool volatile abort_loop;
61
ip_to_hostname(struct sockaddr_storage * ip_storage,const char * ip_string,char ** hostname,uint * connect_errors)62 int ip_to_hostname(struct sockaddr_storage *ip_storage,
63 const char *ip_string,
64 char **hostname,
65 uint *connect_errors)
66 {
67 DBUG_ASSERT(0);
68 return 1;
69 }
70
register_server_state_observer(Server_state_observer * observer,void * p)71 int register_server_state_observer(Server_state_observer *observer, void *p)
72 {
73 return 0;
74 }
75
unregister_server_state_observer(Server_state_observer * observer,void * p)76 int unregister_server_state_observer(Server_state_observer *observer, void *p)
77 {
78 return 0;
79 }
80
81 extern "C"
ssl_wrapper_version(Vio * vio,char * version,const size_t version_size)82 void ssl_wrapper_version(Vio *vio, char *version, const size_t version_size)
83 {
84 }
85
86 extern "C"
ssl_wrapper_cipher(Vio * vio,char * cipher,const size_t cipher_size)87 void ssl_wrapper_cipher(Vio *vio, char *cipher, const size_t cipher_size)
88 {
89 }
90
91 extern "C"
ssl_wrapper_cipher_list(Vio * vio,const char ** clipher_list,const size_t maximun_num_of_elements)92 long ssl_wrapper_cipher_list(Vio *vio, const char **clipher_list, const size_t maximun_num_of_elements)
93 {
94 return 0;
95 }
96
97 extern "C"
ssl_wrapper_verify_depth(Vio * vio)98 long ssl_wrapper_verify_depth(Vio *vio)
99 {
100 return 0;
101 }
102
103 extern "C"
ssl_wrapper_verify_mode(Vio * vio)104 long ssl_wrapper_verify_mode(Vio *vio)
105 {
106 return 0;
107 }
108
109 extern "C"
ssl_wrapper_get_peer_certificate_issuer(Vio * vio,char * issuer,const size_t issuer_size)110 void ssl_wrapper_get_peer_certificate_issuer(Vio *vio, char *issuer, const size_t issuer_size)
111 {
112 }
113
114 extern "C"
ssl_wrapper_get_peer_certificate_subject(Vio * vio,char * subject,const size_t subject_size)115 void ssl_wrapper_get_peer_certificate_subject(Vio *vio, char *subject, const size_t subject_size)
116 {
117 }
118
119 extern "C"
ssl_wrapper_get_verify_result_and_cert(Vio * vio)120 long ssl_wrapper_get_verify_result_and_cert(Vio *vio)
121 {
122 return 0;
123 }
124
125 extern "C"
ssl_wrapper_ctx_verify_depth(struct st_VioSSLFd * vio_ssl)126 long ssl_wrapper_ctx_verify_depth(struct st_VioSSLFd *vio_ssl)
127 {
128 return 0;
129 }
130
131 extern "C"
ssl_wrapper_ctx_verify_mode(struct st_VioSSLFd * vio_ssl)132 long ssl_wrapper_ctx_verify_mode(struct st_VioSSLFd *vio_ssl)
133 {
134 return 0;
135 }
136
137 extern "C"
ssl_wrapper_ctx_server_not_after(struct st_VioSSLFd * vio_ssl,char * no_after,const size_t no_after_size)138 void ssl_wrapper_ctx_server_not_after(struct st_VioSSLFd *vio_ssl, char *no_after, const size_t no_after_size)
139 {
140 }
141
142 extern "C"
ssl_wrapper_ctx_server_not_before(struct st_VioSSLFd * vio_ssl,char * no_before,const size_t no_before_size)143 void ssl_wrapper_ctx_server_not_before(struct st_VioSSLFd *vio_ssl, char *no_before, const size_t no_before_size)
144 {
145 }
146
147 extern "C"
ssl_wrapper_thread_cleanup()148 void ssl_wrapper_thread_cleanup()
149 {
150 }
151
152 extern "C"
ssl_wrapper_sess_accept(struct st_VioSSLFd * vio_ssl)153 long ssl_wrapper_sess_accept(struct st_VioSSLFd *vio_ssl)
154 {
155 return 0;
156 }
157
158 extern "C"
ssl_wrapper_sess_accept_good(struct st_VioSSLFd * vio_ssl)159 long ssl_wrapper_sess_accept_good(struct st_VioSSLFd *vio_ssl)
160 {
161 return 0;
162 }
163