mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	Merge branch 'main' into stable
This commit is contained in:
		
							
								
								
									
										3
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,7 @@ | ||||
| contact_links: | ||||
|   - name: Language support request & feedback | ||||
|     url: https://github.com/meilisearch/product/discussions/categories/feedback-feature-proposal?discussions_q=label%3Aproduct%3Acore%3Atokenizer+category%3A%22Feedback+%26+Feature+Proposal%22 | ||||
|     about:  The requests and feedback regarding Language support are not managed in this repository. Please upvote the related discussion in our dedicated product repository or open a new one if it doesn't exist. | ||||
|   - name: Feature request & feedback | ||||
|     url: https://github.com/meilisearch/product/discussions/categories/feedback-feature-proposal | ||||
|     about: The feature requests and feedback regarding the already existing features are not managed in this repository. Please open a discussion in our dedicated product repository | ||||
|   | ||||
							
								
								
									
										13
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| # Set update schedule for GitHub Actions only | ||||
|  | ||||
| version: 2 | ||||
| updates: | ||||
|  | ||||
|   - package-ecosystem: "github-actions" | ||||
|     directory: "/" | ||||
|     schedule: | ||||
|       interval: "monthly" | ||||
|     labels: | ||||
|       - 'skip changelog' | ||||
|       - 'dependencies' | ||||
|     rebase-strategy: disabled | ||||
							
								
								
									
										20
									
								
								.github/workflows/README.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/README.md
									
									
									
									
										vendored
									
									
								
							| @@ -1,20 +0,0 @@ | ||||
| # GitHub Actions Workflow for Meilisearch | ||||
|  | ||||
| > **Note:** | ||||
|  | ||||
| > - We do not use [cache](https://github.com/actions/cache) yet but we could use it to speed up CI | ||||
|  | ||||
| ## Workflow | ||||
|  | ||||
| - On each pull request, we trigger `cargo test`. | ||||
| - On each tag, we build: | ||||
|     - the tagged Docker image and publish it to Docker Hub | ||||
|     - the binaries for MacOS, Ubuntu, and Windows | ||||
|     - the Debian package | ||||
| - On each stable release (`v*.*.*` tag): | ||||
|     - we build the `latest` Docker image and publish it to Docker Hub | ||||
|     - we publish the binary to Hombrew and Gemfury | ||||
|  | ||||
| ## Problems | ||||
|  | ||||
| - We do not test on Windows because we are unable to make it work, there is a disk space problem. | ||||
							
								
								
									
										4
									
								
								.github/workflows/coverage.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/coverage.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,7 +8,7 @@ jobs: | ||||
|   nightly-coverage: | ||||
|     runs-on: ubuntu-18.04 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|           toolchain: nightly | ||||
| @@ -25,7 +25,7 @@ jobs: | ||||
|           RUSTFLAGS: "-Zprofile -Ccodegen-units=1 -Cinline-threshold=0 -Clink-dead-code -Coverflow-checks=off -Cpanic=unwind -Zpanic_abort_tests" | ||||
|       - uses: actions-rs/grcov@v0.1 | ||||
|       - name: Upload coverage to Codecov | ||||
|         uses: codecov/codecov-action@v1 | ||||
|         uses: codecov/codecov-action@v3 | ||||
|         with: | ||||
|           token: ${{ secrets.CODECOV_TOKEN }} | ||||
|           file: ${{ steps.coverage.outputs.report }} | ||||
|   | ||||
							
								
								
									
										23
									
								
								.github/workflows/create-issue-dependencies.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/create-issue-dependencies.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| name: Create issue to upgrade dependencies | ||||
| on: | ||||
|   schedule: | ||||
|     - cron: '0 0 1 */3 *' | ||||
|   workflow_dispatch: | ||||
|    | ||||
| jobs: | ||||
|   create-issue: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: Create an issue | ||||
|       uses: actions-ecosystem/action-create-issue@v1 | ||||
|       with: | ||||
|         github_token: ${{ secrets.GITHUB_TOKEN }} | ||||
|         title: Upgrade dependencies | ||||
|         body: | | ||||
|           We need to update the dependencies of the Meilisearch repository, and, if possible, the dependencies of all the core-team repositories that Meilisearch depends on (milli, charabia, heed...). | ||||
|  | ||||
|           ⚠️ This issue should only be done at the beginning of the sprint!      | ||||
|         labels: | | ||||
|           dependencies | ||||
|           maintenance | ||||
							
								
								
									
										2
									
								
								.github/workflows/flaky.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/flaky.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,7 +8,7 @@ jobs: | ||||
|     runs-on: ubuntu-18.04 | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: Install cargo-flaky | ||||
|       run: cargo install cargo-flaky | ||||
|     - name: Run cargo flaky 100 times | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/publish-binaries.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/publish-binaries.yml
									
									
									
									
										vendored
									
									
								
							| @@ -51,7 +51,7 @@ jobs: | ||||
|     - uses: hecrj/setup-rust-action@master | ||||
|       with: | ||||
|         rust-version: stable | ||||
|     - uses: actions/checkout@v2 | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: Build | ||||
|       run: cargo build --release --locked | ||||
|     - name: Upload binaries to release | ||||
| @@ -80,7 +80,7 @@ jobs: | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v2 | ||||
|         uses: actions/checkout@v3 | ||||
|  | ||||
|       - name: Installing Rust toolchain | ||||
|         uses: actions-rs/toolchain@v1 | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/publish-deb-brew-pkg.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/publish-deb-brew-pkg.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,7 +23,7 @@ jobs: | ||||
|         rust-version: stable | ||||
|     - name: Install cargo-deb | ||||
|       run: cargo install cargo-deb | ||||
|     - uses: actions/checkout@v2 | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: Build deb package | ||||
|       run: cargo deb -p meilisearch-http -o target/debian/meilisearch.deb | ||||
|     - name: Upload debian pkg to release | ||||
|   | ||||
							
								
								
									
										28
									
								
								.github/workflows/publish-docker-images.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										28
									
								
								.github/workflows/publish-docker-images.yml
									
									
									
									
										vendored
									
									
								
							| @@ -36,21 +36,35 @@ jobs: | ||||
|         run: bash .github/scripts/check-release.sh | ||||
|  | ||||
|       - name: Set up QEMU | ||||
|         uses: docker/setup-qemu-action@v1 | ||||
|         uses: docker/setup-qemu-action@v2 | ||||
|  | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v1 | ||||
|         uses: docker/setup-buildx-action@v2 | ||||
|  | ||||
|       - name: Login to Docker Hub | ||||
|         if: github.event_name != 'schedule' | ||||
|         uses: docker/login-action@v1 | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
|           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||
|           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||
|  | ||||
|       - name: Check tag format | ||||
|         id: check-tag-format | ||||
|         run: | | ||||
|           # Escape submitted tag name | ||||
|           escaped_tag=$(printf "%q" ${{ github.ref_name }}) | ||||
|  | ||||
|           # Check if tag has format v<nmumber>.<number>.<number> and set output.match | ||||
|           # to create a vX.Y (without patch version) Docker tag | ||||
|           if [[ $escaped_tag =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then | ||||
|             echo ::set-output name=match::true | ||||
|           else | ||||
|             echo ::set-output name=match::false | ||||
|           fi | ||||
|  | ||||
|       - name: Docker meta | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v3 | ||||
|         uses: docker/metadata-action@v4 | ||||
|         with: | ||||
|           images: getmeili/meilisearch | ||||
|           # The lastest and `vX.Y` tags are only pushed for the official Meilisearch releases | ||||
| @@ -63,7 +77,7 @@ jobs: | ||||
|  | ||||
|       - name: Build and push | ||||
|         id: docker_build | ||||
|         uses: docker/build-push-action@v2 | ||||
|         uses: docker/build-push-action@v3 | ||||
|         with: | ||||
|           # We do not push tags for the cron jobs, this is only for test purposes | ||||
|           push: ${{ github.event_name != 'schedule' }} | ||||
|   | ||||
							
								
								
									
										16
									
								
								.github/workflows/rust.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/rust.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,9 +23,9 @@ jobs: | ||||
|       matrix: | ||||
|         os: [ubuntu-18.04, macos-latest, windows-latest] | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|     - uses: actions/checkout@v3 | ||||
|     - name: Cache dependencies | ||||
|       uses: Swatinem/rust-cache@v1.3.0 | ||||
|       uses: Swatinem/rust-cache@v1.4.0 | ||||
|     - name: Run cargo check without any default features | ||||
|       uses: actions-rs/cargo@v1 | ||||
|       with: | ||||
| @@ -42,14 +42,14 @@ jobs: | ||||
|     name: Run tests in debug | ||||
|     runs-on: ubuntu-18.04 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|           profile: minimal | ||||
|           toolchain: stable | ||||
|           override: true | ||||
|       - name: Cache dependencies | ||||
|         uses: Swatinem/rust-cache@v1.3.0 | ||||
|         uses: Swatinem/rust-cache@v1.4.0 | ||||
|       - name: Run tests in debug | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         with: | ||||
| @@ -60,7 +60,7 @@ jobs: | ||||
|     name: Run Clippy | ||||
|     runs-on: ubuntu-18.04 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|           profile: minimal | ||||
| @@ -68,7 +68,7 @@ jobs: | ||||
|           override: true | ||||
|           components: clippy | ||||
|       - name: Cache dependencies | ||||
|         uses: Swatinem/rust-cache@v1.3.0 | ||||
|         uses: Swatinem/rust-cache@v1.4.0 | ||||
|       - name: Run cargo clippy | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         with: | ||||
| @@ -79,7 +79,7 @@ jobs: | ||||
|     name: Run Rustfmt | ||||
|     runs-on: ubuntu-18.04 | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|           profile: minimal | ||||
| @@ -87,6 +87,6 @@ jobs: | ||||
|           override: true | ||||
|           components: rustfmt | ||||
|       - name: Cache dependencies | ||||
|         uses: Swatinem/rust-cache@v1.3.0 | ||||
|         uses: Swatinem/rust-cache@v1.4.0 | ||||
|       - name: Run cargo fmt | ||||
|         run: cargo fmt --all -- --check | ||||
|   | ||||
| @@ -5,6 +5,7 @@ First, thank you for contributing to Meilisearch! The goal of this document is t | ||||
| Remember that there are many ways to contribute other than writing code: writing [tutorials or blog posts](https://github.com/meilisearch/awesome-meilisearch), improving [the documentation](https://github.com/meilisearch/documentation), submitting [bug reports](https://github.com/meilisearch/meilisearch/issues/new?assignees=&labels=&template=bug_report.md&title=) and [feature requests](https://github.com/meilisearch/product/discussions/categories/feedback-feature-proposal)... | ||||
|  | ||||
| ## Table of Contents | ||||
|  | ||||
| - [Assumptions](#assumptions) | ||||
| - [How to Contribute](#how-to-contribute) | ||||
| - [Development Workflow](#development-workflow) | ||||
| @@ -13,7 +14,7 @@ Remember that there are many ways to contribute other than writing code: writing | ||||
|  | ||||
| ## Assumptions | ||||
|  | ||||
| 1. **You're familiar with [Github](https://github.com) and the [Pull Requests](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/about-pull-requests)(PR) workflow.** | ||||
| 1. **You're familiar with [GitHub](https://github.com) and the [Pull Requests](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/about-pull-requests)(PR) workflow.** | ||||
| 2. **You've read the Meilisearch [documentation](https://docs.meilisearch.com).** | ||||
| 3. **You know about the [Meilisearch community](https://docs.meilisearch.com/learn/what_is_meilisearch/contact.html). | ||||
|    Please use this for help.** | ||||
| @@ -23,7 +24,7 @@ Remember that there are many ways to contribute other than writing code: writing | ||||
| 1. Ensure your change has an issue! Find an | ||||
|    [existing issue](https://github.com/meilisearch/meilisearch/issues/) or [open a new issue](https://github.com/meilisearch/meilisearch/issues/new). | ||||
|    * This is where you can get a feel if the change will be accepted or not. | ||||
| 2. Once approved, [fork the Meilisearch repository](https://help.github.com/en/github/getting-started-with-github/fork-a-repo) in your own Github account. | ||||
| 2. Once approved, [fork the Meilisearch repository](https://help.github.com/en/github/getting-started-with-github/fork-a-repo) in your own GitHub account. | ||||
| 3. [Create a new Git branch](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-and-deleting-branches-within-your-repository) | ||||
| 4. Review the [Development Workflow](#development-workflow) section that describes the steps to maintain the repository. | ||||
| 5. Make your changes on your branch. | ||||
| @@ -45,6 +46,8 @@ We recommend using the `--release` flag to test the full performance of Meilisea | ||||
| cargo test | ||||
| ``` | ||||
|  | ||||
| This command will be triggered to each PR as a requirement for merging it. | ||||
|  | ||||
| If you get a "Too many open files" error you might want to increase the open file limit using this command: | ||||
|  | ||||
| ```bash | ||||
| @@ -69,7 +72,7 @@ As minimal requirements, your commit message should: | ||||
|  | ||||
| We don't follow any other convention, but if you want to use one, we recommend [the Chris Beams one](https://chris.beams.io/posts/git-commit/). | ||||
|  | ||||
| ### Github Pull Requests | ||||
| ### GitHub Pull Requests | ||||
|  | ||||
| Some notes on GitHub PRs: | ||||
|  | ||||
| @@ -92,6 +95,16 @@ _[Read more about this](https://github.com/meilisearch/integration-guides/blob/m | ||||
|  | ||||
| The full Meilisearch release process is described in [this guide](https://github.com/meilisearch/core-team/blob/main/resources/meilisearch-release.md). Please follow it carefully before doing any release. | ||||
|  | ||||
| ### Release assets | ||||
|  | ||||
| For each release, the following assets are created: | ||||
| - Binaries for differents platforms (Linux, MacOS, Windows and ARM architectures) are attached to the GitHub release | ||||
| - Binaries are pushed to HomeBrew and APT (not published for RC) | ||||
| - Docker tags are created/updated: | ||||
|   - `vX.Y.Z` | ||||
|   - `vX.Y` (not published for RC) | ||||
|   - `latest` (not published for RC) | ||||
|  | ||||
| <hr> | ||||
|  | ||||
| Thank you again for reading this through, we can not wait to begin to work with you if you made your way through this contributing guide ❤️ | ||||
|   | ||||
| @@ -1,19 +1,24 @@ | ||||
| use enum_iterator::IntoEnumIterator; | ||||
| use serde::{Deserialize, Serialize}; | ||||
| use std::hash::Hash; | ||||
|  | ||||
| #[derive(IntoEnumIterator, Copy, Clone, Serialize, Deserialize, Debug, Eq, PartialEq)] | ||||
| #[derive(IntoEnumIterator, Copy, Clone, Serialize, Deserialize, Debug, Eq, PartialEq, Hash)] | ||||
| #[repr(u8)] | ||||
| pub enum Action { | ||||
|     #[serde(rename = "*")] | ||||
|     All = actions::ALL, | ||||
|     #[serde(rename = "search")] | ||||
|     Search = actions::SEARCH, | ||||
|     #[serde(rename = "documents.*")] | ||||
|     DocumentsAll = actions::DOCUMENTS_ALL, | ||||
|     #[serde(rename = "documents.add")] | ||||
|     DocumentsAdd = actions::DOCUMENTS_ADD, | ||||
|     #[serde(rename = "documents.get")] | ||||
|     DocumentsGet = actions::DOCUMENTS_GET, | ||||
|     #[serde(rename = "documents.delete")] | ||||
|     DocumentsDelete = actions::DOCUMENTS_DELETE, | ||||
|     #[serde(rename = "indexes.*")] | ||||
|     IndexesAll = actions::INDEXES_ALL, | ||||
|     #[serde(rename = "indexes.create")] | ||||
|     IndexesAdd = actions::INDEXES_CREATE, | ||||
|     #[serde(rename = "indexes.get")] | ||||
| @@ -22,14 +27,22 @@ pub enum Action { | ||||
|     IndexesUpdate = actions::INDEXES_UPDATE, | ||||
|     #[serde(rename = "indexes.delete")] | ||||
|     IndexesDelete = actions::INDEXES_DELETE, | ||||
|     #[serde(rename = "tasks.*")] | ||||
|     TasksAll = actions::TASKS_ALL, | ||||
|     #[serde(rename = "tasks.get")] | ||||
|     TasksGet = actions::TASKS_GET, | ||||
|     #[serde(rename = "settings.*")] | ||||
|     SettingsAll = actions::SETTINGS_ALL, | ||||
|     #[serde(rename = "settings.get")] | ||||
|     SettingsGet = actions::SETTINGS_GET, | ||||
|     #[serde(rename = "settings.update")] | ||||
|     SettingsUpdate = actions::SETTINGS_UPDATE, | ||||
|     #[serde(rename = "stats.*")] | ||||
|     StatsAll = actions::STATS_ALL, | ||||
|     #[serde(rename = "stats.get")] | ||||
|     StatsGet = actions::STATS_GET, | ||||
|     #[serde(rename = "dumps.*")] | ||||
|     DumpsAll = actions::DUMPS_ALL, | ||||
|     #[serde(rename = "dumps.create")] | ||||
|     DumpsCreate = actions::DUMPS_CREATE, | ||||
|     #[serde(rename = "version")] | ||||
| @@ -50,17 +63,23 @@ impl Action { | ||||
|         match repr { | ||||
|             ALL => Some(Self::All), | ||||
|             SEARCH => Some(Self::Search), | ||||
|             DOCUMENTS_ALL => Some(Self::DocumentsAll), | ||||
|             DOCUMENTS_ADD => Some(Self::DocumentsAdd), | ||||
|             DOCUMENTS_GET => Some(Self::DocumentsGet), | ||||
|             DOCUMENTS_DELETE => Some(Self::DocumentsDelete), | ||||
|             INDEXES_ALL => Some(Self::IndexesAll), | ||||
|             INDEXES_CREATE => Some(Self::IndexesAdd), | ||||
|             INDEXES_GET => Some(Self::IndexesGet), | ||||
|             INDEXES_UPDATE => Some(Self::IndexesUpdate), | ||||
|             INDEXES_DELETE => Some(Self::IndexesDelete), | ||||
|             TASKS_ALL => Some(Self::TasksAll), | ||||
|             TASKS_GET => Some(Self::TasksGet), | ||||
|             SETTINGS_ALL => Some(Self::SettingsAll), | ||||
|             SETTINGS_GET => Some(Self::SettingsGet), | ||||
|             SETTINGS_UPDATE => Some(Self::SettingsUpdate), | ||||
|             STATS_ALL => Some(Self::StatsAll), | ||||
|             STATS_GET => Some(Self::StatsGet), | ||||
|             DUMPS_ALL => Some(Self::DumpsAll), | ||||
|             DUMPS_CREATE => Some(Self::DumpsCreate), | ||||
|             VERSION => Some(Self::Version), | ||||
|             KEYS_CREATE => Some(Self::KeysAdd), | ||||
| @@ -76,17 +95,23 @@ impl Action { | ||||
|         match self { | ||||
|             Self::All => ALL, | ||||
|             Self::Search => SEARCH, | ||||
|             Self::DocumentsAll => DOCUMENTS_ALL, | ||||
|             Self::DocumentsAdd => DOCUMENTS_ADD, | ||||
|             Self::DocumentsGet => DOCUMENTS_GET, | ||||
|             Self::DocumentsDelete => DOCUMENTS_DELETE, | ||||
|             Self::IndexesAll => INDEXES_ALL, | ||||
|             Self::IndexesAdd => INDEXES_CREATE, | ||||
|             Self::IndexesGet => INDEXES_GET, | ||||
|             Self::IndexesUpdate => INDEXES_UPDATE, | ||||
|             Self::IndexesDelete => INDEXES_DELETE, | ||||
|             Self::TasksAll => TASKS_ALL, | ||||
|             Self::TasksGet => TASKS_GET, | ||||
|             Self::SettingsAll => SETTINGS_ALL, | ||||
|             Self::SettingsGet => SETTINGS_GET, | ||||
|             Self::SettingsUpdate => SETTINGS_UPDATE, | ||||
|             Self::StatsAll => STATS_ALL, | ||||
|             Self::StatsGet => STATS_GET, | ||||
|             Self::DumpsAll => DUMPS_ALL, | ||||
|             Self::DumpsCreate => DUMPS_CREATE, | ||||
|             Self::Version => VERSION, | ||||
|             Self::KeysAdd => KEYS_CREATE, | ||||
| @@ -100,21 +125,27 @@ impl Action { | ||||
| pub mod actions { | ||||
|     pub(crate) const ALL: u8 = 0; | ||||
|     pub const SEARCH: u8 = 1; | ||||
|     pub const DOCUMENTS_ADD: u8 = 2; | ||||
|     pub const DOCUMENTS_GET: u8 = 3; | ||||
|     pub const DOCUMENTS_DELETE: u8 = 4; | ||||
|     pub const INDEXES_CREATE: u8 = 5; | ||||
|     pub const INDEXES_GET: u8 = 6; | ||||
|     pub const INDEXES_UPDATE: u8 = 7; | ||||
|     pub const INDEXES_DELETE: u8 = 8; | ||||
|     pub const TASKS_GET: u8 = 9; | ||||
|     pub const SETTINGS_GET: u8 = 10; | ||||
|     pub const SETTINGS_UPDATE: u8 = 11; | ||||
|     pub const STATS_GET: u8 = 12; | ||||
|     pub const DUMPS_CREATE: u8 = 13; | ||||
|     pub const VERSION: u8 = 15; | ||||
|     pub const KEYS_CREATE: u8 = 16; | ||||
|     pub const KEYS_GET: u8 = 17; | ||||
|     pub const KEYS_UPDATE: u8 = 18; | ||||
|     pub const KEYS_DELETE: u8 = 19; | ||||
|     pub const DOCUMENTS_ALL: u8 = 2; | ||||
|     pub const DOCUMENTS_ADD: u8 = 3; | ||||
|     pub const DOCUMENTS_GET: u8 = 4; | ||||
|     pub const DOCUMENTS_DELETE: u8 = 5; | ||||
|     pub const INDEXES_ALL: u8 = 6; | ||||
|     pub const INDEXES_CREATE: u8 = 7; | ||||
|     pub const INDEXES_GET: u8 = 8; | ||||
|     pub const INDEXES_UPDATE: u8 = 9; | ||||
|     pub const INDEXES_DELETE: u8 = 10; | ||||
|     pub const TASKS_ALL: u8 = 11; | ||||
|     pub const TASKS_GET: u8 = 12; | ||||
|     pub const SETTINGS_ALL: u8 = 13; | ||||
|     pub const SETTINGS_GET: u8 = 14; | ||||
|     pub const SETTINGS_UPDATE: u8 = 15; | ||||
|     pub const STATS_ALL: u8 = 16; | ||||
|     pub const STATS_GET: u8 = 17; | ||||
|     pub const DUMPS_ALL: u8 = 18; | ||||
|     pub const DUMPS_CREATE: u8 = 19; | ||||
|     pub const VERSION: u8 = 20; | ||||
|     pub const KEYS_CREATE: u8 = 21; | ||||
|     pub const KEYS_GET: u8 = 22; | ||||
|     pub const KEYS_UPDATE: u8 = 23; | ||||
|     pub const KEYS_DELETE: u8 = 24; | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| use std::borrow::Cow; | ||||
| use std::cmp::Reverse; | ||||
| use std::collections::HashSet; | ||||
| use std::convert::TryFrom; | ||||
| use std::convert::TryInto; | ||||
| use std::fs::create_dir_all; | ||||
| @@ -88,12 +89,48 @@ impl HeedAuthStore { | ||||
|         // create inverted database. | ||||
|         let db = self.action_keyid_index_expiration; | ||||
|  | ||||
|         let actions = if key.actions.contains(&Action::All) { | ||||
|             // if key.actions contains All, we iterate over all actions. | ||||
|             Action::into_enum_iter().collect() | ||||
|         } else { | ||||
|             key.actions.clone() | ||||
|         }; | ||||
|         let mut actions = HashSet::new(); | ||||
|         for action in &key.actions { | ||||
|             match action { | ||||
|                 Action::All => actions.extend(Action::into_enum_iter()), | ||||
|                 Action::DocumentsAll => { | ||||
|                     actions.extend( | ||||
|                         [ | ||||
|                             Action::DocumentsGet, | ||||
|                             Action::DocumentsDelete, | ||||
|                             Action::DocumentsAdd, | ||||
|                         ] | ||||
|                         .iter(), | ||||
|                     ); | ||||
|                 } | ||||
|                 Action::IndexesAll => { | ||||
|                     actions.extend( | ||||
|                         [ | ||||
|                             Action::IndexesAdd, | ||||
|                             Action::IndexesDelete, | ||||
|                             Action::IndexesGet, | ||||
|                             Action::IndexesUpdate, | ||||
|                         ] | ||||
|                         .iter(), | ||||
|                     ); | ||||
|                 } | ||||
|                 Action::SettingsAll => { | ||||
|                     actions.extend([Action::SettingsGet, Action::SettingsUpdate].iter()); | ||||
|                 } | ||||
|                 Action::DumpsAll => { | ||||
|                     actions.insert(Action::DumpsCreate); | ||||
|                 } | ||||
|                 Action::TasksAll => { | ||||
|                     actions.insert(Action::TasksGet); | ||||
|                 } | ||||
|                 Action::StatsAll => { | ||||
|                     actions.insert(Action::StatsGet); | ||||
|                 } | ||||
|                 other => { | ||||
|                     actions.insert(*other); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         let no_index_restriction = key.indexes.contains(&StarOr::Star); | ||||
|         for action in actions { | ||||
|   | ||||
| @@ -46,7 +46,7 @@ fn payload_to_stream(mut payload: Payload) -> impl Stream<Item = Result<Bytes, P | ||||
| } | ||||
|  | ||||
| /// Extracts the mime type from the content type and return | ||||
| /// a meilisearch error if anyhthing bad happen. | ||||
| /// a meilisearch error if anything bad happen. | ||||
| fn extract_mime_type(req: &HttpRequest) -> Result<Option<Mime>, MeilisearchHttpError> { | ||||
|     match req.mime_type() { | ||||
|         Ok(Some(mime)) => Ok(Some(mime)), | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -11,41 +11,41 @@ pub static AUTHORIZATIONS: Lazy<HashMap<(&'static str, &'static str), HashSet<&' | ||||
|         hashmap! { | ||||
|             ("POST",    "/indexes/products/search") =>                         hashset!{"search", "*"}, | ||||
|             ("GET",     "/indexes/products/search") =>                         hashset!{"search", "*"}, | ||||
|             ("POST",    "/indexes/products/documents") =>                      hashset!{"documents.add", "*"}, | ||||
|             ("GET",     "/indexes/products/documents") =>                      hashset!{"documents.get", "*"}, | ||||
|             ("GET",     "/indexes/products/documents/0") =>                    hashset!{"documents.get", "*"}, | ||||
|             ("DELETE",  "/indexes/products/documents/0") =>                    hashset!{"documents.delete", "*"}, | ||||
|             ("GET",     "/tasks") =>                                           hashset!{"tasks.get", "*"}, | ||||
|             ("GET",     "/tasks?indexUid=products") =>                         hashset!{"tasks.get", "*"}, | ||||
|             ("GET",     "/tasks/0") =>                                         hashset!{"tasks.get", "*"}, | ||||
|             ("PATCH",   "/indexes/products/") =>                               hashset!{"indexes.update", "*"}, | ||||
|             ("GET",     "/indexes/products/") =>                               hashset!{"indexes.get", "*"}, | ||||
|             ("DELETE",  "/indexes/products/") =>                               hashset!{"indexes.delete", "*"}, | ||||
|             ("POST",    "/indexes") =>                                         hashset!{"indexes.create", "*"}, | ||||
|             ("GET",     "/indexes") =>                                         hashset!{"indexes.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings") =>                       hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/displayed-attributes") =>  hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/distinct-attribute") =>    hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/filterable-attributes") => hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/ranking-rules") =>         hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/searchable-attributes") => hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/sortable-attributes") =>   hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/stop-words") =>            hashset!{"settings.get", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/synonyms") =>              hashset!{"settings.get", "*"}, | ||||
|             ("DELETE",  "/indexes/products/settings") =>                       hashset!{"settings.update", "*"}, | ||||
|             ("PATCH",   "/indexes/products/settings") =>                       hashset!{"settings.update", "*"}, | ||||
|             ("PATCH",   "/indexes/products/settings/typo-tolerance") =>        hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/displayed-attributes") =>  hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/distinct-attribute") =>    hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/filterable-attributes") => hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/ranking-rules") =>         hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/searchable-attributes") => hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/sortable-attributes") =>   hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/stop-words") =>            hashset!{"settings.update", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/synonyms") =>              hashset!{"settings.update", "*"}, | ||||
|             ("GET",     "/indexes/products/stats") =>                          hashset!{"stats.get", "*"}, | ||||
|             ("GET",     "/stats") =>                                           hashset!{"stats.get", "*"}, | ||||
|             ("POST",    "/dumps") =>                                           hashset!{"dumps.create", "*"}, | ||||
|             ("POST",    "/indexes/products/documents") =>                      hashset!{"documents.add", "documents.*", "*"}, | ||||
|             ("GET",     "/indexes/products/documents") =>                      hashset!{"documents.get", "documents.*", "*"}, | ||||
|             ("GET",     "/indexes/products/documents/0") =>                    hashset!{"documents.get", "documents.*", "*"}, | ||||
|             ("DELETE",  "/indexes/products/documents/0") =>                    hashset!{"documents.delete", "documents.*", "*"}, | ||||
|             ("GET",     "/tasks") =>                                           hashset!{"tasks.get", "tasks.*", "*"}, | ||||
|             ("GET",     "/tasks?indexUid=products") =>                         hashset!{"tasks.get", "tasks.*", "*"}, | ||||
|             ("GET",     "/tasks/0") =>                                         hashset!{"tasks.get", "tasks.*", "*"}, | ||||
|             ("PATCH",   "/indexes/products/") =>                               hashset!{"indexes.update", "indexes.*", "*"}, | ||||
|             ("GET",     "/indexes/products/") =>                               hashset!{"indexes.get", "indexes.*", "*"}, | ||||
|             ("DELETE",  "/indexes/products/") =>                               hashset!{"indexes.delete", "indexes.*", "*"}, | ||||
|             ("POST",    "/indexes") =>                                         hashset!{"indexes.create", "indexes.*", "*"}, | ||||
|             ("GET",     "/indexes") =>                                         hashset!{"indexes.get", "indexes.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings") =>                       hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/displayed-attributes") =>  hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/distinct-attribute") =>    hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/filterable-attributes") => hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/ranking-rules") =>         hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/searchable-attributes") => hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/sortable-attributes") =>   hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/stop-words") =>            hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/settings/synonyms") =>              hashset!{"settings.get", "settings.*", "*"}, | ||||
|             ("DELETE",  "/indexes/products/settings") =>                       hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PATCH",   "/indexes/products/settings") =>                       hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PATCH",   "/indexes/products/settings/typo-tolerance") =>        hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/displayed-attributes") =>  hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/distinct-attribute") =>    hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/filterable-attributes") => hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/ranking-rules") =>         hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/searchable-attributes") => hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/sortable-attributes") =>   hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/stop-words") =>            hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("PUT",     "/indexes/products/settings/synonyms") =>              hashset!{"settings.update", "settings.*", "*"}, | ||||
|             ("GET",     "/indexes/products/stats") =>                          hashset!{"stats.get", "stats.*", "*"}, | ||||
|             ("GET",     "/stats") =>                                           hashset!{"stats.get", "stats.*", "*"}, | ||||
|             ("POST",    "/dumps") =>                                           hashset!{"dumps.create", "dumps.*", "*"}, | ||||
|             ("GET",     "/version") =>                                         hashset!{"version", "*"}, | ||||
|             ("PATCH",   "/keys/mykey/") =>                                     hashset!{"keys.update", "*"}, | ||||
|             ("GET",     "/keys/mykey/") =>                                     hashset!{"keys.get", "*"}, | ||||
|   | ||||
| @@ -115,7 +115,7 @@ static REFUSED_KEYS: Lazy<Vec<Value>> = Lazy::new(|| { | ||||
|     ] | ||||
| }); | ||||
|  | ||||
| macro_rules! compute_autorized_search { | ||||
| macro_rules! compute_authorized_search { | ||||
|     ($tenant_tokens:expr, $filter:expr, $expected_count:expr) => { | ||||
|         let mut server = Server::new_auth().await; | ||||
|         server.use_admin_key("MASTER_KEY").await; | ||||
| @@ -251,7 +251,7 @@ async fn search_authorized_simple_token() { | ||||
|         }, | ||||
|     ]; | ||||
|  | ||||
|     compute_autorized_search!(tenant_tokens, {}, 5); | ||||
|     compute_authorized_search!(tenant_tokens, {}, 5); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| @@ -305,7 +305,7 @@ async fn search_authorized_filter_token() { | ||||
|         }, | ||||
|     ]; | ||||
|  | ||||
|     compute_autorized_search!(tenant_tokens, {}, 3); | ||||
|     compute_authorized_search!(tenant_tokens, {}, 3); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| @@ -359,7 +359,7 @@ async fn filter_search_authorized_filter_token() { | ||||
|         }, | ||||
|     ]; | ||||
|  | ||||
|     compute_autorized_search!(tenant_tokens, "color = yellow", 1); | ||||
|     compute_authorized_search!(tenant_tokens, "color = yellow", 1); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
|   | ||||
| @@ -625,7 +625,7 @@ async fn add_documents_no_index_creation() { | ||||
|         OffsetDateTime::parse(response["enqueuedAt"].as_str().unwrap(), &Rfc3339).unwrap(); | ||||
|     assert!(processed_at > enqueued_at); | ||||
|  | ||||
|     // index was created, and primary key was infered. | ||||
|     // index was created, and primary key was inferred. | ||||
|     let (response, code) = index.get().await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["primaryKey"], "id"); | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| // This modules contains all the test concerning search. Each particular feture of the search | ||||
| // This modules contains all the test concerning search. Each particular feature of the search | ||||
| // should be tested in its own module to isolate tests and keep the tests readable. | ||||
|  | ||||
| mod errors; | ||||
|   | ||||
| @@ -39,7 +39,7 @@ async fn get_task_status() { | ||||
|     index.wait_task(0).await; | ||||
|     let (_response, code) = index.get_task(1).await; | ||||
|     assert_eq!(code, 200); | ||||
|     // TODO check resonse format, as per #48 | ||||
|     // TODO check response format, as per #48 | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
|   | ||||
| @@ -9,7 +9,7 @@ anyhow = { version = "1.0.56", features = ["backtrace"] } | ||||
| async-stream = "0.3.3" | ||||
| async-trait = "0.1.52" | ||||
| atomic_refcell = "0.1.8" | ||||
| byte-unit = { version = "4.0.14", default-features = false, features = ["std"] } | ||||
| byte-unit = { version = "4.0.14", default-features = false, features = ["std", "serde"] } | ||||
| bytes = "1.1.0" | ||||
| clap = { version = "3.1.6", features = ["derive", "env"] } | ||||
| crossbeam-channel = "0.5.2" | ||||
|   | ||||
| @@ -38,7 +38,7 @@ impl BatchContent { | ||||
|  | ||||
| #[derive(Debug)] | ||||
| pub struct Batch { | ||||
|     // Only batches that contains a persistant tasks are given an id. Snapshot batches don't have | ||||
|     // Only batches that contains a persistent tasks are given an id. Snapshot batches don't have | ||||
|     // an id. | ||||
|     pub id: Option<BatchId>, | ||||
|     pub created_at: OffsetDateTime, | ||||
|   | ||||
| @@ -33,7 +33,7 @@ pub trait BatchHandler: Sync + Send + 'static { | ||||
|     /// `accept` beforehand. | ||||
|     async fn process_batch(&self, batch: Batch) -> Batch; | ||||
|  | ||||
|     /// `finish` is called when the result of `process` has been commited to the task store. This | ||||
|     /// `finish` is called when the result of `process` has been committed to the task store. This | ||||
|     /// method can be used to perform cleanup after the update has been completed for example. | ||||
|     async fn finish(&self, batch: &Batch); | ||||
| } | ||||
|   | ||||
| @@ -189,7 +189,7 @@ impl TaskQueue { | ||||
|             Entry::Occupied(entry) => { | ||||
|                 // A task list already exists for this index, all we have to to is to push the new | ||||
|                 // update to the end of the list. This won't change the order since ids are | ||||
|                 // monotically increasing. | ||||
|                 // monotonically increasing. | ||||
|                 let mut list = entry.get().borrow_mut(); | ||||
|  | ||||
|                 // We only need the first element to be lower than the one we want to | ||||
|   | ||||
| @@ -78,7 +78,7 @@ impl TaskEvent { | ||||
|  | ||||
| /// A task represents an operation that Meilisearch must do. | ||||
| /// It's stored on disk and executed from the lowest to highest Task id. | ||||
| /// Everytime a new task is created it has a higher Task id than the previous one. | ||||
| /// Every time a new task is created it has a higher Task id than the previous one. | ||||
| /// See also `Job`. | ||||
| #[derive(Clone, Debug, Serialize, Deserialize, PartialEq)] | ||||
| #[cfg_attr(test, derive(proptest_derive::Arbitrary))] | ||||
|   | ||||
| @@ -122,7 +122,7 @@ impl TaskStore { | ||||
|     } | ||||
|  | ||||
|     /// This methods takes a `Processing` which contains the next task ids to process, and returns | ||||
|     /// the coresponding tasks along with the ownership to the passed processing. | ||||
|     /// the corresponding tasks along with the ownership to the passed processing. | ||||
|     /// | ||||
|     /// We need get_processing_tasks to take ownership over `Processing` because we need it to be | ||||
|     /// valid for 'static. | ||||
|   | ||||
| @@ -49,7 +49,7 @@ impl UpdateLoop { | ||||
|             }; | ||||
|  | ||||
|             if let Err(e) = self.process_next_batch().await { | ||||
|                 log::error!("an error occured while processing an update batch: {}", e); | ||||
|                 log::error!("an error occurred while processing an update batch: {}", e); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user