2014-03-23 15:12:18 -04:00
|
|
|
# jsontools
|
|
|
|
|
2014-03-24 14:09:57 -04:00
|
|
|
Handy command line tools for dealing with json data.
|
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
To use it, add `jsontools` to the plugins array in your zshrc file:
|
2014-03-24 14:09:57 -04:00
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
```zsh
|
|
|
|
plugins=(... jsontools)
|
|
|
|
```
|
2014-03-23 15:12:18 -04:00
|
|
|
|
2014-03-26 18:47:57 -04:00
|
|
|
## Usage
|
2014-03-23 15:12:18 -04:00
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
Usage is simple... just take your json data and pipe it into the appropriate jsontool:
|
|
|
|
|
|
|
|
- `pp_json`: pretty prints json.
|
|
|
|
- `is_json`: returns true if valid json; false otherwise.
|
|
|
|
- `urlencode_json`: returns a url encoded string for the given json.
|
|
|
|
- `urldecode_json`: returns decoded json for the given url encoded string.
|
|
|
|
|
|
|
|
### Examples
|
|
|
|
|
|
|
|
- **pp_json**:
|
2014-03-24 14:09:57 -04:00
|
|
|
|
2014-03-23 15:12:18 -04:00
|
|
|
```sh
|
|
|
|
# curl json data and pretty print the results
|
|
|
|
curl https://coderwall.com/bobwilliams.json | pp_json
|
2014-03-25 16:20:25 -04:00
|
|
|
```
|
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
- **is_json**:
|
|
|
|
|
2014-03-25 16:20:25 -04:00
|
|
|
```sh
|
2020-04-26 15:55:00 +05:30
|
|
|
# Validate if file's content conforms to a valid JSON schema
|
2014-03-25 16:20:25 -04:00
|
|
|
less data.json | is_json
|
2014-03-26 18:47:57 -04:00
|
|
|
```
|
2014-03-25 16:20:25 -04:00
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
- **urlencode_json**:
|
|
|
|
|
2014-03-26 18:47:57 -04:00
|
|
|
```sh
|
2014-03-25 16:20:25 -04:00
|
|
|
# json data directly from the command line
|
2014-03-26 18:47:57 -04:00
|
|
|
echo '{"b":2, "a":1}' | urlencode_json
|
2014-03-27 10:34:54 -04:00
|
|
|
```
|
|
|
|
|
2020-03-11 19:57:46 +01:00
|
|
|
- **urldecode_json**:
|
|
|
|
|
2014-03-27 10:34:54 -04:00
|
|
|
```sh
|
|
|
|
# url encoded string to decode
|
|
|
|
echo '%7B%22b%22:2,%20%22a%22:1%7D%0A' | urldecode_json
|
2020-03-11 19:57:46 +01:00
|
|
|
```
|