Skip to main content

Bring Your Code to the Web with Ease using a Lightweight WSGI Application.

Project description

pyWSGIapp

pywsgiapp is a lightweight WSGI application framework aimed at simplifying the development of WSGI-based web applications. It offers an intuitive interface for managing HTTP requests and responses, enabling easy creation and deployment of web applications.


Features

  • Lightweight and easy-to-use WSGI framework.
  • Customizable request handler for processing HTTP requests.
  • Compatible with WSGI servers like gunicorn.

Installation

To install the package, use the following command:

pip install pywsgiapp

Usage

Example: Basic WSGI Application

Here’s an example of how to use pywsgiapp to create a simple WSGI application:

from pywsgiapp.WSGIApp import createWSGIApp

# Define a request handler function
def requestHandler(url: str, requestHeaders: dict, postData: dict) -> dict:
    response_body = f"Received URL: {url}, Headers: {requestHeaders}, Post Data: {postData}"
    return {
        "responseCode": 200,
        "responseHeaders": {"Content-Type": "text/plain"},
        "responseBody": response_body
    }

# Create the WSGI application
app = createWSGIApp(requestHandler)

Save this code in a file (e.g., basic.py) and run it with a WSGI server like gunicorn:

gunicorn basic:app

For more examples, see the Examples Documentation.


  • pywsgiapp/: The main package containing the framework code.
  • examples/: Example scripts demonstrating how to use the framework.
  • setup.py: Metadata and installation configuration.
  • requirements.txt: List of dependencies for development and deployment.

Development

If you want to contribute or modify the framework, follow these steps:

  1. Clone the repository:

    git clone https://github.com/jaythorat/pywsgiapp.git
    cd pywsgiapp
    
  2. Install the package in editable mode:

    pip install -e .
    

Dependencies

The framework requires the following dependencies:

  • gunicorn>=20.1.0

Install them using:

pip install -r requirements.txt

License

This project is licensed under the MIT License. See the LICENSE file for details.


Contributing

Contributions are welcome! If you’d like to contribute, please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature or bugfix.
  3. Commit your changes and push the branch.
  4. Open a pull request.

Contact

For any questions or issues, feel free to contact the author:

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

pywsgiapp-0.0.6.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pywsgiapp-0.0.6-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file pywsgiapp-0.0.6.tar.gz.

File metadata

  • Download URL: pywsgiapp-0.0.6.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pywsgiapp-0.0.6.tar.gz
Algorithm Hash digest
SHA256 c1bfecafcc87ea0591e90633d283d90741085a499acba494d0eec18a139061f6
MD5 d4290d23387c0f62c8ec2d22f9555c01
BLAKE2b-256 1eaaf3be48093ea4055d8b81d540a97ea4c3025a71949a55f4b018742bb4b5e2

See more details on using hashes here.

File details

Details for the file pywsgiapp-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: pywsgiapp-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pywsgiapp-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 59fcda94bab7e0c301fca4d0e9b1a6d0d5601cda9d45e3cd0e31276dfe8766f0
MD5 b14e5c23a06699e53e313d1db853115d
BLAKE2b-256 346e7e06a622e2ae5bdb722501efbfcf0ac77ff3d0f49691d3c83c9c34efcd99

See more details on using hashes here.

Supported by

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