A FastAPI-based framework with plugin management.
Project description
FastPluggy
FastPluggy is a FastAPI-based framework that simplifies the process of building modular applications with plugin management and database handling. It allows you to easily configure plugins, static files, Jinja2 templates, and databases, making it a powerful and flexible solution for FastAPI projects.
Features
- Plugin Management: Easily manage, enable, disable, and configure plugins.
- Database Integration: Supports SQLAlchemy for database handling.
- Static Files and Templates: Serve static files and Jinja2 templates seamlessly.
- Extensibility: Use FastPluggy as a library to extend your FastAPI applications.
- Simple Setup: Configure your project with a single class, easy initialization.
Installation
You can install FastPluggy using pip:
pip install FastPluggy
Getting Started
1. Create a FastAPI App with FastPluggy
In your FastAPI project, import FastPluggy from FastPluggy and use it to configure your app:
from fastapi import FastAPI
from fastpluggy.fastpluggy import FastPluggy
app = FastAPI()
# Initialize the FastPluggy class which sets up everything
fast_pluggy = FastPluggy(app)
# Run the application using Uvicorn or another ASGI server
if __name__ == "__main__":
import uvicorn
uvicorn.run(fast_pluggy.app, host="0.0.0.0", port=8000)
2. Running the Application
Once the configuration is complete, you can run the FastAPI app using Uvicorn:
uvicorn your_project:app --reload
3. Plugin Management
With FastPluggy, managing plugins is straightforward.
The PluginManager class handles loading, enabling, disabling, and configuring plugins in your application.
You can define plugins and control their behavior from the admin interface or directly in code.
Example Plugin Definition
To create a plugin, simply create a Python module with a FastAPI router and define plugin-specific functionality.
from fastapi import APIRouter
plugin_router = APIRouter()
@plugin_router.get("/hello")
def hello_plugin():
return {"message": "Hello from the plugin!"}
FastPluggy will automatically detect and integrate this plugin into your application.
File Structure
After installing FastPluggy, your project structure might look like this:
your_project/
│
├── src/
│ ├── your_project/
│ │ ├── __init__.py
│ │ ├── main.py
│ │ ├── core/
│ │ ├── templates/
│ │ ├── static/
│ └── your_project.egg-info/
│
├── tests/
├── README.md
├── setup.py
└── pyproject.toml
- main.py: Entry point for your application.
- core/: Core logic for plugins, database handling, etc.
- templates/: Jinja2 templates for rendering HTML.
- static/: Static files like CSS and JavaScript.
- tests/: Directory for unit tests.
Contributing
Contributions are welcome! If you'd like to contribute to FastPluggy, please fork the repository and submit a pull request. Be sure to follow the contribution guidelines.
License
This project is licensed under the MIT License. See the LICENSE file for more information.
Links
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fastpluggy-0.3.11.tar.gz.
File metadata
- Download URL: fastpluggy-0.3.11.tar.gz
- Upload date:
- Size: 92.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
de59bab97db0162d1493e27995297c82e2783d5694f47cebe9a05f0f84c5fcd1
|
|
| MD5 |
c13e49a985c82a0dd7771b827bba5897
|
|
| BLAKE2b-256 |
f165e2528c11753eafb8aabd122cca5f414b477db2dcb7da889ac211a66992da
|
File details
Details for the file fastpluggy-0.3.11-py3-none-any.whl.
File metadata
- Download URL: fastpluggy-0.3.11-py3-none-any.whl
- Upload date:
- Size: 123.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0f2aa7f1997b1cf7ac4431b225a2ba362bb39ccbd87d019a9646979cf4654ab
|
|
| MD5 |
b538d68245c90816bf0981eb2f7f0811
|
|
| BLAKE2b-256 |
0fa3cc94b01cba90551e91251fad7758d8c8e15aecf4f51423ab5ccb58e03552
|