Skip to main content

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.

Screenshot

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


# The `allowed_hosts` argument is required when running under HTTPS. It's used
# for additional CSRF defence.
admin = create_admin([Director, Movie], allowed_hosts=['my_site.com'])


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

piccolo_admin-0.10.3.tar.gz (729.7 kB view details)

Uploaded Source

Built Distribution

piccolo_admin-0.10.3-py3-none-any.whl (736.4 kB view details)

Uploaded Python 3

File details

Details for the file piccolo_admin-0.10.3.tar.gz.

File metadata

  • Download URL: piccolo_admin-0.10.3.tar.gz
  • Upload date:
  • Size: 729.7 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

Hashes for piccolo_admin-0.10.3.tar.gz
Algorithm Hash digest
SHA256 06ae6b3c5f2d3dcd119deccfe33fd4b237fe531992ad0717497a0bc1a66488f6
MD5 15fcbfb7ad5937c32c5844d484477cd7
BLAKE2b-256 71024b3558bc4c6ba8d463d9c1c3eef513aae98a1a445a1f29c82273ceb34254

See more details on using hashes here.

File details

Details for the file piccolo_admin-0.10.3-py3-none-any.whl.

File metadata

  • Download URL: piccolo_admin-0.10.3-py3-none-any.whl
  • Upload date:
  • Size: 736.4 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

Hashes for piccolo_admin-0.10.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ad6317d3b64df27ed43db57e7c7850089dba7afad561b66ade38125060baa65c
MD5 c22d2f58266286079456c0a097d0b3a4
BLAKE2b-256 4c992f08c4e073abd6b91369b5635cb469b0fa8dffb2db258f7ecf5a4e76cc67

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