Metadata-Version: 2.4
Name: gway
Version: 0.1.44
Summary: Software Project Infrastructure by https://www.gelectriic.com
Author-email: "Rafael J. Guillén-Osorio" <tecnologia@gelectriic.com>
License-Expression: MIT
Project-URL: Repository, https://github.com/arthexis/gway.git
Project-URL: Homepage, https://arthexis.com
Project-URL: Sponsor, https://www.gelectriic.com/
Classifier: Programming Language :: Python :: 3
Classifier: Operating System :: OS Independent
Requires-Python: >=3.7
Description-Content-Type: text/x-rst
License-File: LICENSE.md
Requires-Dist: toml
Requires-Dist: setuptools
Requires-Dist: twine
Requires-Dist: build
Requires-Dist: colorama
Requires-Dist: bottle
Requires-Dist: paste
Requires-Dist: requests
Requires-Dist: dateparser
Requires-Dist: fastapi
Requires-Dist: uvicorn
Requires-Dist: docutils
Requires-Dist: croniter
Requires-Dist: qrcode[pil]
Requires-Dist: cryptography
Requires-Dist: jinja2
Requires-Dist: pygame
Requires-Dist: python-multipart
Dynamic: license-file

GWAY
====

Welcome [Viajante], this is the GWAY project README.rst file and website.

**GWAY** is an **experimental** CLI and function-dispatch framework that allows you to invoke and chain Python functions from your own projects or built-ins, with automatic sigil & context resolution, argument injection, inversion control, auto-wired recipes, and multi-environment support. GWAY is async-compatible and fully instrumented.

`Lowering barrier to enter a higher-level of programming.`


Features
--------

- 🔌 Seamless function calling from CLI or code (e.g., ``gway.awg.find_cable()``)
- ⛓️ CLI chaining support: ``func1 - func2`` or ``func1 ; func2``
- 🧠 Sigil-based context resolution (e.g., ``[result_context_or_env_key|fallback]``)
- ⚙️ Automatic CLI argument generation, with support for ``*args`` and ``**kwargs``
- 🧪 Built-in test runner and packaging: ``gway run-tests`` and ``gway project build``
- 📦 Environment-aware loading (e.g., ``clients`` and ``servers`` .env files)

Examples
--------

AWG Cable Calculation
~~~~~~~~~~~~~~~~~~~~~

Given a project ``awg.py`` containing logic to calculate cable sizes and conduit requirements:

**Call from Python**

.. code-block:: python

    from gway import gw

    result = gw.awg.find_cable(meters=30, amps=60, material="cu", volts=240)
    print(result)

**Call from CLI**

.. code-block:: bash

    # Basic cable sizing
    gway awg find-cable --meters 30 --amps 60 --material cu --volts 240

    # With conduit calculation
    gway awg find-cable --meters 30 --amps 60 --material cu --volts 240 --conduit emt

**Chaining Example**

.. code-block:: bash

    # Chain cable calculation and echo the result
    gway awg find-cable --meters 25 --amps 60 - print --text "[awg]"

**Online Example**

You can test the AWG cable sizer online here, or in your own instance:

https://arthexis.com/gway/awg-finder


GWAY Website Server
~~~~~~~~~~~~~~~~~~~

You can also run a lightweight help/documentation server directly using GWAY:

.. code-block:: powershell

    > gway --debug website start-server --daemon - hold

This launches an interactive web UI that lets you browse your project, inspect help docs, and search callable functions.

Visit `http://localhost:8888` once it's running.

Online Help & Documentation
---------------------------

Browse built-in and project-level function documentation online at:

📘 https://arthexis.com/gway/help

- Use the **search box** in the top left to find any callable by name (e.g., ``find_cable``, ``resource``, ``start_server``).
- You can also navigate directly to: ``https://arthexis.com/gway/help/<project>/<function>`` or ``https://arthexis.com/gway/help/<built-in>``

This is useful for both the included out-of-the-box GWAY tools and your own projects, assuming they follow the GWAY format.


Installation
------------

Install via PyPI:

.. code-block:: bash

    pip install gway

Install from Source:

.. code-block:: bash

    git clone https://github.com/arthexis/gway.git
    cd gway

    # Run directly from shell or command prompt
    ./gway.sh        # On Linux/macOS
    gway.bat         # On Windows

When running GWAY from source for the first time, it will **auto-install** dependencies if needed.

To **upgrade** to the latest version from source:

.. code-block:: bash

    ./upgrade.sh     # On Linux/macOS
    upgrade.bat      # On Windows

This pulls the latest updates from the `main` branch and refreshes dependencies.

Project Structure
-----------------

Here's a quick reference of the main directories in a typical GWAY workspace:

+----------------+-------------------------------------------------------------+
| Directory      | Description                                                 |
+================+=============================================================+
| envs/clients/  | Per-user environment files (e.g., ``username.env``)         |
+----------------+-------------------------------------------------------------+
| envs/servers/  | Per-host environment files (e.g., ``hostname.env``)         |
+----------------+-------------------------------------------------------------+
| projects/      | Your own Python modules — callable via GWAY                 |
+----------------+-------------------------------------------------------------+
| logs/          | Runtime logs and outputs                                    |
+----------------+-------------------------------------------------------------+
| tests/         | Unit tests for your own projects                            |
+----------------+-------------------------------------------------------------+
| data/          | Static assets, resources, and other data files              |
+----------------+-------------------------------------------------------------+
| temp/          | Temporary working directory for intermediate output files   |
+----------------+-------------------------------------------------------------+
| scripts/       | .gws script files (for --batch mode)                        |
+----------------+-------------------------------------------------------------+


After placing your modules under `projects/`, you can immediately invoke them from the CLI with:

.. code-block:: bash

    gway project-name my-function --arg1 value


🧪 Recipes
----------

Gway recipes are lightweight `.gwr` scripts containing one command per line, optionally interspersed with comments. These recipes are executed sequentially, with context and results automatically passed from one step to the next.

Each line undergoes **sigil resolution** using the evolving context before being executed. This makes recipes ideal for scripting interactive workflows where the result of one command feeds into the next.

🔁 How It Works
~~~~~~~~~~~~~~~

Under the hood, recipes are executed using the `run_recipe` function:

.. code-block:: python

    from gway import gw

    # Run a named recipe
    gw.recipe.run("example")

    # Or with extra context:
    # Project and size are assumed to be parameters of the example function.
    gw.recipe.run("example", project="Delta", size=12)

If the file isn't found directly, Gway will look in its internal `recipes/` resource folder.


🌐 Example: `website.gwr`
~~~~~~~~~~~~~~~~~~~~~~~~~

An example recipe named `website.gwr` is already included. It generates a basic web setup using inferred context. Here's what it contains:

.. code-block:: 

    # Default GWAY website ingredients

    web setup-app
    web start-server --daemon
    until --lock-file VERSION --lock-pypi


You can run it with:

.. code-block:: bash

    gway -r website


Or in Python:

.. code-block:: python

    from gway import gw
    gw.recipe.run("website")


This script sets up a web application, launches the server in daemon mode, and waits for lock conditions using built-in context.

---

Recipes make Gway scripting modular and composable. Include them in your automation flows for maximum reuse and clarity.


INCLUDED PROJECTS
=================

.. rubric:: awg

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - find_cable
   * - find_conduit

.. rubric:: clip

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - copy
   * - requires

.. rubric:: etron

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - extract_records

.. rubric:: gif

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - animate

.. rubric:: gui

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - lookup_font
   * - notify
   * - requires

.. rubric:: job

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - schedule

.. rubric:: net

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - export_connections

.. rubric:: ocpp

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - setup_csms_app
   * - setup_sink_app

.. rubric:: odoo

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - Form
   * - asynccontextmanager
   * - create_quote
   * - execute
   * - fetch_customers
   * - fetch_order
   * - fetch_products
   * - fetch_quotes
   * - fetch_templates
   * - get_user_info
   * - read_chat
   * - send_chat
   * - setup_chatbot_app

.. rubric:: png

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - credit_images
   * - sanitize_filename

.. rubric:: qr

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - generate_b64data
   * - generate_image
   * - generate_img
   * - generate_url
   * - requires
   * - scan_image
   * - scan_img

.. rubric:: readme

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - collect_projects

.. rubric:: recipe

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - register_gwr
   * - run

.. rubric:: release

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - build
   * - build_help
   * - extract_todos

.. rubric:: sql

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - connect
   * - contextmanager
   * - infer_type

.. rubric:: t

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - now
   * - now_plus
   * - to_download
   * - ts

.. rubric:: tests

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - dummy_function
   * - variadic_both
   * - variadic_keyword
   * - variadic_positional

.. rubric:: web

.. list-table:: Functions
   :header-rows: 1

   * - Function
   * - awg_finder
   * - build_url
   * - help
   * - qr_code
   * - readme
   * - redirect_error
   * - requires
   * - setup_app
   * - setup_proxy
   * - start_server
   * - theme
   * - urlencode
   * - wraps


License
-------

MIT License
