2 * Copyright (c) 2008, 2009, 2010 Nicira Networks.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #define STREAM_SSL_H 1
22 bool stream_ssl_is_configured(void);
24 void stream_ssl_set_private_key_file(const char *file_name);
25 void stream_ssl_set_certificate_file(const char *file_name);
26 void stream_ssl_set_ca_cert_file(const char *file_name, bool bootstrap);
28 void stream_ssl_set_key_and_cert(const char *private_key_file,
29 const char *certificate_file);
32 void stream_ssl_set_peer_ca_cert_file(const char *file_name);
34 /* Define the long options for SSL support.
36 * Note that the definition includes a final comma, and therefore a comma
37 * must not be supplied when using the definition. This is done so that
38 * compilation succeeds whether or not HAVE_OPENSSL is defined. */
39 #define STREAM_SSL_LONG_OPTIONS \
40 {"private-key", required_argument, 0, 'p'}, \
41 {"certificate", required_argument, 0, 'c'}, \
42 {"ca-cert", required_argument, 0, 'C'},
44 #define STREAM_SSL_OPTION_HANDLERS \
46 stream_ssl_set_private_key_file(optarg); \
50 stream_ssl_set_certificate_file(optarg); \
54 stream_ssl_set_ca_cert_file(optarg, false); \
56 #else /* !HAVE_OPENSSL */
57 static inline bool stream_ssl_is_configured(void)
61 #define STREAM_SSL_LONG_OPTIONS
62 #define STREAM_SSL_OPTION_HANDLERS
63 #endif /* !HAVE_OPENSSL */
65 #endif /* stream-ssl.h */