2012-09-24 17:11:48 +01:00
/* X.509 certificate parser internal definitions
*
* Copyright ( C ) 2012 Red Hat , Inc . All Rights Reserved .
* Written by David Howells ( dhowells @ redhat . com )
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public Licence
* as published by the Free Software Foundation ; either version
* 2 of the Licence , or ( at your option ) any later version .
*/
2013-08-30 16:16:34 +01:00
# include <linux/time.h>
2012-09-24 17:11:48 +01:00
# include <crypto/public_key.h>
struct x509_certificate {
struct x509_certificate * next ;
struct public_key * pub ; /* Public key details */
char * issuer ; /* Name of certificate issuer */
char * subject ; /* Name of certificate subject */
char * fingerprint ; /* Key fingerprint as hex */
char * authority ; /* Authority key fingerprint as hex */
2012-10-02 14:36:16 +01:00
struct tm valid_from ;
struct tm valid_to ;
2012-09-24 17:11:48 +01:00
const void * tbs ; /* Signed data */
2013-08-30 16:18:02 +01:00
unsigned tbs_size ; /* Size of signed data */
unsigned raw_sig_size ; /* Size of sigature */
const void * raw_sig ; /* Signature data */
struct public_key_signature sig ; /* Signature parameters */
2012-09-24 17:11:48 +01:00
} ;
/*
* x509_cert_parser . c
*/
extern void x509_free_certificate ( struct x509_certificate * cert ) ;
extern struct x509_certificate * x509_cert_parse ( const void * data , size_t datalen ) ;
2013-08-30 16:18:02 +01:00
/*
* x509_public_key . c
*/
extern int x509_get_sig_params ( struct x509_certificate * cert ) ;
extern int x509_check_signature ( const struct public_key * pub ,
struct x509_certificate * cert ) ;