vlc_tls.h 2.83 KB
Newer Older
1
/*****************************************************************************
2
 * vlc_tls.h: Transport Layer Security API
3
 *****************************************************************************
4
 * Copyright (C) 2004-2011 Rémi Denis-Courmont
Jean-Baptiste Kempf's avatar
LGPL  
Jean-Baptiste Kempf committed
5
 * Copyright (C) 2005-2006 VLC authors and VideoLAN
6
 *
Jean-Baptiste Kempf's avatar
LGPL  
Jean-Baptiste Kempf committed
7 8 9
 * 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
10 11 12 13
 * (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
Jean-Baptiste Kempf's avatar
LGPL  
Jean-Baptiste Kempf committed
14 15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
16
 *
Jean-Baptiste Kempf's avatar
LGPL  
Jean-Baptiste Kempf committed
17 18 19
 * 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.
20 21
 *****************************************************************************/

22 23
#ifndef VLC_TLS_H
# define VLC_TLS_H
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
24

25 26 27 28 29
/**
 * \file
 * This file defines Transport Layer Security API (TLS) in vlc
 */

Clément Stenac's avatar
Clément Stenac committed
30
# include <vlc_network.h>
31

32
typedef struct vlc_tls_sys vlc_tls_sys_t;
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
33

34
typedef struct vlc_tls
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
35
{
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
36 37
    VLC_COMMON_MEMBERS

38 39 40 41 42
    union {
        module_t *module; /**< Plugin handle (client) */
        void    (*close) (struct vlc_tls *); /**< Close callback (server) */
    } u;
    vlc_tls_sys_t *sys;
43

44 45 46
    struct virtual_socket_t sock;
    int  (*handshake) (struct vlc_tls *);
} vlc_tls_t;
47

48 49 50
VLC_API vlc_tls_t *vlc_tls_ClientCreate (vlc_object_t *, int fd,
                                         const char *hostname);
VLC_API void vlc_tls_ClientDelete (vlc_tls_t *);
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
51

52 53
/* 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))
54

55
# define tls_Recv( a, b, c ) (((vlc_tls_t *)a)->sock.pf_recv (a, b, c))
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
56 57


58
typedef struct vlc_tls_creds_sys vlc_tls_creds_sys_t;
Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
59

60 61 62 63
/** TLS (server-side) credentials */
typedef struct vlc_tls_creds
{
    VLC_COMMON_MEMBERS
64

65 66
    module_t  *module;
    vlc_tls_creds_sys_t *sys;
67

68 69
    int (*add_CA) (struct vlc_tls_creds *, const char *path);
    int (*add_CRL) (struct vlc_tls_creds *, const char *path);
70

71 72
    vlc_tls_t *(*open) (struct vlc_tls_creds *, int fd);
} vlc_tls_creds_t;
73

74 75 76 77 78
vlc_tls_creds_t *vlc_tls_ServerCreate (vlc_object_t *,
                                       const char *cert, const char *key);
void vlc_tls_ServerDelete (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);
79

80 81 82
vlc_tls_t *vlc_tls_ServerSessionCreate (vlc_tls_creds_t *, int fd);
int vlc_tls_ServerSessionHandshake (vlc_tls_t *);
void vlc_tls_ServerSessionDelete (vlc_tls_t *);
83

Rémi Denis-Courmont's avatar
Rémi Denis-Courmont committed
84
#endif