meilisearch-python-sdk 4.10.0__py3-none-any.whl → 4.11.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of meilisearch-python-sdk might be problematic. Click here for more details.

@@ -36,6 +36,7 @@ from meilisearch_python_sdk.models.search import (
36
36
  from meilisearch_python_sdk.models.settings import MeilisearchSettings
37
37
  from meilisearch_python_sdk.models.task import TaskInfo, TaskResult, TaskStatus
38
38
  from meilisearch_python_sdk.models.version import Version
39
+ from meilisearch_python_sdk.models.webhook import Webhook, WebhookCreate, Webhooks, WebhookUpdate
39
40
  from meilisearch_python_sdk.plugins import AsyncIndexPlugins, IndexPlugins
40
41
  from meilisearch_python_sdk.types import JsonDict
41
42
 
@@ -252,6 +253,124 @@ class AsyncClient(BaseClient):
252
253
 
253
254
  return Network(**response.json())
254
255
 
256
+ async def get_webhooks(self) -> Webhooks:
257
+ """Get all webhooks.
258
+
259
+ Returns:
260
+ An instance of Webhooks containing all configured webhooks.
261
+
262
+ Raises:
263
+ MeilisearchCommunicationError: If there was an error communicating with the server.
264
+ MeilisearchApiError: If the Meilisearch API returned an error.
265
+
266
+ Examples:
267
+ >>> from meilisearch_python_sdk import AsyncClient
268
+ >>> async with AsyncClient("http://localhost.com", "masterKey") as client:
269
+ >>> webhooks = await client.get_webhooks()
270
+ """
271
+ response = await self._http_requests.get("webhooks")
272
+
273
+ return Webhooks(**response.json())
274
+
275
+ async def get_webhook(self, uuid: str) -> Webhook:
276
+ """Get a specific webhook by UUID.
277
+
278
+ Args:
279
+ uuid: The webhook's unique identifier.
280
+
281
+ Returns:
282
+ An instance of Webhook containing the webhook information.
283
+
284
+ Raises:
285
+ MeilisearchCommunicationError: If there was an error communicating with the server.
286
+ MeilisearchApiError: If the Meilisearch API returned an error.
287
+
288
+ Examples:
289
+ >>> from meilisearch_python_sdk import AsyncClient
290
+ >>> async with AsyncClient("http://localhost.com", "masterKey") as client:
291
+ >>> webhook = await client.get_webhook("abc-123")
292
+ """
293
+ response = await self._http_requests.get(f"webhooks/{uuid}")
294
+
295
+ return Webhook(**response.json())
296
+
297
+ async def create_webhook(self, webhook: WebhookCreate) -> Webhook:
298
+ """Create a new webhook.
299
+
300
+ Args:
301
+ webhook: The webhook configuration to create.
302
+
303
+ Returns:
304
+ The created webhook.
305
+
306
+ Raises:
307
+ MeilisearchCommunicationError: If there was an error communicating with the server.
308
+ MeilisearchApiError: If the Meilisearch API returned an error.
309
+
310
+ Examples:
311
+ >>> from meilisearch_python_sdk import AsyncClient
312
+ >>> from meilisearch_python_sdk.models.webhook import WebhookCreate
313
+ >>> async with AsyncClient("http://localhost.com", "masterKey") as client:
314
+ >>> webhook_config = WebhookCreate(
315
+ >>> url="https://example.com/webhook",
316
+ >>> headers={"Authorization": "Bearer token"}
317
+ >>> )
318
+ >>> webhook = await client.create_webhook(webhook_config)
319
+ """
320
+ response = await self._http_requests.post(
321
+ "webhooks", webhook.model_dump(by_alias=True, exclude_none=True)
322
+ )
323
+
324
+ return Webhook(**response.json())
325
+
326
+ async def update_webhook(self, *, uuid: str, webhook: WebhookUpdate) -> Webhook:
327
+ """Update an existing webhook.
328
+
329
+ Args:
330
+ uuid: The webhook's unique identifier.
331
+ webhook: The webhook configuration updates.
332
+
333
+ Returns:
334
+ The updated webhook.
335
+
336
+ Raises:
337
+ MeilisearchCommunicationError: If there was an error communicating with the server.
338
+ MeilisearchApiError: If the Meilisearch API returned an error.
339
+
340
+ Examples:
341
+ >>> from meilisearch_python_sdk import AsyncClient
342
+ >>> from meilisearch_python_sdk.models.webhook import WebhookUpdate
343
+ >>> async with AsyncClient("http://localhost.com", "masterKey") as client:
344
+ >>> webhook_update = WebhookUpdate(url="https://example.com/new-webhook")
345
+ >>> webhook = await client.update_webhook("abc-123", webhook_update)
346
+ """
347
+ response = await self._http_requests.patch(
348
+ f"webhooks/{uuid}", webhook.model_dump(by_alias=True, exclude_none=True)
349
+ )
350
+
351
+ return Webhook(**response.json())
352
+
353
+ async def delete_webhook(self, uuid: str) -> int:
354
+ """Delete a webhook.
355
+
356
+ Args:
357
+ uuid: The webhook's unique identifier.
358
+
359
+ Returns:
360
+ The Response status code. 204 signifies a successful delete.
361
+
362
+ Raises:
363
+ MeilisearchCommunicationError: If there was an error communicating with the server.
364
+ MeilisearchApiError: If the Meilisearch API returned an error.
365
+
366
+ Examples:
367
+ >>> from meilisearch_python_sdk import AsyncClient
368
+ >>> async with AsyncClient("http://localhost.com", "masterKey") as client:
369
+ >>> await client.delete_webhook("abc-123")
370
+ """
371
+ response = await self._http_requests.delete(f"webhooks/{uuid}")
372
+ return response.status_code
373
+
255
374
  async def create_dump(self) -> TaskInfo:
256
375
  """Trigger the creation of a Meilisearch dump.
257
376
 
@@ -1229,6 +1348,124 @@ class Client(BaseClient):
1229
1348
 
1230
1349
  return Network(**response.json())
1231
1350
 
1351
+ def get_webhooks(self) -> Webhooks:
1352
+ """Get all webhooks.
1353
+
1354
+ Returns:
1355
+ An instance of Webhooks containing all configured webhooks.
1356
+
1357
+ Raises:
1358
+ MeilisearchCommunicationError: If there was an error communicating with the server.
1359
+ MeilisearchApiError: If the Meilisearch API returned an error.
1360
+
1361
+ Examples:
1362
+ >>> from meilisearch_python_sdk import Client
1363
+ >>> client = Client("http://localhost.com", "masterKey")
1364
+ >>> webhooks = client.get_webhooks()
1365
+ """
1366
+ response = self._http_requests.get("webhooks")
1367
+
1368
+ return Webhooks(**response.json())
1369
+
1370
+ def get_webhook(self, uuid: str) -> Webhook:
1371
+ """Get a specific webhook by UUID.
1372
+
1373
+ Args:
1374
+ uuid: The webhook's unique identifier.
1375
+
1376
+ Returns:
1377
+ An instance of Webhook containing the webhook information.
1378
+
1379
+ Raises:
1380
+ MeilisearchCommunicationError: If there was an error communicating with the server.
1381
+ MeilisearchApiError: If the Meilisearch API returned an error.
1382
+
1383
+ Examples:
1384
+ >>> from meilisearch_python_sdk import Client
1385
+ >>> client = Client("http://localhost.com", "masterKey")
1386
+ >>> webhook = client.get_webhook("abc-123")
1387
+ """
1388
+ response = self._http_requests.get(f"webhooks/{uuid}")
1389
+
1390
+ return Webhook(**response.json())
1391
+
1392
+ def create_webhook(self, webhook: WebhookCreate) -> Webhook:
1393
+ """Create a new webhook.
1394
+
1395
+ Args:
1396
+ webhook: The webhook configuration to create.
1397
+
1398
+ Returns:
1399
+ The created webhook.
1400
+
1401
+ Raises:
1402
+ MeilisearchCommunicationError: If there was an error communicating with the server.
1403
+ MeilisearchApiError: If the Meilisearch API returned an error.
1404
+
1405
+ Examples:
1406
+ >>> from meilisearch_python_sdk import Client
1407
+ >>> from meilisearch_python_sdk.models.webhook import WebhookCreate
1408
+ >>> client = Client("http://localhost.com", "masterKey")
1409
+ >>> webhook_config = WebhookCreate(
1410
+ >>> url="https://example.com/webhook",
1411
+ >>> headers={"Authorization": "Bearer token"}
1412
+ >>> )
1413
+ >>> webhook = client.create_webhook(webhook_config)
1414
+ """
1415
+ response = self._http_requests.post(
1416
+ "webhooks", webhook.model_dump(by_alias=True, exclude_none=True)
1417
+ )
1418
+
1419
+ return Webhook(**response.json())
1420
+
1421
+ def update_webhook(self, *, uuid: str, webhook: WebhookUpdate) -> Webhook:
1422
+ """Update an existing webhook.
1423
+
1424
+ Args:
1425
+ uuid: The webhook's unique identifier.
1426
+ webhook: The webhook configuration updates.
1427
+
1428
+ Returns:
1429
+ The updated webhook.
1430
+
1431
+ Raises:
1432
+ MeilisearchCommunicationError: If there was an error communicating with the server.
1433
+ MeilisearchApiError: If the Meilisearch API returned an error.
1434
+
1435
+ Examples:
1436
+ >>> from meilisearch_python_sdk import Client
1437
+ >>> from meilisearch_python_sdk.models.webhook import WebhookUpdate
1438
+ >>> client = Client("http://localhost.com", "masterKey")
1439
+ >>> webhook_update = WebhookUpdate(url="https://example.com/new-webhook")
1440
+ >>> webhook = client.update_webhook("abc-123", webhook_update)
1441
+ """
1442
+ response = self._http_requests.patch(
1443
+ f"webhooks/{uuid}", webhook.model_dump(by_alias=True, exclude_none=True)
1444
+ )
1445
+
1446
+ return Webhook(**response.json())
1447
+
1448
+ def delete_webhook(self, uuid: str) -> int:
1449
+ """Delete a webhook.
1450
+
1451
+ Args:
1452
+ uuid: The webhook's unique identifier.
1453
+
1454
+ Returns:
1455
+ The Response status code. 204 signifies a successful delete.
1456
+
1457
+ Raises:
1458
+ MeilisearchCommunicationError: If there was an error communicating with the server.
1459
+ MeilisearchApiError: If the Meilisearch API returned an error.
1460
+
1461
+ Examples:
1462
+ >>> from meilisearch_python_sdk import Client
1463
+ >>> client = Client("http://localhost.com", "masterKey")
1464
+ >>> client.delete_webhook("abc-123")
1465
+ """
1466
+ response = self._http_requests.delete(f"webhooks/{uuid}")
1467
+ return response.status_code
1468
+
1232
1469
  def create_dump(self) -> TaskInfo:
1233
1470
  """Trigger the creation of a Meilisearch dump.
1234
1471
 
@@ -1 +1 @@
1
- VERSION = "4.10.0"
1
+ VERSION = "4.11.0"
@@ -3593,7 +3593,7 @@ class AsyncIndex(_BaseIndex):
3593
3593
 
3594
3594
  return TaskInfo(**response.json())
3595
3595
 
3596
- async def get_filterable_attributes(self) -> list[str] | list[FilterableAttributes] | None:
3596
+ async def get_filterable_attributes(self) -> list[str | FilterableAttributes] | None:
3597
3597
  """Get filterable attributes of the index.
3598
3598
 
3599
3599
  Returns:
@@ -3616,22 +3616,22 @@ class AsyncIndex(_BaseIndex):
3616
3616
 
3617
3617
  response_json = response.json()
3618
3618
 
3619
- if isinstance(response_json[0], str):
3620
- return response_json
3621
-
3622
- filterable_attributes = []
3619
+ filterable_attributes: list[str | FilterableAttributes] = []
3623
3620
  for r in response_json:
3624
- filterable_attributes.append(
3625
- FilterableAttributes(
3626
- attribute_patterns=r["attributePatterns"],
3627
- features=FilterableAttributeFeatures(**r["features"]),
3621
+ if isinstance(r, str):
3622
+ filterable_attributes.append(r)
3623
+ else:
3624
+ filterable_attributes.append(
3625
+ FilterableAttributes(
3626
+ attribute_patterns=r["attributePatterns"],
3627
+ features=FilterableAttributeFeatures(**r["features"]),
3628
+ )
3628
3629
  )
3629
- )
3630
3630
 
3631
3631
  return filterable_attributes
3632
3632
 
3633
3633
  async def update_filterable_attributes(
3634
- self, body: list[str] | list[FilterableAttributes], *, compress: bool = False
3634
+ self, body: list[str | FilterableAttributes], *, compress: bool = False
3635
3635
  ) -> TaskInfo:
3636
3636
  """Update filterable attributes of the index.
3637
3637
 
@@ -7224,7 +7224,7 @@ class Index(_BaseIndex):
7224
7224
 
7225
7225
  return TaskInfo(**response.json())
7226
7226
 
7227
- def get_filterable_attributes(self) -> list[str] | list[FilterableAttributes] | None:
7227
+ def get_filterable_attributes(self) -> list[str | FilterableAttributes] | None:
7228
7228
  """Get filterable attributes of the index.
7229
7229
 
7230
7230
  Returns:
@@ -7247,22 +7247,22 @@ class Index(_BaseIndex):
7247
7247
 
7248
7248
  response_json = response.json()
7249
7249
 
7250
- if isinstance(response_json[0], str):
7251
- return response_json
7252
-
7253
- filterable_attributes = []
7250
+ filterable_attributes: list[str | FilterableAttributes] = []
7254
7251
  for r in response_json:
7255
- filterable_attributes.append(
7256
- FilterableAttributes(
7257
- attribute_patterns=r["attributePatterns"],
7258
- features=FilterableAttributeFeatures(**r["features"]),
7252
+ if isinstance(r, str):
7253
+ filterable_attributes.append(r)
7254
+ else:
7255
+ filterable_attributes.append(
7256
+ FilterableAttributes(
7257
+ attribute_patterns=r["attributePatterns"],
7258
+ features=FilterableAttributeFeatures(**r["features"]),
7259
+ )
7259
7260
  )
7260
- )
7261
7261
 
7262
7262
  return filterable_attributes
7263
7263
 
7264
7264
  def update_filterable_attributes(
7265
- self, body: list[str] | list[FilterableAttributes], *, compress: bool = False
7265
+ self, body: list[str | FilterableAttributes], *, compress: bool = False
7266
7266
  ) -> TaskInfo:
7267
7267
  """Update filterable attributes of the index.
7268
7268
 
@@ -167,7 +167,7 @@ class MeilisearchSettings(CamelBase):
167
167
  synonyms: JsonDict | None = None
168
168
  stop_words: list[str] | None = None
169
169
  ranking_rules: list[str] | None = None
170
- filterable_attributes: list[str] | list[FilterableAttributes] | None = None
170
+ filterable_attributes: list[str | FilterableAttributes] | None = None
171
171
  distinct_attribute: str | None = None
172
172
  searchable_attributes: list[str] | None = None
173
173
  displayed_attributes: list[str] | None = None
@@ -0,0 +1,24 @@
1
+ from __future__ import annotations
2
+
3
+ from camel_converter.pydantic_base import CamelBase
4
+
5
+
6
+ class Webhook(CamelBase):
7
+ uuid: str
8
+ url: str
9
+ headers: dict[str, str] | None = None
10
+ is_editable: bool
11
+
12
+
13
+ class Webhooks(CamelBase):
14
+ results: list[Webhook]
15
+
16
+
17
+ class WebhookCreate(CamelBase):
18
+ url: str
19
+ headers: dict[str, str] | None = None
20
+
21
+
22
+ class WebhookUpdate(CamelBase):
23
+ url: str | None = None
24
+ headers: dict[str, str] | None = None
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: meilisearch-python-sdk
3
- Version: 4.10.0
3
+ Version: 4.11.0
4
4
  Summary: A Python client providing both async and sync support for the Meilisearch API
5
5
  Project-URL: repository, https://github.com/sanders41/meilisearch-python-sdk
6
6
  Project-URL: homepage, https://github.com/sanders41/meilisearch-python-sdk
@@ -1,13 +1,13 @@
1
1
  meilisearch_python_sdk/__init__.py,sha256=SB0Jlm6FwT13J9xasZKseZzTWBk0hkfe1CWyWmIIZnE,258
2
2
  meilisearch_python_sdk/_batch.py,sha256=Hbt-M8Lt8ZDZqcKToUMzUd5zvT-gku709er4pRlvXWk,5065
3
- meilisearch_python_sdk/_client.py,sha256=wwSNx0pKkVz3tMYw_Zk04C5DmjrqxjP0Hi6iD3l9RAI,81729
3
+ meilisearch_python_sdk/_client.py,sha256=HA0FdvsVGAHhUt6mVB-sK03bIzVivN7ProcimeQdgjQ,90624
4
4
  meilisearch_python_sdk/_http_requests.py,sha256=O3M3n-t1jAKwccWowPbk-HPD3ExtHq8a3XhnZT5facs,6746
5
5
  meilisearch_python_sdk/_task.py,sha256=QgVcqMlZdURRS_oYpB_bTBa5dvT3Sp_-O0-s6TqAxHk,12485
6
6
  meilisearch_python_sdk/_utils.py,sha256=NoCDxJPhjABeuSxFTNCih585UDWdXEUBD_FvdgtScQw,1539
7
- meilisearch_python_sdk/_version.py,sha256=NzVhpOSZyYUYSW4PUD6no8sHaIfvdmRhQGP6pe-HgrM,19
7
+ meilisearch_python_sdk/_version.py,sha256=P-An9BGfasfrCKgh22bKMbdgfN7f7BM-eGimBxENmes,19
8
8
  meilisearch_python_sdk/decorators.py,sha256=njMn40P-qOzKGGQLCDpsBKWyj2ai10s4XG4IUBSHoD4,8674
9
9
  meilisearch_python_sdk/errors.py,sha256=RNNHXtXLBiCVZaLM2MeKKs9RbRuE-SLRttiPeVAEXgA,2133
10
- meilisearch_python_sdk/index.py,sha256=1hKuVPQPH1bpQ_3DrnihpypMZk5ZZok0-pU3RjO0Sfo,349340
10
+ meilisearch_python_sdk/index.py,sha256=XxUgfOBUo6ClayI94I0AljGW4obam5hBIHeAz7d8f4Q,349474
11
11
  meilisearch_python_sdk/json_handler.py,sha256=c1rGKzYlE0dGfLygQjPqVUNfQkN1JvafBGmIx31JW8g,2044
12
12
  meilisearch_python_sdk/plugins.py,sha256=YySzTuVr4IrogTgrP8q-gZPsew8TwedopjWnTj5eV48,3607
13
13
  meilisearch_python_sdk/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -19,10 +19,11 @@ meilisearch_python_sdk/models/documents.py,sha256=eT3FHrPND-g2IzNRyOHQApTTJ1WbFc
19
19
  meilisearch_python_sdk/models/health.py,sha256=hvruti7ylsk7bAh8RPOhTPcRrjx6MPgdkDFX9vZ5Qks,95
20
20
  meilisearch_python_sdk/models/index.py,sha256=WLQOi3_HChko134FkRU1H3_cJjhHJCFclcx4oDBlqHU,1228
21
21
  meilisearch_python_sdk/models/search.py,sha256=U3ph1GW9Xkbw33pIlGDa7rlTGsdvqahjRJjPxUou8n8,3581
22
- meilisearch_python_sdk/models/settings.py,sha256=3UdJWbrXfTrwvzu3Gq-aY1fDmAejysSz7yRQ-7yXCwQ,5736
22
+ meilisearch_python_sdk/models/settings.py,sha256=eh0xnro4D_sj8ck2nifa3tBdf2_7RcZlAY_zQhfsY0s,5730
23
23
  meilisearch_python_sdk/models/task.py,sha256=JVYF46ylD-XwqVVNq2offhLOkljaGxPyRVuF6PwLOBU,2174
24
24
  meilisearch_python_sdk/models/version.py,sha256=YDu-aj5H-d6nSaWRTXzlwWghmZAoiknaw250UyEd48I,215
25
- meilisearch_python_sdk-4.10.0.dist-info/METADATA,sha256=F4EJvoyqdCCc8QkggKdoO2UF7PrExHLqGOXwjthh9IA,9764
26
- meilisearch_python_sdk-4.10.0.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
27
- meilisearch_python_sdk-4.10.0.dist-info/licenses/LICENSE,sha256=xVzevI1TrlKfM0plmJ7vfK1Muu0V9n-dGE8RnDrOFlM,1069
28
- meilisearch_python_sdk-4.10.0.dist-info/RECORD,,
25
+ meilisearch_python_sdk/models/webhook.py,sha256=zSkEJJdEflinW3_seJTLQ_ZWs4w-pjTD3SS1ZawC32k,455
26
+ meilisearch_python_sdk-4.11.0.dist-info/METADATA,sha256=PygEoNhWOtRVqDTIRr5SXzoz0aezlr_g7fSBwaJ1Mu4,9764
27
+ meilisearch_python_sdk-4.11.0.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
28
+ meilisearch_python_sdk-4.11.0.dist-info/licenses/LICENSE,sha256=xVzevI1TrlKfM0plmJ7vfK1Muu0V9n-dGE8RnDrOFlM,1069
29
+ meilisearch_python_sdk-4.11.0.dist-info/RECORD,,