| /** |
| * Copyright 2020, The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package android.app.appsearch; |
| |
| import com.android.internal.infra.AndroidFuture; |
| |
| parcelable AppSearchBatchResult; |
| |
| /** {@hide} */ |
| interface IAppSearchManager { |
| /** |
| * Sets the schema. |
| * |
| * @param schemaBytes Serialized SchemaProto. |
| * @param forceOverride Whether to apply the new schema even if it is incompatible. All |
| * incompatible documents will be deleted. |
| * @param callback {@link AndroidFuture}<{@link Void}>. Will be completed with |
| * {@code null} upon successful completion of the setSchema call, or completed |
| * exceptionally if setSchema fails. |
| */ |
| void setSchema(in byte[] schemaBytes, boolean forceOverride, in AndroidFuture callback); |
| |
| /** |
| * Inserts documents into the index. |
| * |
| * @param documentsBytes {@link List}<byte[]> of serialized DocumentProtos. |
| * @param callback |
| * {@link AndroidFuture}<{@link AppSearchBatchResult}<{@link String}, {@link Void}>>. |
| * If the call fails to start, {@code callback} will be completed exceptionally. Otherwise, |
| * {@code callback} will be completed with an |
| * {@link AppSearchBatchResult}<{@link String}, {@link Void}> |
| * where the keys are document URIs, and the values are {@code null}. |
| */ |
| void putDocuments(in List documentsBytes, in AndroidFuture<AppSearchBatchResult> callback); |
| |
| /** |
| * Searches a document based on a given specifications. |
| * |
| * @param searchSpecBytes Serialized SearchSpecProto. |
| * @param resultSpecBytes Serialized SearchResultsProto. |
| * @param scoringSpecBytes Serialized ScoringSpecProto. |
| * @param callback {@link AndroidFuture}. Will be completed with a serialized |
| * {@link SearchResultsProto}, or completed exceptionally if query fails. |
| */ |
| void query(in byte[] searchSpecBytes, in byte[] resultSpecBytes, |
| in byte[] scoringSpecBytes, in AndroidFuture callback); |
| } |