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 3.5-3.7 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 hfm. A folder path to any 3rd party HCLI module can be provided in the same way:

$ gunicorn –workers=5 –threads=2 –chdir `hcli_core path` “hcli_core:HCLI("`hcli_core sample hfm`").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

$ 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

This version

0.2.1

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.2.1.tar.gz (13.2 kB view details)

Uploaded Source

File details

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

File metadata

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

File hashes

Hashes for hcli_core-0.2.1.tar.gz
Algorithm Hash digest
SHA256 d6f827f0462fa7f3f124cc84ae505d4908a625226307a2d28ec45f2dc2ac17b9
MD5 196d7672dfda9e91cc1c89a3160d2f7c
BLAKE2b-256 6c5e69af3582e906ad416c994586245de3e0e8bf5b4395b0d2941c83129626a2

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