An HCLI connector that can be used to expose any CLI expressed through hypertext command line interface (HCLI) semantics.
Project description
An HCLI Connector that can be used to expose a REST API with a built-in CLI, via hypertext command line interface (HCLI) semantics.
HCLI Core implements an HCLI Connector, a type of Service Connector, as a WSGI application and provides a way for developers to expose a service hosted CLI, as a REST API, via HCLI semantics. Such an API exposes a “built-in” CLI that can be interacted with dynamically with any HCLI client. Up to date, in-band, man page style API/CLI documentation is readily available for use to help understand how to interact with the API.
Most, if not all, programming languages have a way to issue shell commands. With the help of a generic HCLI client, such as Huckle [1], APIs that make use of HCLI semantics are readily consumable anywhere via the familiar command line (CLI) mode of operation, and this, without there being a need to write a custom and dedicated CLI to interact with a specific HCLI API.
You can find out more about HCLI on hcli.io [2]
The HCLI Internet-Draft [3] is a work in progress by the author and the current implementation leverages hal+json alongside a static form of ALPS (semantic profile) [4] to help enable widespread cross media-type support.
Help shape HCLI and it’s ecosystem by raising issues on github!
[1] https://github.com/cometaj2/huckle
[2] http://hcli.io
[3] https://github.com/cometaj2/I-D/tree/master/hcli
[4] http://alps.io
Installation
hcli_core requires a supported version of Python and pip.
You’ll need an WSGI compliant application server to run hcli_core. For example, you can use Green Unicorn (https://gunicorn.org/)
pip install gunicorn
Install hcli_core via pip. You can launch gunicorn from anywhere by using “hcli_core path”. You can also look at the hcli_core help file.
You can curl your new service to understand what is being exposed. The HCLI root URL, to use with an HCLI client, is the cli link relation.
Install an HCLI client, for example Huckle (https://github.com/cometaj2/huckle), and access the sample CLI (e.g. jsonf or hg) exposed by HCLI Core. You may need to restart your terminal to be able to use the sample CLI by name directly (e.g. jsonf or hg); otherwise you can attempt to source ~/.bash_profile or ~/.bashrc).
Note that no CLI is actually installed by huckle. Huckle reads the HCLI semantics dynamically and ends up behaving like the CLI it targets:
pip install hcli_core
hcli_core help
gunicorn --workers=5 --threads=2 -b 127.0.0.1:8000 --chdir `hcli_core path` "hcli_core:connector()"
curl http://127.0.0.1:8000
pip install huckle
huckle help
huckle cli install http://127.0.0.1:8000
jsonf help
If you want to load a sample HCLI other than the default sample application, you can try loading the sample hg HCLI (hypertext GPT-3.5 chatbot). A folder path to any other 3rd party HCLI can be provided in the same way:
gunicorn --workers=5 --threads=2 --chdir `hcli_core path` "hcli_core:connector(\"`hcli_core sample hg`\")"
huckle cli install http://127.0.0.1:8000
hg help
Bugs
No good handling of control over request and response in cli code which can lead to exceptions and empty response client side.
The hfm sample HCLI fails disgracefully when copying a remote file name that doesn’t exist (server error).
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 hcli_core-0.11.3.tar.gz
.
File metadata
- Download URL: hcli_core-0.11.3.tar.gz
- Upload date:
- Size: 51.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d1ccc4688874bcb3e8ab53b6fe1224f87dda6b8e2d17793f5ff5bc27043a97e3 |
|
MD5 | 2b268a3880d44002e9161d2ada946a39 |
|
BLAKE2b-256 | 216b1b267b998754e6e2b370c7698277a269c5f66941a299aa2e1428cfcb4ada |
File details
Details for the file hcli_core-0.11.3-py2.py3-none-any.whl
.
File metadata
- Download URL: hcli_core-0.11.3-py2.py3-none-any.whl
- Upload date:
- Size: 69.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e37ce6e80eb33026db0616bdc0b70b7bea00b65c094fb3af3c7b2120b0084fed |
|
MD5 | 167ce44bac1ba2570df3e49c65c1e986 |
|
BLAKE2b-256 | 2aa8693873fedd9f397e05936cb840caa0d5c09fa0ed6aa99d6c59cf89576cbe |