Scroll to navigation

SSL_CTX_SET1_GROUPS(3) Library Functions Manual SSL_CTX_SET1_GROUPS(3)

NAME

SSL_CTX_set1_groups, SSL_CTX_set1_groups_list, SSL_set1_groups, SSL_set1_groups_list, SSL_CTX_set1_curves, SSL_CTX_set1_curves_list, SSL_set1_curves, SSL_set1_curves_listchoose supported EC groups

SYNOPSIS

#include <openssl/ssl.h>

int
SSL_CTX_set1_groups(SSL_CTX *ctx, const int *glist, size_t glistlen);

int
SSL_CTX_set1_groups_list(SSL_CTX *ctx, const char *list);

int
SSL_set1_groups(SSL *ssl, const int *glist, size_t glistlen);

int
SSL_set1_groups_list(SSL *ssl, const char *list);

int
SSL_CTX_set1_curves(SSL_CTX *ctx, const int *clist, size_t clistlen);

int
SSL_CTX_set1_curves_list(SSL_CTX *ctx, const char *list);

int
SSL_set1_curves(SSL *ssl, const int *clist, size_t clistlen);

int
SSL_set1_curves_list(SSL *ssl, const char *list);

DESCRIPTION

() sets the supported groups for ctx to the glistlen groups in the array glist. The array consists of group NIDs in preference order. For a TLS client, the groups are used directly in the supported groups extension. For a TLS server, the groups are used to determine the set of shared groups.

() sets the supported groups for ctx to the list represented as a colon separated list of group NIDs or names, for example "P-521:P-384:P-256".

() and () are similar except that they set supported groups for the SSL structure ssl only.

The curve functions are deprecated synonyms for the equivalently named group functions and are identical in every respect except that they are implemented as macros. They exist because prior to TLS1.3, there was only the concept of supported curves. In TLS1.3, this was renamed to supported groups and extended to include Diffie Hellman groups.

If an application wishes to make use of several of these functions for configuration purposes either on a command line or in a file, it should consider using the SSL_CONF interface instead of manually parsing options.

RETURN VALUES

All these functions return 1 for success or 0 for failure.

SEE ALSO

ssl(3), SSL_CTX_add_extra_chain_cert(3), SSL_CTX_set_cipher_list(3), SSL_CTX_set_options(3), SSL_new(3)

HISTORY

The curve functions first appeared in OpenSSL 1.0.2 and the group functions in OpenSSL 1.1.1. Both have been available since OpenBSD 6.1.

August 19, 2017 Linux 6.4.0-150600.23.25-default