/***************************************************************************** * vlc_tls.h: Transport Layer Security API ***************************************************************************** * Copyright (C) 2004-2011 RĂ©mi Denis-Courmont * Copyright (C) 2005-2006 VLC authors and VideoLAN * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ #ifndef VLC_TLS_H # define VLC_TLS_H /** * \file * This file defines Transport Layer Security API (TLS) in vlc */ # include typedef struct vlc_tls vlc_tls_t; typedef struct vlc_tls_sys vlc_tls_sys_t; typedef struct vlc_tls_creds vlc_tls_creds_t; typedef struct vlc_tls_creds_sys vlc_tls_creds_sys_t; /** TLS session */ struct vlc_tls { VLC_COMMON_MEMBERS vlc_tls_sys_t *sys; struct virtual_socket_t sock; int (*handshake) (vlc_tls_t *, const char *host, const char *service); }; VLC_API vlc_tls_t *vlc_tls_ClientSessionCreate (vlc_tls_creds_t *, int fd, const char *host, const char *service); vlc_tls_t *vlc_tls_SessionCreate (vlc_tls_creds_t *, int fd, const char *host); int vlc_tls_SessionHandshake (vlc_tls_t *, const char *host, const char *serv); VLC_API void vlc_tls_SessionDelete (vlc_tls_t *); /* NOTE: It is assumed that a->sock.p_sys = a */ # define tls_Send( a, b, c ) (((vlc_tls_t *)a)->sock.pf_send (a, b, c)) # define tls_Recv( a, b, c ) (((vlc_tls_t *)a)->sock.pf_recv (a, b, c)) /** TLS credentials (certificate, private and trust settings) */ struct vlc_tls_creds { VLC_COMMON_MEMBERS module_t *module; vlc_tls_creds_sys_t *sys; int (*add_CA) (vlc_tls_creds_t *, const char *path); int (*add_CRL) (vlc_tls_creds_t *, const char *path); int (*open) (vlc_tls_creds_t *, vlc_tls_t *, int fd, const char *host); void (*close) (vlc_tls_creds_t *, vlc_tls_t *); }; VLC_API vlc_tls_creds_t *vlc_tls_ClientCreate (vlc_object_t *); vlc_tls_creds_t *vlc_tls_ServerCreate (vlc_object_t *, const char *cert, const char *key); VLC_API void vlc_tls_Delete (vlc_tls_creds_t *); int vlc_tls_ServerAddCA (vlc_tls_creds_t *srv, const char *path); int vlc_tls_ServerAddCRL (vlc_tls_creds_t *srv, const char *path); #endif