Skip to content

Commit

Permalink
Release 5.9.0
Browse files Browse the repository at this point in the history
### BREAKING CHANGES:
* Change ``CORS_ALLOWED_ORIGIN_REGEXES`` settings name to ``CORS_ALLOWED_ORIGIN_REGEX`` and and value type to string.
* Change ``results_expiry_days`` setting name to `results_expiry` and provide time seconds instead of days (default still 1 day).
* ``msgpack`` is used as default serializer for celery instead of ``pickle``.

### Changelog:
* Feature(backend): Add Etag-based caching for swagger schema.
* Feature(backend): Add tarantool drivers for celery.
* Feature(backend): Add support for django cache in tarantool.
* Feature(backend): Use ``_display_mode`` property from serializer to set display mode.
* Feature(backend): Provide support for msgpack in celery messages via ormsgpack.
* Feature(backend): Webpush notifications.
* Feature(backend): Translations customization by apps.
* Feature(backend): Service worker customization by apps.
* Feature(backend): Allow to pass `require_confirmation` in `Action` and `SimpleAction` decorator.
* Feature(frontend): Add new display mode for detail views (stepped for creation and tabbed for read only and edit).
* Feature(frontend): Ability to hide fields using values in data.
* Feature(frontend): Bulk requests can be disabled globally.
* Fix(backend): Removed openapi doc generator plugin.
* Fix(backend): Update LDAP libs and search problems.
* Fix(backend): Add fields limits in schema.
* Fix(backend): ``DecimalField`` empty value validation.
* Fix(backend): Fix ``CORS_ALLOWED_ORIGIN_REGEX`` setting.
* Fix(backend): Update new project generation templates.
* Fix(frontend): In ``RatingField`` use standard schema properties for determining minimum and maximum values.
* Fix(frontend): Make active tab of tabbed view disabled.
* Fix(frontend): Fail validation if trying to save non nullable field with null value.
* Fix(frontend): Translate operation buttons titles.
* Fix(frontend): Nested lists pagination.
* Fix(docs): Improved russian translation.
* Chore(backend): Update dependencies for stubs and docs.
* Chore(frontend): Update dependencies in project template.
* Doc(backend): Add information about tarantool as transport, result and cache backend.
* Docs(backend): Improve backend api documentation for better comprehension.
* Docs(frontend): Translate frontend docs.

See merge request vst/vst-utils!624
  • Loading branch information
onegreyonewhite committed Feb 8, 2024
2 parents 6b6e372 + 71de92e commit fd89925
Show file tree
Hide file tree
Showing 111 changed files with 8,390 additions and 2,587 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/review.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ jobs:
runs-on: "ubuntu-22.04"
strategy:
matrix:
python: [3.8, "3.11"]
python: [3.8, "3.12"]

steps:
- name: Checkout the source code
Expand Down
2 changes: 1 addition & 1 deletion NOTICE
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
The VSTUtils Framework project.
Copyright 2018-2023 VST Consulting
Copyright 2018-2024 VST Consulting

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
Expand Down
2 changes: 1 addition & 1 deletion README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -67,4 +67,4 @@ License
VSTUtils is licensed under the terms of the Apache License 2.0.
See the file "LICENSE" for more information.

Copyright 2018-2023 VST Consulting
Copyright 2018-2024 VST Consulting
89 changes: 87 additions & 2 deletions doc/backend.rst
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,14 @@ as BModel provides plenty of Meta attributes to autogenerate serializers and vie
:members: register_view_action


You can also use custom models without using database:
Vstutils supports models that don't necessitate direct database interaction or aren't inherently tied to database tables.
These models exhibit diverse behaviors, such as fetching data directly from class attributes, loading data from files,
or implementing custom data retrieval mechanisms.
Remarkably, there are models that, in a sense, implement the mechanism of SQL views with pre-defined queries.
This flexibility allows developers to define a wide range of models that cater to specific data needs,
from in-memory models to those seamlessly integrating external data sources.
Vstutils' model system is not confined to traditional database-backed structures,
providing a versatile foundation for crafting various data representations.

.. automodule:: vstutils.models.custom_model
:members: ListModel,FileModel,ExternalCustomModel,ViewCustomModel
Expand Down Expand Up @@ -57,17 +64,45 @@ Serializers
~~~~~~~~~~~

.. automodule:: vstutils.api.serializers
:members: BaseSerializer,VSTSerializer,EmptySerializer,JsonObjectSerializer
:members: DisplayMode,BaseSerializer,VSTSerializer,EmptySerializer,JsonObjectSerializer

Views
~~~~~
VSTUtils extends the standard behavior of ViewSets from Django REST Framework (DRF) by providing
built-in mechanisms for managing model views that cater to the most commonly encountered development patterns.
This framework enhancement simplifies the process of creating robust and scalable web applications by offering
a rich set of tools and utilities that automate much of the boilerplate code required in API development.
Through these extensions, developers can easily implement custom business logic, data validation,
and access control with minimal effort, thus significantly reducing development time and improving code maintainability.


.. automodule:: vstutils.api.base
:members: GenericViewSet,ModelViewSet,ReadOnlyModelViewSet,HistoryModelViewSet,CopyMixin,FileResponseRetrieveMixin

.. automodule:: vstutils.api.decorators
:members: nested_view,subaction

-------------

**An ETag** (Entity Tag) is a mechanism defined by the HTTP protocol for web cache validation and to manage resource versions efficiently.
It represents a unique identifier for the content of a resource at a given time, allowing client and server to determine
if the resource has changed without downloading the entire content.
This mechanism significantly reduces bandwidth and improves web performance by enabling conditional requests.
Servers send ETags in responses to clients, which can cache these tags along with the resources.
On subsequent requests, clients send the cached ETag back to the server in an If-None-Match header.
If the resource has not changed (the ETag matches), the server responds with a 304 Not Modified status, indicating that the client's cached version is up-to-date.

Beyond GET requests, ETags can also be instrumental in other HTTP methods like PUT or DELETE to ensure consistency
and prevent unintended overwrites or deletions, known as "mid-air collision avoidance."
By including an ETag in the If-Match header of non-GET requests, clients signal that the operation should proceed only
if the resource's current state matches the specified ETag, thus safeguarding against concurrent modifications by different clients.
This application of ETags enhances the reliability and integrity of web applications by ensuring that operations are performed on the correct version of a resource.

Here is main functionality provided for working with ETag's mechanism:


.. automodule:: vstutils.api.base
:members: CachableHeadMixin,check_request_etag,get_etag_value,EtagDependency

Actions
~~~~~~~
Expand Down Expand Up @@ -399,3 +434,53 @@ Vstutils uses mosts of these functions under the hood.

.. automodule:: vstutils.utils
:members:


.. _webpush-manual:

Integrating Web Push Notifications
----------------------------------

Web push notifications are an effective way to engage users with real-time messaging.
To integrate web push notifications in your VSTUtils project, follow these steps:

1. **Configuration**: First, include the ``vstutils.webpush`` module in the ``INSTALLED_APPS`` section of your ``settings.py`` file.
This enables the web push functionality provided by VSTUtils. Additionally,
configure the necessary settings as described in the web push settings section (see :ref:`here<webpush-settings>` for details).
2. **Creating Notifications**: To create a web push notification, you need to define a class that inherits from
either :class:`vstutils.webpush.BaseWebPush` or :class:`vstutils.webpush.BaseWebPushNotification`.
VSTUtils automatically detects and utilizes web push classes defined in the ``webpushes`` module of all ``INSTALLED_APPS``.
Below is an example that illustrates how to implement custom web push classes:


.. literalinclude:: ../test_src/test_proj/webpushes.py
:language: python
:linenos:

This example contains three classes:

- `TestWebPush`: Sends notifications to all subscribed users.
- `TestNotification`: Targets notifications to specific users.
- `StaffOnlyNotification`: Restricts notifications to staff users only. Sometimes you may want to allow only some users to subscribe on specific notifications.

3. **Sending Notifications**: To dispatch a web push notification, invoke the ``send`` or ``send_in_task``
method on an instance of your web push class. For instance, to send a notification using `TestNotification`,
you can do the following:

.. code-block:: python
from test_proj.webpushes import TestNotification
# Sending a notification immediately (synchronously)
TestNotification(name='Some user', user_id=1).send()
# Sending a notification as a background task (asynchronously)
TestNotification.send_in_task(name='Some user', user_id=1)
.. warning::
The asynchronous sending of web push notifications (using methods like ``send_in_task``) requires a configured Celery setup
in your project, as it relies on Celery tasks "under the hood".
Ensure that Celery is properly set up and running to utilize asynchronous notification dispatching.


By following these steps, you can fast integrate and utilize web push notifications in projects with VSTUtils.
1 change: 0 additions & 1 deletion doc/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,6 @@
'sphinx_autodoc_typehints',
'sphinxcontrib.mermaid',
'sphinxcontrib.httpdomain',
'vstutils.api.doc_generator',
'sphinx.ext.intersphinx',
'sphinx.ext.extlinks',
]
Expand Down
Loading

0 comments on commit fd89925

Please sign in to comment.