mirror of
https://github.com/MariaDB/server.git
synced 2025-01-28 01:34:17 +01:00
bac0f8999d
implement --ssl-fp and --ssl-fplist for all clients. --ssl-fp takes one certificate fingerprint, for example, 00:11:22:33:44:55:66:77:88:99:AA:BB:CC:DD:EE:FF:00:11:22:33 --ssl-fplist takes a path to a file with one fingerprint per line. if the server's certificate fingerprint matches ssl-fp or is found in the file - the certificate is considered verified. If the fingerprint is specified but doesn't match - the connection is aborted independently from the --ssl-verify-server-cert
66 lines
2.9 KiB
C
66 lines
2.9 KiB
C
#ifndef SSLOPT_LONGOPTS_INCLUDED
|
|
#define SSLOPT_LONGOPTS_INCLUDED
|
|
|
|
/*
|
|
Copyright (c) 2000, 2010, Oracle and/or its affiliates.
|
|
|
|
This program 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; version 2 of the License.
|
|
|
|
This program 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 this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335 USA */
|
|
|
|
#if defined(HAVE_OPENSSL) && !defined(EMBEDDED_LIBRARY)
|
|
|
|
{"ssl", OPT_SSL_SSL,
|
|
"Enable SSL for connection (automatically enabled with other flags).",
|
|
&opt_use_ssl, &opt_use_ssl, 0, GET_BOOL, OPT_ARG, 1, 0, 0, 0, 0, 0},
|
|
{"ssl-ca", OPT_SSL_CA,
|
|
"CA file in PEM format (check OpenSSL docs, implies --ssl).",
|
|
&opt_ssl_ca, &opt_ssl_ca, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-capath", OPT_SSL_CAPATH,
|
|
"CA directory (check OpenSSL docs, implies --ssl).",
|
|
&opt_ssl_capath, &opt_ssl_capath, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-cert", OPT_SSL_CERT, "X509 cert in PEM format (implies --ssl).",
|
|
&opt_ssl_cert, &opt_ssl_cert, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-cipher", OPT_SSL_CIPHER, "SSL cipher to use (implies --ssl).",
|
|
&opt_ssl_cipher, &opt_ssl_cipher, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-key", OPT_SSL_KEY, "X509 key in PEM format (implies --ssl).",
|
|
&opt_ssl_key, &opt_ssl_key, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-crl", OPT_SSL_CRL, "Certificate revocation list (implies --ssl).",
|
|
&opt_ssl_crl, &opt_ssl_crl, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"ssl-crlpath", OPT_SSL_CRLPATH,
|
|
"Certificate revocation list path (implies --ssl).",
|
|
&opt_ssl_crlpath, &opt_ssl_crlpath, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
{"tls-version", OPT_TLS_VERSION,
|
|
"TLS protocol version for secure connection.",
|
|
&opt_tls_version, &opt_tls_version, 0, GET_STR, REQUIRED_ARG,
|
|
0, 0, 0, 0, 0, 0},
|
|
|
|
#ifdef MYSQL_CLIENT
|
|
{"ssl-fp", OPT_SSL_FP, "Server certificate fingerprint (implies --ssl).",
|
|
&opt_ssl_fp, &opt_ssl_fp, 0, GET_STR, REQUIRED_ARG, 0, 0, 0, 0, 0, 0},
|
|
{"ssl-fplist", OPT_SSL_FPLIST, "File with accepted server certificate "
|
|
"fingerprints, one per line (implies --ssl).",
|
|
&opt_ssl_fplist, &opt_ssl_fplist, 0, GET_STR, REQUIRED_ARG, 0, 0, 0, 0, 0, 0},
|
|
{"ssl-verify-server-cert", OPT_SSL_VERIFY_SERVER_CERT,
|
|
"Verify server's certificate to prevent man-in-the-middle attacks",
|
|
&opt_ssl_verify_server_cert, &opt_ssl_verify_server_cert,
|
|
0, GET_BOOL, OPT_ARG, 0, 0, 0, 0, 0, 0},
|
|
#endif
|
|
#endif /* HAVE_OPENSSL */
|
|
#endif /* SSLOPT_LONGOPTS_INCLUDED */
|