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.

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 the database, supporting a variety of database systems.
  • 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 job processed, allowing for easy tracking and management of tasks.

Prerequisites

Before you begin, ensure you have the following installed:

  • Python 3.6 or later
  • Flask
  • SQLAlchemy
  • Requests

Additionally, you will need:

  • A PostgreSQL database or any SQL database supported by SQLAlchemy.
  • An .env file configured with your database URI and authorization key.

Installation

Install Drumpler via pip: pip install Drumpler

Configuration

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

DATABASE_URI=your_database_uri_here 
AUTHORIZATION_KEY=your_authorization_key_here 
Drumpler_HOST=0.0.0.0 
Drumpler_PORT=5000 
Drumpler_DEBUG=True

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

Using the Application

To start the Drumpler API server:

import drumpler

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

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

API Endpoints

The application exposes several endpoints for interacting with the 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.

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-1.0.2.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

Drumpler-1.0.2-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file Drumpler-1.0.2.tar.gz.

File metadata

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

File hashes

Hashes for Drumpler-1.0.2.tar.gz
Algorithm Hash digest
SHA256 f7388b9a114053eeb5c4483e213e0297721450d607b6cb0b32b959ace55ec3ba
MD5 275f14cb644ca12b119cc90faf4668b4
BLAKE2b-256 ad17f88f7f3fade92316369ee4890f68457f7a79e451578838800a01aca978e9

See more details on using hashes here.

File details

Details for the file Drumpler-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: Drumpler-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for Drumpler-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f86ea01cd8d56ea3088e41d3d1d05ef9ee195079b2715524601059bb75affe58
MD5 87b3101801cb57e62855466f79d33c9b
BLAKE2b-256 950daff6e53d00c97cdaced7ea73ffb7cfefb02d2c36ae38eecb50bc2fc092f2

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