Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 1 | =pod |
| 2 | |
| 3 | =head1 NAME |
| 4 | |
| 5 | SSL_CONF_cmd - send configuration command |
| 6 | |
| 7 | =head1 SYNOPSIS |
| 8 | |
| 9 | #include <openssl/ssl.h> |
| 10 | |
| 11 | int SSL_CONF_cmd(SSL_CONF_CTX *cctx, const char *cmd, const char *value); |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 12 | int SSL_CONF_cmd_value_type(SSL_CONF_CTX *cctx, const char *cmd); |
| 13 | int SSL_CONF_finish(SSL_CONF_CTX *cctx); |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 14 | |
| 15 | =head1 DESCRIPTION |
| 16 | |
| 17 | The function SSL_CONF_cmd() performs configuration operation B<cmd> with |
| 18 | optional parameter B<value> on B<ctx>. Its purpose is to simplify application |
| 19 | configuration of B<SSL_CTX> or B<SSL> structures by providing a common |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 20 | framework for command line options or configuration files. |
| 21 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 22 | SSL_CONF_cmd_value_type() returns the type of value that B<cmd> refers to. |
| 23 | |
| 24 | The function SSL_CONF_finish() must be called after all configuration |
| 25 | operations have been completed. It is used to finalise any operations |
| 26 | or to process defaults. |
| 27 | |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 28 | =head1 SUPPORTED COMMAND LINE COMMANDS |
| 29 | |
| 30 | Currently supported B<cmd> names for command lines (i.e. when the |
| 31 | flag B<SSL_CONF_CMDLINE> is set) are listed below. Note: all B<cmd> names |
Jeff Trawick | 4b64e0c | 2014-01-10 23:01:30 +0000 | [diff] [blame] | 32 | are case sensitive. Unless otherwise stated commands can be used by |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 33 | both clients and servers and the B<value> parameter is not used. The default |
| 34 | prefix for command line commands is B<-> and that is reflected below. |
| 35 | |
| 36 | =over 4 |
| 37 | |
| 38 | =item B<-sigalgs> |
| 39 | |
| 40 | This sets the supported signature algorithms for TLS v1.2. For clients this |
| 41 | value is used directly for the supported signature algorithms extension. For |
| 42 | servers it is used to determine which signature algorithms to support. |
| 43 | |
| 44 | The B<value> argument should be a colon separated list of signature algorithms |
| 45 | in order of decreasing preference of the form B<algorithm+hash>. B<algorithm> |
| 46 | is one of B<RSA>, B<DSA> or B<ECDSA> and B<hash> is a supported algorithm |
| 47 | OID short name such as B<SHA1>, B<SHA224>, B<SHA256>, B<SHA384> of B<SHA512>. |
| 48 | Note: algorithm and hash names are case sensitive. |
| 49 | |
| 50 | If this option is not set then all signature algorithms supported by the |
| 51 | OpenSSL library are permissible. |
| 52 | |
| 53 | =item B<-client_sigalgs> |
| 54 | |
| 55 | This sets the supported signature algorithms associated with client |
| 56 | authentication for TLS v1.2. For servers the value is used in the supported |
| 57 | signature algorithms field of a certificate request. For clients it is |
| 58 | used to determine which signature algorithm to with the client certificate. |
| 59 | If a server does not request a certificate this option has no effect. |
| 60 | |
| 61 | The syntax of B<value> is identical to B<-sigalgs>. If not set then |
| 62 | the value set for B<-sigalgs> will be used instead. |
| 63 | |
| 64 | =item B<-curves> |
| 65 | |
Dr. Stephen Henson | 65f2a56 | 2012-12-06 23:26:11 +0000 | [diff] [blame] | 66 | This sets the supported elliptic curves. For clients the curves are |
| 67 | sent using the supported curves extension. For servers it is used |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 68 | to determine which curve to use. This setting affects curves used for both |
| 69 | signatures and key exchange, if applicable. |
| 70 | |
| 71 | The B<value> argument is a colon separated list of curves. The curve can be |
| 72 | either the B<NIST> name (e.g. B<P-256>) or an OpenSSL OID name (e.g |
| 73 | B<prime256v1>). Curve names are case sensitive. |
| 74 | |
| 75 | =item B<-named_curve> |
| 76 | |
| 77 | This sets the temporary curve used for ephemeral ECDH modes. Only used by |
| 78 | servers |
| 79 | |
| 80 | The B<value> argument is a curve name or the special value B<auto> which |
| 81 | picks an appropriate curve based on client and server preferences. The curve |
| 82 | can be either the B<NIST> name (e.g. B<P-256>) or an OpenSSL OID name |
| 83 | (e.g B<prime256v1>). Curve names are case sensitive. |
| 84 | |
| 85 | =item B<-cipher> |
| 86 | |
| 87 | Sets the cipher suite list to B<value>. Note: syntax checking of B<value> is |
| 88 | currently not performed unless a B<SSL> or B<SSL_CTX> structure is |
| 89 | associated with B<cctx>. |
| 90 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 91 | =item B<-cert> |
| 92 | |
| 93 | Attempts to use the file B<value> as the certificate for the appropriate |
Rich Salz | fc1d88f | 2014-07-02 22:42:40 -0400 | [diff] [blame] | 94 | context. It currently uses SSL_CTX_use_certificate_chain_file() if an B<SSL_CTX> |
| 95 | structure is set or SSL_use_certificate_file() with filetype PEM if an B<SSL> |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 96 | structure is set. This option is only supported if certificate operations |
| 97 | are permitted. |
| 98 | |
| 99 | =item B<-key> |
| 100 | |
| 101 | Attempts to use the file B<value> as the private key for the appropriate |
| 102 | context. This option is only supported if certificate operations |
| 103 | are permitted. Note: if no B<-key> option is set then a private key is |
| 104 | not loaded: it does not currently use the B<-cert> file. |
| 105 | |
Dr. Stephen Henson | c557f92 | 2013-10-22 07:35:22 +0100 | [diff] [blame] | 106 | =item B<-dhparam> |
| 107 | |
| 108 | Attempts to use the file B<value> as the set of temporary DH parameters for |
| 109 | the appropriate context. This option is only supported if certificate |
| 110 | operations are permitted. |
| 111 | |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 112 | =item B<-no_ssl2>, B<-no_ssl3>, B<-no_tls1>, B<-no_tls1_1>, B<-no_tls1_2> |
| 113 | |
| 114 | Disables protocol support for SSLv2, SSLv3, TLS 1.0, TLS 1.1 or TLS 1.2 |
| 115 | by setting the corresponding options B<SSL_OP_NO_SSL2>, B<SSL_OP_NO_SSL3>, |
| 116 | B<SSL_OP_NO_TLS1>, B<SSL_OP_NO_TLS1_1> and B<SSL_OP_NO_TLS1_2> respectively. |
| 117 | |
| 118 | =item B<-bugs> |
| 119 | |
| 120 | Various bug workarounds are set, same as setting B<SSL_OP_ALL>. |
| 121 | |
| 122 | =item B<-no_comp> |
| 123 | |
| 124 | Disables support for SSL/TLS compression, same as setting B<SSL_OP_NO_COMPRESS>. |
| 125 | |
| 126 | =item B<-no_ticket> |
| 127 | |
| 128 | Disables support for session tickets, same as setting B<SSL_OP_NO_TICKET>. |
| 129 | |
| 130 | =item B<-serverpref> |
| 131 | |
| 132 | Use server and not client preference order when determining which cipher suite, |
| 133 | signature algorithm or elliptic curve to use for an incoming connection. |
| 134 | Equivalent to B<SSL_OP_CIPHER_SERVER_PREFERENCE>. Only used by servers. |
| 135 | |
Dr. Stephen Henson | f0ef019 | 2014-03-27 15:51:25 +0000 | [diff] [blame] | 136 | =item B<-no_resumption_on_reneg> |
| 137 | |
| 138 | set SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION flag. Only used by servers. |
| 139 | |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 140 | =item B<-legacyrenegotiation> |
| 141 | |
| 142 | permits the use of unsafe legacy renegotiation. Equivalent to setting |
| 143 | B<SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION>. |
| 144 | |
| 145 | =item B<-legacy_server_connect>, B<-no_legacy_server_connect> |
| 146 | |
| 147 | permits or prohibits the use of unsafe legacy renegotiation for OpenSSL |
| 148 | clients only. Equivalent to setting or clearing B<SSL_OP_LEGACY_SERVER_CONNECT>. |
| 149 | Set by default. |
| 150 | |
| 151 | =item B<-strict> |
| 152 | |
| 153 | enables strict mode protocol handling. Equivalent to setting |
| 154 | B<SSL_CERT_FLAG_TLS_STRICT>. |
| 155 | |
| 156 | =item B<-debug_broken_protocol> |
| 157 | |
| 158 | disables various checks and permits several kinds of broken protocol behaviour |
| 159 | for testing purposes: it should B<NEVER> be used in anything other than a test |
| 160 | environment. Only supported if OpenSSL is configured with |
| 161 | B<-DOPENSSL_SSL_DEBUG_BROKEN_PROTOCOL>. |
| 162 | |
| 163 | =back |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 164 | |
| 165 | =head1 SUPPORTED CONFIGURATION FILE COMMANDS |
| 166 | |
| 167 | Currently supported B<cmd> names for configuration files (i.e. when the |
| 168 | flag B<SSL_CONF_FLAG_FILE> is set) are listed below. All configuration file |
Rich Salz | 854dfcd | 2014-07-01 12:55:32 -0400 | [diff] [blame] | 169 | B<cmd> names are case insensitive so B<signaturealgorithms> is recognised |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 170 | as well as B<SignatureAlgorithms>. Unless otherwise stated the B<value> names |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 171 | are also case insensitive. |
| 172 | |
| 173 | Note: the command prefix (if set) alters the recognised B<cmd> values. |
| 174 | |
| 175 | =over 4 |
| 176 | |
Dr. Stephen Henson | 65f2a56 | 2012-12-06 23:26:11 +0000 | [diff] [blame] | 177 | =item B<CipherString> |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 178 | |
| 179 | Sets the cipher suite list to B<value>. Note: syntax checking of B<value> is |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 180 | currently not performed unless an B<SSL> or B<SSL_CTX> structure is |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 181 | associated with B<cctx>. |
| 182 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 183 | =item B<Certificate> |
| 184 | |
| 185 | Attempts to use the file B<value> as the certificate for the appropriate |
Rich Salz | fc1d88f | 2014-07-02 22:42:40 -0400 | [diff] [blame] | 186 | context. It currently uses SSL_CTX_use_certificate_chain_file() if an B<SSL_CTX> |
| 187 | structure is set or SSL_use_certificate_file() with filetype PEM if an B<SSL> |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 188 | structure is set. This option is only supported if certificate operations |
| 189 | are permitted. |
| 190 | |
| 191 | =item B<PrivateKey> |
| 192 | |
| 193 | Attempts to use the file B<value> as the private key for the appropriate |
| 194 | context. This option is only supported if certificate operations |
| 195 | are permitted. Note: if no B<-key> option is set then a private key is |
| 196 | not loaded: it does not currently use the B<Certificate> file. |
| 197 | |
Dr. Stephen Henson | 5b7f36e | 2014-01-03 23:13:40 +0000 | [diff] [blame] | 198 | =item B<ServerInfoFile> |
| 199 | |
| 200 | Attempts to use the file B<value> in the "serverinfo" extension using the |
| 201 | function SSL_CTX_use_serverinfo_file. |
| 202 | |
Dr. Stephen Henson | c557f92 | 2013-10-22 07:35:22 +0100 | [diff] [blame] | 203 | =item B<DHParameters> |
| 204 | |
| 205 | Attempts to use the file B<value> as the set of temporary DH parameters for |
| 206 | the appropriate context. This option is only supported if certificate |
| 207 | operations are permitted. |
| 208 | |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 209 | =item B<SignatureAlgorithms> |
| 210 | |
| 211 | This sets the supported signature algorithms for TLS v1.2. For clients this |
| 212 | value is used directly for the supported signature algorithms extension. For |
| 213 | servers it is used to determine which signature algorithms to support. |
| 214 | |
| 215 | The B<value> argument should be a colon separated list of signature algorithms |
| 216 | in order of decreasing preference of the form B<algorithm+hash>. B<algorithm> |
| 217 | is one of B<RSA>, B<DSA> or B<ECDSA> and B<hash> is a supported algorithm |
| 218 | OID short name such as B<SHA1>, B<SHA224>, B<SHA256>, B<SHA384> of B<SHA512>. |
| 219 | Note: algorithm and hash names are case sensitive. |
| 220 | |
| 221 | If this option is not set then all signature algorithms supported by the |
| 222 | OpenSSL library are permissible. |
| 223 | |
| 224 | =item B<ClientSignatureAlgorithms> |
| 225 | |
| 226 | This sets the supported signature algorithms associated with client |
| 227 | authentication for TLS v1.2. For servers the value is used in the supported |
| 228 | signature algorithms field of a certificate request. For clients it is |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 229 | used to determine which signature algorithm to with the client certificate. |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 230 | |
| 231 | The syntax of B<value> is identical to B<SignatureAlgorithms>. If not set then |
| 232 | the value set for B<SignatureAlgorithms> will be used instead. |
| 233 | |
| 234 | =item B<Curves> |
| 235 | |
Dr. Stephen Henson | 65f2a56 | 2012-12-06 23:26:11 +0000 | [diff] [blame] | 236 | This sets the supported elliptic curves. For clients the curves are |
| 237 | sent using the supported curves extension. For servers it is used |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 238 | to determine which curve to use. This setting affects curves used for both |
| 239 | signatures and key exchange, if applicable. |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 240 | |
| 241 | The B<value> argument is a colon separated list of curves. The curve can be |
| 242 | either the B<NIST> name (e.g. B<P-256>) or an OpenSSL OID name (e.g |
| 243 | B<prime256v1>). Curve names are case sensitive. |
| 244 | |
| 245 | =item B<ECDHParameters> |
| 246 | |
Dr. Stephen Henson | 13cfb04 | 2012-11-20 01:01:33 +0000 | [diff] [blame] | 247 | This sets the temporary curve used for ephemeral ECDH modes. Only used by |
| 248 | servers |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 249 | |
| 250 | The B<value> argument is a curve name or the special value B<Automatic> which |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 251 | picks an appropriate curve based on client and server preferences. The curve |
| 252 | can be either the B<NIST> name (e.g. B<P-256>) or an OpenSSL OID name |
| 253 | (e.g B<prime256v1>). Curve names are case sensitive. |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 254 | |
| 255 | =item B<Protocol> |
| 256 | |
| 257 | The supported versions of the SSL or TLS protocol. |
| 258 | |
| 259 | The B<value> argument is a comma separated list of supported protocols to |
| 260 | enable or disable. If an protocol is preceded by B<-> that version is disabled. |
| 261 | All versions are enabled by default, though applications may choose to |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 262 | explicitly disable some. Currently supported protocol values are B<SSLv2>, |
| 263 | B<SSLv3>, B<TLSv1>, B<TLSv1.1> and B<TLSv1.2>. The special value B<ALL> refers |
| 264 | to all supported versions. |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 265 | |
| 266 | =item B<Options> |
| 267 | |
| 268 | The B<value> argument is a comma separated list of various flags to set. |
| 269 | If a flag string is preceded B<-> it is disabled. See the |
| 270 | B<SSL_CTX_set_options> function for more details of individual options. |
| 271 | |
| 272 | Each option is listed below. Where an operation is enabled by default |
| 273 | the B<-flag> syntax is needed to disable it. |
| 274 | |
| 275 | B<SessionTicket>: session ticket support, enabled by default. Inverse of |
| 276 | B<SSL_OP_NO_TICKET>: that is B<-SessionTicket> is the same as setting |
| 277 | B<SSL_OP_NO_TICKET>. |
| 278 | |
| 279 | B<Compression>: SSL/TLS compression support, enabled by default. Inverse |
| 280 | of B<SSL_OP_NO_COMPRESSION>. |
| 281 | |
| 282 | B<EmptyFragments>: use empty fragments as a countermeasure against a |
| 283 | SSL 3.0/TLS 1.0 protocol vulnerability affecting CBC ciphers. It |
| 284 | is set by default. Inverse of B<SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS>. |
| 285 | |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 286 | B<Bugs>: enable various bug workarounds. Same as B<SSL_OP_ALL>. |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 287 | |
Dr. Stephen Henson | c7b7984 | 2012-11-17 00:21:34 +0000 | [diff] [blame] | 288 | B<DHSingle>: enable single use DH keys, set by default. Inverse of |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 289 | B<SSL_OP_DH_SINGLE>. Only used by servers. |
| 290 | |
| 291 | B<ECDHSingle> enable single use ECDH keys, set by default. Inverse of |
| 292 | B<SSL_OP_ECDH_SINGLE>. Only used by servers. |
| 293 | |
| 294 | B<ServerPreference> use server and not client preference order when |
| 295 | determining which cipher suite, signature algorithm or elliptic curve |
| 296 | to use for an incoming connection. Equivalent to |
| 297 | B<SSL_OP_CIPHER_SERVER_PREFERENCE>. Only used by servers. |
| 298 | |
Dr. Stephen Henson | f0ef019 | 2014-03-27 15:51:25 +0000 | [diff] [blame] | 299 | B<NoResumptionOnRenegotiation> set |
| 300 | B<SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION> flag. Only used by servers. |
| 301 | |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 302 | B<UnsafeLegacyRenegotiation> permits the use of unsafe legacy renegotiation. |
| 303 | Equivalent to B<SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION>. |
| 304 | |
| 305 | B<UnsafeLegacyServerConnect> permits the use of unsafe legacy renegotiation |
| 306 | for OpenSSL clients only. Equivalent to B<SSL_OP_LEGACY_SERVER_CONNECT>. |
| 307 | Set by default. |
| 308 | |
| 309 | =back |
| 310 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 311 | =head1 SUPPORTED COMMAND TYPES |
| 312 | |
| 313 | The function SSL_CONF_cmd_value_type() currently returns one of the following |
| 314 | types: |
| 315 | |
| 316 | =over 4 |
| 317 | |
| 318 | =item B<SSL_CONF_TYPE_UNKNOWN> |
| 319 | |
| 320 | The B<cmd> string is unrecognised, this return value can be use to flag |
| 321 | syntax errors. |
| 322 | |
| 323 | =item B<SSL_CONF_TYPE_STRING> |
| 324 | |
| 325 | The value is a string without any specific structure. |
| 326 | |
| 327 | =item B<SSL_CONF_TYPE_FILE> |
| 328 | |
| 329 | The value is a file name. |
| 330 | |
| 331 | =item B<SSL_CONF_TYPE_DIR> |
| 332 | |
| 333 | The value is a directory name. |
| 334 | |
Chris Rorvick | fa9d77d | 2014-04-26 11:10:45 -0500 | [diff] [blame] | 335 | =back |
| 336 | |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 337 | =head1 NOTES |
| 338 | |
| 339 | The order of operations is significant. This can be used to set either defaults |
| 340 | or values which cannot be overridden. For example if an application calls: |
| 341 | |
| 342 | SSL_CONF_cmd(ctx, "Protocol", "-SSLv2"); |
| 343 | SSL_CONF_cmd(ctx, userparam, uservalue); |
| 344 | |
| 345 | it will disable SSLv2 support by default but the user can override it. If |
| 346 | however the call sequence is: |
| 347 | |
| 348 | SSL_CONF_cmd(ctx, userparam, uservalue); |
| 349 | SSL_CONF_cmd(ctx, "Protocol", "-SSLv2"); |
| 350 | |
| 351 | SSLv2 is B<always> disabled and attempt to override this by the user are |
| 352 | ignored. |
| 353 | |
| 354 | By checking the return code of SSL_CTX_cmd() it is possible to query if a |
| 355 | given B<cmd> is recognised, this is useful is SSL_CTX_cmd() values are |
| 356 | mixed with additional application specific operations. |
| 357 | |
| 358 | For example an application might call SSL_CTX_cmd() and if it returns |
| 359 | -2 (unrecognised command) continue with processing of application specific |
| 360 | commands. |
| 361 | |
| 362 | Applications can also use SSL_CTX_cmd() to process command lines though the |
| 363 | utility function SSL_CTX_cmd_argv() is normally used instead. One way |
Dr. Stephen Henson | 821244c | 2012-11-18 18:06:16 +0000 | [diff] [blame] | 364 | to do this is to set the prefix to an appropriate value using |
| 365 | SSL_CONF_CTX_set1_prefix(), pass the current argument to B<cmd> and the |
| 366 | following argument to B<value> (which may be NULL). |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 367 | |
| 368 | In this case if the return value is positive then it is used to skip that |
| 369 | number of arguments as they have been processed by SSL_CTX_cmd(). If -2 is |
| 370 | returned then B<cmd> is not recognised and application specific arguments |
| 371 | can be checked instead. If -3 is returned a required argument is missing |
| 372 | and an error is indicated. If 0 is returned some other error occurred and |
| 373 | this can be reported back to the user. |
| 374 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 375 | The function SSL_CONF_cmd_value_type() can be used by applications to |
| 376 | check for the existence of a command or to perform additional syntax |
| 377 | checking or translation of the command value. For example if the return |
| 378 | value is B<SSL_CONF_TYPE_FILE> an application could translate a relative |
| 379 | pathname to an absolute pathname. |
| 380 | |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 381 | =head1 EXAMPLES |
| 382 | |
| 383 | Set supported signature algorithms: |
| 384 | |
| 385 | SSL_CONF_cmd(ctx, "SignatureAlgorithms", "ECDSA+SHA256:RSA+SHA256:DSA+SHA256"); |
| 386 | |
| 387 | Enable all protocols except SSLv3 and SSLv2: |
| 388 | |
| 389 | SSL_CONF_cmd(ctx, "Protocol", "ALL,-SSLv3,-SSLv2"); |
| 390 | |
| 391 | Only enable TLSv1.2: |
| 392 | |
| 393 | SSL_CONF_cmd(ctx, "Protocol", "-ALL,TLSv1.2"); |
| 394 | |
| 395 | Disable TLS session tickets: |
| 396 | |
| 397 | SSL_CONF_cmd(ctx, "Options", "-SessionTicket"); |
| 398 | |
| 399 | Set supported curves to P-256, P-384: |
| 400 | |
| 401 | SSL_CONF_cmd(ctx, "Curves", "P-256:P-384"); |
| 402 | |
| 403 | Set automatic support for any elliptic curve for key exchange: |
| 404 | |
| 405 | SSL_CONF_cmd(ctx, "ECDHParameters", "Automatic"); |
| 406 | |
| 407 | =head1 RETURN VALUES |
| 408 | |
Dr. Stephen Henson | 4365e4a | 2013-02-26 15:27:56 +0000 | [diff] [blame] | 409 | SSL_CONF_cmd() returns 1 if the value of B<cmd> is recognised and B<value> is |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 410 | B<NOT> used and 2 if both B<cmd> and B<value> are used. In other words it |
| 411 | returns the number of arguments processed. This is useful when processing |
| 412 | command lines. |
| 413 | |
| 414 | A return value of -2 means B<cmd> is not recognised. |
| 415 | |
| 416 | A return value of -3 means B<cmd> is recognised and the command requires a |
| 417 | value but B<value> is NULL. |
| 418 | |
| 419 | A return code of 0 indicates that both B<cmd> and B<value> are valid but an |
| 420 | error occurred attempting to perform the operation: for example due to an |
| 421 | error in the syntax of B<value> in this case the error queue may provide |
| 422 | additional information. |
| 423 | |
Dr. Stephen Henson | ec2f7e5 | 2013-10-18 16:09:12 +0100 | [diff] [blame] | 424 | SSL_CONF_finish() returns 1 for success and 0 for failure. |
| 425 | |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 426 | =head1 SEE ALSO |
| 427 | |
| 428 | L<SSL_CONF_CTX_new(3)|SSL_CONF_CTX_new(3)>, |
| 429 | L<SSL_CONF_CTX_set_flags(3)|SSL_CONF_CTX_set_flags(3)>, |
| 430 | L<SSL_CONF_CTX_set1_prefix(3)|SSL_CONF_CTX_set1_prefix(3)>, |
| 431 | L<SSL_CONF_CTX_set_ssl_ctx(3)|SSL_CONF_CTX_set_ssl_ctx(3)>, |
| 432 | L<SSL_CONF_cmd_argv(3)|SSL_CONF_cmd_argv(3)> |
| 433 | |
| 434 | =head1 HISTORY |
| 435 | |
Dr. Stephen Henson | 4365e4a | 2013-02-26 15:27:56 +0000 | [diff] [blame] | 436 | SSL_CONF_cmd() was first added to OpenSSL 1.0.2 |
Dr. Stephen Henson | 3db935a | 2012-11-16 19:12:24 +0000 | [diff] [blame] | 437 | |
| 438 | =cut |