Skip to main content

A lightweight WSGI application

Project description

pywsgiapp

pywsgiapp is a lightweight WSGI application framework designed to simplify the creation of WSGI-based web applications. It provides a simple interface for handling HTTP requests and responses, making it easy to build and deploy 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

  • 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.2.tar.gz (6.6 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.2-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pywsgiapp-0.0.2.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pywsgiapp-0.0.2.tar.gz
Algorithm Hash digest
SHA256 432ed784486ccddc5565cd7e317a4d980562fd80dd13e18501437e86dcf96b00
MD5 f0a5f95fea87caf15bbf1fca80f22bd6
BLAKE2b-256 488c0f5461112a6ff7ea05e8682209a22741a096e4388ca7b89a71d327de5fe4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pywsgiapp-0.0.2.tar.gz:

Publisher: python-publish.yml on jaythorat/pywsgiapp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

  • Download URL: pywsgiapp-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pywsgiapp-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8a96b810bfc5d6b2a00b61295dc19b9f81422d49143e736cb5c2bdb57ed19bec
MD5 659efc08662ae414b6300d780ebb31fc
BLAKE2b-256 c8b20020d5d03d59fad5f68ff34ac1b8d4ea0fc605a7263d3216855b229cbfab

See more details on using hashes here.

Provenance

The following attestation bundles were made for pywsgiapp-0.0.2-py3-none-any.whl:

Publisher: python-publish.yml on jaythorat/pywsgiapp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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