actube/src/capwap/dtls_openssl_init.c

42 lines
985 B
C

int dtls_openssl_init(struct conn * conn,const SSL_METHOD * method)
{
conn->dtls_data = malloc(sizeof(struct dtls_data));
struct dtls_data * dtls_data = conn->dtls_data;
if (!dtls_data)
return 0;
dtls_data->pos=0;
dtls_data->len=0;
SSL_CTX *ctx;
SSL *ssl;
BIO *bio = BIO_new(&bio_methods);
bio->ptr = conn;
printf("Assigning conn %p\n",bio->ptr);
OpenSSL_add_ssl_algorithms();
SSL_load_error_strings();
printf("Getting CTX\n");
ctx = SSL_CTX_new(method); //DTLSv1_client_method());
printf("CTX: %p\n",ctx);
int rc = SSL_CTX_set_cipher_list(ctx, "PSK-AES128-CBC-SHA");
printf("Set cipher RC: %d\n",rc);
SSL_CTX_set_psk_client_callback( ctx, psk_cb);
SSL_CTX_set_psk_server_callback( ctx, psk_server_cb);
SSL_CTX_set_read_ahead(ctx, 1);
SSL_CTX_set_cookie_generate_cb(ctx, generate_cookie);
SSL_CTX_set_cookie_verify_cb(ctx, verify_cookie);
ssl = SSL_new(ctx);
SSL_set_bio(ssl, bio, bio);
printf("New rc %p\n",ssl);
dtls_data->ssl=ssl;
return 0;
}