update-searchable-attributes
Modify which fields in a Meilisearch index are used for search queries to improve relevance and performance.
Instructions
Update the searchable attributes setting
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| indexUid | Yes | Unique identifier of the index | |
| value | Yes | JSON value for the setting |
Implementation Reference
- src/tools/settings-tools.ts:236-248 (handler)Shared handler for update tools: parses JSON value input, performs PUT request to `/indexes/${indexUid}/settings/searchable-attributes` using apiClient, returns JSON response or error.async ({ indexUid, value }) => { try { // Parse the value string to ensure it's valid JSON const parsedValue = JSON.parse(value); const response = await apiClient.put(`/indexes/${indexUid}/settings/${endpoint}`, parsedValue); return { content: [{ type: "text", text: JSON.stringify(response.data, null, 2) }], }; } catch (error) { return createErrorResponse(error); } }
- src/tools/settings-tools.ts:232-235 (schema)Input schema using Zod: indexUid (string, Meilisearch index UID), value (string, JSON-serialized setting value).{ indexUid: z.string().describe("Unique identifier of the index"), value: z.string().describe("JSON value for the setting"), },
- src/tools/settings-tools.ts:170-174 (registration)Tool configuration in updateSettingsTools array: specifies name, endpoint ("searchable-attributes"), and description for dynamic server.tool() registration.{ name: "update-searchable-attributes", endpoint: "searchable-attributes", description: "Update the searchable attributes setting", },
- src/index.ts:67-67 (registration)Top-level call to registerSettingsTools(server), which dynamically registers the "update-searchable-attributes" tool via the loop in settings-tools.ts.registerSettingsTools(server);