blob: 5f76a8ccb858e7dcab4fee8910b41932bcce684a [file] [log] [blame]
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_WEBUI_HELP_APP_UI_SEARCH_SEARCH_HANDLER_H_
#define ASH_WEBUI_HELP_APP_UI_SEARCH_SEARCH_HANDLER_H_
#include <memory>
#include <optional>
#include <vector>
#include "ash/webui/help_app_ui/search/search.mojom.h"
#include "ash/webui/help_app_ui/search/search_concept.h"
#include "ash/webui/help_app_ui/search/search_tag_registry.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "base/time/time.h"
#include "chromeos/ash/components/local_search_service/public/cpp/local_search_service_proxy.h"
#include "chromeos/ash/components/local_search_service/public/mojom/index.mojom.h"
#include "mojo/public/cpp/bindings/pending_receiver.h"
#include "mojo/public/cpp/bindings/pending_remote.h"
#include "mojo/public/cpp/bindings/receiver_set.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "mojo/public/cpp/bindings/remote_set.h"
namespace ash::help_app {
// This enum class is defined in the `search_handler.cc` with explanations.
namespace {
enum class CacheStatus;
}
// Handles search queries for the help app. Search() is expected to be invoked
// by the Launcher search UI. Search results are obtained by matching the
// provided query against search tags indexed in the LocalSearchService and
// cross-referencing results with SearchTagRegistry.
//
// Either `Update()` or `OnProfileDirAvailable()` needs to be called before
// `Search()` will work. Searches that do not work or do not provide any matches
// result in an empty results array.
class SearchHandler : public mojom::SearchHandler,
public SearchTagRegistry::Observer {
public:
SearchHandler(SearchTagRegistry* search_tag_registry,
local_search_service::LocalSearchServiceProxy*
local_search_service_proxy);
~SearchHandler() override;
SearchHandler(const SearchHandler& other) = delete;
SearchHandler& operator=(const SearchHandler& other) = delete;
void BindInterface(
mojo::PendingReceiver<mojom::SearchHandler> pending_receiver);
// mojom::SearchHandler:
void Search(const std::u16string& query,
uint32_t max_num_results,
SearchCallback callback) override;
void Update(std::vector<mojom::SearchConceptPtr> concepts,
UpdateCallback callback) override;
void Observe(
mojo::PendingRemote<mojom::SearchResultsObserver> observer) override;
void OnProfileDirAvailable(const base::FilePath& profile_dir);
private:
// SearchTagRegistry::Observer:
void OnRegistryUpdated() override;
std::vector<mojom::SearchResultPtr> GenerateSearchResultsArray(
const std::vector<local_search_service::Result>&
local_search_service_results,
uint32_t max_num_results) const;
void OnFindComplete(
SearchCallback callback,
uint32_t max_num_results,
local_search_service::ResponseStatus response_status,
const std::optional<std::vector<local_search_service::Result>>&
local_search_service_results);
void OnPersistenceReadComplete(std::vector<mojom::SearchConceptPtr> concepts);
// Converts an LSS search result to the format used by this search handler.
mojom::SearchResultPtr ResultToSearchResult(
const local_search_service::Result& result) const;
raw_ptr<SearchTagRegistry> search_tag_registry_;
mojo::Remote<local_search_service::mojom::Index> index_remote_;
CacheStatus cache_status_;
// The time this class is constructed. This is also used as a flag to indicate
// if the availability latency has been logged. After logging, the
// `construction_time_` will be reset to null.
base::TimeTicks construction_time_;
// Note: Expected to have multiple clients, so ReceiverSet/RemoteSet are used.
mojo::ReceiverSet<mojom::SearchHandler> receivers_;
mojo::RemoteSet<mojom::SearchResultsObserver> observers_;
std::unique_ptr<SearchConcept> persistence_;
base::WeakPtrFactory<SearchHandler> weak_ptr_factory_{this};
};
} // namespace ash::help_app
#endif // ASH_WEBUI_HELP_APP_UI_SEARCH_SEARCH_HANDLER_H_