Skip to content

Latest commit

 

History

History

docs

Restish Logo

Works With Restish User Guide CI codecov Docs Go Report Card GitHub Likes

Restish is a CLI for interacting with REST-ish HTTP APIs with some nice features built-in, like always having the latest API resources, fields, and operations available when they go live on the API without needing to install or update anything.

Why use this?

Every API deserves a CLI for quick access and for power users to script against the service. Building CLIs from scratch is a pain. Restish provides one tool your users can install that just works for multiple APIs and is always up to date, because the interface is defined by the server. See how it compares to cURL and HTTPie.

Getting started

Start with the guide to learn how to install and configure Restish as well as getting an overview of all of its features.

Features

  • HTTP/2 (RFC 7540) with TLS by default with fallback to HTTP/1.1
  • Generic HEAD/GET/POST/PUT/PATCH/DELETE verbs like curl or HTTPie
  • Generated commands for CLI operations, e.g. restish my-api list-users
    • Automatically discovers API descriptions
    • Supported formats
    • Automatic configuration of API auth if advertised by the API
    • Shell command completion for Bash, Fish, Zsh, Powershell
  • Automatic pagination of resource collections via RFC 5988 prev and next hypermedia links
  • API endpoint-based auth built-in with support for profiles:
    • HTTP Basic
    • API key via header or query param
    • OAuth2 client credentials flow (machine-to-machine, RFC 6749)
    • OAuth2 authorization code (with PKCE RFC 7636) flow
  • Content negotiation, decoding & unmarshalling built-in:
  • Automatic retries with support for Retry-After and X-Retry-In headers when APIs are rate-limited.
  • Standardized hypermedia parsing into queryable/followable response links:
  • Local caching that respects RFC 7234 Cache-Control and Expires headers
  • Client-side bulk resource management (like git for API resources)
  • CLI shorthand for structured data input (e.g. for JSON)
  • Shorthand query response filtering & projection
  • Colorized prettified readable output
  • Fast native zero-dependency binary

Articles