Hermes cURL is a lightweight wrapper on top of cURL that provides reusable HTTP request configurations in YAML.
Project description
Hermes cURL
Hermes cURL is a lightweight wrapper on top of cURL that provides reusable HTTP request configurations in YAML. Configuration files can import attributes from other files which allows for common settings such as hostnames and authentication headers to be shared by multiple cURL calls.
Usage
Set up a base configuration for an entire API:
# api_base.yml
headers:
Authorization: Token MySecretAPIToken
Content-Type: application/json
host: localhost:5000
curl_flags:
"--location":
Set up a configuration for a specific endpoint and import our the base settings:
# api.yml
from: api_base.yml
method: PUT
path: /my/api
body: >
{"hello": "world"}
Run the hermes
command:
$ hermes api.yml
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 128 100 112 100 16 3960 565 --:--:-- --:--:-- --:--:-- 4000
{
"msg": "hello Mr world"
}
See examples for a working example.
Installation
python3 -m pip install hermes-curl
Configuration file reference
Options
from
(optional): specify a path to another configuration file to inherit configurations from. This path is relative to the current file.path
(requires): path on the server to send the request to, including any query params.method
(required): HTTP method to use.host
(required): server host, including protocol and port.headers
(optional): dictionary of headers in the form. ExHeader: value
.body
(optional): request body.curl_flags
(optional): a dictionary with any other curl flags to add. Ex"--cacert: certfile"
.template_defaults
(optional): a dictionary of default template variables.
Config Inheritance
Configurations are merged in the following fashion:
- Dictionaries are merged. Values set in child configs having precedence and override any values from the parent configuration.
path
is concatenated, so settingpath: /foo/
in the parent andpath: /bar/
in the child will result inpath: /foo/bar/
- All other top level configurations use whatever value is set in the child configuration.
This includes
method
,body
, andhost
.
Template Variables
Configurations can contain variables using the {variable_name}
syntax. Variables can
be passed into the configuration by either setting -t variable_name=value
on the cli
or by setting template_defaults
in the configuration. Values passed on the cli have
precedence over values set in template_defaults.
Example
Running hermes -t pk=2 example.yml
will GET http://localhost/api/thing/2/
and running
hermes example.yml
will GET http://localhost/api/thing/1/
host: http://localhost/
path: api/thing/{pk}/
method: GET
template_defaults:
pk: 1
Example
Template variables can also be used via environment variables. This will inject the TOKEN
environment variable into the Token
header.
headers:
Content-Type: application/json
Authorization: "Token {env[TOKEN]}"
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file hermes_curl-1.0.8.tar.gz
.
File metadata
- Download URL: hermes_curl-1.0.8.tar.gz
- Upload date:
- Size: 4.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 706f9c51fd5ccda729f89edfc2d84cd1c8c1984123703445308d19dfddc06966 |
|
MD5 | f64f2b83b327be35df44dce42abcc422 |
|
BLAKE2b-256 | 046ca34f247324aeb1c5af871d9e9ce52345a51f4fa259ec3e43e7b1b92069dc |
File details
Details for the file hermes_curl-1.0.8-py3-none-any.whl
.
File metadata
- Download URL: hermes_curl-1.0.8-py3-none-any.whl
- Upload date:
- Size: 4.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1ffb3e835f185a9b98f87a0c3595fb6b70260bedb1b4199230183c83ec4702c0 |
|
MD5 | 13c69b5191b1309d5eef3167e114c166 |
|
BLAKE2b-256 | 579ad85bfbe612a4456fec0859f2c431345f5a0bc4b7173c842cdcfb8f04fdff |