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)
45 FREERDP_API rdpCertificate* freerdp_certificate_new(
void);
47 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
49 FREERDP_API rdpCertificate* freerdp_certificate_new_from_file(const
char* file);
51 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
53 FREERDP_API rdpCertificate* freerdp_certificate_new_from_pem(const
char* pem);
55 WINPR_ATTR_MALLOC(freerdp_certificate_free, 1)
57 FREERDP_API rdpCertificate* freerdp_certificate_new_from_der(const BYTE* data,
size_t length);
60 FREERDP_API BOOL freerdp_certificate_is_rsa(const rdpCertificate* certificate);
62 WINPR_ATTR_MALLOC(free, 1)
64 FREERDP_API
char* freerdp_certificate_get_hash(const rdpCertificate* certificate,
65 const
char* hash,
size_t* plength);
67 WINPR_ATTR_MALLOC(free, 1)
69 FREERDP_API
char* freerdp_certificate_get_fingerprint_by_hash(const rdpCertificate* certificate,
72 WINPR_ATTR_MALLOC(free, 1)
75 freerdp_certificate_get_fingerprint_by_hash_ex(const rdpCertificate* certificate,
76 const
char* hash, BOOL separator);
78 WINPR_ATTR_MALLOC(free, 1)
80 FREERDP_API
char* freerdp_certificate_get_fingerprint(const rdpCertificate* certificate);
82 WINPR_ATTR_MALLOC(free, 1)
84 FREERDP_API
char* freerdp_certificate_get_pem(const rdpCertificate* certificate,
96 WINPR_ATTR_MALLOC(free, 1)
98 FREERDP_API
char* freerdp_certificate_get_pem_ex(const rdpCertificate* certificate,
99 size_t* pLength, BOOL withCertChain);
101 WINPR_ATTR_MALLOC(free, 1)
103 FREERDP_API BYTE* freerdp_certificate_get_der(const rdpCertificate* certificate,
106 WINPR_ATTR_MALLOC(free, 1)
108 FREERDP_API
char* freerdp_certificate_get_subject(const rdpCertificate* certificate);
110 WINPR_ATTR_MALLOC(free, 1)
112 FREERDP_API
char* freerdp_certificate_get_issuer(const rdpCertificate* certificate);
114 WINPR_ATTR_MALLOC(free, 1)
116 FREERDP_API
char* freerdp_certificate_get_upn(const rdpCertificate* certificate);
118 WINPR_ATTR_MALLOC(free, 1)
120 FREERDP_API
char* freerdp_certificate_get_email(const rdpCertificate* certificate);
129 WINPR_ATTR_MALLOC(free, 1)
131 FREERDP_API
char* freerdp_certificate_get_validity(const rdpCertificate* certificate,
135 FREERDP_API WINPR_MD_TYPE freerdp_certificate_get_signature_alg(const rdpCertificate* cert);
137 WINPR_ATTR_MALLOC(free, 1)
139 FREERDP_API
char* freerdp_certificate_get_common_name(const rdpCertificate* cert,
142 WINPR_ATTR_MALLOC(free, 1)
144 FREERDP_API
char** freerdp_certificate_get_dns_names(const rdpCertificate* cert,
size_t* pcount,
146 FREERDP_API
void freerdp_certificate_free_dns_names(
size_t count,
size_t* lengths,
150 FREERDP_API BOOL freerdp_certificate_check_eku(const rdpCertificate* certificate,
int nid);
153 FREERDP_API BOOL freerdp_certificate_get_public_key(const rdpCertificate* cert,
154 BYTE** PublicKey, DWORD* PublicKeyLength);
157 FREERDP_API BOOL freerdp_certificate_verify(const rdpCertificate* cert,
158 const
char* certificate_store_path);
161 FREERDP_API BOOL freerdp_certificate_is_rdp_security_compatible(const rdpCertificate* cert);
163 WINPR_ATTR_MALLOC(free, 1)
165 FREERDP_API
char* freerdp_certificate_get_param(const rdpCertificate* cert,
166 enum FREERDP_CERT_PARAM what,
size_t* psize);