-
Notifications
You must be signed in to change notification settings - Fork 0
/
ssl.h
78 lines (65 loc) · 1.89 KB
/
ssl.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
* Copyright (c) 2016-2017, Parallels International GmbH
* Copyright (c) 2017-2019 Virtuozzo International GmbH. All rights reserved.
*
* This file is part of OpenVZ libraries. OpenVZ 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 library 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 library. If not, see
* <http://www.gnu.org/licenses/> or write to Free Software Foundation,
* 51 Franklin Street, Fifth Floor Boston, MA 02110, USA.
*
* Our contact details: Virtuozzo International GmbH, Vordergasse 59, 8200
* Schaffhausen, Switzerland.
*
*/
#ifndef __VZS_SSL_H_
#define __VZS_SSL_H_
#include <sys/types.h>
#include <limits.h>
#include <openssl/ssl.h>
#include <openssl/err.h>
#include <openssl/x509.h>
#include "libvzsock.h"
#include "vzsock.h"
/*
AFAIK there are free ports, according
http://www.iana.org/assignments/port-numbers
*/
#define VZMD_DEF_PORT 4422
/* see ERR_error_string man page */
#define SSL_ERR_STRING_MAXLEN 121
struct ssl_data {
int domain;
int type;
int protocol;
struct sockaddr *addr;
socklen_t addr_len;
SSL_CTX * ctx;
char crtfile[PATH_MAX + 1];
char keyfile[PATH_MAX + 1];
char CAfile[PATH_MAX + 1];
char CApath[PATH_MAX + 1];
char ciphers[BUFSIZ+1];
// X509 *cert;
};
struct ssl_conn {
int sock;
SSL * ssl;
};
#ifdef __cplusplus
extern "C" {
#endif
int _vzs_ssl_init(struct vzsock_ctx *ctx, struct vzs_handlers *handlers);
#ifdef __cplusplus
}
#endif
#endif