diff --git a/extra/libtls/authors.txt b/extra/libtls/authors.txt new file mode 100644 index 0000000000..156fc8269d --- /dev/null +++ b/extra/libtls/authors.txt @@ -0,0 +1 @@ +Benjamin Pollack diff --git a/extra/libtls/ffi/ffi.factor b/extra/libtls/ffi/ffi.factor new file mode 100644 index 0000000000..0c2db3431e --- /dev/null +++ b/extra/libtls/ffi/ffi.factor @@ -0,0 +1,70 @@ +USING: alien alien.c-types alien.destructors alien.libraries +alien.syntax combinators io.sockets.secure system unix.types ; + +IN: libtls.ffi + +<< "libtls" { + { [ os windows? ] [ "libtls.dll" ] } + { [ os macosx? ] [ "libtls.dylib" ] } + { [ os unix? ] [ "libtls.so" ] } +} cond cdecl add-library >> + +C-TYPE: tls_config +C-TYPE: tls_ctx + +LIBRARY: libtls + +FUNCTION: int tls_init ( ) +FUNCTION: c-string tls_error ( tls_ctx* ctx ) +FUNCTION: tls_config* tls_config_new ( ) +FUNCTION: void tls_config_free ( tls_config* config ) +FUNCTION: int tls_config_parse_protocols ( uint32_t* protocols, c-string protostr ) +FUNCTION: int tls_config_set_ca_file ( tls_config* config, c-string ca_file ) +FUNCTION: int tls_config_set_ca_path ( tls_config* config, c-string ca_path ) +FUNCTION: int tls_config_set_ca_mem ( tls_config* config, uint8_t *cert, size_t len ) +FUNCTION: int tls_config_set_cert_file ( tls_config* config, c-string cert_file ) +FUNCTION: int tls_config_set_cert_mem ( tls_config* config, uint8_t *cert, size_t len ) +FUNCTION: int tls_config_set_ciphers ( tls_config* config, c-string ciphers ) +FUNCTION: int tls_config_set_dheparams ( tls_config* config, c-string params ) +FUNCTION: int tls_config_set_ecdhecurve ( tls_config* config, c-string name ) +FUNCTION: int tls_config_set_key_file ( tls_config* config, c-string key_file ) +FUNCTION: int tls_config_set_key_mem ( tls_config* config, uint8_t *key, size_t len ) +FUNCTION: void tls_config_set_protocols ( tls_config* config, uint32_t protocols ) +FUNCTION: void tls_config_set_verify_depth ( tls_config* config, int verify_depth ) +FUNCTION: void tls_config_prefer_ciphers_client ( tls_config* config ) +FUNCTION: void tls_config_prefer_ciphers_server ( tls_config* config ) +FUNCTION: void tls_config_clear_keys ( tls_config* config ) +FUNCTION: void tls_config_insecure_noverifycert ( tls_config* config ) +FUNCTION: void tls_config_insecure_noverifyname ( tls_config* config ) +FUNCTION: void tls_config_insecure_noverifytime ( tls_config* config ) +FUNCTION: void tls_config_verify ( tls_config* config ) +FUNCTION: void tls_config_verify_client ( tls_config* config ) +FUNCTION: void tls_config_verify_client_optional ( tls_config* config ) +FUNCTION: int tls_peer_cert_provided ( tls_ctx* ctx ) +FUNCTION: int tls_peer_cert_contains_name ( tls_ctx* ctx, c-string name ) +FUNCTION: c-string tls_peer_cert_issuer ( tls_ctx* ctx ) +FUNCTION: c-string tls_peer_cert_subject ( tls_ctx* ctx ) +FUNCTION: c-string tls_peer_cert_hash ( tls_ctx* ctx ) +FUNCTION: time_t tls_peer_cert_notbefore ( tls_ctx* ctx ) +FUNCTION: time_t tls_peer_cert_notafter ( tls_ctx* ctx ) +FUNCTION: c-string tls_conn_version ( tls_ctx* ctx ) +FUNCTION: c-string tls_conn_cipher ( tls_ctx* ctx ) +FUNCTION: uint8_t* tls_load_file ( c-string file, size_t *len, char *password ) +FUNCTION: tls_ctx* tls_client ( ) +FUNCTION: tls_ctx* tls_server ( ) +FUNCTION: int tls_configure ( tls_ctx* ctx, tls_config* config ) +FUNCTION: void tls_reset ( tls_ctx* ctx ) +FUNCTION: void tls_free ( tls_ctx* ctx ) +FUNCTION: int tls_connect ( tls_ctx* ctx, c-string host, c-string port ) +FUNCTION: int tls_connect_fds ( tls_ctx* ctx, int fd_read, int fd_write, c-string servername ) +FUNCTION: int tls_connect_servername ( tls_ctx* ctx, c-string host, c-string port, c-string servername ) +FUNCTION: int tls_connect_socket ( tls_ctx* ctx, int s, c-string servername ) +FUNCTION: int tls_accept_fds ( tls_ctx* tls, tls_ctx* *cctx, int fd_read, int fd_write ) +FUNCTION: int tls_accept_socket ( tls_ctx* tls, tls_ctx* *cctx, int socket ) +FUNCTION: int tls_handshake ( tls_ctx* ctx ) +FUNCTION: ssize_t tls_read ( tls_ctx* ctx, void* buf, size_t buflen ) +FUNCTION: ssize_t tls_write ( tls_ctx* ctx, void* buf, size_t buflen ) +FUNCTION: int tls_close ( tls_ctx* ctx ) + +DESTRUCTOR: tls_config_free +DESTRUCTOR: tls_free diff --git a/extra/libtls/ffi/summary.txt b/extra/libtls/ffi/summary.txt new file mode 100644 index 0000000000..8e4a9da09d --- /dev/null +++ b/extra/libtls/ffi/summary.txt @@ -0,0 +1 @@ +Raw bindings to the high-level libtls bindings in LibreSSL diff --git a/extra/libtls/tags.txt b/extra/libtls/tags.txt new file mode 100644 index 0000000000..e644cf4d50 --- /dev/null +++ b/extra/libtls/tags.txt @@ -0,0 +1 @@ +security