The cState MonitorBot is a Node.js-based monitoring tool that checks the status of websites and services and creates incident reports for your Hugo/cState static site. It's designed to be self-hosted and can deploy incident reports via local file system updates, FTP, or Git.
- Multiple Check Types:
- HTTP(S) Status: Checks if websites are up and returning the expected HTTP status codes.
- SSL Certificate: Monitors SSL certificate validity and expiration dates.
- DNS Resolution: Verifies that DNS records are resolving correctly.
- Port/TCP Connectivity: Checks if specific ports on a server are reachable.
- Ping (ICMP): Measures latency and checks if hosts are reachable via ICMP echo requests.
- Flexible Deployment:
- Local: Updates incident reports directly on the local file system where your Hugo/cState site is located.
- FTP: Deploys incident reports to a remote server via FTP.
- Git: Commits and pushes incident reports to a Git repository (e.g., GitHub, GitLab).
- Test Mode: Allows you to run checks and see the results without actually creating or modifying incident files.
- Configurable: Easily configure the sites to monitor, check intervals, and other settings.
- Color-Coded Output: Uses
chalk
to provide clear and informative color-coded output in the console. - Incident Report Format: Generates incident reports in Markdown format with frontmatter for easy integration with cState.
- Extensible, e.g. for staff notifications (your own): Can act as push service for notifications if extended with custom code.
- Node.js: Version 14 or higher (recommended to use the latest LTS version).
- npm: Usually comes bundled with Node.js.
- Hugo/cState: You should have a Hugo site set up with cState installed to display the incident reports.
- Clone the repository:
git clone https://github.com/cstate/monitorbot.git
cd monitorbot
- Install dependencies:
npm install
- Environment Variables (
.env
):
Create a .env
file in the root of the project and configure the following variables based on your deployment method:
Local Deployment:
LOCAL_CSTATE_PATH=../cstate # Relative path to your Hugo/cState site
FTP Deployment:
FTP_HOST=your_ftp_host
FTP_USER=your_ftp_username
FTP_PASSWORD=your_ftp_password
FTP_REMOTE_PATH=/path/to/remote/cstate/content/issues
Git Deployment:
GIT_REMOTE=your_git_remote_url (e.g., git@github.com:user/repo.git)
GIT_BRANCH=main # Or your default branch
LOCAL_CSTATE_PATH=../cstate # Relative path to your Hugo/cState site (for Git, it's used as a working directory)
- Configuration File (
config.js
):
Modify the config.js
file to set up the sites you want to monitor and adjust other settings:
export default {
checkInterval: 60 * 1000, // Check interval in milliseconds (60 seconds)
testMode: true, // Set to false for actual deployment
deployment: {
method: 'local', // Deployment method: local, ftp, or git
},
httpMonitor: {
urls: [
{
name: "Example Site",
url: "https://www.example.com",
followRedirect: false, // Follow redirects (default: false)
expectStatus: 200, // Expected HTTP status code (default: 200)
method: 'GET', // HTTP method (default: GET)
maxRedirects: 5, // Maximum number of redirects to follow (default: 5)
},
// ... more sites
],
},
sslMonitor: {
expirationThresholdDays: 14, // Warn if expiring within 14 days
sites: [
{
name: "Example Site",
url: "https://www.example.com",
},
// ... more sites
],
},
dnsMonitor: {
sites: [
{
name: "Example Site",
url: "https://www.example.com",
dnsConfig: {
host: "example.com",
recordType: "A",
expectedValue: "93.184.216.34", // Expected IP
},
},
// ... more sites
],
},
portMonitor: {
timeout: 5000, // Timeout in milliseconds
sites: [
{
name: "Example Site",
url: "https://www.example.com",
portConfig: {
port: 80, // Port to check
},
},
// ... more sites
],
},
pingMonitor: {
timeout: 5, // Timeout in seconds
sites: [
{
name: "Example Site",
url: "https://www.example.com",
},
// ... more sites
],
},
};
- Test Mode (Dry Run):
To run the checks without creating/modifying incident files, make sure testMode
is set to true
in config.js
. Then run:
node index.js
If you edit the config.js
file, you will need to restart the script for the changes to take effect.
This will output the results of the checks to the console in a color-coded format.
- Deployment Mode (Create/Update Incidents):
- Set
testMode
tofalse
inconfig.js
. - Choose your deployment method (
local
,ftp
, orgit
) inconfig.js
. - Make sure your
.env
file is configured correctly for your chosen deployment method. - Run:
node index.js
This will perform the checks and create/update incident Markdown files in your Hugo/cState site based on the results.
The bot uses cron
to run checks periodically. The default interval is set to 60 seconds in config.js
. You can adjust the checkInterval
value or modify the cron expression in index.js
for more advanced scheduling.
Example (run every 5 minutes):
// In index.js
const job = new CronJob(
'0 */5 * * * *', // Cron expression for every 5 minutes
runChecks,
null,
true,
'America/Los_Angeles'
);
Incident reports are generated as Markdown files in the content/issues
directory of your Hugo/cState site. They use the following frontmatter:
---
title: "Incident Title"
date: 2024-01-10T12:00:00Z
resolved: false
section: issue
automated: true
severity: "down" # Or "disrupted", "notice"
affected: ["Example Site"]
id: "http-status-example-site"
---
Incident description here...
Contributions are welcome! If you find a bug or want to add a new feature, please open an issue or submit a pull request.
This project is licensed under the MIT License.