private.h 3.62 KB
/*
 * "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