Jan Dittberner
16e8cb41fe
- Update dependency versions to those of Debian Buster - link to bug tracker - fix minor formatting issues
101 lines
3.8 KiB
Markdown
101 lines
3.8 KiB
Markdown
# `check_xmppng` - check plugin for XMPP
|
|
|
|
This program implements a nagios check plugin for XMPP servers implementing the
|
|
XMPP protocol as specified in [RFC 6120](http://tools.ietf.org/html/rfc6120).
|
|
|
|
The program implements the following features:
|
|
|
|
* check client to server (C2S) as well as server to server (S2S) ports
|
|
* check XMPP servers on IPv6 and IPv4 addresses
|
|
* support STARTTLS as specified in RFC 6120 section 5.
|
|
* check the validity of the server certificate presented by the XMPP server
|
|
|
|
The plugin has been implemented because of insufficiencies in `check_ssl_cert`
|
|
and the existing
|
|
[`check_xmpp`](https://exchange.icinga.org/exchange/check_xmpp).
|
|
|
|
Maximum acceptable timeouts as well as minimum acceptable number of days the
|
|
server certificate needs to be valid can be specified as command line
|
|
parameters. For a full list of parameters see the *Usage* section below.
|
|
|
|
|
|
## Dependencies
|
|
|
|
The program is implemented in Python 3 and uses the following libraries besides
|
|
the Python standard library:
|
|
|
|
* [defusedxml](https://pypi.python.org/pypi/defusedxml/) to sanitize XML from
|
|
the XMPP server
|
|
* [nagiosplugin](https://pypi.python.org/pypi/nagiosplugin) to take care of the
|
|
nagios plugin interface boilerplate code
|
|
|
|
The software has been developed and tested with the following versions:
|
|
|
|
* Python 3.7.3
|
|
* defusedxml 0.5.0
|
|
* nagiosplugin 1.2.4
|
|
|
|
|
|
## License
|
|
|
|
`check_xmppng` is free software: you can redistribute it and/or modify it under
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
Foundation, either version 3 of the License, or (at your option) any later
|
|
version.
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
this program in the file `COPYING`. If not, see
|
|
http://www.gnu.org/licenses/.
|
|
|
|
|
|
## Usage
|
|
|
|
```
|
|
usage: check_xmppng [-h] -H HOST_ADDRESS [-p PORT] [--s2s | --c2s] [-4 | -6]
|
|
[--servername SERVERNAME] [--starttls] [-w SECONDS]
|
|
[-c SECONDS] [--no-check-certificates] [-r CAROOTS]
|
|
[--warn-days WARNDAYS] [--crit-days CRITDAYS] [-v]
|
|
|
|
Check XMPP services
|
|
|
|
optional arguments:
|
|
-h, --help show this help message and exit
|
|
-H HOST_ADDRESS, --host-address HOST_ADDRESS
|
|
host address
|
|
-p PORT, --port PORT port
|
|
--s2s server to server (s2s)
|
|
--c2s client to server (c2s)
|
|
-4, --ipv4 enforce IPv4
|
|
-6, --ipv6 enforce IPv6
|
|
--servername SERVERNAME
|
|
server name to be used
|
|
--starttls check whether the service allows starttls
|
|
-w SECONDS, --warning SECONDS
|
|
return warning if connection setup takes longer than
|
|
SECONDS
|
|
-c SECONDS, --critical SECONDS
|
|
return critical if connection setup takes longer than
|
|
SECONDS
|
|
--no-check-certificates
|
|
do not check whether the XMPP server's certificate is
|
|
valid
|
|
-r CAROOTS, --ca-roots CAROOTS
|
|
path to a file or directory where CA certifcates can
|
|
be found
|
|
--warn-days WARNDAYS set state to WARN if the certificate is valid for not
|
|
more than the given number of days
|
|
--crit-days CRITDAYS set state to CRITICAL if the certificate is valid for
|
|
not more than the given number of days
|
|
-v, --verbose
|
|
```
|
|
|
|
|
|
## Contact
|
|
|
|
If you want to provide feedback or bug reports please use the [bug
|
|
tracker](https://git.dittberner.info/jan/check_xmppng/issues) or send me an
|
|
email to jan (at) dittberner [dot] info.
|