9 releases (4 breaking)
new 0.15.0 | May 1, 2024 |
---|---|
0.14.0 | Apr 23, 2024 |
0.13.0 | Apr 18, 2024 |
0.12.0 | Apr 17, 2024 |
0.11.3 | Apr 15, 2024 |
#102 in Web programming
865 downloads per month
4.5MB
6.5K
SLoC
ATAC βπ©
Table Of Contents
- Description
- How to install
- Features
- Documentation
- Technical precisions
- Contributors
- Star history
- License
Description
ATAC is Arguably a Terminal API Client. It is based on well-known clients such as Postman, Insomnia, or even Bruno, but inside your terminal without any specific graphical environment needed.
The philosophy of ATAC is to be free, account-less, and offline for now and forever.
How to install
Install with cargo
[!IMPORTANT] First, make sure your rust version is at least 1.76
Simply use:
cargo install atac
Install from Arch
You can use pacman to install:
pacman -S atac
Install with Homebrew
Simply use:
brew tap julien-cpsn/atac
brew install atac
Install from Fedora copr
Simply use:
dnf enable joxcat/atac
dnf install atac
Binary
The binaries from the latest release can be found here
[!IMPORTANT] Remember to run it from a terminal. For example, you can add the binary into your PATH. You won't be able to run it like other graphical applications since it needs CLI arguments.
[!TIP] Note for macOS users. After downloading the binary you may need to run the command
sudo xattr -rd com.apple.quarantine ~/bin/atac
(modify to reflect the path whereatac
is located).
Compile by yourself
[!IMPORTANT] First, make sure your rust version is at least 1.76
Simply clone the repository and use:
cargo run
cargo run -- -h
[!TIP] Build the latest release
cargo build --release
Features
Current
Features | ATAC | Postman | Insomnia |
---|---|---|---|
Manage collections & requests | β | β | β |
HTTP Client | β | β | β |
Methods | β | β | β |
- GET | β | β | β |
- POST | β | β | β |
- PUT | β | β | β |
- PATCH | β | β | β |
- DELETE | β | β | β |
- HEAD | β | β | β |
- OPTIONS | β | β | β |
Authentication | Partial | β | β |
- Basic auth | β | β | β |
- Bearer token | β | β | β |
- JWT, Digest, OAuth1-2, AWS | β π | β | β |
Headers | β | β | β |
Body | β | β | β |
- Multipart form | β | β | β |
- URL Encoded form | β | β | β |
- File | β | β | β |
- Plain text | β | β | β |
- JSON, XML, HTML, Javascript | β | β | β |
Full response | β | β | β |
- Status code | β | β | β |
- Cookies | β | β | β |
- Headers | β | β | β |
- Duration | β | β | β |
Scripting | β π | Partial | β |
- Pre-request script | β π | β | β |
- Post-request script | β π | β | β |
Asynchronous requests | β | β | β |
Per-request settings | β | β | β |
- Use proxy | β | β | β |
- Allow redirects | β | β | β |
- Store cookies | β | β | β |
WebSocket Client | β π | β | β |
GraphQL | β π | β | β |
gRPC | β π | β | β |
MQTT | β π | β | β |
Free | β | Depends | Depends |
Lightweight, fast and efficient | β | β | β |
Data storage | Your own committable, readable and versioned files | Tied to your account | Tied to your account |
Offline | β | β | β |
Real-time collaboration | β (not planned) | β | β |
Environment files and variables | β (committable, readable and versioned) | β | β |
View options | β | β | β |
Global configuration file | β | β | β |
- HTTP/HTTPS Proxy | β | β | β |
- Disable CORS | β | β | β |
- Toggle syntax highlighting | β | β | β |
Postman v2.1.0 import | β | β | β |
OpenAPI import | β π | β | β |
TODO v1.0.0
-
To add
- Create a repo wiki
- Document whole code
- Copy response content to clipboard
-
To improve
- Sign binary
-
To fix
- Query parameters bug
TODO v2.0.0
-
To add
- Command line usage (send requests, add new requests)
- Request body syntax highlighting
- Export a request to other code formats (curl, PHP, JS, Rust, ...)
- Pre and post-request script (javascript v8 engine)
- OpenAPI & Insomnia import
-
To improve
- Editing cookies
- Auto-completion on env file variables
- Manage multipart Content-type header (auto-generated for now)
TODO v3.0.0
- To add
- WebSocket requests
- Maybe GraphQL requests
- Maybe MQTT requests
- Maybe gRPC requests
Ideas (will think about it later)
- Base URL property on collections
- YAML support for collections file format
Documentation
[!NOTE] Documentation will soon be published in the wiki section
Technical precisions
Tested on
- Console Host
- Windows 11 (Pro)
- WSL2 Debian
- Windows 10 (Pro)
- Windows 8.1 (N)
- Ubuntu Desktop Terminal
- Ubuntu 17.10
- Pop!_OS 20.04
- (Arch, Manjaro) KDE Konsole
- (Arch, NixOS) Kitty
- Linux Mint
- (OpenSuse) Alacritty
- (Chrome OS) Crostini
(List from here)
Dependencies
Library | Version | Reason |
---|---|---|
reqwest & reqwest cookie store | 0.11.27 & 0.6.0 | Send requests |
ratatui | 0.26.2 | Terminal UI framework |
crossterm | 0.27.0 | Terminal Backend |
crokey | 0.6.4 | Used to parse, use key bindings files and some utilities |
tui-big-text | 0.4.2 | Display big texts. Only used for displaying ATAC in the homepage. |
tui-tree-widget | 0.19.0 | Display tree-like lists. Used for displaying the collections. |
tui-textarea | 0.5.0 | Text area that handle a lot of features. Used for editing request body. |
throbber-widgets-tui | 0.4.1 | Display loading UI elements. Used when request is pending. |
syntect | 5.2.0 | Syntax highlighting |
serde & serde_json | 1.0.197 & 1.0.144 | Serialize & Deserialize application data into JSON files |
jsonxf | 0.1.1 | Pretty print JSON |
toml | 0.8.11 | Serialize & Deserialize application config files |
envfile | 0.2.1 | Deserialize application environment files |
My fork of postman_collection | 0.2.1 | Deserialize Postman collection files |
clap | 4.5.0 | Command Line Argument Parser |
arboard | 3.3.2 | Copy response body to clipboard |
tokio | 1.0.0 | Handle asynchronous requests |
strum | 0.26.2 | Enum facilities |
lazy_static | 1.4.0 | Allows for more flexible constants. Mainly used for accessing CLI arguments everywhere |
nestify | 0.3.3 | Used to nest struct definitions |
regex | 1.10.3 | Regex. Using for parsing requests URL |
Binary size
The binary file size goes from ~4.5 MB to ~7 MB depending on the platform. I try to keep it as small as possible.
Contributors
Maintainers
Packagers
- Cargo, Brew - @julien-cpsn
- Arch - @orhun
- Fedora copr - @joxcat
Star history
License
The MIT license for this project can be seen here
Dependencies
~23β42MB
~720K SLoC