A simple and powerful admin for Piccolo models, using ASGI.
Project description
Piccolo Admin
piccolo_admin provides a simple yet powerful admin interface on top of Piccolo models - allowing you to easily add / edit / filter your data.
Try it
Try it online (username: piccolo, password: piccolo123).
Local Demo
To run a demo locally, using Python 3.7 or above:
pip install piccolo_admin
admin_demo
And then just launch localhost:8000
in your browser.
To see what happens behind the scenes, see piccolo_admin/example.py
.
In a few lines of code we are able to:
- Define our models
- Setup a database
- Create a REST API
- Setup a web server and admin interface
ASGI
Since the admin is an ASGI app, you can either run it standalone like in the demo, or integrate it with a larger ASGI app.
For example, using Starlette routes:
from piccolo_admin.endpoints import create_admin
from starlette.routing import Router, Route
import uvicorn
from my_project.tables import Director, Movie
admin = create_admin([Director, Movie])
router = Router([
Route(path="/", endpoint=Hello),
Mount(path="/admin/", app=admin),
])
if __name__ == '__main__':
uvicorn.run(router)
Session table
The admin uses session auth, which requires a database table.
Add piccolo_admin.piccolo_app
to the APP_REGISTRY in your piccolo_conf.py
project file, then run:
piccolo migrations forwards session_auth
To learn more about the Piccolo project files, check out the docs.
Contributing
The backend is just vanilla Python.
The front end is built using Vue.js. To make modifications, clone the repo, and cd into the admin_ui
directory.
Install the npm dependencies:
npm install
And then you can launch the admin as follows:
npm run serve
It will auto refresh the UI as you make changes to the source files.
The UI needs an API to interact with - the easiest way to do this is to use the demo app.
admin_demo
# Or alternatively
python -m piccolo_admin.example
You will need to configure a local webserver as a proxy - see extra/piccolo_admin.
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
File details
Details for the file piccolo_admin-0.6.4.tar.gz
.
File metadata
- Download URL: piccolo_admin-0.6.4.tar.gz
- Upload date:
- Size: 693.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 98b0c0b16cf8bb797f89333485871d20e357ed5d213934d4270cc0c1d9bc4bc7 |
|
MD5 | 026b8fd5c3c83789ab0d87bdea3c3c7a |
|
BLAKE2b-256 | 3c50911742766fafafc082c816e4d944b5d180225163b0abb939cb7cb7f8cefe |
File details
Details for the file piccolo_admin-0.6.4-py3-none-any.whl
.
File metadata
- Download URL: piccolo_admin-0.6.4-py3-none-any.whl
- Upload date:
- Size: 700.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0c9e155a9bd98fa21070520b192d69dcbcc3177a39b0fbc70bb40ceb8f53e1e7 |
|
MD5 | 2cfa2b12bbf946d79ab8f07301fe497e |
|
BLAKE2b-256 | 60f45c4f8f98aa327837bb82eef04bcae689deabc088c947aea4db9840d5a2c2 |