hcli-core


Namehcli-core JSON
Version 3.4.1 PyPI version JSON
download
home_pageNone
SummaryAn HCLI Connector that can be used to expose a REST API that behaves as a CLI, via hypertext command line interface (HCLI) semantics.
upload_time2025-01-14 20:38:56
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseMIT
keywords cli client server connector hypermedia rest generic development
VCS
bugtrack_url
requirements falcon portalocker huckle
Travis-CI No Travis.
coveralls test coverage No coveralls.
            |pypi| |build status| |pyver| |huckle| |hc| |hg|

HCLI Core
=========

An HCLI Connector that can be used to expose a REST API that behaves as a 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

Related HCLI Projects
---------------------

- hcli-hc, a python package for an HCLI (hc) that can act both as a gcode streamer (e.g. for OpenBuilds Blackbox controller v1.1g) and CNC interface. In other words, this HCLI acts in the same capacity as the OpenBuilds CONTROL software and OpenBuilds Interface CNC Touch hardware to help control a GRBL v1.1g controlled CNC. [5]

- hcli-hai, a python package wrapper for an HCLI (hai) that can interact with LLMs via terminal input and output streams. [6]

[5] https://github.com/cometaj2/hcli_hc

[6] https://github.com/cometaj2/hcli_hai

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/), and an
HCLI client such as Huckle (https://github.com/cometaj2/huckle). The following runs the default *jsonf* HCLI bundled with HCLI Core.


.. code-block:: console

    pip install hcli-core
    pip install gunicorn
    pip install huckle
    gunicorn --workers=1 --threads=2 -b 127.0.0.1:8000 "hcli_core:connector()"

Usage
-----

Open a different shell window.

Setup the huckle env eval in your .bash_profile (or other bash configuration) to avoid having to execute eval everytime you want to invoke HCLIs by name (e.g. jsonf).

Note that no CLI is actually installed by Huckle. Huckle reads the HCLI semantics exposed by the API and ends up behaving *like* the CLI it targets.


.. code-block:: console

    huckle cli install http://127.0.0.1:8000
    eval $(huckle env)
    jsonf help

3rd Party HCLI Installation
---------------------------

If you want to load a sample HCLI other than the default sample application, you can try loading one of the other sample HCLIs
developped independently of HCLI Core. For example, the *hai* HCLI (hypertext LLM command line chat application).

A folder path to any other 3rd party HCLI can be provided in the same way to the HCLI Connector, provided the 3rd party HCLI meets
CLI interface (cli.py) and HCLI template (template.json) requirements:

.. code-block:: console

    pip install hcli-hai
    pip install hcli-core
    pip install gunicorn
    pip install huckle
    gunicorn --workers=1 --threads=2 "hcli_core:connector(\"`hcli_hai path`\")"

3rd Party HCLI Usage
--------------------

Open a different shell window.

Setup the huckle env eval in your .bash_profile (or other bash configuration) to avoid having to execute eval everytime you want to invoke HCLIs by name (e.g. hg).

.. code-block:: console
    
    huckle cli install http://127.0.0.1:8000
    eval $(huckle env)
    hg help

Versioning
----------
    
This project makes use of semantic versioning (http://semver.org) and may make use of the "devx",
"prealphax", "alphax" "betax", and "rcx" extensions where x is a number (e.g. 0.3.0-prealpha1)
on github. Only full major.minor.patch releases will be pushed to pip from now on.

Supports
--------

- HTTP/HTTPS.
- HCLI version 1.0 server semantics for hal+json.
- Web Server Gateway Interface (WSGI) through PEP 3333 and Falcon.
- Bundled Sample HCLIs:
    - jsonf - a simple formatter for JSON.
    - hfm   - a file upload and download manager that works with \*nix terminal shell input and output streams.
    - hptt  - a rudimentary HCLI Push To Talk (PTT) channel management service.
    - hub   - a rudimentary HCLI service discovery hub.
    - nw    - a flexible IP Address Management (IPAM) service.
- Support for use of any 3rd party HCLI code that meets CLI interface requirements and HCLI template requirements (i.e. see sample HCLIs).
- Support large input and output streams as application/octet-stream.
- HTTP Basic Authentication.  See hcli_core help for details.
- HCLI Core API Key (HCOAK) Authencitation. See hcli_core help for details.
- Support HTTP API Problem Details [RFC9457] per spec to help with client-side STDERR output.
- Credentials Management via the hco HCLI.
- Centralized remote authentication support via hco for HCLI Core services configured for remote credential management.
- Serverless deployment (i.e. AWS Lambda).

Authentication
--------------

HCLI Core makes available the deployment of an HCLI Management app (hco) to manage authentication credentials for the deployed 3rd party HCLI service, and can be configured for authentication in two distinct ways:

- local - HCLI Core manages the credentials locally for the 3rd party HCLI app.
- remote - HCLI Core forwards credentials validation to a remotely hosted hco for 3rd party HCLI app access.

The remote configuration allows for centralized remote authentication support across many deployed HCLIs. This is trivially accomplished via HCLI Core making use of the huckle HCLI client, and via hco and HCLI semantics, to forward validation of provided credentials to a remotely hosted hcli_core service exposing hco. See 'hcli_core help' for details.

Security
--------

HCLI Core implements a trusted integration model. In other words, 3rd party HCLIs running via HCLI Core MUST be trusted not to interfere with HCLI Core. 3rd party HCLIs are inherently able to do anything that Python can do, and as such, a 3rd party HCLI cannot coherently be isolated from HCLI Core as a security boundary. If a trust boundary needs to be established on authentication grounds, then authentication SHOULD be managed elsewhere (i.e. by another layer on the network or via a remotely hosted hco; see Authentication).

To Do
-----

- Automated tests for all bundled HCLI samples.
- Separate out HCLI applications from HCLI Core to help avoid application dependencies bleeding onto HCLI Core.
- Rate limiting.
- Lockout on multiple failed authentications.
- Better role handling for admin vs users for remote validation.
- Better logging configuration support.
- Role assignment for hco remote validation authorization.

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).
- Routing can ambiguous and fail if the 3rd party HCLI app's name start with hco in core.root aggregate configuration (template.py owns)

.. |build status| image:: https://circleci.com/gh/cometaj2/hcli_core.svg?style=shield
   :target: https://circleci.com/gh/cometaj2/hcli_core
.. |pypi| image:: https://img.shields.io/pypi/v/hcli-core?label=hcli-core
   :target: https://pypi.org/project/hcli-core
.. |pyver| image:: https://img.shields.io/pypi/pyversions/hcli-core.svg
   :target: https://pypi.org/project/hcli-core
.. |huckle| image:: https://img.shields.io/pypi/v/huckle?label=huckle
   :target: https://pypi.org/project/huckle
.. |hc| image:: https://img.shields.io/pypi/v/hcli-hc?label=hcli-hc
   :target: https://pypi.org/project/hcli-hc
.. |hg| image:: https://img.shields.io/pypi/v/hcli-hg?label=hcli-hai
   :target: https://pypi.org/project/hcli-hai

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "hcli-core",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "cli, client, server, connector, hypermedia, rest, generic, development",
    "author": null,
    "author_email": "Jeff Michaud <cometaj2@proton.me>",
    "download_url": "https://files.pythonhosted.org/packages/77/c9/ebb98c0ba210eaca55bedf076f38f34507a5bdcdf3b8b74d2e93c15c10db/hcli_core-3.4.1.tar.gz",
    "platform": null,
    "description": "|pypi| |build status| |pyver| |huckle| |hc| |hg|\n\nHCLI Core\n=========\n\nAn HCLI Connector that can be used to expose a REST API that behaves as a CLI, via hypertext\ncommand line interface (HCLI) semantics.\n\n----\n\nHCLI Core implements an HCLI Connector, a type of Service Connector, as a WSGI application, and provides a way\nfor developers to expose a service hosted CLI, as a REST API, via HCLI semantics. Such an API exposes a \"built-in\"\nCLI that can be interacted with dynamically with any HCLI client. Up to date, in-band, man page style API/CLI\ndocumentation is readily available for use to help understand how to interact with the API.\n\nMost, if not all, programming languages have a way to issue shell commands. With the help\nof a generic HCLI client, such as Huckle [1], APIs that make use of HCLI semantics are readily consumable\nanywhere via the familiar command line (CLI) mode of operation, and this, without there being a need to write\na custom and dedicated CLI to interact with a specific HCLI API.\n\nYou can find out more about HCLI on hcli.io [2]\n\nThe HCLI Internet-Draft [3] is a work in progress by the author and \nthe current implementation leverages hal+json alongside a static form of ALPS\n(semantic profile) [4] to help enable widespread cross media-type support.\n\nHelp shape HCLI and it's ecosystem by raising issues on github!\n\n[1] https://github.com/cometaj2/huckle\n\n[2] http://hcli.io\n\n[3] https://github.com/cometaj2/I-D/tree/master/hcli\n\n[4] http://alps.io\n\nRelated HCLI Projects\n---------------------\n\n- hcli-hc, a python package for an HCLI (hc) that can act both as a gcode streamer (e.g. for OpenBuilds Blackbox controller v1.1g) and CNC interface. In other words, this HCLI acts in the same capacity as the OpenBuilds CONTROL software and OpenBuilds Interface CNC Touch hardware to help control a GRBL v1.1g controlled CNC. [5]\n\n- hcli-hai, a python package wrapper for an HCLI (hai) that can interact with LLMs via terminal input and output streams. [6]\n\n[5] https://github.com/cometaj2/hcli_hc\n\n[6] https://github.com/cometaj2/hcli_hai\n\nInstallation\n------------\n\nhcli_core requires a supported version of Python and pip.\n\nYou'll need an WSGI compliant application server to run hcli_core. For example, you can use Green Unicorn (https://gunicorn.org/), and an\nHCLI client such as Huckle (https://github.com/cometaj2/huckle). The following runs the default *jsonf* HCLI bundled with HCLI Core.\n\n\n.. code-block:: console\n\n    pip install hcli-core\n    pip install gunicorn\n    pip install huckle\n    gunicorn --workers=1 --threads=2 -b 127.0.0.1:8000 \"hcli_core:connector()\"\n\nUsage\n-----\n\nOpen a different shell window.\n\nSetup the huckle env eval in your .bash_profile (or other bash configuration) to avoid having to execute eval everytime you want to invoke HCLIs by name (e.g. jsonf).\n\nNote that no CLI is actually installed by Huckle. Huckle reads the HCLI semantics exposed by the API and ends up behaving *like* the CLI it targets.\n\n\n.. code-block:: console\n\n    huckle cli install http://127.0.0.1:8000\n    eval $(huckle env)\n    jsonf help\n\n3rd Party HCLI Installation\n---------------------------\n\nIf you want to load a sample HCLI other than the default sample application, you can try loading one of the other sample HCLIs\ndevelopped independently of HCLI Core. For example, the *hai* HCLI (hypertext LLM command line chat application).\n\nA folder path to any other 3rd party HCLI can be provided in the same way to the HCLI Connector, provided the 3rd party HCLI meets\nCLI interface (cli.py) and HCLI template (template.json) requirements:\n\n.. code-block:: console\n\n    pip install hcli-hai\n    pip install hcli-core\n    pip install gunicorn\n    pip install huckle\n    gunicorn --workers=1 --threads=2 \"hcli_core:connector(\\\"`hcli_hai path`\\\")\"\n\n3rd Party HCLI Usage\n--------------------\n\nOpen a different shell window.\n\nSetup the huckle env eval in your .bash_profile (or other bash configuration) to avoid having to execute eval everytime you want to invoke HCLIs by name (e.g. hg).\n\n.. code-block:: console\n    \n    huckle cli install http://127.0.0.1:8000\n    eval $(huckle env)\n    hg help\n\nVersioning\n----------\n    \nThis project makes use of semantic versioning (http://semver.org) and may make use of the \"devx\",\n\"prealphax\", \"alphax\" \"betax\", and \"rcx\" extensions where x is a number (e.g. 0.3.0-prealpha1)\non github. Only full major.minor.patch releases will be pushed to pip from now on.\n\nSupports\n--------\n\n- HTTP/HTTPS.\n- HCLI version 1.0 server semantics for hal+json.\n- Web Server Gateway Interface (WSGI) through PEP 3333 and Falcon.\n- Bundled Sample HCLIs:\n    - jsonf - a simple formatter for JSON.\n    - hfm   - a file upload and download manager that works with \\*nix terminal shell input and output streams.\n    - hptt  - a rudimentary HCLI Push To Talk (PTT) channel management service.\n    - hub   - a rudimentary HCLI service discovery hub.\n    - nw    - a flexible IP Address Management (IPAM) service.\n- Support for use of any 3rd party HCLI code that meets CLI interface requirements and HCLI template requirements (i.e. see sample HCLIs).\n- Support large input and output streams as application/octet-stream.\n- HTTP Basic Authentication.  See hcli_core help for details.\n- HCLI Core API Key (HCOAK) Authencitation. See hcli_core help for details.\n- Support HTTP API Problem Details [RFC9457] per spec to help with client-side STDERR output.\n- Credentials Management via the hco HCLI.\n- Centralized remote authentication support via hco for HCLI Core services configured for remote credential management.\n- Serverless deployment (i.e. AWS Lambda).\n\nAuthentication\n--------------\n\nHCLI Core makes available the deployment of an HCLI Management app (hco) to manage authentication credentials for the deployed 3rd party HCLI service, and can be configured for authentication in two distinct ways:\n\n- local - HCLI Core manages the credentials locally for the 3rd party HCLI app.\n- remote - HCLI Core forwards credentials validation to a remotely hosted hco for 3rd party HCLI app access.\n\nThe remote configuration allows for centralized remote authentication support across many deployed HCLIs. This is trivially accomplished via HCLI Core making use of the huckle HCLI client, and via hco and HCLI semantics, to forward validation of provided credentials to a remotely hosted hcli_core service exposing hco. See 'hcli_core help' for details.\n\nSecurity\n--------\n\nHCLI Core implements a trusted integration model. In other words, 3rd party HCLIs running via HCLI Core MUST be trusted not to interfere with HCLI Core. 3rd party HCLIs are inherently able to do anything that Python can do, and as such, a 3rd party HCLI cannot coherently be isolated from HCLI Core as a security boundary. If a trust boundary needs to be established on authentication grounds, then authentication SHOULD be managed elsewhere (i.e. by another layer on the network or via a remotely hosted hco; see Authentication).\n\nTo Do\n-----\n\n- Automated tests for all bundled HCLI samples.\n- Separate out HCLI applications from HCLI Core to help avoid application dependencies bleeding onto HCLI Core.\n- Rate limiting.\n- Lockout on multiple failed authentications.\n- Better role handling for admin vs users for remote validation.\n- Better logging configuration support.\n- Role assignment for hco remote validation authorization.\n\nBugs\n----\n\n- No good handling of control over request and response in cli code which can lead to exceptions and empty response client side.\n- The hfm sample HCLI fails disgracefully when copying a remote file name that doesn't exist (server error).\n- Routing can ambiguous and fail if the 3rd party HCLI app's name start with hco in core.root aggregate configuration (template.py owns)\n\n.. |build status| image:: https://circleci.com/gh/cometaj2/hcli_core.svg?style=shield\n   :target: https://circleci.com/gh/cometaj2/hcli_core\n.. |pypi| image:: https://img.shields.io/pypi/v/hcli-core?label=hcli-core\n   :target: https://pypi.org/project/hcli-core\n.. |pyver| image:: https://img.shields.io/pypi/pyversions/hcli-core.svg\n   :target: https://pypi.org/project/hcli-core\n.. |huckle| image:: https://img.shields.io/pypi/v/huckle?label=huckle\n   :target: https://pypi.org/project/huckle\n.. |hc| image:: https://img.shields.io/pypi/v/hcli-hc?label=hcli-hc\n   :target: https://pypi.org/project/hcli-hc\n.. |hg| image:: https://img.shields.io/pypi/v/hcli-hg?label=hcli-hai\n   :target: https://pypi.org/project/hcli-hai\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "An HCLI Connector that can be used to expose a REST API that behaves as a CLI, via hypertext command line interface (HCLI) semantics.",
    "version": "3.4.1",
    "project_urls": {
        "Homepage": "https://github.com/cometaj2/hcli_core"
    },
    "split_keywords": [
        "cli",
        " client",
        " server",
        " connector",
        " hypermedia",
        " rest",
        " generic",
        " development"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "36573fc3815983754ed3d7b55cfed7746386c2d475c77d277d1f7dbfb6e1f187",
                "md5": "48ebeda963e34cdce09eeeb14ec6fdc2",
                "sha256": "f9c93cf52ac14972d41fc1ca3398e3847cfc4e78f9071360a154209ebecb1675"
            },
            "downloads": -1,
            "filename": "hcli_core-3.4.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "48ebeda963e34cdce09eeeb14ec6fdc2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 58816,
            "upload_time": "2025-01-14T20:38:53",
            "upload_time_iso_8601": "2025-01-14T20:38:53.837038Z",
            "url": "https://files.pythonhosted.org/packages/36/57/3fc3815983754ed3d7b55cfed7746386c2d475c77d277d1f7dbfb6e1f187/hcli_core-3.4.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "77c9ebb98c0ba210eaca55bedf076f38f34507a5bdcdf3b8b74d2e93c15c10db",
                "md5": "f2b5f9de93e80bb411335f466d97203b",
                "sha256": "f544f4ca536903ef52676986c75768e0c9f2709395c1fb23b465c5493dc713a3"
            },
            "downloads": -1,
            "filename": "hcli_core-3.4.1.tar.gz",
            "has_sig": false,
            "md5_digest": "f2b5f9de93e80bb411335f466d97203b",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 47209,
            "upload_time": "2025-01-14T20:38:56",
            "upload_time_iso_8601": "2025-01-14T20:38:56.374639Z",
            "url": "https://files.pythonhosted.org/packages/77/c9/ebb98c0ba210eaca55bedf076f38f34507a5bdcdf3b8b74d2e93c15c10db/hcli_core-3.4.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-14 20:38:56",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "cometaj2",
    "github_project": "hcli_core",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "circle": true,
    "requirements": [
        {
            "name": "falcon",
            "specs": [
                [
                    "==",
                    "4.0.2"
                ]
            ]
        },
        {
            "name": "portalocker",
            "specs": [
                [
                    "==",
                    "2.10.1"
                ]
            ]
        },
        {
            "name": "huckle",
            "specs": [
                [
                    "==",
                    "5.5.0"
                ]
            ]
        }
    ],
    "lcname": "hcli-core"
}
        
Elapsed time: 3.07487s