tuip

tuip is a CLI and TUI tool for checking public SaaS status pages.
Screenshots
Dashboard overview
Provider details
Features
- CLI and TUI workflows for ad-hoc checks, reusable dashboards, and interactive status browsing.
- Normalized status states:
operational, degraded, partial_outage, major_outage, maintenance, unknown, and error.
- Built-in provider catalog with SaaS, cloud, data, developer tools, observability, collaboration, finance, HR, and related services.
- Shareable YAML dashboards backed by stable provider IDs.
- Detailed provider output when available, including incidents, maintenance windows, components, source URLs, and update timestamps.
- No credentials required for built-in providers;
tuip only uses public status APIs/pages.
Installation
Homebrew
brew install ikan31/tap/tuip
Go
go install github.com/ikan31/tuip/cmd/tuip@latest
Make sure your Go install directory is on your PATH:
export PATH="$(go env GOPATH)/bin:$PATH"
GitHub Releases
Tagged releases publish prebuilt binaries and checksums to GitHub Releases.
From source
go run ./cmd/tuip --help
Build a local binary:
go build -o tuip ./cmd/tuip
./tuip --help
Quick start
Check a few providers:
tuip status slack github cloudflare
Open the interactive TUI:
tuip
Find providers:
tuip providers list
tuip providers search github
Create and use a dashboard:
tuip dashboard create work slack github jira asana cloudflare
tuip dashboard use work
tuip status
CLI reference
Global flags:
--config <path> overrides the config file path.
--log-level <off|debug|info|warn|error> enables diagnostics logging. It defaults to TUIP_LOG_LEVEL, then off.
tuip status
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 work
Flags:
--json writes normalized JSON for scripts.
--details includes incidents, scheduled maintenance, and components when the provider exposes them.
--dashboard <name> checks a named configured dashboard.
tuip providers
Discover built-in provider IDs.
tuip providers list
tuip providers search github eu
tuip providers search qbo
Aliases are accepted anywhere provider IDs are used.
tuip dashboard
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 work
dashboard also has the alias dashboards.
Interactive TUI
Run the TUI with no subcommand:
tuip
The TUI loads the configured default dashboard. If no default dashboard exists, it shows the virtual all dashboard with every built-in provider.
Common keys:
- Arrow keys or
h/j/k/l: move through panes and status cards.
enter: select management items, select dashboards, toggle providers, or open status details.
/: focus the dashboard filter in the status pane.
esc: leave filter/details focus without quitting.
c, r, d, s: create, rename, delete/details, or set the default dashboard.
R: force-refresh the active dashboard and bypass the cache.
ctrl+c: quit.
The TUI keeps a 60-second provider-level status cache. Error snapshots are cached for 10 seconds.
Built-in providers
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 qbo
Provider 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:
- Most providers use Atlassian Statuspage-compatible JSON (
/api/v2/summary.json).
- Some providers use PagerDuty-hosted status-page JSON (
/api/data).
- Some providers use Uptime Kuma public status-page JSON.
- Slack uses Slack's public status API for top-level status and active incidents.
Configuration
Dashboard config is YAML. Dashboard name all is reserved for tuip's virtual 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 list
Example config:
version: 1
default_dashboard: work
dashboards:
work:
services:
- provider: slack
- provider: github
- provider: jira
- provider: asana
- provider: cloudflare
Runtime 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 debug
tuip.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.
Privacy and network access
- Built-in providers do not require credentials.
tuip fetches 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.
Development
Common commands:
make fmt
make lint
go test ./...
Build locally:
make build
./bin/tuip --help
Release 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.0
Provider contribution guidance lives in CONTRIBUTING.md. Architecture and implementation notes live in docs/architecture.md.