Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 7 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,15 +66,15 @@ async with AsyncClient('http://127.0.0.1:7700', 'masterKey') as client:
```py
from meilisearch_python_sdk import Client

client = Client('http://127.0.0.1:7700', 'masterKey')
index = client.index("books")
with Client('http://127.0.0.1:7700', 'masterKey') as client:
index = client.index("books")

documents = [
{"id": 1, "title": "Ready Player One"},
{"id": 42, "title": "The Hitchhiker's Guide to the Galaxy"},
]
documents = [
{"id": 1, "title": "Ready Player One"},
{"id": 42, "title": "The Hitchhiker's Guide to the Galaxy"},
]

index.add_documents(documents)
index.add_documents(documents)
```

The server will return an update id that can be used to
Expand Down
36 changes: 27 additions & 9 deletions docs/client_api.md
Original file line number Diff line number Diff line change
@@ -1,16 +1,17 @@
## `client` Usage

### Create a client
### Create a client with a context manager

To create a client:
This client runs in a context manager which ensures that everything is cleaned up after the use of
the client is done. To create a client:

```py
from milisearch_python_sdk import Client
from meilisearch-python-sdk import Client


client = Client("http://localhost:7700", "masterKey")
index = client.index("movies")
...
with Client("http://localhost:7700", "masterKey") as client:
index = client.index("movies")
...
```

### Custom headers
Expand All @@ -21,15 +22,32 @@ client.
```py
from meilisearch_python_sdk import Client

client = Client(
with Client(
"http://127.0.0.1:7700",
"masterKey",
custom_headers={"header_key_1": "header_value_1", "header_key_2": "header_value_2"}
)
index = client.index("movies")
) as client:
index = client.index("movies")
...
```

### Create a client without a context manager

It is also possible to call the client without using a context manager, but in doing so you will
need to make sure to do the cleanup yourself:

```py
from meilisearch-python-sdk import Client


try:
client = Client("http://localhost:7700", "masterKey")
...
finally:
await client.close()

```

## `Client` API

::: meilisearch_python_sdk.Client
18 changes: 9 additions & 9 deletions docs/json_handler.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,9 +37,9 @@ documents = [
{"id": uuid4(), "title": "test 1", "when": datetime.now()},
{"id": uuid4(), "title": "Test 2", "when": datetime.now()},
]
client = Client("http://127.0.0.1:7700", json_handler=BuiltinHandler(serializer=CustomEncoder))
index = client.index("movies", primary_key="id")
index.add_documents(documents)
with Client("http://127.0.0.1:7700", json_handler=BuiltinHandler(serializer=CustomEncoder)) as client:
index = client.index("movies", primary_key="id")
index.add_documents(documents)
```

## orjson
Expand All @@ -57,9 +57,9 @@ documents = [
{"id": uuid4(), "title": "test 1"},
{"id": uuid4(), "title": "Test 2"},
]
client = Client("http://127.0.0.1:7700", json_handler=OrjsonHandler())
index = client.index("movies", primary_key="id")
index.add_documents(documents)
with Client("http://127.0.0.1:7700", json_handler=OrjsonHandler()) as client:
index = client.index("movies", primary_key="id")
index.add_documents(documents)
```

## ujson
Expand All @@ -77,7 +77,7 @@ documents = [
{"id": uuid4(), "title": "test 1"},
{"id": uuid4(), "title": "Test 2"},
]
client = Client("http://127.0.0.1:7700", json_handler=UjsonHandler())
index = client.index("movies", primary_key="id")
index.add_documents(documents)
with Client("http://127.0.0.1:7700", json_handler=UjsonHandler()) as client:
index = client.index("movies", primary_key="id")
index.add_documents(documents)
```
72 changes: 36 additions & 36 deletions docs/plugins.md
Original file line number Diff line number Diff line change
Expand Up @@ -84,13 +84,13 @@ async def main() -> int:
with open("datasets/small_movies.json") as f:
documents = json.load(f)

client = AsyncClient("http://127.0.0.1:7700", "masterKey")
plugins = AsyncIndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = await client.create_index("movies", primary_key="id", plugins=plugins)
task = await index.add_documents(documents)
await client.wait_for_task(task.task_uid)
result = await index.search("Cars")
print(result) # noqa: T201
async with AsyncClient("http://127.0.0.1:7700", "masterKey") as client:
plugins = AsyncIndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = await client.create_index("movies", primary_key="id", plugins=plugins)
task = await index.add_documents(documents)
await client.wait_for_task(task.task_uid)
result = await index.search("Cars")
print(result) # noqa: T201

return 0

Expand Down Expand Up @@ -142,13 +142,13 @@ def main() -> int:
with open("datasets/small_movies.json") as f:
documents = json.load(f)

client = Client("http://127.0.0.1:7700", "masterKey")
plugins = IndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("Cars")
print(result) # noqa: T201
with Client("http://127.0.0.1:7700", "masterKey") as client:
plugins = IndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("Cars")
print(result) # noqa: T201

return 0

Expand Down Expand Up @@ -224,17 +224,17 @@ async def main() -> int:
with open("datasets/small_movies.json") as f:
documents = json.load(f)

client = AsyncClient("http://127.0.0.1:7700", "masterKey")
plugins = AsyncIndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = await client.create_index("movies", primary_key="id", plugins=plugins)
task = await index.add_documents(documents)
await client.wait_for_task(task.task_uid)
result = await index.search("cars")
print(result) # noqa: T201
async with AsyncClient("http://127.0.0.1:7700", "masterKey") as client:
plugins = AsyncIndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = await client.create_index("movies", primary_key="id", plugins=plugins)
task = await index.add_documents(documents)
await client.wait_for_task(task.task_uid)
result = await index.search("cars")
print(result) # noqa: T201

return 0

Expand Down Expand Up @@ -295,17 +295,17 @@ def main() -> int:
with open("datasets/small_movies.json") as f:
documents = json.load(f)

client = Client("http://127.0.0.1:7700", "masterKey")
plugins = IndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("cars")
print(result) # noqa: T201
with Client("http://127.0.0.1:7700", "masterKey") as client:
plugins = IndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("cars")
print(result) # noqa: T201

return 0

Expand Down
10 changes: 5 additions & 5 deletions examples/add_documents_decorator.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,12 @@ def load_documents() -> list[dict[str, Any]]:


def main() -> int:
client = Client("http://127.0.0.1:7700", "masterKey")
index = client.create_index("movies", "id")
load_documents()
documents = index.get_documents()
with Client("http://127.0.0.1:7700", "masterKey") as client:
index = client.create_index("movies", "id")
load_documents()
documents = index.get_documents()

print(documents) # noqa: T201
print(documents) # noqa: T201

return 0

Expand Down
8 changes: 4 additions & 4 deletions examples/add_documents_in_batches.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,11 @@ def main() -> int:
with open("../datasets/small_movies.json") as f:
documents = json.load(f)

client = Client("http://127.0.0.1:7700", "masterKey")
index = client.index("movies")
with Client("http://127.0.0.1:7700", "masterKey") as client:
index = client.index("movies")

# Meilisearch prefers larger batch sizes so set this as large as you can.
index.add_documents_in_batches(documents, primary_key="id", batch_size=1000)
# Meilisearch prefers larger batch sizes so set this as large as you can.
index.add_documents_in_batches(documents, primary_key="id", batch_size=1000)

return 0

Expand Down
22 changes: 11 additions & 11 deletions examples/documents_and_search_results.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,17 +50,17 @@ def main() -> int:
with open("../datasets/small_movies.json") as f:
documents = json.load(f)

client = Client("http://127.0.0.1:7700", "masterKey")
plugins = IndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("cars")
print(result) # noqa: T201
with Client("http://127.0.0.1:7700", "masterKey") as client:
plugins = IndexPlugins(
add_documents_plugins=(ModifyDocumentPlugin(),),
update_documents_plugins=(ModifyDocumentPlugin(),),
search_plugins=(FilterSearchResultsPlugin(),),
)
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = index.add_documents(documents)
client.wait_for_task(task.task_uid)
result = index.search("cars")
print(result) # noqa: T201

return 0

Expand Down
6 changes: 3 additions & 3 deletions examples/orjson_example.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@


def add_documents(file_path: Path | str = "../datasets/small_movies.json") -> TaskInfo:
client = Client("http://127.0.0.1:7700", "masterKey", json_handler=OrjsonHandler())
index = client.create_index("movies", primary_key="id")
return index.add_documents_from_file(file_path)
with Client("http://127.0.0.1:7700", "masterKey", json_handler=OrjsonHandler()) as client:
index = client.create_index("movies", primary_key="id")
return index.add_documents_from_file(file_path)


def main() -> int:
Expand Down
14 changes: 7 additions & 7 deletions examples/search_tracker.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,13 +53,13 @@ def search(index: Index, query: str) -> SearchResults[JsonDict]:


def main() -> int:
client = Client("http://127.0.0.1:7700", "masterKey")
plugins = IndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = add_documents(index)
client.wait_for_task(task.task_uid)
result = search(index, "Cars")
print(result) # noqa: T201
with Client("http://127.0.0.1:7700", "masterKey") as client:
plugins = IndexPlugins(search_plugins=(SearchTrackerPlugin(),))
index = client.create_index("movies", primary_key="id", plugins=plugins)
task = add_documents(index)
client.wait_for_task(task.task_uid)
result = search(index, "Cars")
print(result) # noqa: T201

return 0

Expand Down
6 changes: 3 additions & 3 deletions examples/ujson_example.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@


def add_documents(file_path: Path | str = "../datasets/small_movies.json") -> TaskInfo:
client = Client("http://127.0.0.1:7700", "masterKey", json_handler=UjsonHandler())
index = client.create_index("movies", primary_key="id")
return index.add_documents_from_file(file_path)
with Client("http://127.0.0.1:7700", "masterKey", json_handler=UjsonHandler()) as client:
index = client.create_index("movies", primary_key="id")
return index.add_documents_from_file(file_path)


def main() -> int:
Expand Down
10 changes: 5 additions & 5 deletions examples/update_settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,11 @@ def update_settings(index: Index) -> TaskInfo:


def main() -> int:
client = Client("http://127.0.0.1:7700", "masterKey")
index = client.create_index("movies", primary_key="id")
task = update_settings(index)
client.wait_for_task(task.task_uid)
add_documents(index)
with Client("http://127.0.0.1:7700", "masterKey") as client:
index = client.create_index("movies", primary_key="id")
task = update_settings(index)
client.wait_for_task(task.task_uid)
add_documents(index)

return 0

Expand Down
Loading