]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
mdssvc: better support for search with mdfind from Macs
authorRalph Boehme <slow@samba.org>
Tue, 29 Aug 2023 14:14:38 +0000 (16:14 +0200)
committerRalph Boehme <slow@samba.org>
Wed, 30 Aug 2023 10:51:40 +0000 (10:51 +0000)
When searching Samba via Spotlight from a Mac with mdfind, only 50 results are
returned.

It seems the changes for bug #15342 where one step in the right
direction. There, a status indicator meaning "search is still being processed"
was implemented, returning a special status indicator (0x23) in a response, when
the query was still running in the backend, eg Elasticsearch, and we haven't got
any result when when the Mac already comes along asking for results of a query.

Turns out, we should also return 0x23, ie "search is still being processed" when
we have some initial search results from the backend. Otherwise mdfind will stop
querying for more results. It works in Finder, as the Finder by default employs
a "live" search where it just keeps polling for more results even after the
server returned an empty result set. The Finder just keeps on querying in some
interval, typically 4 seconds, and a Mac server Spotlight server might return
new results if new files where created that match the query, hence "live"
search.

BUG: https://bugzilla.samba.org/show_bug.cgi?id=15463

Signed-off-by: Ralph Boehme <slow@samba.org>
Reviewed-by: Noel Power <noel.power@suse.com>
Autobuild-User(master): Ralph Böhme <slow@samba.org>
Autobuild-Date(master): Wed Aug 30 10:51:40 UTC 2023 on atb-devel-224

source3/rpc_server/mdssvc/mdssvc.c

index e79be666dbe7d82ce38a10607d7f610d64d73288..23a30884b696d03848bcad1df61928b290ec6dc2 100644 (file)
@@ -313,11 +313,11 @@ static bool add_results(sl_array_t *array, struct sl_query *slq)
        bool ok;
 
        /*
-        * Taken from a network trace against a macOS SMB Spotlight server. If
-        * the first fetch-query-results has no results yet because the search
-        * is still running, macOS returns 0x23, otherwise 0x0.
+        * Taken from network traces against a macOS SMB Spotlight server: if
+        * the search is not finished yet in the backend macOS returns 0x23,
+        * otherwise 0x0.
         */
-       if (slq->state >= SLQ_STATE_RESULTS ) {
+       if (slq->state >= SLQ_STATE_DONE) {
                status = 0;
        } else {
                status = 0x23;