#ifndef UCSPITLS_H
#define UCSPITLS_H

#include <openssl/ssl.h>
#include <openssl/opensslv.h>
#include <openssl/ec.h>
#include "stralloc.h"

#define SSL_NAME_LEN 256
#define OPENSSL_VERSION_NUMBER 0x101010100L

#if (OPENSSL_VERSION_NUMBER < 0x10100000L)
#define ssl_client() (ssl_context(SSLv23_client_method()))
#define ssl_server() (ssl_context(SSLv23_server_method()))
#else
#define ssl_client() (ssl_context(TLS_client_method()))
#define ssl_server() (ssl_context(TLS_server_method()))
#endif

extern int ssl_errno;
int ssl_io(SSL *,int,int,unsigned int);
SSL_CTX *ssl_context(SSL_METHOD *);
int ssl_timeoutconn(SSL *,unsigned int);
int ssl_timeoutaccept(SSL *,unsigned int);
SSL *ssl_new(SSL_CTX *,int);
int ssl_certkey(SSL_CTX *,const char *,const char *,pem_password_cb *);
int ssl_ca(SSL_CTX *,const char *,const char *,int);
int ssl_cca(SSL_CTX *,const char *);
int ssl_ciphers(SSL_CTX *,const char *);
int ssl_verify(SSL *,const char *);
int ssl_params(SSL_CTX *,const char *,int);
int ssl_server_env(SSL *,stralloc *);
int ssl_client_env(SSL *,stralloc *);
char *ssl_error_str(int);

#define ssl_errstr() (SSL_load_error_strings())
#define ssl_free(ssl) (SSL_free((ssl)))
#define ssl_close(ssl) (close(SSL_get_fd((ssl))))

#define ssl_pending(ssl) (SSL_pending((ssl)))
#define ssl_shutdown(ssl) (SSL_shutdown((ssl)))
#define ssl_shutdown_pending(ssl) (SSL_get_shutdown((ssl)) & SSL_RECEIVED_SHUTDOWN)
#define ssl_shutdown_sent(ssl) (SSL_get_shutdown((ssl)) & SSL_SENT_SHUTDOWN)

#endif