/* * Copyright (C) 2021 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.nearby; import android.annotation.IntDef; import android.annotation.NonNull; import android.annotation.SystemApi; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; /** * Reports newly discovered devices. * Note: The frequency of the callback is dependent on whether the caller * is in the foreground or background. Foreground callbacks will occur * as fast as the underlying medium supports, whereas background * use cases will be rate limited to improve performance (ie, only on * found/lost/significant changes). * * @hide */ @SystemApi public interface ScanCallback { /** General error code for scan. */ int ERROR_UNKNOWN = 0; /** * Scan failed as the request is not supported. */ int ERROR_UNSUPPORTED = 1; /** * Invalid argument such as out-of-range, illegal format etc. */ int ERROR_INVALID_ARGUMENT = 2; /** * Request from clients who do not have permissions. */ int ERROR_PERMISSION_DENIED = 3; /** * Request cannot be fulfilled due to limited resource. */ int ERROR_RESOURCE_EXHAUSTED = 4; /** @hide **/ @Retention(RetentionPolicy.SOURCE) @IntDef({ERROR_UNKNOWN, ERROR_UNSUPPORTED, ERROR_INVALID_ARGUMENT, ERROR_PERMISSION_DENIED, ERROR_RESOURCE_EXHAUSTED}) @interface ErrorCode { } /** * Reports a {@link NearbyDevice} being discovered. * * @param device {@link NearbyDevice} that is found. */ void onDiscovered(@NonNull NearbyDevice device); /** * Reports a {@link NearbyDevice} information(distance, packet, and etc) changed. * * @param device {@link NearbyDevice} that has updates. */ void onUpdated(@NonNull NearbyDevice device); /** * Reports a {@link NearbyDevice} is no longer within range. * * @param device {@link NearbyDevice} that is lost. */ void onLost(@NonNull NearbyDevice device); /** * Notifies clients of error from the scan. * * @param errorCode defined by Nearby */ default void onError(@ErrorCode int errorCode) {} }