-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnsscommon.h
98 lines (78 loc) · 3.22 KB
/
nsscommon.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#ifndef NSS_COMMON_H
#define NSS_COMMON_H 1
/* Used for parameters with default C++ values which are also called from C */
#if defined(c_plusplus) || defined(__cplusplus)
#define INIT(v,i) v = (i)
#else
#define INIT(v,i) v
#endif
/* These functions are called from both C and C++. */
#if defined(c_plusplus) || defined(__cplusplus)
extern "C" {
#endif
#include <pk11func.h>
#include <nss.h>
#include "config.h"
#if ENABLE_NLS
#include <libintl.h>
#include <locale.h>
#endif
#if ENABLE_NLS
#define _(string) gettext(string)
#define _N(string, string_plural, count) \
ngettext((string), (string_plural), (count))
#else
#define _(string) (string)
#define _N(string, string_plural, count) \
( (count) == 1 ? (string) : (string_plural) )
#endif
#define _F(format, ...) autosprintf(_(format), __VA_ARGS__)
#define _NF(format, format_plural, count, ...) \
autosprintf(_N((format), (format_plural), (count)), __VA_ARGS__)
char *nssPasswordCallback (PK11SlotInfo *info __attribute ((unused)),
PRBool retry __attribute ((unused)),
void *arg __attribute ((unused)));
SECStatus nssInit (const char *db_path, INIT (int readWrite, 0), INIT (int issueMessage, 1));
NSSInitContext * nssInitContext (const char *db_path, INIT (int readWrite, 0), INIT (int issueMessage, 1));
void nssCleanup (const char *db_path, NSSInitContext *context);
void nsscommon_error (const char *msg, INIT(int logit, 1));
void nssError (void);
PRInt32 PR_Read_Complete (PRFileDesc *fd, void *buf, PRInt32 requestedBytes);
#if defined(c_plusplus) || defined(__cplusplus)
}
#endif
#if defined(c_plusplus) || defined(__cplusplus)
/* These functions are only called from C++ */
#include <string>
const char *server_cert_nickname ();
std::string server_cert_db_path ();
std::string local_client_cert_db_path ();
std::string add_cert_db_prefix (const std::string &db_path);
void nsscommon_error (const std::string &msg, int logit = 1);
void start_log (const char *arg, bool redirect_clog = false);
bool log_ok ();
void log (const std::string &msg);
void end_log ();
bool get_host_name (CERTCertificate *c, std::string &host_name);
#ifdef HAVE_HTTP_SUPPORT
bool cvt_nss_to_pem (CERTCertificate *c, std::string &cert_pem);
bool get_pem_cert (const std::string &db_path, const std::string &nss_cert_name, const std::string &host, std::string &cert);
bool have_san_match (std::string & hostname, std::string & server_cert);
#endif
int check_cert (const std::string &db_path, const std::string &nss_cert_name, bool use_db_password = false);
int gen_cert_db (const std::string &db_path, const std::string &extraDnsNames, bool use_password);
typedef enum {db_no_nssinit, db_nssinitcontext, db_nssinit} db_init_types;
SECStatus add_client_cert (const std::string &inFileName, const std::string &db_path, db_init_types db_init_type);
void sign_file (
const std::string &db_path,
const std::string &nss_cert_name,
const std::string &inputName,
const std::string &outputName
);
CERTCertList *get_cert_list_from_db (const std::string &cert_nickname);
SECStatus
read_cert_info_from_file (const std::string &certPath,
std::string &fingerprint);
#endif // defined(c_plusplus) || defined(__cplusplus)
#endif // NSS_COMMON_H
/* vim: set sw=2 ts=8 cino=>4,n-2,{2,^-2,t0,(0,u0,w1,M1 : */