2013-08-05 19:49:24 +04:00
/*
* Copyright ( C ) 2011 - 2013 Red Hat , Inc .
*
* This library 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/>.
*/
2019-06-18 19:13:14 +03:00
# pragma once
2013-08-05 19:49:24 +04:00
2019-06-18 19:13:14 +03:00
# include <gnutls/gnutls.h>
# include <gnutls/x509.h>
2013-08-05 19:49:24 +04:00
2019-06-18 19:13:14 +03:00
# if !defined WIN32 && HAVE_LIBTASN1_H && LIBGNUTLS_VERSION_NUMBER >= 0x020600
2013-08-05 19:49:24 +04:00
2019-06-18 19:13:14 +03:00
# include <libtasn1.h>
2018-12-13 16:32:06 +03:00
2019-06-18 19:13:14 +03:00
# include "rpc / virnettlscontext.h"
2013-08-05 19:49:24 +04:00
/*
* This contains parameter about how to generate
* certificates .
*/
struct testTLSCertReq {
gnutls_x509_crt_t crt ;
const char * filename ;
/* Identifying information */
const char * country ;
const char * cn ;
const char * altname1 ;
const char * altname2 ;
const char * ipaddr1 ;
const char * ipaddr2 ;
/* Basic constraints */
bool basicConstraintsEnable ;
bool basicConstraintsCritical ;
bool basicConstraintsIsCA ;
/* Key usage */
bool keyUsageEnable ;
bool keyUsageCritical ;
int keyUsageValue ;
/* Key purpose (aka Extended key usage) */
bool keyPurposeEnable ;
bool keyPurposeCritical ;
const char * keyPurposeOID1 ;
const char * keyPurposeOID2 ;
/* zero for current time, or non-zero for hours from now */
int start_offset ;
/* zero for 24 hours from now, or non-zero for hours from now */
int expire_offset ;
} ;
2013-08-05 20:08:17 +04:00
void testTLSGenerateCert ( struct testTLSCertReq * req ,
gnutls_x509_crt_t ca ) ;
2013-08-06 15:31:20 +04:00
void testTLSWriteCertChain ( const char * filename ,
gnutls_x509_crt_t * certs ,
size_t ncerts ) ;
2013-08-05 19:49:24 +04:00
void testTLSDiscardCert ( struct testTLSCertReq * req ) ;
2013-08-09 02:08:25 +04:00
void testTLSInit ( const char * keyfile ) ;
void testTLSCleanup ( const char * keyfile ) ;
2013-08-05 19:49:24 +04:00
2019-06-18 19:13:14 +03:00
# endif