/* * "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> * * 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 #ifdef _WIN32 #include #include #else #include #endif // _WIN32 #include #include #include #include #include #include #include #include #include #include #include #include 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