tuip is a CLI and TUI tool for checking public SaaS status pages.
Features
- 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
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
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:
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 toTUIP_LOG_LEVEL, thenoff.
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:
--jsonwrites normalized JSON for scripts.--detailsincludes 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:
The 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.
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:
- 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}
- Public RSS feeds with provider-specific active incident parsing
- AWS, Azure, Docker
- Custom public APIs when a provider needs provider-specific handling
- Google Cloud, Slack
Configuration
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 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 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.
Privacy and network access
- 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.
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.0Architecture and implementation notes live in docs/architecture.md.
























