Skip to content

Commit

Permalink
Add docs for command-based querying
Browse files Browse the repository at this point in the history
  • Loading branch information
LucasPickering committed Jan 2, 2025
1 parent 6f0e524 commit 890c5aa
Show file tree
Hide file tree
Showing 17 changed files with 104 additions and 30 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ Slumber is a TUI (terminal user interface) HTTP client. Define, execute, and sha
- Source-first configuration, for easy persistence and sharing
- [Import from external formats (e.g. Insomnia)](https://slumber.lucaspickering.me/book/user_guide/import.html)
- [Build requests dynamically from other requests, files, and shell commands](https://slumber.lucaspickering.me/book/user_guide/templates.html)
- [Browse response data using JSONPath selectors](https://slumber.lucaspickering.me/book/user_guide/filter_query.html)
- [Browse response data using JSONPath selectors](https://slumber.lucaspickering.me/book/user_guide/tui/filter_query.html)
- Switch between different environments easily using [profiles](https://slumber.lucaspickering.me/book/api/request_collection/profile.html)
- And more!

Expand Down
7 changes: 4 additions & 3 deletions docs/src/SUMMARY.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,12 @@
- [Key Concepts](./user_guide/key_concepts.md)
- [Terminal User Interface (TUI)](./user_guide/tui/index.md)
- [In-App Editing & File Viewing](./user_guide/tui/editor.md)
- [Data Filtering & Querying](./user_guide/tui/filter_query.md)
- [Command Line Interface (CLI)](./user_guide/cli.md)
- [Templates](./user_guide/templates.md)
- [Chains - Complex Template Values](./user_guide/chains.md)
- [Templates](./user_guide/templates/index.md)
- [Chains - Complex Template Values](./user_guide/templates/chains.md)
- [Data Extraction via JSONPath](./user_guide/templates/selector.md)
- [Collection Reuse & Inheritance](./user_guide/inheritance.md)
- [Data Filtering & Querying](./user_guide/filter_query.md)
- [Importing External Collections](./user_guide/import.md)

# CLI Commands
Expand Down
4 changes: 2 additions & 2 deletions docs/src/api/configuration/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,15 +40,15 @@ The following fields are available in `config.yml`:

**Default:** `[sh, -c]` (Unix), `[cmd, /S, /C]` (Windows)

Shell used to execute commands within the TUI. [More info](#commands)
Shell used to execute commands within the TUI. Use `[]` for no shell (commands will be parsed and executed directly). [More info](../../user_guide/tui/filter_query.md)

### `commands.query_default`

**Type:** `string`

**Default:** `""`

Default query command for all responses. [More info](#commands)
Default query command for all responses. [More info](../../user_guide/tui/filter_query.md)

### `debug`

Expand Down
2 changes: 1 addition & 1 deletion docs/src/api/request_collection/chain.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ To use a chain in a template, reference it as `{{chains.<id>}}`.
| --------------- | -------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------- |
| `source` | [`ChainSource`](./chain_source.md) | Source of the chained value | Required |
| `sensitive` | `boolean` | Should the value be hidden in the UI? | `false` |
| `selector` | [`JSONPath`](https://www.ietf.org/archive/id/draft-goessner-dispatch-jsonpath-00.html) | Selector to transform/narrow down results in a chained value. See [Filtering & Querying](../../user_guide/filter_query.md) | `null` |
| `selector` | [`JSONPath`](https://www.ietf.org/archive/id/draft-goessner-dispatch-jsonpath-00.html) | Selector to transform/narrow down results in a chained value. See [Data Extraction via JSONPath](../../user_guide/templates/selector.md) | `null` |
| `selector_mode` | [`SelectorMode`](#selector-mode) | Control selector behavior when query returns multiple results | `auto` |
| `content_type` | `string` | Force content type. Not required for `request` and `file` chains, as long as the `Content-Type` header/file extension matches the data. See [here](./content_type.md) for a list of supported types. | |
| `trim` | [`ChainOutputTrim`](#chain-output-trim) | Trim whitespace from the rendered output | `none` |
Expand Down
2 changes: 1 addition & 1 deletion docs/src/api/request_collection/content_type.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Content Type

Content type defines the various data formats that Slumber recognizes and can manipulate. Slumber is capable of displaying any text-based data format, but only specific formats support additional features such as [querying](../../user_guide/filter_query.md) and formatting.
Content type defines the various data formats that Slumber recognizes and can manipulate. Slumber is capable of displaying any text-based data format, but only specific formats support additional features such as [querying](../../user_guide/tui/filter_query.md) and formatting.

## Auto-detection

Expand Down
Binary file removed docs/src/images/query.gif
Binary file not shown.
Binary file added docs/src/images/query_error.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/src/images/query_jq.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/src/images/query_pipe.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ requests:
authentication: !bearer "{{chains.auth_token}}"
```
> For more info on the `selector` field, see [Data Filtering & Querying](./filter_query.md)
> For more info on the `selector` field, see [Data Extraction via JSONPath](./selector.md)

### Automatically Executing the Upstream Request

Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,12 +1,6 @@
# Data Filtering & Querying
# Data Extraction via JSONPath

Slumber supports querying data structures to transform or reduce response data.

There are two main use cases for querying:

- In [chained template values](../api/request_collection/chain.md), to extract data
- Provided via chain's `selector` argument
- In the TUI response body browser, to limit the response data shown
[Chains](./chains.md) support querying data structures to transform or reduce response data. THis is done via the `selector` field of a chain.

**Regardless of data format, querying is done via [JSONPath](https://www.ietf.org/archive/id/draft-goessner-dispatch-jsonpath-00.html).** For non-JSON formats, the data will be converted to JSON, queried, and converted back. This keeps querying simple and uniform across data types.

Expand Down Expand Up @@ -99,9 +93,3 @@ requests:
```

You can use this capability to manipulate responses via `grep`, `awk`, or any other program you like.

## Querying Response in TUI

You can visually query a response body using the filter box at the bottom:

![Querying response via JSONPath](../images/query.gif)
32 changes: 32 additions & 0 deletions docs/src/user_guide/tui/filter_query.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# Data Filtering & Querying

When browsing an HTTP response in Slumber, you may want to filter, query, or otherwise transform the response to make it easier to view. Slumber supports this via embedded shell commands. The query box at the bottom of the response pane allows you to execute any shell command, which will be passed the response body via stdin and its output will be shown in the response pane. You can use `grep`, `jq`, `sed`, or any other text processing tool.

![Querying response via jq](../../images/query_jq.gif)

_Example of querying with jq_

![Querying response with pipes](../../images/query_pipe.gif)

_Example of using pipes in a query command_

## Side Effects

Keep in mind that your queries are being executed as shell commands on your system. You should avoid running any commands that interact with the file system, such as using `>` or `<` to pipe to/from files. TODO add more about side-effect commands once implemented

## Errors

We can't all be perfect. Sometimes you run a command that fails. To view the error, press `?` (make sure you exit the text box first!).

![View query error](../../images/query_error.gif)

## Which shell does Slumber use?

By default, Slumber executes your command via `sh -c` on Unix and `cmd /S /C` on Windows. You can customize this via the [`commands.shell` configuration field](../../api/configuration/index.md#commandsshell). For example, to use `fish` instead of `sh`:

```yaml
commands:
shell: [fish, -c]
```
If you don't want to execute via _any_ shell, you can set it to `[]`. In this case, query commands will be parsed via [shell-words](https://docs.rs/shell-words/latest/shell_words/) and executed directly. For example, `jq .args` will be parsed into `["jq", ".args"]`, then `jq` will be executed with a single argument: `.args`.
7 changes: 2 additions & 5 deletions gifs.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,18 +35,15 @@ def generate_all(tapes: list[str]) -> None:
tapes = get_tapes()
print(f"Generating GIFs for: {tapes}")

print("Deleting data/")
shutil.rmtree("data/")

run(["cargo", "build"])
for tape in tapes:
generate(tape)
print("Don't forget to check all GIFs before pushing!")


def generate(tape: str) -> None:
gif = get_gif_path(tape)
print(f"Generating {tape} -> {gif}")
print("Deleting data/")
shutil.rmtree("data/")
run(["vhs", tape])


Expand Down
29 changes: 29 additions & 0 deletions tapes/query_error.tape
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
Output "docs/src/images/query_error.gif"
Set Shell bash
Set Width 1200
Set Height 800
Set FontSize 18
Set Framerate 24
Set Margin 0
Set Padding 10
Set Theme "MaterialDark"

Hide
Type "cargo run"
Enter
Sleep 2s

Enter # Send login request
Type "hunter2"
Enter
Sleep 2s
Type "rf" # Fullscreen response pane
Show

Type "/"
Sleep 1s
Type "jq error!"
Enter
Sleep 1s
Type "?"
Sleep 3s
5 changes: 3 additions & 2 deletions tapes/query.tape → tapes/query_jq.tape
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
Output "docs/src/images/query.gif"
Output "docs/src/images/query_jq.gif"
Set Shell bash
Set Width 1200
Set Height 800
Expand All @@ -12,6 +12,7 @@ Hide
Type "cargo run"
Enter
Sleep 2s

Enter # Send login request
Type "hunter2"
Enter
Expand All @@ -22,7 +23,7 @@ Show
Sleep 1s
Type "/"
Sleep 1s
Type "$.args"
Type "jq .args"
Sleep 2s
Type ".fast"
Sleep 2s
26 changes: 26 additions & 0 deletions tapes/query_pipe.tape
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
Output "docs/src/images/query_pipe.gif"
Set Shell bash
Set Width 1200
Set Height 800
Set FontSize 18
Set Framerate 24
Set Margin 0
Set Padding 10
Set Theme "MaterialDark"

Hide
Type "cargo run"
Enter
Sleep 2s

Enter # Send login request
Type "hunter2"
Enter
Sleep 2s
Type "rf" # Fullscreen response pane
Show

Type "/"
Sleep 1s
Type "jq .args | head -n 3"
Sleep 2s

0 comments on commit 890c5aa

Please sign in to comment.