-
Notifications
You must be signed in to change notification settings - Fork 58
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
SearchResult is badly shaped #426
Comments
Hi @juchom,
Paginated search:
That's for the explanation. If you have a better alternative I'm all ears, knowing that your inputs are always very interesting and that we are open to any improvement to reduce user friction 😊 |
Thanks @alallema, I double checked the api doc and see that both fields are present depending on how you query the server. I understand why you made this choice. But I think, it's not a good decision, having to safely upcast an interface to its concrete implementation and then use this upcasted object is inefficient and the dev experience is not great. According to the doc (even if it's not clear, you should add a column saying if the field in the response is optional, https://www.meilisearch.com/docs/reference/api/search#response), the api response are marking this fields as optional and this should be the same in C#. The |
I just checked your rust client and it's shaped with one model with optional properties : |
Yes, the Golang too!
It's very interesting, thank you. I agree with you in fact I think it would probably be easier to use with optional for the users |
Hi @juchom, thanks for raising this topic with us! The decision to use the interface was a no-brainer to me since it seems the correct way to map this type of API in a statically typed OOP language. In fact, I didn't consider using the C# optionals. I probably didn't remember C# had it 😄. Before committing to this breaking change, I would like to get more context about why this isn't good. Is this bad just because this is a library? And will it be harder to make things work if you have to cast the object? Some usage examples:
Because to be honest, I think it is safer to have the type-casted object compared to the nullable version. Also, we could change even more the current responses, so adding more optionals will not be that interesting (the SearchResult object will be a God Object). |
The main reasons for this are :
I understand why you made this decision, but I think this client is not responsible for this kind of transformations. As a end user I really expect to have an object that match the api response, other transformations / mapping can be done by the end user (by hand or using some libraries).
If the api can send this fields, then the object receiving it is not supposed to lie and show them as optional to exactly match the api response. |
Got it! Thanks for the reply! Do you have some examples of other popular SDKs with the same type of implementation/behavior? I would like to have some examples to back the decision. |
Have a look at Algolia's SearchResponse, this is a massive object with many objects that all can be null This is also how it is shaped in your rust client : |
One more thing, this is not a class with logic inside, this is just a DTO. The god object problem does not really apply here. |
I suggest either changing the interface the Dto, which won't be a breaking change if the Dto inherits from the interface. |
The method should map to only one object without inheritance. This object is matching the spec of the api, what happened next is pure mapping and the responsability of the end user. If you think that |
I think it's better how the class is implemented in rust (actually it's called with the plural name, SearchResults). |
528: Implements show ranking scores in search query r=curquiza a=massijay # Pull Request ## Related issue Fixes #458 ## What does this PR do? - Implements show ranking scores in search query - Does not implement a user friendly way to retrieve the score in the response (impossible to do without making breaking changes, see also #315, #426) users have to add the field in their classes themselves ## PR checklist Please check if your PR fulfills the following requirements: - [x] Does this PR fix an existing issue, or have you listed the changes applied in the PR description (and why they are needed)? - [x] Have you read the contributing guidelines? - [x] Have you made sure that the title is accurate and descriptive of the changes? Thank you so much for contributing to Meilisearch! Co-authored-by: Massimiliano Cristarella <[email protected]> Co-authored-by: Massimiliano Cristarella <[email protected]> Co-authored-by: Clémentine U. - curqui <[email protected]>
i'm hoping to clarify this usage with an update to the documentation and code samples in PR #579 var result = await index.SearchAsync<T>(...);
if (result is SearchResult<T> searchResult)
{
//...
} or var result = await index.SearchAsync<T>(...);
if (result is PaginatedSearchResult<T> searchResult)
{
//...
} |
Description
The API is a bit weird when searching documents.
The C# api when searching returns an
ISearchable<T>
which is implemented bySearchResult<T>
and byPaginatedSearchResult<T>
.The Meilisearch Server response has only one format according to the doc here : https://www.meilisearch.com/docs/reference/api/search#response
Is there any reason to have the C# client designed like this ?
This raise many issues :
Expected behavior
The server is sending only one type of response, so we should only have a single object matching the response.
The interface
ISearchable<T>
, the classPaginatedSearchResult<T>
and the converterISearchableJsonConverterFactory
are not needed at all.The
SearchResult<T>
needs to be updated to support the Meilisearch response according to the doc.The text was updated successfully, but these errors were encountered: