private.h
3.55 KB
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
* "Software G3270, desenvolvido com base nos códigos fontes do WC3270 e X3270
* (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a
* aplicativos mainframe. Registro no INPI sob o nome G3270.
*
* Copyright (C) <2008> <Banco do Brasil S.A.>
*
* Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob
* os termos da GPL v.2 - Licença Pública Geral ', conforme publicado pela
* Free Software Foundation.
*
* Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER
* GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO
* A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para
* obter mais detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este
* programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin
* St, Fifth Floor, Boston, MA 02110-1301 USA
*
* Este programa está nomeado como private.h e possui - linhas de código.
*
* Contatos:
*
* perry.werneck@gmail.com (Alexandre Perry de Souza Werneck)
* erico.mendonca@gmail.com (Erico Mascarenhas de Mendonça)
*
*/
#ifndef LIB3270_OPENSSL_MODULE_PRIVATE_H_INCLUDED
#define LIB3270_OPENSSL_MODULE_PRIVATE_H_INCLUDED
#include <config.h>
#ifdef _WIN32
#include <winsock2.h>
#include <windows.h>
#else
#include <fcntl.h>
#endif // _WIN32
#include <lib3270.h>
#include <lib3270/log.h>
#include <lib3270/popup.h>
#include <lib3270/os.h>
#include <array.h>
#include <internals.h>
#include <networking.h>
#include <trace_dsc.h>
#include <openssl/ssl.h>
#include <openssl/x509.h>
#include <openssl/x509v3.h>
#include <openssl/err.h>
struct _lib3270_network_popup {
LIB3270_POPUP_HEAD
long id;
const char * icon; ///< @brief Icon name from https://specifications.freedesktop.org/icon-naming-spec/icon-naming-spec-latest.html
};
struct _lib3270_net_context {
int sock; ///< @brief Session socket.
SSL * con; ///< @brief SSL Connection handle.
struct {
char download; ///< @brief Non zero to download CRL.
char * prefer; ///< @brief Prefered protocol for CRL.
char * url; ///< @brief URL for CRL download.
X509_CRL * cert; ///< @brief Loaded CRL (can be null).
} crl;
struct {
unsigned long error; ///< @brief The last OpenSSL error code.
const char * message; ///< @brief The last OpenSSL state message.
const char * alert; ///< @brief The last OpenSSL alert message.
} state;
};
/// @brief X509 auto-cleanup.
static inline void lib3270_autoptr_cleanup_X509(X509 **ptr) {
if(*ptr)
X509_free(*ptr);
*ptr = NULL;
}
/// @brief Dist points auto-cleanup.
static inline void lib3270_autoptr_cleanup_CRL_DIST_POINTS(CRL_DIST_POINTS **ptr) {
if(*ptr)
CRL_DIST_POINTS_free(*ptr);
*ptr = NULL;
}
static inline void lib3270_autoptr_cleanup_BIO(BIO **ptr) {
if(*ptr)
BIO_free_all(*ptr);
*ptr = NULL;
}
LIB3270_INTERNAL SSL_CTX * lib3270_openssl_get_context(H3270 *hSession);
LIB3270_INTERNAL int lib3270_openssl_get_ex_index(H3270 *hSession);
LIB3270_INTERNAL const LIB3270_NETWORK_POPUP * lib3270_openssl_get_popup_from_error_code(long id);
LIB3270_INTERNAL int openssl_network_start_tls(H3270 *hSession);
LIB3270_INTERNAL LIB3270_STRING_ARRAY * lib3270_openssl_get_crls_from_peer(H3270 *hSession, X509 *cert);
LIB3270_INTERNAL const LIB3270_SSL_MESSAGE * lib3270_openssl_message_from_id(long id);
LIB3270_INTERNAL void lib3270_openssl_crl_free(LIB3270_NET_CONTEXT *context);
#endif // !LIB3270_OPENSSL_MODULE_PRIVATE_H_INCLUDED