forked from jfillmore/rest-cli
jasimmk/rest-cli
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
usage: rest-cli http-verb|command API [API_PARAMS] [ARGUMENTS] ARGUMENTS --------------------------------------------------------------------------- HTTP OPTIONS (each may be specified multiple times) -F, --file FILE File to add to request. -Q, --query QUERY_DATA Query data to include (e.g. foo=bar&food=yummy). -P, --post POST_DATA Extra POST data to add to request. -H, --header HEADER HTTP header (e.g. 'Foo: bar') . OTHER OPTIONS (may also be set via 'set' command) -q, --quiet Do not print API return response. -r, --raw Don't format response data; return raw response. -v, --verbose Print verbose debugging info to stderr. -i, --invert Invert colors in formatted JSON responses. -C, --no-color Do not color formatted JSON responses. -h, --help This information. -u, --url URL URL to the API location (default: https://localhost/). -j, --json STRING Append JSON-encoded list to API parameters. -s, --shell Shell mode for running multiple APIs within a session. -O, --oauth CK CS T TS Authenticate via OAuth using the supplied consumer key, secret, token, and token secret. -x, --extract PATH Parse JSON to only return requested data; may be repeated. -X, --exclude PATH Exclude specified path from JSON data; may be repeated. API PARAMS --------------------------------------------------------------------------- Dictionaries can be created on demand using dot notation. Multiple params within the same dictionary will merge together. Values are always encoded as strings unless ":=" is used to assign the value. foo {"foo": true} !foo {"foo": false} foo=bar {"foo": "bar"} foo.bar=3 foo.bard=abc {"foo": {"bar": "3", "bard": "abc"}} foo:='{"bar":3}' {"foo": {"bar": 3}} foo.bar:=3.14 {"foo": {"bar": 3.14}} JSON PATHS --------------------------------------------------------------------------- The JSON data can be filtered based on index, key matches, ranges, etc. Arrays: By Index: - 'foo/0', 'foo/2', 'foo/-1' (last item) By Range: - 'foo/:' or 'foo/*' (all items within the array), - 'foo/2:', 'foo/:2', 'foo/1:5', 'foo/-2:' (last 2), - 'foo/:-2' (all but last two), - 'foo/1:-3' (between first and up until 3rd to last) Dictionaries: Regular Expressions: - 'foo/b..?r' = foo/bar, foo/beer - 'foo/bar/.*[pP]assw(or)?d' == anything within foo/bar that looks like a password SHELL COMMANDS --------------------------------------------------------------------------- cd Change the base URL (e.g. "cd customers/8; cd ../9"). help This information. quit Adios! (quit shell). set Set configuration options. config List current configuration infomation. sh CMD Run a BASH shell command. > FILE Write API response to specified file. >> FILE Append API response to specified file. EXAMPLES: --------------------------------------------------------------------------- rest-cli -u https://foo.com/api -s > get site/foo.com -v > post site -j domain=foo.com > cd site/foo.com > get ./
About
RESTful API client shell with using a bash-like syntax
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published
Languages
- Python 100.0%