Metadata-Version: 2.4
Name: guillotina
Version: 7.1.2
Summary: asyncio REST API Resource database
Home-page: https://github.com/plone/guillotina
Author: Ramon Navarro Bosch & Nathan Van Gheem
Author-email: ramon@plone.org
License: BSD
Keywords: asyncio,REST,Framework,transactional,asgi
Classifier: License :: OSI Approved :: BSD License
Classifier: Intended Audience :: Developers
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.7.0
License-File: LICENSE
Requires-Dist: uvicorn
Requires-Dist: websockets
Requires-Dist: jsonschema==4.24.1
Requires-Dist: python-dateutil
Requires-Dist: pycryptodome
Requires-Dist: jwcrypto
Requires-Dist: setuptools
Requires-Dist: orjson<4,>=3
Requires-Dist: zope.interface
Requires-Dist: pyjwt
Requires-Dist: asyncpg
Requires-Dist: cffi
Requires-Dist: PyYAML>=5.1
Requires-Dist: lru-dict
Requires-Dist: mypy_extensions
Requires-Dist: argon2-cffi
Requires-Dist: backoff
Requires-Dist: multidict
Requires-Dist: typing_extensions
Requires-Dist: watchfiles>=0.16.1
Provides-Extra: test
Requires-Dist: pytest<8.0.0,>=7.4.0; extra == "test"
Requires-Dist: docker==7.1.0; extra == "test"
Requires-Dist: backoff; extra == "test"
Requires-Dist: psycopg2-binary; extra == "test"
Requires-Dist: pytest-asyncio<0.22.0,>=0.21.0; extra == "test"
Requires-Dist: pytest-cov; extra == "test"
Requires-Dist: coverage>=4.0.3; extra == "test"
Requires-Dist: pytest-docker-fixtures==1.4.2; extra == "test"
Requires-Dist: pytest-rerunfailures<13.0,>=12.0; extra == "test"
Requires-Dist: async-asgi-testclient<2.0.0; extra == "test"
Requires-Dist: openapi-spec-validator==0.8.4; extra == "test"
Requires-Dist: aiohttp<4.0.0,>=3.0.0; extra == "test"
Requires-Dist: asyncmock; extra == "test"
Requires-Dist: prometheus-client; extra == "test"
Provides-Extra: docs
Requires-Dist: async-asgi-testclient<2.0.0; extra == "docs"
Requires-Dist: sphinx; extra == "docs"
Requires-Dist: recommonmark; extra == "docs"
Requires-Dist: sphinxcontrib-httpdomain; extra == "docs"
Requires-Dist: sphinxcontrib-httpexample; extra == "docs"
Requires-Dist: sphinx-guillotina-theme; extra == "docs"
Requires-Dist: sphinx-autodoc-typehints; extra == "docs"
Provides-Extra: testdata
Requires-Dist: aiohttp<3.6.0,>=3.0.0; python_version < "3.8" and extra == "testdata"
Requires-Dist: aiohttp<4.0.0,>=3.6.0; python_version >= "3.8" and extra == "testdata"
Provides-Extra: redis
Requires-Dist: redis>=4.3.0; extra == "redis"
Provides-Extra: mailer
Requires-Dist: html2text>=2018.1.9; extra == "mailer"
Requires-Dist: aiosmtplib>=1.0.6; extra == "mailer"
Provides-Extra: memcached
Requires-Dist: emcache; extra == "memcached"
Provides-Extra: validation
Requires-Dist: pytz==2020.1; extra == "validation"
Provides-Extra: recaptcha
Requires-Dist: aiohttp<4; extra == "recaptcha"
Provides-Extra: mcp
Requires-Dist: mcp>=1.0.0; extra == "mcp"
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: home-page
Dynamic: keywords
Dynamic: license
Dynamic: license-file
Dynamic: provides-extra
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

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

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

.. image:: https://github.com/plone/guillotina/workflows/CI/badge.svg
   :target: https://github.com/plone/guillotina/actions
   :alt: CI Status

.. 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

.. image:: https://img.shields.io/docker/cloud/build/plone/guillotina
   :target: https://hub.docker.com/r/guillotina/guillotina
   :alt: Docker Cloud Build Status

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.8
* PostgreSQL >= 9.6


Quickstart
----------

We use pip

.. code-block:: shell

    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

.. code-block:: shell

    make run-postgres



Run the server
--------------

To run the server

.. code-block:: shell

    g


Then...

.. code-block:: shell

    curl http://localhost:8080


Or, better yet, use `Postman <https://www.getpostman.com/>`_ 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 <https://github.com/guillotinaweb/guillotina-heroku>`_.

.. image:: https://www.herokucdn.com/deploy/button.svg
   :target: https://www.heroku.com/deploy?template=https://github.com/guillotinaweb/guillotina-heroku

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

Using pip (requires Python > 3.7)

.. code-block:: shell

    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 <https://docs.pytest.org/en/latest/>`_

.. code-block:: shell

    ./bin/pytest guillotina

and for test coverage

.. code-block:: shell

    ./bin/pytest --cov=guillotina guillotina/

With file watcher...

.. code-block:: shell

    ./bin/ptw guillotina --runner=./bin/py.test


To run tests with cockroach db

.. code-block:: shell

    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

.. code-block:: shell

    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

.. code-block:: shell

    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
=========

7.1.2 (2026-05-22)
------------------

- MCP: remove redundant ``serialize_resource`` and confusing
  ``notify_modified`` built-in tools. Use ``resolve_path`` with
  ``include_serialized=true`` for full resource JSON.
  [rboixaderg]
- Copy backing file storage when duplicating content with cloud file fields,
  including dict-valued multi-file fields, so duplicated content does not share
  mutable file blobs with the source object.
  [nilbacardit26]
- Replace the docs build usage of deprecated ``pkg_resources`` with
  ``importlib.metadata`` and update ``sphinxcontrib-httpexample`` for
  compatibility with current setuptools.
  [nilbacardit26]


7.1.1 (2026-05-15)
------------------

- Fix list-valued mailer recipient headers for ``To`` and ``Cc``.
  [nilbacardit26]


7.1.0 (2026-05-07)
------------------

- BREAKING CHANGE: Drop support for Python 3.8 and 3.9. Guillotina is
  now tested and supported on Python 3.10, 3.11, and 3.12.
  [nilbacardit26]
- Add `guillotina.contrib.mcp` with low-level MCP server integration
  (`mcp.server.lowlevel`), tool registry utility, MCP services,
  cache invalidation subscribers, and tests/docs coverage.
- Optimize MCP `list_children` tool to prefer catalog queries and
  fallback to `async_items` when catalog is unavailable.
- Upgrade the pytest stack so the CI test environment stays compatible
  with the optional MCP SDK and its AnyIO pytest plugin on Python 3.10+.
  [finalchaz, nilbacardit26]
- Docs: Update documentation and configuration settings
- Chore: Update sphinx-guillotina-theme version to 1.0.9
  [rboixaderg]


7.0.6 (2025-10-10)
------------------

- Adding POST @groups endpoint in dbusers
- Upgrading postgres version when running test in conftest
- Updating .readthedocs.yml to version 2. Updating docs dependencies,
  upgrading sphinx to version 8
  [nilbacardit26]
- Adding serve-reload command to run the server with auto-reload
- Updated role definitions in permissions.py to include default values for 'guillotina.Member' and 'guillotina.Manager' to ensure the correct parameters are passed to the role.
- Modified ListGroups and ListUsers services to include '@id' and 'username' fields in the response.
- Use the group name as the ID in groups if it is provided.
- Updated @users and @groups endpoints to adapt them to volto/plone api
- Fixed updating users in groups in custom and standard API
  [rboixaderg]

7.0.5 (2025-04-03)
------------------

- Adding cc argument in mailer's send coroutine


7.0.4 (2025-03-25)
------------------

- Trigger notify event when user_manager folder is created, and also for group_manager.
- Refactor CockroachDB storage integration to work with the latest version of Cockroach.
- Upgrade Pillow to the latest version.
- Upgrade mypy and adjust setup.cfg to improve compatibility with the existing codebase.
  [nilbacardit26]
- Integrating the @count endpoint into the catalog interface and
  implementing the associated functionality for pg catalog.
  [nilbacardit26]

7.0.3 (2024-10-01)
------------------

- Calling register and notify when sorting OrderedDicts
- Calling register and notify when deleting file keys
  [nilbacardit26]


7.0.2 (2024-01-23)
------------------

- Dummy Release [bloodbare]


7.0.1 (2024-01-23)
------------------

- Being able to use schema.Time [nilbacardit26]
- Feat: Add metadata info to workflows
- Fix: Update workflow vocabulary name
- Feat: Update workflow vocabulary title attribute to use metadata
  [rboixaderg]


7.0.0 (2023-12-06)
------------------

- BREAKING CHANGE: Passging sql_copy_from_where and jit parameters to
  asyncpg.connection.ServerCapabilities and pinning asyncpg in
  requirements to 0.29.0. Dropping 3.7.0 python support
  [nilbacardit26]

6.4.5 (2023-11-28)
------------------

- Fix: Index full object after move it
  [rboixaderg]

- Chore: Update multidict dependency
  [rboixaderg]


6.4.4 (2023-11-20)
------------------

- Removing implements import in components/interfaces.py
  [nilbacardit26]


6.4.3 (2023-10-11)
------------------

- Fix not checking if the ID is valid when duplicating a resource
  [masipcat]

- Fix content.async_get() catches KeyError exceptions unrelated to txn.get_child()
  [masipcat]

- Deps: replace aioredis with redis-py
  [masipcat]

- Deps: updated flake8 so it won't depend on 'importlib-metadata<5'
  [masipcat]

- Fix path__starts. Add a slash when parsing the path of the query if
  the context of the search is not the container, to avoid getting the
  results of contexts that starts with the same path.
  [nilbacardit26]

- Adding render_options when registering a user.
  [nilbacardit26]

- Adding OrderedDict field, and exposing @orderImages to the images'
  api to order the keys of a field
  [nilbacardit26]


6.4.2 (2022-08-25)
------------------

- Being able to call do_action with super powers in the Workflow
  utility
  [nilbacardit26]


6.4.1 (2022-07-27)
------------------

- Fix build count query, PG catalog, ignore null and format tuple type. 
  [rboixaderg]


6.4.0 (2022-04-12)
------------------

- Fix PubSub utility stuck in infinite loop when Redis connection is interrupted
  [masipcat]


6.4.0rc3 (2022-03-16)
---------------------

- Fix Pillow dependency
  [bloodbare]

- Breaking change: guillotina futures won't have the txn set anymore.
  [masipcat]

- Fix @pytest.mark.app_settings modified original settings dictionary
  [masipcat]

- Fix previous change in mailer utility
  [masipcat]

- Improve error logging in futures
  [masipcat]
- Documentation: Enhance search endpoint documentation
  [ksuess]
- Documentation: Add info about catalog_max_results
  [ksuess]

- Add a dict parameter `render_options` to pass custom values to
  rendered template in EmailValidationUtility
  [jotare]

6.4.0rc2 (2021-11-22)
---------------------

- Nothing changed yet.


6.4.0rc1 (2021-11-22)
---------------------

- Some fixes and improvements to the new TransactionConnectionContextManager
  [masipcat]

- Port the following changes:
- Remove db transaction strategy support
- Try not to reserve connection when possible
  [vangheem]

- Black to 21.10b0 version
  [bloodbare]

- Add the possibility of configuring the ttl of the email_validation
  using app_settings["ttl_email_validation"] in the utility of the
  email_validation. By default is 3660s.
  [nilbacardit26]
- Fix docs: Create group with id/name
  [ksuess]

- doc: installation: fix duplicated line and link to contrib/dbusers
  [jotare]



...

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.

