guillotina-elasticsearch


Nameguillotina-elasticsearch JSON
Version 8.0.9 PyPI version JSON
download
home_pagehttps://github.com/plone/guillotina_elasticsearch
Summaryelasticsearch catalog support for guillotina
upload_time2024-10-21 09:10:04
maintainerNone
docs_urlNone
authorRamon Navarro Bosch & Nathan Van Gheem
requires_pythonNone
licenseGPL version 3
keywords search async guillotina elasticsearch
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            .. contents::

GUILLOTINA_ELASTICSEARCH
========================

.. image:: https://travis-ci.org/guillotinaweb/guillotina_elasticsearch.svg?branch=master
   :target: https://travis-ci.org/guillotinaweb/guillotina_elasticsearch

Elasticsearch integration for guillotina. Supports Elastic search 7.x
and 8.x


Installation
------------

`pip install guillotina_elasticsearch` defaults to Elasticsearch 8.x
support.


Configuration
-------------

config.yaml can include elasticsearch section

.. code-block:: yaml

    elasticsearch:
      index_name_prefix: "guillotina-"
      connection_settings:
        hosts:
          - "http://127.0.0.1:9200"
        sniffer_timeout: 0.5
        sniff_on_start: true
      security_query_builder: "guillotina_elasticsearch.queries.build_security_query"


Example custom `security_query_builder` settings:

.. code-block:: python

    async def security_query_builder(container, request):
        return {
            'query': {
                'bool': {
                    'filter': {
                        'bool': {
                            'should': [{'match': {'access_roles': "foobar"}}],
                            'minimum_should_match': 1
                        }
                    }
                }
            }
        }

Development and testing
-----------------------
Setup your python virtual environment for version >=3,8. Tested with
3.8, 3.9 and 3.10

.. code-block:: bash

   # Linux
   pip install -e ".[test]"
   pytest tests/

By default the tests run an ES fixture with version 8. If you
want to run the tests for ES version 7, change the image version in
the conftest.py


Installation on a site
----------------------

POST SITE_URL/@catalog

{}

Uninstall on a site
-------------------

DELETE SITE_URL/@catalog

{}


Migrate Command
---------------

`guillotina_elasticsearch` comes with a `es-migrate` guillotina command::

    ./bin/g es-migrate


This command will perform a live migration on the index. It does this by
performing the reindex on a new index while the other one is still active.

New index and delete requests are performed on both indexes during live migration.

It is also smart about how to migrate, doing a diff on the mapping and only
reindexing the fields that changed.

Breaking changes in 8.0.0
-------------------------

In this version, the library elasticsearch 7 has been upgraded to
elasticsearch 8. There are some changes that need to be taken into
account in the settings of old elasticsearch config files.

- The hosts field in the guillotina's configuration file, need to
  include the scheme: http or https
- The sniffer_timeout in the guillotina's configureation file, can not be None
- The doc_type has been removed. Specifying types in requests is no longer supported.
- The include_type_name parameter is removed.

The elasticsearch field of the config.yaml file is directly passed to
instantiate AsyncElasticsearch. The class definition is the same of
the synchronous one, to know how to configure your ES take a look at:
https://elasticsearch-py.readthedocs.io/en/v8.12.0/api/elasticsearch.html#elasticsearch.Elasticsearch


Breaking changes in 2.0
-----------------------

- ES 6 does not have doc types support
- aioes deprecated
- IElasticSearchUtility changes:

  - query: doc_type param no longer used

- IElasticSearchUtility.conn changes:

  - put_mapping
  - put_settings
  - put_alias
  - get: needs doc_type=DOC_TYPE
  - bulk: needs doc_type=DOC_TYPE
  - conn.transport.get_connection(): ._session -> .session, ._base_url -> .base_url
  - conn.transport.get_connection().[method] -> need to include content-type: application/json


Testing
-------

If container es (elasticsearch) fails to start when running tests,
you should increase max_map_count. command

.. code-block:: bash

   # Linux
   sudo sysctl -w vm.max_map_count=262144


Index Mappings
--------------

All mappings are flattened when they are applied to Elastic Search.

Elasticsearch doesn't support different mappings for different types.

If there are conflicting mappings, this plugin will choose the mapping
in the addon last `applications` listed which follows the guillotina practice
of allowing the last listed application to override the settings of
the previously list application


Security configuration
----------------------


.. code-block:: yaml

    elasticsearch:
      index_name_prefix: "guillotina-"
      connection_settings:
        hosts:
          - "127.0.0.1:9200"
        sniffer_timeout: 0.5
        sniff_on_start: true
        use_ssl: true
        http_auth: admin:admin

8.0.9 (2024-10-21)
------------------

- Avoiding possible error when getting the index_settings in
  search_raw
  [nilbacardit26]


8.0.8 (2024-10-17)
------------------

- Do not raise an error when the real_index_name is not synchronize
  with the registry when doing a search and calculating the
  max_result_window_value
  [nilbacardit26]


8.0.7 (2024-10-17)
------------------

- Getting items_total from conn.count instead of getting it from the
  hits of the result
  [nilbacardit26]


8.0.6 (2024-10-01)
------------------

- Log results every time data is bulk_inserted when updating
  [nilbacardit26]


8.0.5 (2024-10-01)
------------------

- Do not log results if there are none to show, preventing errors
  [nilbacardit26]


8.0.4 (2024-07-19)
------------------

- Adding the reason of the error when migrating
- Adding query parameter to the get_doc_count coroutine 
  [nilbacardit26]


8.0.3 (2024-04-10)
------------------

- Adding search analyzers functionality
  [nilbacardit26]


8.0.2 (2024-03-25)
------------------

- Being able to search using multifields
  [nilbacardit26]


8.0.1 (2024-03-21)
------------------

- Adding missing index kwarg when deleting the index in the middle
  of a migration
  [nilbacardit26]


8.0.0 (2024-01-23)
------------------

- Support for elasticsearch 8.
- Changing ES fixture to bitnami version 8. Tests passing for both
  versions
- Removing deprecated doc_type argument from get calls.
- Dropping support for elastic search 6.x
  [nilbacardit26]


7.0.5 (2023-12-20)
------------------

- Fixing applications in __init__.py: Removing
  guillotina_elasticsearch from it


7.0.4 (2023-12-15)
------------------

- Not adding a slash in the __start modifier of the parser if it is
  already included from the base parser.


7.0.3 (2023-02-08)
------------------

- Adding multifields functionality, mutlifields param can be passed to
  index_field. Useful when wanting to index the same field in
  different ways


7.0.2 (2022-11-23)
------------------

- Being able to build mappings properties with normalizers
  [nilbacardit26]


7.0.1 (2022-10-28)
------------------

- Fix potential indexing bug when full=True and reindex_security=True
  [masipcat]

- Being able to build mappings properties with analyzers
  [nilbacardit26]


7.0.0 (2022-03-16)
------------------

- Adapt guillotina_elasticserach code to guillotina 6.4 breaking changes
  [masipcat]


7.0.0a7 (2021-09-14)
--------------------

- Fix guillotina_elasticserach 7.0.0a6 doesn't load catalog automatically as before
  [masipcat]


7.0.0a6 (2021-09-13)
--------------------

- [BREAKING CHANGE] Remove 'sub indexes' logic
  [masipcat]
- Minor changes to ElasticSearchUtility
  [masipcat]
- Remove deprecated parameter 'doc_type'
  [masipcat]
- ElasticSearchUtility: removed obsolete methods get_by_uuid(), get_by_uuids(),
  get_by_type() and get_by_type()
  [masipcat]
- ElasticSearchUtility: removed unused internal method _get_type_query()
  [masipcat]
- Solving bug when searching within the same context that starts by
  the same path. ej: /container/folder/type_one and /container/folder/type.
  [nilbacardit26]
- Enlarging the max time to wait for the ES docker container. Useful
  when passing test with xdist with multiple threads.
  [nilbacardit26]


7.0.0a5 (2021-07-30)
--------------------

- Modifying the parse to be able to parse the __or field as a list of elements. Eg:
  catalog_utility.search({"type_name__or": ["Folder", "Item"]})
  [nilbacardit26]


7.0.0a4 (2021-07-15)
--------------------

- Adding path as a wildcard in the parser. Searches will be done
  within the same context using the endpoint @search. FYI: If no depth is
  specified, the query resolves greater or equal than the content depth of the context plus one
  [nilbacardit26]


7.0.0a3 (2021-06-22)
--------------------

- Fixing the date parser. Using the default format
  strict_date_optional_time instead of using the epoch_millis that
  leads to the error: failed to parse date field [1.624173663E9].


7.0.0a2 (2021-06-09)
--------------------

- Added __or in parser. With this we can query keywords with the or
  operator like: `type_name=Item&__or=id=foo_item%26id=foo_item2`
  [nilbacardit26]


7.0.0a1 (2021-06-04)
--------------------

- Unrestricted parameter added to search_raw, in order to search as root
  [nilbacardit26]


7.0.0a0 (2021-05-03)
--------------------

- Replace aioelasticsearch with elasticsearchpy
  [masipcat]

- Dropped support for Elasticsearch 6.x
  [masipcat]


6.0.3 (2021-04-30)
------------------

- Disable dynamic mapping (as it was in v3.x)
  [masipcat]

- Fix tm is None when migration is cancelled
  [masipcat]


6.0.2 (2021-04-21)
------------------

- Allow to search on context object
  [bloodbare]

- Fix tests not passing
  [masipcat]


6.0.1 (2021-03-02)
------------------

- Replacing _from to from in Parser's __call__ [nilbacardit26]


6.0.0 (2020-07-10)
------------------

- Changed es_requester fixture to only cleanup indices that match 'index_name_prefix'


6.0.0a2 (2020-05-12)
--------------------

- Support es6 and es7 [lferran]

- Add github actions and remove travis [lferran]

- Add setting 'refresh'
  [masipcat]

- Check code format
  [acatlla]


6.0.0a1 (2020-03-25)
--------------------

- Move default settings definition to function `default_settings()`
  [masipcat]


6.0.0a0 (2020-03-12)
--------------------

- Support Guillotina 6
  [masipcat]

- Support elasticsearch 7.0
  [jordic]

- Make sure to save sub index changes in ES
  [vangheem]

- Fix default index settings
  [vangheem]

- Pinned aioelasticsearch to <0.6.0
  [masipcat]

- Be able to import types
  [vangheem]

- Retry conflict errors on delete by query

- Pay attention to trashed objects in pg
- Fix commands using missing attribute `self.request`

- ISecurityInfo can be async

- Fix not iterating over all content indexes in elasticsearch
  [vangheem]

- build_security_query(): changed 'query.bool.filter' to use a list instead of a single object
  [masipcat]

- Fix release

- Missing pg conn lock with vacuuming
  [vangheem]

- Pass request on the index progress when possible

- Fix release

- Do not require request object for vacuuming
  [vangheem]

- G5 support
  [vangheem]

- Do not close indexes on create/delete
  [vangheem]

- Handle another index not found error on vacuum
  [vangheem]

- logging
  [vangheem]

- Handle index not found error
  [vangheem]


5.0.0 (2019-10-21)
------------------

- final


5.0.0a3 (2019-10-21)
--------------------

- more G5 fixes


5.0.0a2 (2019-06-21)
--------------------

- Add parser to work with g5 automatic parsing

- Use `@id` in results results instead of `@absolute_url`


5.0.0a1 (2019-06-19)
--------------------

- Support only elasticsearch 7

- We may want to pin newest version of aioelasticsearch when that also
  supports ES7: https://github.com/aio-libs/aioelasticsearch/pull/165

- Check supported ES version on utility initialize

- Validate index name does not have ':' characters

[lferran]

3.4.0 (2019-05-28)
------------------

- Support for elasticsearch 7
  [bloodbare]


3.3.1 (2019-05-20)
------------------

- Handle `ModuleNotFoundError` error in vacuum
  [vangheem]


3.3.0 (2019-04-10)
------------------

- Be able to customize how you create es connection object
  [vangheem]

- Not loading utility by default and avoid crash when utility is not configured
  [bloodbare]

- Support for opendistro
  [vangheem]


3.2.6 (2019-02-18)
------------------

- Make sure to use transaction lock in vacuum
  [vangheem]

3.2.5 (2019-02-08)
------------------

- be able to customize security query by customizing
  `elasticsearch["security_query_builder"]` setting.
  [vangheem]


3.2.4 (2019-02-05)
------------------

- include highlight in results
  [vangheem]


3.2.3 (2019-01-31)
------------------

- Add 'creation_date', 'modification_date', 'tags' to stored fields
  [vangheem]

- Log indexing errors
  [vangheem]


3.2.2 (2019-01-26)
------------------

- Resolve mapping conflicts in a smarter way that allows addons
  to override base packages/guillotina
  [vangheem]

3.2.1 (2019-01-25)
------------------

- vacuum should work with customized pg table names
  [vangheem]

- Use cursor for iterating over data
  [vangheem]


3.2.0 (2018-12-12)
------------------

- Add kw argument `cache=True` to `Migrator` and `Reindexer` to choose
  overwrite the txn._cache or not [masipcat]
- Prevent more than one index_field define different mappings
  [masipcat]
- Remove use of clear_conn_statement_cache
  [vangheem]


3.1.0 (2018-11-20)
------------------

- upgrade to guillotina >= 4.3.0
  [vangheem]

- Fix indexing when object does not yet exist in index
  [vangheem]

- Fix tid check in vacuum
  [vangheem]


3.0.26 (2018-07-19)
-------------------

- The guillotina.async import is a syntax error on python 3.7
  [vangheem]

- Don't fail on CREATE_INDEX


3.0.25 (2018-06-18)
-------------------

- Do not reprocess if tid is not present in data
  [vangheem]

- retry conflict errors and thread pool exceeded errors
  [vangheem]


3.0.24 (2018-06-13)
-------------------

- add pg index to make vacuuming faster
  [vangheem]


3.0.23 (2018-06-11)
-------------------

- Handle TypeError when vacuuming
  [vangheem]


3.0.22 (2018-06-08)
-------------------

- Upgrade vacuum command to work with moved content
  that wasn't reindexed correctly
  [vangheem]


3.0.21 (2018-06-07)
-------------------

- Fix compatibility with guillotina 4
  [vangheem]


3.0.20 (2018-05-31)
-------------------

- Fix last


3.0.19 (2018-05-31)
-------------------

- utilize ignore_unavailable for elasticsearch queries
  [vangheem]


3.0.18 (2018-05-30)
-------------------

- Also handle ModuleNotFoundError when migrating data
  [vangheem]


3.0.17 (2018-05-29)
-------------------

- Handle running migration when existing index does not exist
  [vangheem]

- Make sure to refresh object before writing to it.
  [vangheem]


3.0.16 (2018-05-29)
-------------------

- Raise QueryErrorException instead of returning it
  [vangheem]


3.0.15 (2018-05-25)
-------------------

- Fix update_by_query indexes param
  [vangheem]


3.0.14 (2018-05-25)
-------------------

- be able to provide context for update_by_query
  [vangheem]


3.0.13 (2018-05-25)
-------------------

- Fix vacuuming with sub indexes
  [vangheem]


3.0.12 (2018-05-24)
-------------------

- fix format_hit handling of list fields better
  [vangheem]


3.0.11 (2018-05-24)
-------------------

- Provide format_hit util
  [vangheem]


3.0.10 (2018-05-23)
-------------------

- Add more stored fields
  [vangheem]


3.0.9 (2018-05-23)
------------------

- add backoff for some elasticsearch operations
  [vangheem]


3.0.8 (2018-05-22)
------------------

- make IIndexManager.get_schemas async
  [vangheem]


3.0.7 (2018-05-21)
------------------

- Handle missing __parent__
  [vangheem]


3.0.6 (2018-05-21)
------------------

- Fix bug in reindexing security for children of sub indexes
  [vangheem]


3.0.5 (2018-05-21)
------------------

- Fix release
  [vangheem]


3.0.4 (2018-05-21)
------------------

- cleanup_es accepts a prefix value
  [vangheem]


3.0.3 (2018-05-21)
------------------

- provide get_index_for util
  [vangheem]

- provide cleanup_es test util
  [vangheem]

- fix storing annotation data on sub index
  [vangheem]

- get_by_path should accept index param
  [vangheem]


3.0.2 (2018-05-21)
------------------

- Fix release
  [vangheem]

- add utils.get_all_indexes_identifier
  [vangheem]


3.0.1 (2018-05-21)
------------------

- Create index with mappings/indexes instead of updating them after creation
  [vangheem]

- Add `es-fields` command to inspect configured fields
  [vangheem]


3.0.0 (2018-05-19)
------------------

- Add support for sub indexes
  [vangheem]

- Raise exception instead of returning ErrorResponse
  [vangheem]

- Add scroll support to query
  [gitcarbs]

2.0.1 (2018-05-10)
------------------

- Add more logging for migrations
  [vangheem]

- Added IIndexProgress to hook on reindex process
- Added new event on reindex start.
- Added context to the IIndexProgress event
  [jordic]


2.0.0 (2018-05-06)
------------------

- replace aioes(unsupported) with aioelasticsearch
  [vangheem]

- Elasticsearch 6 compatibility.
  [vangheem]


1.3.13 (2018-05-02)
-------------------

- Format stored field results like source results
  [vangheem]


1.3.12 (2018-05-01)
-------------------

- More vacuum improvements


1.3.11 (2018-04-30)
-------------------

- More vacuum improvements
  [vangheem]

1.3.10 (2018-04-30)
-------------------

- migrate script should not use transactions
  [vangheem]

1.3.9 (2018-04-30)
------------------

- Optimized vacuum script to use tid sorting which should prevent
  needing to go through so many docs to do the vacuum check
  [vangheem]


1.3.8 (2018-04-27)
------------------

- Provide `@name` in results
  [vangheem]


1.3.7 (2018-04-26)
------------------

- change `@id` in search results to `@uid`
  [vangheem]

- Add support for analysis character filter
  [gitcarbs]


1.3.6 (2018-04-18)
------------------

- Work with store=true mappings
  [vangheem]


1.3.5 (2018-04-15)
------------------

- Smaller bulk sizes for es vacuum
  [vangheem]


1.3.4 (2018-04-15)
------------------

- Some performance fixes for vacuuming
  [vangheem]


1.3.3 (2018-04-14)
------------------

- Provide profile data in results
  [gitcarbs]


1.3.2 (2018-04-03)
------------------

- Upgrade tests to use pytest-docker-fixtures
  [vangheem]


1.3.1 (2018-03-14)
------------------

- Pay attention to `index_data` configuration
  [vangheem]


1.3.0 (2018-03-14)
------------------

- Upgrade to work with guillotina 2.4.x
  [vangheem]


1.2.11 (2018-03-09)
-------------------

- Implement statement cache clearing
  [vangheem]


1.2.10 (2018-03-02)
-------------------

- Do not use cached statement for vacuum
  [vangheem]


1.2.9 (2018-02-07)
------------------

- Handle errors unpickling object for es vacuum
  [vangheem]


1.2.8 (2018-01-11)
------------------

- Make sure to change transaction strategy for commands
  [vangheem]


1.2.7 (2018-01-08)
------------------

- Make sure to close out connection in commands
  [vangheem]


1.2.6 (2017-12-18)
------------------

- Use `traverse` instead of `do_traverse`.
  [vangheem]


1.2.5 (2017-12-08)
------------------

- Retry on conflict for updates
  [vangheem]


1.2.4 (2017-12-06)
------------------

- Use futures instead of threads for migrations
  [vangheem]


1.2.3 (2017-11-21)
------------------

- Upgrade testing infrastructure with latest guillotina
  [vangheem]


1.2.2 (2017-11-08)
------------------

- Fix test setup with jenkins
  [vangheem]


1.2.1 (2017-11-08)
------------------

- Make logging less noisy
  [vangheem]


1.2.0 (2017-11-06)
------------------

- Upgrade to guillotina 2.0.0
  [vangheem]


1.1.24 (2017-10-12)
-------------------

- Close connection after done in vacuum command
  [vangheem]


1.1.23 (2017-10-09)
-------------------

- Make sure to use `async with` syntax for manual api calls to elasticsearch using
  session object.
  [vangheem]


1.1.22 (2017-09-28)
-------------------

- Another tweak for missing indexes on running migration
  [vangheem]


1.1.21 (2017-09-21)
-------------------

- All indexing/removing operations are already in a future so no need to add futures
  to operations.
  [vangheem]


1.1.20 (2017-09-21)
-------------------

- Use latest guillotina futures request api
  [vangheem]


1.1.19 (2017-09-14)
-------------------

- Change page size and scroll of esvacuum to prevent timeouts
  [vangheem]


1.1.18 (2017-08-22)
-------------------

- Fix TIDConflictError when registry is edited during a migration.
  [vangheem]


1.1.17 (2017-08-11)
-------------------

- Handle missing types from migrations when mappings change better
  [vangheem]


1.1.16 (2017-08-09)
-------------------

- Results from search should return sort value
  [gitcarbs]


1.1.15 (2017-07-28)
-------------------

- Fix vacuum to handle empty scroll errors when iterating through all keys
  [vangheem]


1.1.14 (2017-07-21)
-------------------

- Fix deadlock issue on unindex when migration is active
  [vangheem]


1.1.13 (2017-07-12)
-------------------

- Wait a bit before running migration so addons that use async to calculate
  dynamic types can load


1.1.12 (2017-07-12)
-------------------

- Fix scenario where doc type is missing in the upgraded mapping
  [vangheem]


1.1.11 (2017-07-10)
-------------------

- Add update_by_query method
  [vangheem]


1.1.10 (2017-07-06)
-------------------

- Add reindex command
  [vangheem]


1.1.9 (2017-07-06)
------------------

- Fix invalid import in migrate script
  [vangheem]


1.1.8 (2017-07-05)
------------------

- Add more logging for vacuum
  [vangheem]


1.1.7 (2017-06-29)
------------------

- Add vacuum command
  [vangheem]


1.1.6 (2017-06-23)
------------------

- Fix group query to not prepend 'group:' to security query for groups
  [vangheem]


1.1.5 (2017-06-21)
------------------

- Fix migration when objects were deleted while migrating that were thought to
  be orphaned
  [vangheem]


1.1.4 (2017-06-20)
------------------

- Prevent auto mapping of metadata
  [bloodbare]


1.1.3 (2017-06-15)
------------------

- Fix reindexing
  [vangheem]


1.1.2 (2017-06-15)
------------------

- Fix import for client_exceptions aiohttp errors
  [vangheem]


1.1.1 (2017-06-09)
------------------

- Move fixtures out of conftest.py into it's own module. This could break
  tests that depend on it!
  [vangheem]


1.1.0 (2017-06-09)
------------------

- Add Reindexer utility that specializes just in reindexing instead of
  using the migrator
  [vangheem]


1.0.29 (2017-06-08)
-------------------

- Clean mapping before it's compared to prevent false positives for detecting
  differences in mappings
  [vangheem]


1.0.28 (2017-06-08)
-------------------

- Be able to migrate the mapping only and skip working through content on the site
  [vangheem]


1.0.27 (2017-06-07)
-------------------

- Make sure to flush reindexed items when calling reindex_all_content
  [vangheem]


1.0.26 (2017-05-26)
-------------------

- When adding groups to query that is built, make sure to prepend each group with
  "group:" so we can distinguish groups from users and somehow can not potentially
  hack it where they add a "root" group they are a part of
  [vangheem]


1.0.25 (2017-05-26)
-------------------

- Handle potential issue where data is changing while you're doing the reindex
  [vangheem]


1.0.24 (2017-05-26)
-------------------

- Fix issue where a bad original index would screw up index diff calculation
  [vangheem]

- Fix migration failure issue before flipping new index on
  [vangheem]


1.0.23 (2017-05-25)
-------------------

- Fix reindexing on security change
  [vangheem]

1.0.22 (2017-05-19)
-------------------

- Be able to cancel migration and have it do some cleanup
  [vangheem]


1.0.21 (2017-05-19)
-------------------

- A bunch of migration fixes to make it more resilient
  [vangheem]


1.0.20 (2017-05-18)
-------------------

- Implement live migration command
  [vangheem]


1.0.19 (2017-05-16)
-------------------

- Reindex with clean option should delete, re-create index
  [vangheem]


1.0.18 (2017-05-16)
-------------------

- Use dummy cache on reindex for all request types
  [vangheem]

1.0.17 (2017-05-16)
-------------------

- Disable caching when reindexing
  [vangheem]


1.0.16 (2017-05-15)
-------------------

- Use threads when bulk indexing on elasticsearch to make sure to always
  keep elasticsearch busy.
  [vangheem]

- Forcing the update of mapping
  [bloodbare]


1.0.15 (2017-05-12)
-------------------

- close and open the indices to define the settings
  [bloodbare]

1.0.14 (2017-05-12)
-------------------

- Enabling size on query by type
  [bloodbare]


1.0.13 (2017-05-11)
-------------------

- Also set settings on force_mappings
  [bloodare]


1.0.12 (2017-05-11)
-------------------

- Changing permissions name to guillotina
  [bloodbare]


1.0.11 (2017-05-11)
-------------------

- Option to set the mapping without reindexing in case of mapping mutation
  [bloodbare]


1.0.10 (2017-05-09)
-------------------

- Fix --update-missing argument with `es-reindex` command
  [vangheem]


1.0.9 (2017-05-09)
------------------

- Fix bug when deleting nodes
  [bloodbare]


1.0.8 (2017-05-08)
------------------

- Improve performance of reindexing of bushy content by using asyncio.gather
  to traverse sub-trees and index at the same time.
  [vangheem]

- Improve options to reindex command
  [vangheem]


1.0.7 (2017-05-04)
------------------

- reindex_all_content takes update and update_missing params now
  [vangheem]


1.0.6 (2017-05-03)
------------------

- Be able to update from an existing reindex
  [vangheem]


1.0.5 (2017-05-02)
------------------

- Need to avoid using long running queries on reindex because they can timeout
  for very large folders
  [vangheem]


1.0.4 (2017-05-02)
------------------

- optimize reindex more
  [vangheem]


1.0.3 (2017-05-02)
------------------

- More memory efficient reindex
  [vangheem]


1.0.2 (2017-05-02)
------------------

- Fix reindexing content
  [vangheem]


1.0.1 (2017-04-25)
------------------

- Provide as async utility as it allows us to close connections when the object
  is destroyed
  [vangheem]


1.0.0 (2017-04-24)
------------------

- initial release

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/plone/guillotina_elasticsearch",
    "name": "guillotina-elasticsearch",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "search async guillotina elasticsearch",
    "author": "Ramon Navarro Bosch & Nathan Van Gheem",
    "author_email": "ramon@plone.org",
    "download_url": "https://files.pythonhosted.org/packages/cb/0b/475bdd7f98cfc5b60a266400b032695cdc3c1fa16dc1a4b009073600536f/guillotina_elasticsearch-8.0.9.tar.gz",
    "platform": null,
    "description": ".. contents::\n\nGUILLOTINA_ELASTICSEARCH\n========================\n\n.. image:: https://travis-ci.org/guillotinaweb/guillotina_elasticsearch.svg?branch=master\n   :target: https://travis-ci.org/guillotinaweb/guillotina_elasticsearch\n\nElasticsearch integration for guillotina. Supports Elastic search 7.x\nand 8.x\n\n\nInstallation\n------------\n\n`pip install guillotina_elasticsearch` defaults to Elasticsearch 8.x\nsupport.\n\n\nConfiguration\n-------------\n\nconfig.yaml can include elasticsearch section\n\n.. code-block:: yaml\n\n    elasticsearch:\n      index_name_prefix: \"guillotina-\"\n      connection_settings:\n        hosts:\n          - \"http://127.0.0.1:9200\"\n        sniffer_timeout: 0.5\n        sniff_on_start: true\n      security_query_builder: \"guillotina_elasticsearch.queries.build_security_query\"\n\n\nExample custom `security_query_builder` settings:\n\n.. code-block:: python\n\n    async def security_query_builder(container, request):\n        return {\n            'query': {\n                'bool': {\n                    'filter': {\n                        'bool': {\n                            'should': [{'match': {'access_roles': \"foobar\"}}],\n                            'minimum_should_match': 1\n                        }\n                    }\n                }\n            }\n        }\n\nDevelopment and testing\n-----------------------\nSetup your python virtual environment for version >=3,8. Tested with\n3.8, 3.9 and 3.10\n\n.. code-block:: bash\n\n   # Linux\n   pip install -e \".[test]\"\n   pytest tests/\n\nBy default the tests run an ES fixture with version 8. If you\nwant to run the tests for ES version 7, change the image version in\nthe conftest.py\n\n\nInstallation on a site\n----------------------\n\nPOST SITE_URL/@catalog\n\n{}\n\nUninstall on a site\n-------------------\n\nDELETE SITE_URL/@catalog\n\n{}\n\n\nMigrate Command\n---------------\n\n`guillotina_elasticsearch` comes with a `es-migrate` guillotina command::\n\n    ./bin/g es-migrate\n\n\nThis command will perform a live migration on the index. It does this by\nperforming the reindex on a new index while the other one is still active.\n\nNew index and delete requests are performed on both indexes during live migration.\n\nIt is also smart about how to migrate, doing a diff on the mapping and only\nreindexing the fields that changed.\n\nBreaking changes in 8.0.0\n-------------------------\n\nIn this version, the library elasticsearch 7 has been upgraded to\nelasticsearch 8. There are some changes that need to be taken into\naccount in the settings of old elasticsearch config files.\n\n- The hosts field in the guillotina's configuration file, need to\n  include the scheme: http or https\n- The sniffer_timeout in the guillotina's configureation file, can not be None\n- The doc_type has been removed. Specifying types in requests is no longer supported.\n- The include_type_name parameter is removed.\n\nThe elasticsearch field of the config.yaml file is directly passed to\ninstantiate AsyncElasticsearch. The class definition is the same of\nthe synchronous one, to know how to configure your ES take a look at:\nhttps://elasticsearch-py.readthedocs.io/en/v8.12.0/api/elasticsearch.html#elasticsearch.Elasticsearch\n\n\nBreaking changes in 2.0\n-----------------------\n\n- ES 6 does not have doc types support\n- aioes deprecated\n- IElasticSearchUtility changes:\n\n  - query: doc_type param no longer used\n\n- IElasticSearchUtility.conn changes:\n\n  - put_mapping\n  - put_settings\n  - put_alias\n  - get: needs doc_type=DOC_TYPE\n  - bulk: needs doc_type=DOC_TYPE\n  - conn.transport.get_connection(): ._session -> .session, ._base_url -> .base_url\n  - conn.transport.get_connection().[method] -> need to include content-type: application/json\n\n\nTesting\n-------\n\nIf container es (elasticsearch) fails to start when running tests,\nyou should increase max_map_count. command\n\n.. code-block:: bash\n\n   # Linux\n   sudo sysctl -w vm.max_map_count=262144\n\n\nIndex Mappings\n--------------\n\nAll mappings are flattened when they are applied to Elastic Search.\n\nElasticsearch doesn't support different mappings for different types.\n\nIf there are conflicting mappings, this plugin will choose the mapping\nin the addon last `applications` listed which follows the guillotina practice\nof allowing the last listed application to override the settings of\nthe previously list application\n\n\nSecurity configuration\n----------------------\n\n\n.. code-block:: yaml\n\n    elasticsearch:\n      index_name_prefix: \"guillotina-\"\n      connection_settings:\n        hosts:\n          - \"127.0.0.1:9200\"\n        sniffer_timeout: 0.5\n        sniff_on_start: true\n        use_ssl: true\n        http_auth: admin:admin\n\n8.0.9 (2024-10-21)\n------------------\n\n- Avoiding possible error when getting the index_settings in\n  search_raw\n  [nilbacardit26]\n\n\n8.0.8 (2024-10-17)\n------------------\n\n- Do not raise an error when the real_index_name is not synchronize\n  with the registry when doing a search and calculating the\n  max_result_window_value\n  [nilbacardit26]\n\n\n8.0.7 (2024-10-17)\n------------------\n\n- Getting items_total from conn.count instead of getting it from the\n  hits of the result\n  [nilbacardit26]\n\n\n8.0.6 (2024-10-01)\n------------------\n\n- Log results every time data is bulk_inserted when updating\n  [nilbacardit26]\n\n\n8.0.5 (2024-10-01)\n------------------\n\n- Do not log results if there are none to show, preventing errors\n  [nilbacardit26]\n\n\n8.0.4 (2024-07-19)\n------------------\n\n- Adding the reason of the error when migrating\n- Adding query parameter to the get_doc_count coroutine \n  [nilbacardit26]\n\n\n8.0.3 (2024-04-10)\n------------------\n\n- Adding search analyzers functionality\n  [nilbacardit26]\n\n\n8.0.2 (2024-03-25)\n------------------\n\n- Being able to search using multifields\n  [nilbacardit26]\n\n\n8.0.1 (2024-03-21)\n------------------\n\n- Adding missing index kwarg when deleting the index in the middle\n  of a migration\n  [nilbacardit26]\n\n\n8.0.0 (2024-01-23)\n------------------\n\n- Support for elasticsearch 8.\n- Changing ES fixture to bitnami version 8. Tests passing for both\n  versions\n- Removing deprecated doc_type argument from get calls.\n- Dropping support for elastic search 6.x\n  [nilbacardit26]\n\n\n7.0.5 (2023-12-20)\n------------------\n\n- Fixing applications in __init__.py: Removing\n  guillotina_elasticsearch from it\n\n\n7.0.4 (2023-12-15)\n------------------\n\n- Not adding a slash in the __start modifier of the parser if it is\n  already included from the base parser.\n\n\n7.0.3 (2023-02-08)\n------------------\n\n- Adding multifields functionality, mutlifields param can be passed to\n  index_field. Useful when wanting to index the same field in\n  different ways\n\n\n7.0.2 (2022-11-23)\n------------------\n\n- Being able to build mappings properties with normalizers\n  [nilbacardit26]\n\n\n7.0.1 (2022-10-28)\n------------------\n\n- Fix potential indexing bug when full=True and reindex_security=True\n  [masipcat]\n\n- Being able to build mappings properties with analyzers\n  [nilbacardit26]\n\n\n7.0.0 (2022-03-16)\n------------------\n\n- Adapt guillotina_elasticserach code to guillotina 6.4 breaking changes\n  [masipcat]\n\n\n7.0.0a7 (2021-09-14)\n--------------------\n\n- Fix guillotina_elasticserach 7.0.0a6 doesn't load catalog automatically as before\n  [masipcat]\n\n\n7.0.0a6 (2021-09-13)\n--------------------\n\n- [BREAKING CHANGE] Remove 'sub indexes' logic\n  [masipcat]\n- Minor changes to ElasticSearchUtility\n  [masipcat]\n- Remove deprecated parameter 'doc_type'\n  [masipcat]\n- ElasticSearchUtility: removed obsolete methods get_by_uuid(), get_by_uuids(),\n  get_by_type() and get_by_type()\n  [masipcat]\n- ElasticSearchUtility: removed unused internal method _get_type_query()\n  [masipcat]\n- Solving bug when searching within the same context that starts by\n  the same path. ej: /container/folder/type_one and /container/folder/type.\n  [nilbacardit26]\n- Enlarging the max time to wait for the ES docker container. Useful\n  when passing test with xdist with multiple threads.\n  [nilbacardit26]\n\n\n7.0.0a5 (2021-07-30)\n--------------------\n\n- Modifying the parse to be able to parse the __or field as a list of elements. Eg:\n  catalog_utility.search({\"type_name__or\": [\"Folder\", \"Item\"]})\n  [nilbacardit26]\n\n\n7.0.0a4 (2021-07-15)\n--------------------\n\n- Adding path as a wildcard in the parser. Searches will be done\n  within the same context using the endpoint @search. FYI: If no depth is\n  specified, the query resolves greater or equal than the content depth of the context plus one\n  [nilbacardit26]\n\n\n7.0.0a3 (2021-06-22)\n--------------------\n\n- Fixing the date parser. Using the default format\n  strict_date_optional_time instead of using the epoch_millis that\n  leads to the error: failed to parse date field [1.624173663E9].\n\n\n7.0.0a2 (2021-06-09)\n--------------------\n\n- Added __or in parser. With this we can query keywords with the or\n  operator like: `type_name=Item&__or=id=foo_item%26id=foo_item2`\n  [nilbacardit26]\n\n\n7.0.0a1 (2021-06-04)\n--------------------\n\n- Unrestricted parameter added to search_raw, in order to search as root\n  [nilbacardit26]\n\n\n7.0.0a0 (2021-05-03)\n--------------------\n\n- Replace aioelasticsearch with elasticsearchpy\n  [masipcat]\n\n- Dropped support for Elasticsearch 6.x\n  [masipcat]\n\n\n6.0.3 (2021-04-30)\n------------------\n\n- Disable dynamic mapping (as it was in v3.x)\n  [masipcat]\n\n- Fix tm is None when migration is cancelled\n  [masipcat]\n\n\n6.0.2 (2021-04-21)\n------------------\n\n- Allow to search on context object\n  [bloodbare]\n\n- Fix tests not passing\n  [masipcat]\n\n\n6.0.1 (2021-03-02)\n------------------\n\n- Replacing _from to from in Parser's __call__ [nilbacardit26]\n\n\n6.0.0 (2020-07-10)\n------------------\n\n- Changed es_requester fixture to only cleanup indices that match 'index_name_prefix'\n\n\n6.0.0a2 (2020-05-12)\n--------------------\n\n- Support es6 and es7 [lferran]\n\n- Add github actions and remove travis [lferran]\n\n- Add setting 'refresh'\n  [masipcat]\n\n- Check code format\n  [acatlla]\n\n\n6.0.0a1 (2020-03-25)\n--------------------\n\n- Move default settings definition to function `default_settings()`\n  [masipcat]\n\n\n6.0.0a0 (2020-03-12)\n--------------------\n\n- Support Guillotina 6\n  [masipcat]\n\n- Support elasticsearch 7.0\n  [jordic]\n\n- Make sure to save sub index changes in ES\n  [vangheem]\n\n- Fix default index settings\n  [vangheem]\n\n- Pinned aioelasticsearch to <0.6.0\n  [masipcat]\n\n- Be able to import types\n  [vangheem]\n\n- Retry conflict errors on delete by query\n\n- Pay attention to trashed objects in pg\n- Fix commands using missing attribute `self.request`\n\n- ISecurityInfo can be async\n\n- Fix not iterating over all content indexes in elasticsearch\n  [vangheem]\n\n- build_security_query(): changed 'query.bool.filter' to use a list instead of a single object\n  [masipcat]\n\n- Fix release\n\n- Missing pg conn lock with vacuuming\n  [vangheem]\n\n- Pass request on the index progress when possible\n\n- Fix release\n\n- Do not require request object for vacuuming\n  [vangheem]\n\n- G5 support\n  [vangheem]\n\n- Do not close indexes on create/delete\n  [vangheem]\n\n- Handle another index not found error on vacuum\n  [vangheem]\n\n- logging\n  [vangheem]\n\n- Handle index not found error\n  [vangheem]\n\n\n5.0.0 (2019-10-21)\n------------------\n\n- final\n\n\n5.0.0a3 (2019-10-21)\n--------------------\n\n- more G5 fixes\n\n\n5.0.0a2 (2019-06-21)\n--------------------\n\n- Add parser to work with g5 automatic parsing\n\n- Use `@id` in results results instead of `@absolute_url`\n\n\n5.0.0a1 (2019-06-19)\n--------------------\n\n- Support only elasticsearch 7\n\n- We may want to pin newest version of aioelasticsearch when that also\n  supports ES7: https://github.com/aio-libs/aioelasticsearch/pull/165\n\n- Check supported ES version on utility initialize\n\n- Validate index name does not have ':' characters\n\n[lferran]\n\n3.4.0 (2019-05-28)\n------------------\n\n- Support for elasticsearch 7\n  [bloodbare]\n\n\n3.3.1 (2019-05-20)\n------------------\n\n- Handle `ModuleNotFoundError` error in vacuum\n  [vangheem]\n\n\n3.3.0 (2019-04-10)\n------------------\n\n- Be able to customize how you create es connection object\n  [vangheem]\n\n- Not loading utility by default and avoid crash when utility is not configured\n  [bloodbare]\n\n- Support for opendistro\n  [vangheem]\n\n\n3.2.6 (2019-02-18)\n------------------\n\n- Make sure to use transaction lock in vacuum\n  [vangheem]\n\n3.2.5 (2019-02-08)\n------------------\n\n- be able to customize security query by customizing\n  `elasticsearch[\"security_query_builder\"]` setting.\n  [vangheem]\n\n\n3.2.4 (2019-02-05)\n------------------\n\n- include highlight in results\n  [vangheem]\n\n\n3.2.3 (2019-01-31)\n------------------\n\n- Add 'creation_date', 'modification_date', 'tags' to stored fields\n  [vangheem]\n\n- Log indexing errors\n  [vangheem]\n\n\n3.2.2 (2019-01-26)\n------------------\n\n- Resolve mapping conflicts in a smarter way that allows addons\n  to override base packages/guillotina\n  [vangheem]\n\n3.2.1 (2019-01-25)\n------------------\n\n- vacuum should work with customized pg table names\n  [vangheem]\n\n- Use cursor for iterating over data\n  [vangheem]\n\n\n3.2.0 (2018-12-12)\n------------------\n\n- Add kw argument `cache=True` to `Migrator` and `Reindexer` to choose\n  overwrite the txn._cache or not [masipcat]\n- Prevent more than one index_field define different mappings\n  [masipcat]\n- Remove use of clear_conn_statement_cache\n  [vangheem]\n\n\n3.1.0 (2018-11-20)\n------------------\n\n- upgrade to guillotina >= 4.3.0\n  [vangheem]\n\n- Fix indexing when object does not yet exist in index\n  [vangheem]\n\n- Fix tid check in vacuum\n  [vangheem]\n\n\n3.0.26 (2018-07-19)\n-------------------\n\n- The guillotina.async import is a syntax error on python 3.7\n  [vangheem]\n\n- Don't fail on CREATE_INDEX\n\n\n3.0.25 (2018-06-18)\n-------------------\n\n- Do not reprocess if tid is not present in data\n  [vangheem]\n\n- retry conflict errors and thread pool exceeded errors\n  [vangheem]\n\n\n3.0.24 (2018-06-13)\n-------------------\n\n- add pg index to make vacuuming faster\n  [vangheem]\n\n\n3.0.23 (2018-06-11)\n-------------------\n\n- Handle TypeError when vacuuming\n  [vangheem]\n\n\n3.0.22 (2018-06-08)\n-------------------\n\n- Upgrade vacuum command to work with moved content\n  that wasn't reindexed correctly\n  [vangheem]\n\n\n3.0.21 (2018-06-07)\n-------------------\n\n- Fix compatibility with guillotina 4\n  [vangheem]\n\n\n3.0.20 (2018-05-31)\n-------------------\n\n- Fix last\n\n\n3.0.19 (2018-05-31)\n-------------------\n\n- utilize ignore_unavailable for elasticsearch queries\n  [vangheem]\n\n\n3.0.18 (2018-05-30)\n-------------------\n\n- Also handle ModuleNotFoundError when migrating data\n  [vangheem]\n\n\n3.0.17 (2018-05-29)\n-------------------\n\n- Handle running migration when existing index does not exist\n  [vangheem]\n\n- Make sure to refresh object before writing to it.\n  [vangheem]\n\n\n3.0.16 (2018-05-29)\n-------------------\n\n- Raise QueryErrorException instead of returning it\n  [vangheem]\n\n\n3.0.15 (2018-05-25)\n-------------------\n\n- Fix update_by_query indexes param\n  [vangheem]\n\n\n3.0.14 (2018-05-25)\n-------------------\n\n- be able to provide context for update_by_query\n  [vangheem]\n\n\n3.0.13 (2018-05-25)\n-------------------\n\n- Fix vacuuming with sub indexes\n  [vangheem]\n\n\n3.0.12 (2018-05-24)\n-------------------\n\n- fix format_hit handling of list fields better\n  [vangheem]\n\n\n3.0.11 (2018-05-24)\n-------------------\n\n- Provide format_hit util\n  [vangheem]\n\n\n3.0.10 (2018-05-23)\n-------------------\n\n- Add more stored fields\n  [vangheem]\n\n\n3.0.9 (2018-05-23)\n------------------\n\n- add backoff for some elasticsearch operations\n  [vangheem]\n\n\n3.0.8 (2018-05-22)\n------------------\n\n- make IIndexManager.get_schemas async\n  [vangheem]\n\n\n3.0.7 (2018-05-21)\n------------------\n\n- Handle missing __parent__\n  [vangheem]\n\n\n3.0.6 (2018-05-21)\n------------------\n\n- Fix bug in reindexing security for children of sub indexes\n  [vangheem]\n\n\n3.0.5 (2018-05-21)\n------------------\n\n- Fix release\n  [vangheem]\n\n\n3.0.4 (2018-05-21)\n------------------\n\n- cleanup_es accepts a prefix value\n  [vangheem]\n\n\n3.0.3 (2018-05-21)\n------------------\n\n- provide get_index_for util\n  [vangheem]\n\n- provide cleanup_es test util\n  [vangheem]\n\n- fix storing annotation data on sub index\n  [vangheem]\n\n- get_by_path should accept index param\n  [vangheem]\n\n\n3.0.2 (2018-05-21)\n------------------\n\n- Fix release\n  [vangheem]\n\n- add utils.get_all_indexes_identifier\n  [vangheem]\n\n\n3.0.1 (2018-05-21)\n------------------\n\n- Create index with mappings/indexes instead of updating them after creation\n  [vangheem]\n\n- Add `es-fields` command to inspect configured fields\n  [vangheem]\n\n\n3.0.0 (2018-05-19)\n------------------\n\n- Add support for sub indexes\n  [vangheem]\n\n- Raise exception instead of returning ErrorResponse\n  [vangheem]\n\n- Add scroll support to query\n  [gitcarbs]\n\n2.0.1 (2018-05-10)\n------------------\n\n- Add more logging for migrations\n  [vangheem]\n\n- Added IIndexProgress to hook on reindex process\n- Added new event on reindex start.\n- Added context to the IIndexProgress event\n  [jordic]\n\n\n2.0.0 (2018-05-06)\n------------------\n\n- replace aioes(unsupported) with aioelasticsearch\n  [vangheem]\n\n- Elasticsearch 6 compatibility.\n  [vangheem]\n\n\n1.3.13 (2018-05-02)\n-------------------\n\n- Format stored field results like source results\n  [vangheem]\n\n\n1.3.12 (2018-05-01)\n-------------------\n\n- More vacuum improvements\n\n\n1.3.11 (2018-04-30)\n-------------------\n\n- More vacuum improvements\n  [vangheem]\n\n1.3.10 (2018-04-30)\n-------------------\n\n- migrate script should not use transactions\n  [vangheem]\n\n1.3.9 (2018-04-30)\n------------------\n\n- Optimized vacuum script to use tid sorting which should prevent\n  needing to go through so many docs to do the vacuum check\n  [vangheem]\n\n\n1.3.8 (2018-04-27)\n------------------\n\n- Provide `@name` in results\n  [vangheem]\n\n\n1.3.7 (2018-04-26)\n------------------\n\n- change `@id` in search results to `@uid`\n  [vangheem]\n\n- Add support for analysis character filter\n  [gitcarbs]\n\n\n1.3.6 (2018-04-18)\n------------------\n\n- Work with store=true mappings\n  [vangheem]\n\n\n1.3.5 (2018-04-15)\n------------------\n\n- Smaller bulk sizes for es vacuum\n  [vangheem]\n\n\n1.3.4 (2018-04-15)\n------------------\n\n- Some performance fixes for vacuuming\n  [vangheem]\n\n\n1.3.3 (2018-04-14)\n------------------\n\n- Provide profile data in results\n  [gitcarbs]\n\n\n1.3.2 (2018-04-03)\n------------------\n\n- Upgrade tests to use pytest-docker-fixtures\n  [vangheem]\n\n\n1.3.1 (2018-03-14)\n------------------\n\n- Pay attention to `index_data` configuration\n  [vangheem]\n\n\n1.3.0 (2018-03-14)\n------------------\n\n- Upgrade to work with guillotina 2.4.x\n  [vangheem]\n\n\n1.2.11 (2018-03-09)\n-------------------\n\n- Implement statement cache clearing\n  [vangheem]\n\n\n1.2.10 (2018-03-02)\n-------------------\n\n- Do not use cached statement for vacuum\n  [vangheem]\n\n\n1.2.9 (2018-02-07)\n------------------\n\n- Handle errors unpickling object for es vacuum\n  [vangheem]\n\n\n1.2.8 (2018-01-11)\n------------------\n\n- Make sure to change transaction strategy for commands\n  [vangheem]\n\n\n1.2.7 (2018-01-08)\n------------------\n\n- Make sure to close out connection in commands\n  [vangheem]\n\n\n1.2.6 (2017-12-18)\n------------------\n\n- Use `traverse` instead of `do_traverse`.\n  [vangheem]\n\n\n1.2.5 (2017-12-08)\n------------------\n\n- Retry on conflict for updates\n  [vangheem]\n\n\n1.2.4 (2017-12-06)\n------------------\n\n- Use futures instead of threads for migrations\n  [vangheem]\n\n\n1.2.3 (2017-11-21)\n------------------\n\n- Upgrade testing infrastructure with latest guillotina\n  [vangheem]\n\n\n1.2.2 (2017-11-08)\n------------------\n\n- Fix test setup with jenkins\n  [vangheem]\n\n\n1.2.1 (2017-11-08)\n------------------\n\n- Make logging less noisy\n  [vangheem]\n\n\n1.2.0 (2017-11-06)\n------------------\n\n- Upgrade to guillotina 2.0.0\n  [vangheem]\n\n\n1.1.24 (2017-10-12)\n-------------------\n\n- Close connection after done in vacuum command\n  [vangheem]\n\n\n1.1.23 (2017-10-09)\n-------------------\n\n- Make sure to use `async with` syntax for manual api calls to elasticsearch using\n  session object.\n  [vangheem]\n\n\n1.1.22 (2017-09-28)\n-------------------\n\n- Another tweak for missing indexes on running migration\n  [vangheem]\n\n\n1.1.21 (2017-09-21)\n-------------------\n\n- All indexing/removing operations are already in a future so no need to add futures\n  to operations.\n  [vangheem]\n\n\n1.1.20 (2017-09-21)\n-------------------\n\n- Use latest guillotina futures request api\n  [vangheem]\n\n\n1.1.19 (2017-09-14)\n-------------------\n\n- Change page size and scroll of esvacuum to prevent timeouts\n  [vangheem]\n\n\n1.1.18 (2017-08-22)\n-------------------\n\n- Fix TIDConflictError when registry is edited during a migration.\n  [vangheem]\n\n\n1.1.17 (2017-08-11)\n-------------------\n\n- Handle missing types from migrations when mappings change better\n  [vangheem]\n\n\n1.1.16 (2017-08-09)\n-------------------\n\n- Results from search should return sort value\n  [gitcarbs]\n\n\n1.1.15 (2017-07-28)\n-------------------\n\n- Fix vacuum to handle empty scroll errors when iterating through all keys\n  [vangheem]\n\n\n1.1.14 (2017-07-21)\n-------------------\n\n- Fix deadlock issue on unindex when migration is active\n  [vangheem]\n\n\n1.1.13 (2017-07-12)\n-------------------\n\n- Wait a bit before running migration so addons that use async to calculate\n  dynamic types can load\n\n\n1.1.12 (2017-07-12)\n-------------------\n\n- Fix scenario where doc type is missing in the upgraded mapping\n  [vangheem]\n\n\n1.1.11 (2017-07-10)\n-------------------\n\n- Add update_by_query method\n  [vangheem]\n\n\n1.1.10 (2017-07-06)\n-------------------\n\n- Add reindex command\n  [vangheem]\n\n\n1.1.9 (2017-07-06)\n------------------\n\n- Fix invalid import in migrate script\n  [vangheem]\n\n\n1.1.8 (2017-07-05)\n------------------\n\n- Add more logging for vacuum\n  [vangheem]\n\n\n1.1.7 (2017-06-29)\n------------------\n\n- Add vacuum command\n  [vangheem]\n\n\n1.1.6 (2017-06-23)\n------------------\n\n- Fix group query to not prepend 'group:' to security query for groups\n  [vangheem]\n\n\n1.1.5 (2017-06-21)\n------------------\n\n- Fix migration when objects were deleted while migrating that were thought to\n  be orphaned\n  [vangheem]\n\n\n1.1.4 (2017-06-20)\n------------------\n\n- Prevent auto mapping of metadata\n  [bloodbare]\n\n\n1.1.3 (2017-06-15)\n------------------\n\n- Fix reindexing\n  [vangheem]\n\n\n1.1.2 (2017-06-15)\n------------------\n\n- Fix import for client_exceptions aiohttp errors\n  [vangheem]\n\n\n1.1.1 (2017-06-09)\n------------------\n\n- Move fixtures out of conftest.py into it's own module. This could break\n  tests that depend on it!\n  [vangheem]\n\n\n1.1.0 (2017-06-09)\n------------------\n\n- Add Reindexer utility that specializes just in reindexing instead of\n  using the migrator\n  [vangheem]\n\n\n1.0.29 (2017-06-08)\n-------------------\n\n- Clean mapping before it's compared to prevent false positives for detecting\n  differences in mappings\n  [vangheem]\n\n\n1.0.28 (2017-06-08)\n-------------------\n\n- Be able to migrate the mapping only and skip working through content on the site\n  [vangheem]\n\n\n1.0.27 (2017-06-07)\n-------------------\n\n- Make sure to flush reindexed items when calling reindex_all_content\n  [vangheem]\n\n\n1.0.26 (2017-05-26)\n-------------------\n\n- When adding groups to query that is built, make sure to prepend each group with\n  \"group:\" so we can distinguish groups from users and somehow can not potentially\n  hack it where they add a \"root\" group they are a part of\n  [vangheem]\n\n\n1.0.25 (2017-05-26)\n-------------------\n\n- Handle potential issue where data is changing while you're doing the reindex\n  [vangheem]\n\n\n1.0.24 (2017-05-26)\n-------------------\n\n- Fix issue where a bad original index would screw up index diff calculation\n  [vangheem]\n\n- Fix migration failure issue before flipping new index on\n  [vangheem]\n\n\n1.0.23 (2017-05-25)\n-------------------\n\n- Fix reindexing on security change\n  [vangheem]\n\n1.0.22 (2017-05-19)\n-------------------\n\n- Be able to cancel migration and have it do some cleanup\n  [vangheem]\n\n\n1.0.21 (2017-05-19)\n-------------------\n\n- A bunch of migration fixes to make it more resilient\n  [vangheem]\n\n\n1.0.20 (2017-05-18)\n-------------------\n\n- Implement live migration command\n  [vangheem]\n\n\n1.0.19 (2017-05-16)\n-------------------\n\n- Reindex with clean option should delete, re-create index\n  [vangheem]\n\n\n1.0.18 (2017-05-16)\n-------------------\n\n- Use dummy cache on reindex for all request types\n  [vangheem]\n\n1.0.17 (2017-05-16)\n-------------------\n\n- Disable caching when reindexing\n  [vangheem]\n\n\n1.0.16 (2017-05-15)\n-------------------\n\n- Use threads when bulk indexing on elasticsearch to make sure to always\n  keep elasticsearch busy.\n  [vangheem]\n\n- Forcing the update of mapping\n  [bloodbare]\n\n\n1.0.15 (2017-05-12)\n-------------------\n\n- close and open the indices to define the settings\n  [bloodbare]\n\n1.0.14 (2017-05-12)\n-------------------\n\n- Enabling size on query by type\n  [bloodbare]\n\n\n1.0.13 (2017-05-11)\n-------------------\n\n- Also set settings on force_mappings\n  [bloodare]\n\n\n1.0.12 (2017-05-11)\n-------------------\n\n- Changing permissions name to guillotina\n  [bloodbare]\n\n\n1.0.11 (2017-05-11)\n-------------------\n\n- Option to set the mapping without reindexing in case of mapping mutation\n  [bloodbare]\n\n\n1.0.10 (2017-05-09)\n-------------------\n\n- Fix --update-missing argument with `es-reindex` command\n  [vangheem]\n\n\n1.0.9 (2017-05-09)\n------------------\n\n- Fix bug when deleting nodes\n  [bloodbare]\n\n\n1.0.8 (2017-05-08)\n------------------\n\n- Improve performance of reindexing of bushy content by using asyncio.gather\n  to traverse sub-trees and index at the same time.\n  [vangheem]\n\n- Improve options to reindex command\n  [vangheem]\n\n\n1.0.7 (2017-05-04)\n------------------\n\n- reindex_all_content takes update and update_missing params now\n  [vangheem]\n\n\n1.0.6 (2017-05-03)\n------------------\n\n- Be able to update from an existing reindex\n  [vangheem]\n\n\n1.0.5 (2017-05-02)\n------------------\n\n- Need to avoid using long running queries on reindex because they can timeout\n  for very large folders\n  [vangheem]\n\n\n1.0.4 (2017-05-02)\n------------------\n\n- optimize reindex more\n  [vangheem]\n\n\n1.0.3 (2017-05-02)\n------------------\n\n- More memory efficient reindex\n  [vangheem]\n\n\n1.0.2 (2017-05-02)\n------------------\n\n- Fix reindexing content\n  [vangheem]\n\n\n1.0.1 (2017-04-25)\n------------------\n\n- Provide as async utility as it allows us to close connections when the object\n  is destroyed\n  [vangheem]\n\n\n1.0.0 (2017-04-24)\n------------------\n\n- initial release\n",
    "bugtrack_url": null,
    "license": "GPL version 3",
    "summary": "elasticsearch catalog support for guillotina",
    "version": "8.0.9",
    "project_urls": {
        "Homepage": "https://github.com/plone/guillotina_elasticsearch"
    },
    "split_keywords": [
        "search",
        "async",
        "guillotina",
        "elasticsearch"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "cb0b475bdd7f98cfc5b60a266400b032695cdc3c1fa16dc1a4b009073600536f",
                "md5": "91b179d23c251b0c12d6279f96114c8a",
                "sha256": "aac72a473744036552f9b4c2883a944b63e993275ddf359c7c7a59ea83767161"
            },
            "downloads": -1,
            "filename": "guillotina_elasticsearch-8.0.9.tar.gz",
            "has_sig": false,
            "md5_digest": "91b179d23c251b0c12d6279f96114c8a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 57443,
            "upload_time": "2024-10-21T09:10:04",
            "upload_time_iso_8601": "2024-10-21T09:10:04.036440Z",
            "url": "https://files.pythonhosted.org/packages/cb/0b/475bdd7f98cfc5b60a266400b032695cdc3c1fa16dc1a4b009073600536f/guillotina_elasticsearch-8.0.9.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-21 09:10:04",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "plone",
    "github_project": "guillotina_elasticsearch",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "guillotina-elasticsearch"
}
        
Elapsed time: 0.40832s