asyncio REST API Resource database
Project description
Introduction
Please read the detailed docs
This is the working project of the next generation Guillotina server based on asyncio.
Dependencies
Python >= 3.7
PostgreSQL >= 9.6
Quickstart
We use pip
pip install guillotina
Run PostgreSQL
If you don’t have a PostgreSQL server to play with, you can run one with Docker.
Download and start the Docker container by running
make run-postgres
Run the server
To run the server
g
Then…
curl http://localhost:8080
Or, better yet, use Postman to start playing with API.
You can also navigate in your Guillotina server with its built-in web admin interface by visiting http://localhost:8080/+admin/.
Deploy on Heroku
Read more Guillotina-Heroku.
Getting started with development
Using pip (requires Python > 3.7)
git clone git@github.com:plone/guillotina.git
cd guillotina
python3.7 -m venv .
./bin/pip install -r requirements.txt
./bin/pip install -r contrib-requirements.txt
./bin/pip install -e '.[test]'
./bin/pre-commit install
Run tests
We’re using pytest
./bin/pytest guillotina
and for test coverage
./bin/pytest --cov=guillotina guillotina/
With file watcher…
./bin/ptw guillotina --runner=./bin/py.test
To run tests with cockroach db
USE_COCKROACH=true ./bin/pytest guillotina
Default
Default root access can be done with AUTHORIZATION header : Basic root:root
Docker
You can also run Guillotina with Docker!
First, run PostgreSQL
docker run --rm \
-e POSTGRES_DB=guillotina \
-e POSTGRES_USER=guillotina \
-p 127.0.0.1:5432:5432 \
--name postgres \
postgres:9.6
Then, run Guillotina
docker run --rm -it \
--link=postgres -p 127.0.0.1:8080:8080 \
plone/guillotina:latest \
g -c '{"databases": [{"db": {"storage": "postgresql", "dsn": "postgres://guillotina:@postgres/guillotina"}}], "root_user": {"password": "root"}}'
This assumes you have a config.yaml in your current working directory
Chat
Join us to talk about Guillotina at https://gitter.im/plone/guillotina
CHANGELOG
6.3.4 (2021-05-06)
Adding image with scale previews field [bloodbare]
6.3.3 (2021-05-04)
Command: Implement graceful stop (like in asyncio.run()) [masipcat]
Command: Fix same txn copied to all tasks/requests [masipcat]
6.3.2 (2021-04-30)
Command: fix typo introduced in #1125 [masipcat]
6.3.1 (2021-04-30)
On workflow change also trigger object modification [bloodbare]
Command: run the startup/shutdown and main logic inside the loop [masipcat]
6.3.0 (2021-04-21)
Use Context on default catalog security checks [bloodbare]
Return 401 if NoPermissionToAdd is raised in defaultPOST [nilbacardit26]
No longer have dedicated read connection and do not use any prepared statements [vangheem]
6.2.6 (2021-04-12)
Fix bug on search results ids based on container path [bloodbare]
6.2.5 (2021-04-09)
Fix PGCatalog Phrase search [bloodbare]
Fix bug on empty waiting for empty tasks. [bloodbare]
6.2.4 (2021-04-07)
Enable X-Wait header to wait futures. Use only in case you need to make sure all futures are finished before request ends. Alert: Afects performance on request response time. [bloodbare]
6.2.3 (2021-04-07)
Search on pg catalog should check security on context [bloodbare]
6.2.2 (2021-04-01)
Index on PG Catalog IDS should be table named [bloodbare]
6.2.1 (2021-03-12)
Allow to skip pg catalog initialization based on SKIP_PGCATALOG_INIT environmental var. [bloodbare]
6.2.0 (2021-03-04)
Write missing_value to object on deserialization [masipcat]
BREAKING CHANGE: PG Catalog implementation splitted on multiple fields if you are import PGSearchUtility you need to change the import line from: from guillotina.contrib.catalog.pg import PGSearchUtility to from guillotina.contrib.catalog.pg.utility import PGSearchUtility [bloodbare]
6.1.7 (2021-03-03)
ISecurityInfo: field ‘id’ was missing [masipcat]
6.1.6 (2021-02-25)
Reuse modified objects on same transactions on traversal/async_get navigation [bloodbare]
Improve memcached metrics probe [lferran]
6.1.5 (2021-02-09)
Cleaner memcached_container pytest fixture [lferran]
Fixing checking field permission on content creation [bloodbare]
Fix memcached tests not able to start docker image [lferran]
Fixing 6.1.4 release (anonymous users not working on search) [bloodbare]
6.1.4 (2021-01-31)
Apply local roles on @search with pgcatalog [bloodbare]
6.1.3 (2021-01-18)
Fix: patch a role on dbusers:groups don’t remove users from them [jordic]
Fix: patching password on a user hash it [jordic]
Fix: only allow lowercase usernames on dbusers creation [jordic]
Feat: db_users, being able to login by email [jordic]
6.1.2 (2021-01-18)
Fix filter and sort by date field on pgcatalog [bloodbare]
Add memcached support as cache driver [lferran]
Fix: prevent caching large objects on fill_cache [lferran]
Fix: dyncontent vocabularies json serialization [bloodbare]
Fix: prevent caching large objects on fill_cache [lferran]
6.1.1 (2021-01-15)
Support other languages on FTS at pgcatalog [bloodbare]
DB Users storing group on DB due to pickling groups_cache leads to wrong objects [bloodbare]
Improve markup (docs/index.md) [svx]
Various documentation improvements [svx]
Unify wording in dev docs [svx]
…
You are seeing a truncated changelog.
You can read the changelog file for a complete list.
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
Hashes for guillotina-6.3.4-cp38-cp38-macosx_10_15_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2ffcee7464071fa44abd4e682e7ac8290f0e34677d2e85cae4f5e5d20f67416e |
|
MD5 | 050f1e1f09f528b698eb111c79b2610c |
|
BLAKE2b-256 | f1ee0423234403a7204fbdb196e5b601c81b927d0fb5aff800a846acecc125de |