connchk

About

connchk is command-line network verification utility written in Rust. It aims to provide a cross platform utility that can verify if your host can reach targets defined in a TOML document. These hosts are checked in the following ways:

The application expects exactly one argument which is the TOML document defining target hosts.

Starting in version 0.5.0, it is also possible to use connchk as a Rust library. Documentation is available here.

Install

To get connchk run cargo install connchk on a system with Cargo installed.

Example TOML Config

```toml

example.toml

[[tcp]] desc = "GitLab SSH" addr = "gitlab.com:22"

[[tcp]] desc = "Freenode IRC" addr = "irc.freenode.net:6667"

[[http]] desc = "httpbin IP endpoint" addr = "https://httpbin.org/ip"

Posts as a form and reports success if the status code returned is 400

which it will be for this bad request to this particular endpoint

[[http]] desc = "httpbin POST endpoint (form)" addr = "https://httpbin.org/status/undefined" custom = { params = { someKey = "SpecialValue" }, ok = 400 }

Posts as JSON and reports success if the status code returned is 400

as it will be for this particular endpoint

[[http]] desc = "httpbin JSON endpoint" addr = "https://httpbin.org/status/400" custom = { json = { someKey = "SpecialValue" }, ok = 400 }

An example failure - this endpoint will return a 502 status code,

but our configuration expects a 400

[[http]] desc = "httpbin JSON endpoint - Error" addr = "https://httpbin.org/status/502" custom = { json = { someKey = [3, "AnotherValue", false], anotherKey = { nested = "value", count = [1, 2, 3] } }, ok = 400 } ```

Example Usage

$ ./connchk example.toml Successfully connected to GitLab SSH Successfully connected to Freenode IRC Successfully connected to httpbin POST endpoint (form) Successfully connected to httpbin IP endpoint Successfully connected to httpbin JSON endpoint Failed to connect to httpbin JSON endpoint - Error with: Status: 502 Details:

JSON Bodies

The TOML structure of the configuration file maps on to JSON cleanly. Defining JSON bodies should be as easy as custom = { json = <Your JSON Here> }. While this was tested to a reasonable degree it's unlikely that every single possibility has been explored, so if issues are encountered please let it be known.

Major Changes

License

This project uses GPL-3.0+.

Copyright (C) 2020-2021 Anthony Martinez