tuip is a CLI and TUI tool for checking public SaaS status pages.
- CLI and TUI workflows for ad-hoc checks, reusable dashboards, and interactive status browsing
- Normalized status states
- Built-in provider catalog
- Shareable YAML dashboards
- Detailed provider output
- No credentials required
brew install ikan31/tap/tuipgo install github.com/ikan31/tuip/cmd/tuip@latestMake sure your Go install directory is on your PATH:
export PATH="$(go env GOPATH)/bin:$PATH"Tagged releases publish prebuilt binaries and checksums to GitHub Releases.
go run ./cmd/tuip --helpBuild a local binary:
go build -o tuip ./cmd/tuip
./tuip --helpCheck a few providers:
tuip status slack github cloudflareOpen the interactive TUI:
tuipFind providers:
tuip providers list
tuip providers search githubCreate and use a dashboard:
tuip dashboard create work slack github jira asana cloudflare
tuip dashboard use work
tuip statusGlobal flags:
--config <path>overrides the config file path.--log-level <off|debug|info|warn|error>enables diagnostics logging. It defaults toTUIP_LOG_LEVEL, thenoff.
Fetch provider statuses.
tuip status [provider...]With no provider IDs, tuip status checks the configured default dashboard.
Examples:
tuip status slack github cloudflare
tuip status --details cloudflare
tuip status --json github jira asana
tuip status --dashboard workFlags:
--jsonwrites normalized JSON for scripts.--detailsincludes incidents, scheduled maintenance, and components when the provider exposes them.--dashboard <name>checks a named configured dashboard.
Discover built-in provider IDs.
tuip providers list
tuip providers search github eu
tuip providers search qboAliases are accepted anywhere provider IDs are used.
Manage YAML dashboards.
tuip dashboard create work slack github cloudflare
tuip dashboard add work jira asana
tuip dashboard remove work github
tuip dashboard use work
tuip dashboard list
tuip dashboard show workdashboard also has the alias dashboards.
Run the TUI with no subcommand:
tuipThe TUI loads the configured default dashboard. If no default dashboard exists, it shows the all dashboard with every built-in provider.
The TUI keeps a 60-second provider-level status cache. Error snapshots are cached for 10 seconds.
tuip ships with more than 180 built-in providers. Use the CLI as the source of truth for the current catalog:
tuip providers list
tuip providers search github
tuip providers search qboProvider IDs are stable and intended for dashboard config. Aliases are accepted in CLI commands and dashboard config; for example, qbo resolves to quickbooks-online, and ghec-eu resolves to github-enterprise-cloud-eu.
Provider source notes:
- Atlassian Statuspage-compatible JSON
/api/v2/summary.json
- PagerDuty-hosted status-page JSON
/api/data
- Uptime Kuma public status-page JSON
/api/status-page/{provider}
- Custom public APIs when a provider needs provider-specific handling
Dashboard config is YAML. Dashboard name all is reserved for tuip's dashboard containing every built-in provider.
Default location on macOS/Linux:
~/.config/tuip/config.yaml
If XDG_CONFIG_HOME is set, tuip uses:
$XDG_CONFIG_HOME/tuip/config.yaml
Windows uses the native OS user config directory.
Override the config path:
tuip --config ./tuip.yaml dashboard listExample config:
version: 1
default_dashboard: work
dashboards:
work:
services:
- provider: slack
- provider: github
- provider: jira
- provider: asana
- provider: cloudflareRuntime files live beside the configured config file:
~/.config/tuip/
config.yaml
logs/tuip.jsonl
cache/status-cache.json
Diagnostics are off by default. Enable them with either:
TUIP_LOG_LEVEL=debug tuip
# or
tuip --log-level debugtuip.jsonl is rotated when it reaches 5MB. tuip keeps up to three older files as tuip.1.jsonl, tuip.2.jsonl, and tuip.3.jsonl. Each log line includes a run_id, pid, and version.
- Built-in providers do not require credentials.
tuipfetches public status APIs/pages only for the providers you check.- Dashboard config, status cache, and diagnostics logs are written locally under the configured config directory.
- Diagnostics logs are disabled by default. When enabled, they include provider IDs, timing, cache, retry, and error information for troubleshooting.
Common commands:
make fmt
make lint
go test ./...Build locally:
make build
./bin/tuip --helpRelease builds are produced by GoReleaser when a v* tag is pushed:
git tag -a v1.0.0 -m "tuip v1.0.0"
git push origin v1.0.0Architecture and implementation notes live in docs/architecture.md.