-
-
Notifications
You must be signed in to change notification settings - Fork 132
/
Copy pathcheck_ssl_cert.1
574 lines (566 loc) · 15.8 KB
/
check_ssl_cert.1
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
.\" Process this file with
.\" groff -man -Tascii check_ssl_cert.1
.\"
.TH "check_ssl_cert" 1 "January, 2025" "2.85.1" "USER COMMANDS"
.SH NAME
check_ssl_cert \- checks the validity of X.509 certificates
.SH SYNOPSIS
.BR "check_ssl_cert " "-H host [OPTIONS]"
.br
.BR "check_ssl_cert " "-f file [OPTIONS]"
.SH DESCRIPTION
.B check_ssl_cert
A shell script (that can be used as a Nagios/Icinga plugin) to check an SSL/TLS connection
.SH ARGUMENTS
.TP
.BR "-f,--file" " file"
Local file path or URI. With -f you can not only pass a x509 certificate file but also a certificate revocation list (CRL) to check the validity period or a Java KeyStore file
.TP
.BR "-H,--host" " host"
server
.SH OPTIONS
.TP
.BR "-A,--noauth"
Ignore authority warnings (expiration only)
.TP
.BR " --all"
Enable all the possible optional checks at the maximum level
.TP
.BR " --all-local"
Enable all the possible optional checks at the maximum level (without SSL-Labs)
.TP
.BR " --allow-empty-san"
Allow certificates without Subject Alternative Names (SANs)
.TP
.BR "-C,--clientcert" " path"
Use client certificate to authenticate
.TP
.BR "-c,--critical" " days"
Minimum number of days a certificate has to be valid to issue a critical status. Can be a floating point number, e.g., 0.5. Default: 15
.TP
.BR " --check-chain"
The certificate chain cannot contain double or root certificates
.TP
.BR " --check-ciphers" " grade"
Check the offered ciphers
.TP
.BR " --check-ciphers-warnings"
Critical if nmap reports a warning for an offered cipher
.TP
.BR " --check-http-headers"
Check the HTTP headers for best practices
.TP
.BR " --check-ssl-labs-warn grade"
SSL Labs grade on which to warn
.TP
.BR " --clientpass" " phrase"
Set passphrase for client certificate.
.TP
.BR " --configuration" " file"
Read options from the specified file
.TP
.BR " --crl"
Check revocation via CRL (requires --rootcert-file)
.TP
.BR " --curl-bin" " path"
Path of the curl binary to be used
.TP
.BR " --custom-http-header" " string"
Custom HTTP header sent when getting the cert example: 'X-Check-Ssl-Cert: Foobar=1'
.TP
.BR " --dane"
Verify that valid DANE records exist (since OpenSSL 1.1.0)
.TP
.BR " --dane 211"
Verify that a valid DANE-TA(2) SPKI(1) SHA2-256(1) TLSA record exists
.TP
.BR " --dane 301"
Verify that a valid DANE-EE(3) Cert(0) SHA2-256(1) TLSA record exists
.TP
.BR " --dane 302"
Verify that a valid DANE-EE(3) Cert(0) SHA2-512(2) TLSA record exists
.TP
.BR " --dane 311"
Verify that a valid DANE-EE(3) SPKI(1) SHA2-256(1) TLSA record exists
.TP
.BR " --dane 312"
Verify that a valid DANE-EE(3) SPKI(1) SHA2-512(1) TLSA record exists
.TP
.BR " --date" " path"
Path of the date binary to be used
.TP
.BR "-d,--debug"
Produce debugging output (can be specified more than once)
.TP
.BR " --debug-cert"
Store the retrieved certificates in the current directory
.TP
.BR " --debug-file" " file"
Write the debug messages to file
.TP
.BR " --debug-headers"
Store the retrieved HTLM headers in the headers.txt file
.TP
.BR " --debug-time"
Write timing information in the debugging output
.TP
.BR " --default-format"
Print the default output format and exit
.TP
.BR " --dig-bin" " path"
Path of the dig binary to be used
.TP
.BR " --do-not-resolve"
Do not check if the host can be resolved
.TP
.BR " --dtls"
Use the DTLS protocol
.TP
.BR " --dtls1"
Use the DTLS protocol 1.0
.TP
.BR " --dtls1_2"
Use the DTLS protocol 1.2
.TP
.BR "-e,--email" " address"
Pattern (extended regular expression) to match the email address contained in the certificate. You can specify different addresses separated by a pipe (e.g., 'addr1|addr2')
.TP
.BR " --ecdsa"
Signature algorithm selection: force ECDSA certificate
.TP
.BR " --element" " number"
Check up to the N cert element from the beginning of the chain
.TP
.BR " --file-bin" " path"
Path of the file binary to be used
.TP
.BR " --fingerprint" " hash"
Pattern to match the fingerprint
.TP
.BR " --fingerprint-alg" " algorithm"
Algorithm for fingerprint. Default sha1
.TP
.BR " --first-element-only"
Verify just the first cert element, not the whole chain
.TP
.BR " --force-dconv-date"
Force the usage of dconv for date computations
.TP
.BR " --force-perl-date"
Force the usage of Perl for date computations
.TP
.BR " --format" " FORMAT"
Format output template on success, for example: '%SHORTNAME% OK %CN% from %CA_ISSUER_MATCHED%'
.br
List of possible variables:
.br
- %CA_ISSUER_MATCHED%
.br
- %CHECKEDNAMES%
.br
- %CN%
.br
- %DATE%
.br
- %DAYS_VALID%
.br
- %DYSPLAY_CN%
.br
- %HOST%
.br
- %OCSP_EXPIRES_IN_HOURS%
.br
- %OPENSSL_COMMAND%
.br
- %PORT%
.br
- %SELFSIGNEDCERT%
.br
- %SHORTNAME%
.br
- %SIGALGO%
.br
- %SSL_LABS_HOST_GRADE%
.br
See --default-format for the default
.TP
.BR " --grep-bin" " path"
Path of the grep binary to be used
.TP
.BR "-h,--help,-?"
This help message
.TP
.BR " --http-headers-path" " path"
The path to be used to fetch HTTP headers
.TP
.BR " --http-use-get"
Use GET instead of HEAD (default) for the HTTP related checks
.TP
.BR "-i,--issuer" " issuer"
Pattern (extended regular expression) to match the issuer of the certificate. You can specify different issuers separated by a pipe (e.g., 'issuer1|issuer2')
.TP
.BR " --ignore-altnames"
Ignore alternative names when matching pattern specified in -n (or the host name)
.TP
.BR " --ignore-connection-problems" " [state]"
In case of connection problems returns OK or the optional state
.TP
.BR " --ignore-exp"
Ignore expiration date
.TP
.BR " --ignore-http-headers"
Ignore checks on HTTP headers with --all and --all-local
.TP
.BR " --ignore-host-cn"
Do not complain if the CN does not match the host name
.TP
.BR " --ignore-incomplete-chain"
Do not check chain integrity
.TP
.BR " --ignore-maximum-validity"
Ignore the certificate maximum validity
.TP
.BR " --ignore-ocsp"
Do not check revocation with OCSP
.TP
.BR " --ignore-ocsp-errors"
Continue if the OCSP status cannot be checked
.TP
.BR " --ignore-ocsp-timeout"
Ignore OCSP result when timeout occurs while checking
.TP
.BR " --ignore-sct"
Do not check for signed certificate timestamps (SCT)
.TP
.BR " --ignore-sig-alg"
Do not check if the certificate was signed with SHA1 or MD5
.TP
.BR " --ignore-ssl-labs-cache"
Force a new check by SSL Labs (see -L)
.TP
.BR " --ignore-ssl-labs-errors"
Ignore errors if SSL Labs is not accessible or times out
.TP
.BR " --ignore-tls-renegotiation"
Ignore the TLS renegotiation check
.TP
.BR " --ignore-unexpected-eof"
Ignore unclean TLS shutdowns
.TP
.BR " --inetproto protocol"
Force IP version 4 or 6
.TP
.BR " --info"
Print certificate information
.TP
.BR " --init-host-cache"
Initialize the host cache
.TP
.BR " --issuer-cert-cache" " dir"
Directory where to store issuer certificates cache
.TP
.BR " --jks-alias" " alias"
Alias name of the Java KeyStore entry (requires --file)
.TP
.BR "-K,--clientkey" " path"
Use client certificate key to authenticate
.TP
.BR "-L,--check-ssl-labs grade"
SSL Labs assessment (please check https://www.ssllabs.com/about/terms.html). Critical if the grade is lower than specified.
.TP
.BR " --long-output" " list"
Append the specified comma separated (no spaces) list of attributes to the plugin output on additional lines.
Valid attributes are: enddate, startdate, subject, issuer, modulus, serial, hash, email, ocsp_uri and fingerprint. 'all' will include all the available attributes.
.TP
.BR "-m,--match" " name"
Pattern to match the CN or AltName (can be specified multiple times)
.TP
.BR " --maximum-validity" " [days]"
The maximum validity of the certificate must not exceed 'days' (default 397). This check is automatic for HTTPS
.TP
.BR " --nmap-bin" " path"
Path of the nmap binary to be used
.TP
.BR " --nmap-with-proxy"
Allow nmap to be used with a proxy
.TP
.BR " --no-perf"
Do not show performance data
.TP
.BR " --no-proxy"
Ignore the http_proxy and https_proxy environment variables
.TP
.BR " --no-proxy-curl"
Ignore the http_proxy and https_proxy environment variables for curl
.TP
.BR " --no-proxy-s_client"
Ignore the http_proxy and https_proxy environment variables for openssl s_client
.TP
.BR " --no-ssl2"
Disable SSL version 2
.TP
.BR " --no-ssl3"
Disable SSL version 3
.TP
.BR " --no-tls1"
Disable TLS version 1
.TP
.BR " --no-tls1_1"
Disable TLS version 1.1
.TP
.BR " --no-tls1_3"
Disable TLS version 1.3
.TP
.BR " --no-tls1_2"
Disable TLS version 1.2
.TP
.BR " --not-issued-by" " issuer"
Check that the issuer of the certificate does not match the given pattern
.TP
.BR " --not-valid-longer-than" " days"
Critical if the certificate validity is longer than the specified period
.TP
.BR "-o,--org" " org"
Pattern to match the organization of the certificate
.TP
.BR " --ocsp-critical" " hours"
Minimum number of hours an OCSP response has to be valid to issue a critical status
.TP
.BR " --ocsp-warning" " hours"
Minimum number of hours an OCSP response has to be valid to issue a warning status
.TP
.BR " --openssl" " path"
Path of the openssl binary to be used
.TP
.BR "-p,--port" " port"
TCP port (default 443)
.TP
.BR "--precision" " digits"
Number of decimal places for durations: defaults to 0 if critical or warning are integers, 2 otherwise
.TP
.BR "-P,--protocol" " protocol"
Use the specific protocol: dns, ftp, ftps, http, https (default), h2 (HTTP/2), h3 (HTTP/3), imap, imaps, irc, ircs, ldap, ldaps, mqtts, mysql, pop3, pop3s, postgres, sieve, sips, smtp, smtps, tds, xmpp, xmpp-server. ftp, imap, irc, ldap, pop3, postgres, sieve, smtp: switch to TLS using StartTLS.
.BR
These protocols switch to TLS using StartTLS: ftp, imap, irc, ldap, mysql, pop3, smtp.
.TP
.BR " --path" " path"
Set the PATH variable to 'path'
.TP
.BR " --password" " source"
Password source for a local certificate, see the PASS PHRASE ARGUMENTS section openssl(1)
.TP
.BR " --prometheus"
Generate Prometheus/OpenMetrics output
.TP
.BR " --proxy" " proxy"
Set http_proxy and the s_client -proxy option
.TP
.BR " --python-bin" " path"
Path of the python binary to be used
.TP
.BR " --quic"
Use QUIC
.TP
.BR "-q,--quiet"
Do not produce any output
.TP
.BR "-r,--rootcert" " cert"
Root certificate or directory to be used for certificate validation (passed to openssl's -CAfile or -CApath)
.TP
.BR " --require-client-cert" " [list]"
The server must accept a client certificate. 'list' is an optional comma separated list of expected client certificate CAs
.TP
.BR " --require-dnssec"
Require DNSSEC
.TP
.BR " --require-http-header" " header"
Require the specified HTTP header (e.g., strict-transport-security)
.TP
.BR " --require-no-http-header" " header"
Require the absence of the specified HTTP header (e.g., X-Powered-By)
.TP
.BR " --require-no-ssl2"
Critical if SSL version 2 is offered
.TP
.BR " --require-no-ssl3"
Critical if SSL version 3 is offered
.TP
.BR " --require-no-tls1"
Critical if TLS 1 is offered
.TP
.BR " --require-no-tls1_1"
Critical if TLS 1.1 is offered
.TP
.BR " --require-ocsp-stapling"
Require OCSP stapling
.TP
.BR " --require-purpose" " usage"
Require the specified key usage (can be specified more then once)
.TP
.BR " --require-purpose-critical"
The key usage must be critical
.TP
.BR " --require-security-header" " header"
Require the specified HTTP security header (e.g., X-Frame-Options)
.TP
.BR " --require-security-headers"
Require all the HTTP security headers:
Content-Security-Policy
Permissions-Policy
Referrer-Policy
strict-transport-security
X-Content-Type-Options
X-Frame-Options
.TP
.BR " --resolve" " ip"
Provide a custom IP address for the specified host
.TP
.BR " --resolve-over-http" " [server]"
Resolve the host over HTTP using Google or the specified server
.TP
.BR " --rootcert-dir" " dir"
Root directory to be used for certificate validation (passed to openssl's -CApath)
overrides option -r,--rootcert
.TP
.BR " --rootcert-file" " cert"
Root certificate to be used for certificate validation (passed to openssl's -CAfile)
overrides option -r,--rootcert
.TP
.BR " --rsa"
Signature algorithm selection: force RSA certificate
.TP
.BR " --security-level" " number"
Set the security level to specified value. See SSL_CTX_set_security_level(3) for a description of what each level means
.TP
.BR "-s,--selfsigned"
Allow self-signed certificates
.TP
.BR " --serial" " serialnum"
Pattern to match the serial number
.TP
.BR "--skip-element" " number"
Skip checks on the Nth cert element (can be specified multiple times)
.TP
.BR " --sni" " name"
Set the TLS SNI (Server Name Indication) extension in the ClientHello message to 'name'
.TP
.BR " --ssl2"
Force SSL version 2
.TP
.BR " --ssl3"
Force SSL version 3
.TP
.BR "-t,--timeout" " seconds"
Timeout after the specified time (defaults to 120 seconds)
.TP
.BR " --temp" " dir"
Directory where to store the temporary files
.TP
.BR " --terse"
Terse output (also see --verbose)
.TP
.BR " --tls1"
Force TLS version 1
.TP
.BR " --tls1_1"
Force TLS version 1.1
.TP
.BR " --tls1_2"
Force TLS version 1.2
.TP
.BR " --tls1_3"
Force TLS version 1.3
.TP
.BR "-u,--url" " URL"
HTTP request URL
.TP
.BR " --user-agent" " string"
User agent that shall be used for HTTPS connections
.TP
.BR "-v,--verbose"
Verbose output (can be specified more than once)
.TP
.BR "-V,--version"
Version
.TP
.BR "-w,--warning" " days"
Minimum number of days a certificate has to be valid to issue a warning status. Might be a floating point number, e.g., 0.5. Default: 20
.TP
.BR " --xmpphost" " name"
Specify the host for the 'to' attribute of the stream element
.TP
.BR "-4"
Force IPv4
.TP
.BR "-6"
Force IPv6
.SH DEPRECATED OPTIONS
.TP
.BR " --altnames"
Match the pattern specified in -n with alternate names too (enabled by default)
.TP
.BR "-n,--cn" " name"
Pattern to match the CN or AltName (can be specified multiple times)
.TP
.BR " --curl-user-agent" " string"
User agent that curl shall use to obtain the issuer cert
.TP
.BR "-d,--days" " days"
Minimum number of days a certificate has to be valid (see --critical and --warning)
.TP
.BR "-N,--host-cn"
Match CN with the host name (enabled by default)
.TP
.BR " --no_ssl2"
Disable SSLv2 (deprecated use --no-ssl2)
.TP
.BR " --no_ssl3"
Disable SSLv3 (deprecated use --no-ssl3)
.TP
.BR " --no_tls1"
Disable TLSv1 (deprecated use --no-tls1)
.TP
.BR " --no_tls1_1"
Disable TLSv1.1 (deprecated use --no-tls1_1)
.TP
.BR " --no_tls1_2"
Disable TLSv1.1 (deprecated use --no-tls1_2)
.TP
.BR " --no_tls1_3"
Disable TLSv1.1 (deprecated use --no-tls1_3)
.TP
.BR " --ocsp"
Check revocation via OCSP (enabled by default)
.TP
.BR " --require-hsts"
Require HTTP Strict Transport Security (deprecated use --require-security-header strict-transport-security)
.TP
.BR " --require-security-headers-path" " path"
the path to be used to fetch HTTP security headers
.TP
.BR " --require-san"
Require the presence of a Subject Alternative Name extension
.TP
.BR " --require-x-frame-options [path]"
Require the presence of the X-Frame-Options HTTP header. 'path' is the optional path to be used in the URL to check for the header (deprecated use --require-security-header X-Frame-Options and --require-security-headers-path path)
.TP
.BR "-S,--ssl" " version"
Force SSL version (2,3) (see: --ssl2 or --ssl3)
.SH CONFIGURATION
Command line options can be specified in a configuration file (${HOME}/.check_ssl_certrc). For example
$ cat ${HOME}/.check_ssl_certrc
--verbose
--critical 20
--warning 40
Options specified in the configuration file are read before processing the arguments and can be overridden.
.SH NOTES
If the host has multiple certificates and the installed openssl version supports the -servername option it is possible to specify the TLS SNI (Server Name Identificator) with the -N (or --host-cn) option.
.SH "EXIT STATUS"
check_ssl_cert returns a zero exist status if it finds no errors, 1 for warnings, 2 for a critical errors and 3 for unknown problems
.SH BUGS
Please report bugs to:
https://github.com/matteocorti/check_ssl_cert/issues
.SH "EXAMPLE"
check_ssl_cert --host github.com --all-local
.SH "SEE ALSO"
openssl(1), openssl-x509(1)