Skip to main content

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 any CLI via hypertext command line interface (HCLI) semantics.


HCLI Core implements the Service Connector pattern as a WSGI application and provides a way for developers to expose a CLI via HCLI semantics which yields dynamic and up to date in-band access to man page style API/CLI documentation.

Most, if not all, programming languages have a way to issue shell commands. With the help of any generic HCLI client, such as Huckle, 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.

The HCLI Internet-Draft [1] is a work in progress by the author and the current implementation leverages hal+json alongside a static form of ALPS (semantic profile) [2] to help enable widespread cross media-type support.

You can find out more about HCLI on hcli.io [3]

Help shape HCLI and it’s ecosystem on the discussion list [4] or by raising issues on github!

[1] https://github.com/cometaj2/I-D/tree/master/hcli

[2] http://alps.io

[3] https://hcli.io

[4] https://groups.google.com/forum/#!forum/huck-hypermedia-unified-cli-with-a-kick

Installation

hcli_core requires Python 2.7, 3.4-3.6 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

Download the hcli_core wherever you want it to be installed and navigate into the hcli_core folder. For example:

$ cd /home/foma/hcli_core/hcli_core

$ gunicorn –workers=5 –threads=2 “hcli_core:HCLI().connector”

Alternatively, if you 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:

$ pip install hcli_core

$ hcli_core help

$ gunicorn –workers=5 –threads=2 –chdir `hcli_core path` “hcli_core:HCLI().connector”

If you want to load a sample HCLI other than the default, you can try loading the sample hub. A folder path to any HCLI module can be provided in the same way:

$ gunicorn –workers=5 –threads=2 –chdir `hcli_core path` “hcli_core:HCLI("`hcli_core sample hub`").connector”

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:

$ curl http://127.0.0.1:8000

Install an HCLI client, for example Huckle (https://github.com/cometaj2/huckle), and access the default sample jsonf CLI exposed by HCLI Core (you may need to restart your terminal to be able to use jsonf by name directly):

$ pip install huckle

$ huckle cli install http://127.0.0.1:8000/hcli/cli/jsonf?command=jsonf

$ jsonf help

You can also look at the huckle help file:

$ huckle help

Bugs

  • No good handling of control over request and response in cli code which can lead to exceptions and empty response client side.

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

hcli_core-0.1.2.tar.gz (16.6 kB view details)

Uploaded Source

File details

Details for the file hcli_core-0.1.2.tar.gz.

File metadata

  • Download URL: hcli_core-0.1.2.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/36.0.1 requests-toolbelt/0.8.0 tqdm/4.14.0 CPython/2.7.13

File hashes

Hashes for hcli_core-0.1.2.tar.gz
Algorithm Hash digest
SHA256 a8e1ab0a967a9bfe3dca71e29ca3c62b2b044e8d513ca30efa9c73c971301a99
MD5 68c63c3a1dfeb3477d81cd5e6b44e303
BLAKE2b-256 e2d0c3c36a80bdfcab43d43543c2da39cb6a3c28bc7bf4dfeaf028e1464207a3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page