Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
meilisearch-python-sdk
Advanced tools
A Python client providing both async and sync support for the Meilisearch API
Meilisearch Python SDK provides both an async and sync client for the Meilisearch API.
Which client to use depends on your use case. If the code base you are working with uses asyncio,
for example if you are using FastAPI, choose the AsyncClient
,
otherwise choose the sync Client
. The functionality of the two clients is the same, the difference
being that the AsyncClient
provides async methods and uses the AsyncIndex
with its own
additional async methods. On the other hand, Client
provides blocking methods and uses the Index
with its own blocking methods.
Using a virtual environment is recommended for installing this package. Once the virtual environment is created and activated, install the package with:
pip install meilisearch-python-sdk
There are several ways to run Meilisearch. Pick the one that works best for your use case and then start the server.
As as example to use Docker:
docker pull getmeili/meilisearch:latest
docker run -it --rm -p 7700:7700 getmeili/meilisearch:latest ./meilisearch --master-key=masterKey
from meilisearch_python_sdk import AsyncClient
async with AsyncClient('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"},
]
await index.add_documents(documents)
from meilisearch_python_sdk import Client
client = Client('http://127.0.0.1:7700', 'masterKey')
index = client.index("books")
documents = [
{"id": 1, "title": "Ready Player One"},
{"id": 42, "title": "The Hitchhiker's Guide to the Galaxy"},
]
index.add_documents(documents)
The server will return an update id that can be used to
get the status
of the updates. To do this you would save the result response from adding the documents to a
variable, this will be an UpdateId
object, and use it to check the status of the updates.
update = await index.add_documents(documents)
status = await client.index('books').get_update_status(update.update_id)
update = index.add_documents(documents)
status = client.index('books').get_update_status(update.update_id)
search_result = await index.search("ready player")
search_result = index.search("ready player")
SearchResults(
hits = [
{
"id": 1,
"title": "Ready Player One",
},
],
offset = 0,
limit = 20,
nb_hits = 1,
exhaustive_nb_hits = bool,
facets_distributionn = None,
processing_time_ms = 1,
query = "ready player",
)
Information about the parameters can be found in the search parameters section of the documentation.
await index.search(
"guide",
attributes_to_highlight=["title"],
filters="book_id > 10"
)
index.search(
"guide",
attributes_to_highlight=["title"],
filters="book_id > 10"
)
SearchResults(
hits = [
{
"id": 42,
"title": "The Hitchhiker's Guide to the Galaxy",
"_formatted": {
"id": 42,
"title": "The Hitchhiker's Guide to the <em>Galaxy</em>"
}
},
],
offset = 0,
limit = 20,
nb_hits = 1,
exhaustive_nb_hits = bool,
facets_distributionn = None,
processing_time_ms = 5,
query = "galaxy",
)
The following benchmarks compare this library to the official
Meilisearch Python library. Note that all
of the performance gains seen with the AsyncClient
are achieved by taking advantage of asyncio.
This means that if your code is not taking advantage of asyncio or it does not block the event loop,
the gains here will not be seen and the performance between the clients will be very similar.
This test compares how long it takes to send 1 million documents in batches of 1 thousand to the Meilisearch server for indexing (lower is better). The time does not take into account how long Meilisearch takes to index the documents since that is outside of the library functionality.
This test compares how long it takes to complete 1000 searches (lower is better)
Prashanth Rao did some independent testing and found this async client to be ~30% faster than the sync client for data ingestion. You can find a good write-up of the results how he tested them in his blog post.
pytest-meilisearch is a pytest plugin that can help with testing your code. It provides a lot of the boiler plate code you will need.
See our docs for the full documentation.
Contributions to this project are welcome. If you are interested in contributing please see our contributing guide
FAQs
A Python client providing both async and sync support for the Meilisearch API
We found that meilisearch-python-sdk demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.