blob: 2dc4583849b96be72af77266335977b28fe7f646 [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <map>
#include <memory>
#include <string>
#include <vector>
#include "base/macros.h"
#include "base/strings/string16.h"
#include "chrome/services/local_search_service/public/mojom/local_search_service.mojom.h"
#include "chrome/services/local_search_service/public/mojom/types.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"
class TokenizedString;
namespace local_search_service {
struct Data {
// Identifier of the data item, should be unique across the registry. Clients
// will decide what ids to use, they could be paths, urls or any opaque string
// identifiers.
// Ideally IDs should persist across sessions, but this is not strictly
// required now because data is not persisted across sessions.
std::string id;
// Data item will be matched between its search tags and query term.
std::vector<base::string16> search_tags;
Data(const Data& data);
struct SearchParams {
double relevance_threshold = 0.3;
double partial_match_penalty_rate = 0.9;
bool use_prefix_only = false;
bool use_weighted_ratio = true;
bool use_edit_distance = false;
// A numeric range used to represent the start and end position.
struct Range {
uint32_t start;
uint32_t end;
// Result is one item that matches a given query. It contains the id of the item
// and its matching score.
struct Result {
// Id of the data.
std::string id;
// Relevance score, in the range of [0,1].
double score;
// Matching ranges.
std::vector<Range> hits;
Result(const Result& result);
// Status of the search attempt.
// More will be added later.
enum class ResponseStatus {
kUnknownError = 0,
// Query is empty.
kEmptyQuery = 1,
// Index is empty (i.e. no data).
kEmptyIndex = 2,
// Search operation is successful. But there could be no matching item and
// result list is empty.
kSuccess = 3
// Actual implementation of a local search service Index.
// It has a registry of searchable data, which can be updated. It also runs an
// asynchronous search function to find matching items for a given query, and
// returns results via a callback.
// In-process clients can choose to call synchronous versions of these
// functions.
// TODO(jiameng): all async calls will be deleted in the next cl.
class IndexImpl : public mojom::Index {
~IndexImpl() override;
void BindReceiver(mojo::PendingReceiver<mojom::Index> receiver);
// mojom::Index overrides.
// Also included the synchronous versions for in-process clients.
void GetSize(GetSizeCallback callback) override;
uint64_t GetSize();
// IDs of data should not be empty.
void AddOrUpdate(std::vector<mojom::DataPtr> data,
AddOrUpdateCallback callback) override;
void AddOrUpdate(const std::vector<local_search_service::Data>& data);
// IDs should not be empty.
void Delete(const std::vector<std::string>& ids,
DeleteCallback callback) override;
uint32_t Delete(const std::vector<std::string>& ids);
void Find(const base::string16& query,
int32_t max_latency_in_ms,
int32_t max_results,
FindCallback callback) override;
local_search_service::ResponseStatus Find(
const base::string16& query,
int32_t max_latency_in_ms,
int32_t max_results,
std::vector<local_search_service::Result>* results);
void SetSearchParams(mojom::SearchParamsPtr search_params,
SetSearchParamsCallback callback) override;
void SetSearchParams(const local_search_service::SearchParams& search_params);
void GetSearchParamsForTesting(double* relevance_threshold,
double* partial_match_penalty_rate,
bool* use_prefix_only,
bool* use_weighted_ratio,
bool* use_edit_distance);
// Returns all search results for a given query.
std::vector<local_search_service::Result> GetSearchResults(
const base::string16& query) const;
// A map from key to tokenized search-tags.
std::map<std::string, std::vector<std::unique_ptr<TokenizedString>>> data_;
mojo::ReceiverSet<mojom::Index> receivers_;
// Search parameters.
local_search_service::SearchParams search_params_;
} // namespace local_search_service