Skip to main content

asyncio REST API Resource database

Project description

Introduction
============

.. image:: https://img.shields.io/badge/docs-latest-brightgreen.svg?style=flat
:target: http://guillotina.readthedocs.io/en/latest/

.. image:: https://travis-ci.org/plone/guillotina.svg?branch=master
:target: https://travis-ci.org/plone/guillotina

.. image:: https://codecov.io/gh/plone/guillotina/branch/master/graph/badge.svg
:target: https://codecov.io/gh/plone/guillotina/branch/master
:alt: Test Coverage

.. image:: https://img.shields.io/pypi/pyversions/guillotina.svg
:target: https://pypi.python.org/pypi/guillotina/
:alt: Python Versions

.. image:: https://img.shields.io/pypi/v/guillotina.svg
:target: https://pypi.python.org/pypi/guillotina

.. image:: https://img.shields.io/pypi/l/guillotina.svg
:target: https://pypi.python.org/pypi/guillotina/
:alt: License

.. image:: https://badges.gitter.im/plone/guillotina.png
:target: https://gitter.im/plone/guillotina
:alt: Chat

Please `read the detailed docs <http://guillotina.readthedocs.io/en/latest/>`_


This is the working project of the next generation Guillotina server based on asyncio.


Dependencies
------------

* python >= 3.6
* 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 easily
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.


Getting started with development
--------------------------------

Using pip::

./bin/pip install requirements.txt
./bin/pip install -e .[test]


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 \
guillotina/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


3.2.12 (2018-06-04)
-------------------

- Fix behavior's use of zope.interface
[vangheem]


3.2.11 (2018-05-31)
-------------------

- Fix bug in CORS with file upload
[vangheem]


3.2.10 (2018-05-30)
-------------------

- Be able to use and customize GuillotinaUser object without request object
[vangheem]


3.2.9 (2018-05-30)
------------------

- bump

3.2.8 (2018-05-30)
------------------

- Reindex security of group object even if we aren't going to reindex it's children
[vangheem]

- Refactor indexing so we can index security, provide `guillotina.catalog.index.index_object` function
[vangheem]


3.2.7 (2018-05-15)
------------------

- Indexing gathers all data on update instead of
overwriting indexed data
[vangheem]


3.2.6 (2018-05-12)
------------------

- Provide IDatabaseManager.exists for dummy db impelementation
[vangheem]


3.2.5 (2018-05-12)
------------------

- add IDatabaseManager.exists method to be able to check if db exists
[vangheem]


3.2.4 (2018-05-11)
------------------

- Fix dynamic storage urls for cockroach
[vangheem]

- deserialize value before validation on patch fields
[vangheem]


3.2.3 (2018-05-11)
------------------

- Authenticated users have access to view root just like
unauthenticated users
[vangheem]


3.2.2 (2018-05-11)
------------------

- Be able to provide comma separated `permissions` param to `@canido`
[vangheem]


3.2.1 (2018-05-10)
------------------

- Be able to modify file attributes filename, content_type, md5, extension
[vangheem]


3.2.0 (2018-05-10)
------------------

- Provide new IDynamicFields and IDynamicFieldValues behaviors
[vangheem]

- Be able to use PatchField with nested schemas
[vangheem]

- Change Object field to work with dicts and JSON schema
[vangheem]


3.1.8 (2018-05-06)
------------------

- Add `type_name` index
[vangheem]


3.1.7 (2018-05-04)
------------------

- Provide check_security argument on
`guillotina.content.create_content_in_container`
[vangheem]


3.1.6 (2018-04-30)
------------------

- Provide asyncio.Lock on transaction manager
[vangheem]


3.1.5 (2018-04-30)
------------------

- `guillotina.utils.get_containers` does not change
transaction strategy anymore.
[vangheem]


3.1.4 (2018-04-30)
------------------

- Fix getting tid for `dbresolve_readcommitted` txn strategy
[vangheem]


3.1.3 (2018-04-27)
------------------

- Use database constraints if supported
[vangheem]

- Be able to customize oid generator
[vangheem]
...

You are seeing a truncated changelog.

You can read the `changelog file <https://github.com/plone/guillotina/blob/master/CHANGELOG.rst>`_
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

guillotina-3.2.12.tar.gz (314.6 kB view hashes)

Uploaded Source

Built Distribution

guillotina-3.2.12-py3-none-any.whl (368.6 kB view hashes)

Uploaded Python 3

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