21#ifndef FREERDP_CRYPTO_CERTIFICATE_H
22#define FREERDP_CRYPTO_CERTIFICATE_H
24#include <winpr/crypto.h>
26#include <freerdp/api.h>
33 enum FREERDP_CERT_PARAM
39 typedef struct rdp_certificate rdpCertificate;
41 FREERDP_API
void freerdp_certificate_free(rdpCertificate* certificate);
43 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
44 FREERDP_API rdpCertificate* freerdp_certificate_new(
void);
46 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
47 FREERDP_API rdpCertificate* freerdp_certificate_new_from_file(const
char* file);
49 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
50 FREERDP_API rdpCertificate* freerdp_certificate_new_from_pem(const
char* pem);
52 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
53 FREERDP_API rdpCertificate* freerdp_certificate_new_from_der(const BYTE* data,
size_t length);
56 FREERDP_API BOOL freerdp_certificate_is_rsa(const rdpCertificate* certificate);
58 WINPR_ATTR_MALLOC(free, 1)
59 FREERDP_API
char* freerdp_certificate_get_hash(const rdpCertificate* certificate,
60 const
char* hash,
size_t* plength);
62 WINPR_ATTR_MALLOC(free, 1)
63 FREERDP_API
char* freerdp_certificate_get_fingerprint_by_hash(const rdpCertificate* certificate,
66 WINPR_ATTR_MALLOC(free, 1)
68 freerdp_certificate_get_fingerprint_by_hash_ex(const rdpCertificate* certificate,
69 const
char* hash, BOOL separator);
71 WINPR_ATTR_MALLOC(free, 1)
72 FREERDP_API
char* freerdp_certificate_get_fingerprint(const rdpCertificate* certificate);
74 WINPR_ATTR_MALLOC(free, 1)
75 FREERDP_API
char* freerdp_certificate_get_pem(const rdpCertificate* certificate,
87 WINPR_ATTR_MALLOC(free, 1)
88 FREERDP_API
char* freerdp_certificate_get_pem_ex(const rdpCertificate* certificate,
89 size_t* pLength, BOOL withCertChain);
91 WINPR_ATTR_MALLOC(free, 1)
92 FREERDP_API BYTE* freerdp_certificate_get_der(const rdpCertificate* certificate,
95 WINPR_ATTR_MALLOC(free, 1)
96 FREERDP_API
char* freerdp_certificate_get_subject(const rdpCertificate* certificate);
98 WINPR_ATTR_MALLOC(free, 1)
99 FREERDP_API
char* freerdp_certificate_get_issuer(const rdpCertificate* certificate);
101 WINPR_ATTR_MALLOC(free, 1)
102 FREERDP_API
char* freerdp_certificate_get_upn(const rdpCertificate* certificate);
104 WINPR_ATTR_MALLOC(free, 1)
105 FREERDP_API
char* freerdp_certificate_get_email(const rdpCertificate* certificate);
114 WINPR_ATTR_MALLOC(free, 1)
115 FREERDP_API
char* freerdp_certificate_get_validity(const rdpCertificate* certificate,
119 FREERDP_API WINPR_MD_TYPE freerdp_certificate_get_signature_alg(const rdpCertificate* cert);
121 WINPR_ATTR_MALLOC(free, 1)
122 FREERDP_API
char* freerdp_certificate_get_common_name(const rdpCertificate* cert,
125 WINPR_ATTR_MALLOC(free, 1)
126 FREERDP_API
char** freerdp_certificate_get_dns_names(const rdpCertificate* cert,
size_t* pcount,
128 FREERDP_API
void freerdp_certificate_free_dns_names(
size_t count,
size_t* lengths,
132 FREERDP_API BOOL freerdp_certificate_check_eku(const rdpCertificate* certificate,
int nid);
135 FREERDP_API BOOL freerdp_certificate_get_public_key(const rdpCertificate* cert,
136 BYTE** PublicKey, DWORD* PublicKeyLength);
139 FREERDP_API BOOL freerdp_certificate_verify(const rdpCertificate* cert,
140 const
char* certificate_store_path);
143 FREERDP_API BOOL freerdp_certificate_is_rdp_security_compatible(const rdpCertificate* cert);
145 WINPR_ATTR_MALLOC(free, 1)
146 FREERDP_API
char* freerdp_certificate_get_param(const rdpCertificate* cert,
147 enum FREERDP_CERT_PARAM what,
size_t* psize);