A python based tool to check that a given resource (URL, Certificate and DNS entry) is alive and valid.
Project description
kenkou
======
健康 - kenkou - health
A python based tool to check that a given resource is alive and valid.
It can check on URLs, Certificates and also DNS entries.
All redirects are followed and once the final URL is discovered it is tested for a 2XX result. If a 2XX is returned it is also scanned for mixed-content items if the url is HTTPS. Certificates are verified for any HTTPS site.
Currently it assumes port 443 for TLS and also that the given domain resolves to an IP address.
Designed to be run from a cronjob as often as you want to check the sites.
Note: Kenkou will check to see if the [Certifi](https://certifi.io/en/latest/) Python package is installed, and if so, it will use the CA Bundle from that. If not it will check to see if ```/etc/ssl/certs/ca-certificates.crt``` exists. If neither is found it will exit with an error if a certificate check was requested.
Usage
-----
```
python kenkou.py [-c|--config FILENAME]
Where:
-c --config Configuration file (json format)
The output is a based on the value of the "onevent" configuration key:
"json" (default if not present)
"pagerduty"
"postageapp"
```
Requirements
------------
See requirements.txt for details about what Python modules to install.
Configuration
-------------
Example kenkou.cfg file:
```json
{ "pagerduty": {
"url": "https://events.pagerduty.com/generic/2010-04-15/create_event.json",
"method": "POST",
"params": { "service_key": "secret",
"incident_key": "incident_secret",
"event_type": "trigger",
"description": "FAILURE for production/HTTP"
}
},
"postageapp": {
"api_key": "secret",
"recipients": [ "email@example.com" ]
},
"onevent": [ "postageapp" ],
"checks": "kenkou_check.cfg"
}
```
kenkou_check.cfg:
```json
{ "web": { "url": "https://example.com",
"dns": [ "example.com", "127.0.0.1",
[ "ns1.dnsimple.com", "ns2.dnsimple.com" ]
],
"cert": "example.com"
},
"lb": { "url": "http://lb.example.com",
"dns": [ "lb.example.com", "127.0.0.1",
[ "ns1.dnsimple.com", "ns2.dnsimple.com" ]
],
"cert": "lb.example.com"
}
}
```
======
健康 - kenkou - health
A python based tool to check that a given resource is alive and valid.
It can check on URLs, Certificates and also DNS entries.
All redirects are followed and once the final URL is discovered it is tested for a 2XX result. If a 2XX is returned it is also scanned for mixed-content items if the url is HTTPS. Certificates are verified for any HTTPS site.
Currently it assumes port 443 for TLS and also that the given domain resolves to an IP address.
Designed to be run from a cronjob as often as you want to check the sites.
Note: Kenkou will check to see if the [Certifi](https://certifi.io/en/latest/) Python package is installed, and if so, it will use the CA Bundle from that. If not it will check to see if ```/etc/ssl/certs/ca-certificates.crt``` exists. If neither is found it will exit with an error if a certificate check was requested.
Usage
-----
```
python kenkou.py [-c|--config FILENAME]
Where:
-c --config Configuration file (json format)
The output is a based on the value of the "onevent" configuration key:
"json" (default if not present)
"pagerduty"
"postageapp"
```
Requirements
------------
See requirements.txt for details about what Python modules to install.
Configuration
-------------
Example kenkou.cfg file:
```json
{ "pagerduty": {
"url": "https://events.pagerduty.com/generic/2010-04-15/create_event.json",
"method": "POST",
"params": { "service_key": "secret",
"incident_key": "incident_secret",
"event_type": "trigger",
"description": "FAILURE for production/HTTP"
}
},
"postageapp": {
"api_key": "secret",
"recipients": [ "email@example.com" ]
},
"onevent": [ "postageapp" ],
"checks": "kenkou_check.cfg"
}
```
kenkou_check.cfg:
```json
{ "web": { "url": "https://example.com",
"dns": [ "example.com", "127.0.0.1",
[ "ns1.dnsimple.com", "ns2.dnsimple.com" ]
],
"cert": "example.com"
},
"lb": { "url": "http://lb.example.com",
"dns": [ "lb.example.com", "127.0.0.1",
[ "ns1.dnsimple.com", "ns2.dnsimple.com" ]
],
"cert": "lb.example.com"
}
}
```
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
kenkou-0.5.4.tar.gz
(9.6 kB
view details)
Built Distribution
kenkou-0.5.4-py2-none-any.whl
(14.1 kB
view details)
File details
Details for the file kenkou-0.5.4.tar.gz
.
File metadata
- Download URL: kenkou-0.5.4.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2345810af428ec7a318d4f99a38b7c4aeac261ab39d6c0df72d9b4930712ed04 |
|
MD5 | 32b53473aadd0655b9d10107871fb6d5 |
|
BLAKE2b-256 | 02cc39f360cd7c3dcde715cdbd2f88f1c0ecfac2b39b149c6e48788c3a04a56f |
File details
Details for the file kenkou-0.5.4-py2-none-any.whl
.
File metadata
- Download URL: kenkou-0.5.4-py2-none-any.whl
- Upload date:
- Size: 14.1 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4a300f3e276fdc83a0adf3ddf421b90d608bbea9d3faf8ff09b61aefdadc63e7 |
|
MD5 | 27dbef16c83054efa58add6c8b920fc2 |
|
BLAKE2b-256 | 6fb020c8286e2be84cec0508e9837806c4abaa979a2afc37e35aa47a6d593afa |