Commit Graph

177 Commits

Author SHA1 Message Date
marin postma
71226feb74 refactor create_app macro 2021-06-23 16:47:15 +02:00
marin postma
322d6b8cfe fix serialization bug in settings 2021-06-23 15:25:56 +02:00
Clémentine Urquizar
6d24a4744f Roll back facetsDistribution 2021-06-23 10:04:01 +02:00
marin postma
3456a78552 refactor formatter
share the analyzer instance between the formatter and the
compute_matches function
2021-06-22 18:28:20 +02:00
marin postma
97ef4a6c22 implement matches 2021-06-22 18:12:52 +02:00
marin postma
9cc31c2258 fix get search crop len 2021-06-22 16:01:40 +02:00
marin postma
1e4592dd7e enable errors in updates 2021-06-21 18:42:47 +02:00
marin postma
763ee521be fix rebase errors 2021-06-21 12:11:09 +02:00
marin postma
02277ec2cf reintroduce anyhow 2021-06-21 12:11:06 +02:00
marin postma
439db1aae0 enable response error for search routes 2021-06-21 11:00:14 +02:00
marin postma
8afbb9c462 enable response error for documents routes 2021-06-21 10:59:41 +02:00
marin postma
5c52a1393f enable response error for settings routes 2021-06-21 10:59:41 +02:00
marin postma
d1550670a8 enable response error for index routes 2021-06-21 10:59:40 +02:00
marin postma
58f9974be4 remove anyhow refs & implement missing errors 2021-06-21 10:59:38 +02:00
Clémentine Urquizar
623b71e81e Fix clippy errors 2021-06-17 18:02:25 +02:00
Clémentine Urquizar
dc5a3d4a62 Use BTreeSet instead of HashSet 2021-06-16 16:20:10 +02:00
Clémentine Urquizar
65130d9ee7 Change crop_length type from Option(usize) to usize 2021-06-15 17:40:44 +02:00
Clémentine Urquizar
0da8fa115e Add custom croplength for attributes to crop 2021-06-15 17:40:43 +02:00
marin postma
a780cff8fd fix clippy warning 2021-06-14 14:53:47 +02:00
Tamo
18d4d6097a implements the synonyms in transplant 2021-06-14 14:47:51 +02:00
bors[bot]
b119bb4ab0 Merge #197
197: Update milli (v0.3.1) with filterable attributes r=MarinPostma a=curquiza

Fixes #187 and #70
Also fixes #195 

Co-authored-by: Clémentine Urquizar <clementine@meilisearch.com>
2021-06-14 12:19:42 +00:00
bors[bot]
d65b5db97f Merge #144 #173
144: Concurrent update run loop (refactor) r=MarinPostma a=MarinPostma

This PR allows multiple request to the update store to be performed concurently (i.e, one can list updates while an updates in being written to the update store).


173: Convert UpdateStatus to legacy meilisearch format r=MarinPostma a=MarinPostma

Returns the update statuses with the same format as legacy meilisearch.

The number of documents in a document addition/deletion is not known before processing, so it is only returned when the update is `processed`.

close #78 

associated milli PR: https://github.com/meilisearch/milli/pull/178


Co-authored-by: marin postma <postma.marin@protonmail.com>
Co-authored-by: Marin Postma <postma.marin@protonmail.com>
2021-06-14 11:30:44 +00:00
Clémentine Urquizar
88bf867a3e Rename attributes for faceting into filterable attributes 2021-06-14 13:20:43 +02:00
Clémentine Urquizar
aa04124bfc Add changes according to milli update 2021-06-14 13:20:37 +02:00
Marin Postma
11c81ab4cb fix tests 2021-06-14 11:17:49 +02:00
Marin Postma
e8bd5ea4e0 convert UpdateStatus to legacy meilisearch format 2021-06-14 10:21:57 +02:00
bors[bot]
d765397c82 Merge #179
179: Enable filter paramater during search r=MarinPostma a=MarinPostma

This pr makes the necessary changes to transplant in accordance with the specification on filters.

More precisely, it:
- Removes the `filters` parameter
- Renames `facetFilters` to `filter`
- Allows either a string or an array to be passed to the filter param.

It doesn't allow the mixed syntax, that needs to be handled by milli.

close #81
close #140


Co-authored-by: Marin Postma <postma.marin@protonmail.com>
2021-06-14 08:11:30 +00:00
Marin Postma
1c4f0b2ccf clippy, fmt & tests 2021-05-31 16:03:39 +02:00
tamo
6d837e3e07 the route to create a dump must return a 202 2021-05-11 17:34:34 +02:00
tamo
efca63f9ce [WIP] rebase on main 2021-05-10 20:25:09 +02:00
tamo
c3552cecdf WIP rebase on main 2021-05-10 20:24:18 +02:00
tamo
0275b36fb0 [WIP] rebase on main 2021-05-10 20:24:14 +02:00
tamo
e389c088eb WIP: rebasing on master 2021-05-10 20:20:57 +02:00
Marin Postma
706643dfed type setting struct 2021-05-10 17:30:09 +02:00
Marin Postma
b192cb9c1f enable string syntax for the filters 2021-05-06 12:48:31 +02:00
Marin Postma
a717925caa remove filters, rename facet_filters to filter 2021-05-04 18:20:56 +02:00
bors[bot]
8bc7dd8b03 Merge #143
143: Shared update store r=irevoire a=MarinPostma

This PR changes the updates process so that only one instance of an update store is shared among indexes.

This allows updates to always be processed sequentially without additional synchronization, and fixes the bug where all the first pending update for each index were reported as processing whereas only one was.

EDIT:

I ended having to rewrite the whole `UpdateStore` to allow updates being really queued and processed sequentially in the ordered they were added. For that purpose I created a `pending_queue` that orders the updates by a global update id.

To find the next `update_id` to use, both globally and for each index, I have created another database that contains the next id to use.

Finally, all updates that have been processed (with success or otherwise) are all stores in an `updates` database.

The layout for the keys of these databases are such that it is easy to iterate over the elements for a particular index, and greatly reduces the amount of code to do so, compared to the former implementation.

I have also simplified the locking mechanism for the update store, thanks to the StateLock data structure, that allow both an arbitrary number of readers and a single writer to concurrently access the state. The current state can be either Idle, Processing, or Snapshotting. When an update or snapshotting is ongoing, the process holds the state lock until it is done processing its task. When it is done, it sets bask the state to Idle.

I have made other small improvements here and there, and have let some other for work, such as:
- When creating an update file to hold a request's content, it would be preferable to first create a temporary file, and then atomically persist it when we have written to it. This would simplify the case when there is no data to be written to the file, since we wouldn't have to take care about cleaning after ourselves.
- The logic for content validation must be factored.
- Some more tests related to error handling in the process_pending_update function.
- The issue #159

close #114


Co-authored-by: Marin Postma <postma.marin@protonmail.com>
2021-04-27 18:41:55 +00:00
Marin Postma
bb79a15c04 reenable ranking rules route 2021-04-27 15:29:00 +02:00
Marin Postma
4fe2a13c71 rewrite update store 2021-04-27 15:20:52 +02:00
Marin Postma
ee675eadf1 fix stats 2021-04-27 15:10:55 +02:00
Marin Postma
33830d5ecf fix snapshots 2021-04-27 15:09:55 +02:00
Clémentine Urquizar
f80ea24d2b Add tests on every platform and fix clippy errors 2021-04-27 12:42:59 +02:00
Marin Postma
c2461e5066 review fixes 2021-04-26 10:20:46 +02:00
Marin Postma
881b099c8e add tests 2021-04-20 21:23:34 +02:00
Marin Postma
c6bb36efa5 implement _formated 2021-04-20 21:23:28 +02:00
Marin Postma
6c470cf687 enable distinct-attribute setting route 2021-04-20 11:34:18 +02:00
Clémentine Urquizar
8eceba98d3 Handle star in attributes_to_retrieve 2021-04-19 18:20:19 +02:00
tamo
ec3a08ea0c remove another unused legacy file 2021-04-15 14:44:43 +02:00
Alexey Shekhirin
f87afbc558 fix(http): commit date & SHA in startup message 2021-04-13 20:16:18 +03:00
Alexey Shekhirin
9eaf048a06 fix(http): use BTreeMap instead of HashMap to preserve stats order 2021-04-13 11:59:07 +03:00