Skip to main content

A webbased wrapper for the argument parser in Python

Project description

warped can be used to execute single Python file and Python modules. It captures calls to the argparse module of Python and renders a web GUI based on the options and arguments defined. It also displays the output of the program inside the web GUI and allows you to stop, pause and resume the program, as well as downloading the output.

Install

Either get a stable version from PyPI, or install the current version from git

# Installation from PyPI
pip install warped

# Installation from git
pip install git+https://git.k-fortytwo.de/christofsteel/warped/

Usage

warped [-h] [--port PORT] [--host HOST] [--module] file

a Webbased frontend for ARgparse in Python

positional arguments:
file                  File to run

optional arguments:
-h, --help            show this help message and exit
--port PORT, -p PORT  The port to listen on (default 5000)
--host HOST           The host to bind to (default 0.0.0.0)
--module, -m          If set, loads a module instead of a file

Sample

To test the capabilities of warped an example module was included. You can run it like this:

warped -m warped.samples.hooked

Since warped also makes use of the argparse module, warped itself can be //warped//.

warped -m warped.hook

How does it work?

When warped is executed, it starts a flask webserver. The javascript of the website reads the /arguments resource of the server, where the configuration of the argparser returned. In a seperate process the given program is executed using the runpy library, redirecting sys.stdin and sys.stdout to a multiprocessing.Queue, which can be read by the warp process to display it via the web GUI.

Additionally, warped adds an entry for argparse in the sys.modules list. Python looks first looks at this list, everytime a module is imported, to avoid importing a module multiple times. This custom argparse module behaves similar to the original argparse module. In fact with the exception of the ArgumentParser.parse_args() method, it works exactly like the original. Once the program calls the parse_args() method, it blocks and waits for user interaction via the web GUI. Once the user submits the data, the process continues.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

warped-0.1.3.tar.gz (522.1 kB view details)

Uploaded Source

Built Distribution

warped-0.1.3-py3-none-any.whl (681.8 kB view details)

Uploaded Python 3

File details

Details for the file warped-0.1.3.tar.gz.

File metadata

  • Download URL: warped-0.1.3.tar.gz
  • Upload date:
  • Size: 522.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for warped-0.1.3.tar.gz
Algorithm Hash digest
SHA256 a845c47a4ce8ecb105f65c692bd83f4c0b47422e59cff80594a2904f0d0dc060
MD5 202a687928bbbc36c3358e4ff7dc3098
BLAKE2b-256 6d3de602233544f22dbd1e8447cd8ca0e52aefe43d642f42bf8b70383276b6ce

See more details on using hashes here.

File details

Details for the file warped-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for warped-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3971c22d20763786bae869b4b5c2a510adcfafc39b6217931d6081be5b4599e5
MD5 1ba765a62188efd3f9ccfc8264764f02
BLAKE2b-256 55623e437f5d271569d512928a67207ecec47f6bc13ff3f6241e06f1142c8539

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