Skip to main content

Framework for rapidly developing a restful API that requires post processing

Project description

Drumpler

Drumpler is a general-purpose application designed to facilitate efficient workflow automation through RESTful API interactions and job processing. Built on Flask and SQLAlchemy, this application serves as a robust backend for capturing, storing, and processing HTTP requests in a scalable manner. The application is split into two main components: drumpler.py for handling RESTful API requests and mammoth.py for querying the API and processing jobs asynchronously.

High Level Overview

Image Description

Features

  • RESTful API Endpoints: Secure and scalable endpoints for handling HTTP requests, including POST, GET, PUT, and DELETE operations.
  • Database Integration: Utilizes SQLAlchemy for ORM-based interactions with Postgres.
  • Job Processing: Facilitates the asynchronous processing of tasks with support for multi-threading and multi-processing, ensuring efficient workflow automation.
  • Event Logging: Detailed event logging for each HTTP request, job processing and related events, allowing for easy tracking and management of tasks.

Prerequisites

Before you begin, ensure you have the following installed:

  • Python 3.6 or later
  • PostgreSQL

Installation

Install Drumpler via pip: pip install Drumpler

Configuration

Create a .env file in the root directory of the application with the following contents:

AUTHORIZATION_KEY=AUTH_KEY_HERE
DRUMPLER_HOST=IP_HERE
DRUMPLER_PORT=PORT_HERE
DRUMPLER_DEBUG=BOOL_FLAG
DB_NAME=DB_NAME_HERE
DB_HOST=DB_HOST_HERE
DB_USER=DB_USER_HERE
DB_PASS=DB_PASS_HERE

Replace your_database_uri_here and your_authorization_key_here with your actual database URI and desired authorization key.

Using the Application - Drumpler

To create a Drumpler RESTful server, the following is a sample implementation:

import drumpler

# Now, you can create an instance of the Drumpler class
app = drumpler.Drumpler(host="0.0.0.0", port=5000, debug=True)  # Adjust as necessary

# And call the run method on this instance
app.run()

API Endpoints

Drumpler exposes the following endpoints for interacting with its system:

  • POST /request: Submit a new request for processing.
  • GET /request/<int:request_id>: Retrieve a specific request by its ID.
  • GET /request/next-unhandled: Fetch the next unhandled request.
  • PUT /request/<int:request_id>: Update the status of a request.
  • DELETE /request/<int:request_id>: Delete a specific request.

Using the Application - Mammoth

To create a Mammoth (request-processor), the following is a sample implementation:

from drumpler.mammoth import Mammoth

def custom_process_function(session, request, job_id):
    # this is the driver method for your customized workflow
    pass

# Initialize Mammoth
DRUMPLER_HOST = "http://127.0.0.1"
DRUMPLER_PORT = 5000  # Adjust the URL/port as necessary
DRUMPLER_URL = f"{DRUMPLER_HOST}:{DRUMPLER_PORT}"  # Adjust the URL/port as necessary
MAMMOTH_WORKERS = 1
mammoth = Mammoth(process_request_data=custom_process_function, drumpler_url=DRUMPLER_URL, workers=MAMMOTH_WORKERS)

if __name__ == "__main__":
    print("Starting Mammoth... Press CTRL+C to stop.")
    mammoth.run()

Contributing

Contributions to Drumpler are welcome! Please follow the standard fork-branch-PR workflow.

License

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

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

drumpler_mammoth-2.0.2.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

Drumpler_Mammoth-2.0.2-py3-none-any.whl (6.7 kB view details)

Uploaded Python 3

File details

Details for the file drumpler_mammoth-2.0.2.tar.gz.

File metadata

  • Download URL: drumpler_mammoth-2.0.2.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for drumpler_mammoth-2.0.2.tar.gz
Algorithm Hash digest
SHA256 92201c685f1d3e6b98a41ef6154d37079a12746ec08e72d23be4fc7a0ab389f4
MD5 7150c08834585ac27ff62e32a6781ebf
BLAKE2b-256 24a1565e99687ddc343bc914c0ffad81f1e2786587c57e9b0dc388247cc3a887

See more details on using hashes here.

File details

Details for the file Drumpler_Mammoth-2.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for Drumpler_Mammoth-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cb7180aec44b58fee18ef67b17cbc15bdb8b2e1a0b34ef2c897b0fdaeea44d54
MD5 28a2d1b16eb27fdf9c70d3ae0a2f8bce
BLAKE2b-256 a5c211e6854fd2fc25e36834b913d54432399d1cfe2c3e299afda4c329eb2b55

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