1 /* Copyright (c) 2015, 2021, Oracle and/or its affiliates.
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   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