xref: /aosp_15_r20/hardware/interfaces/biometrics/fingerprint/aidl/default/Session.cpp (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*4d7e907cSAndroid Build Coastguard Worker  *
4*4d7e907cSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*4d7e907cSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*4d7e907cSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*4d7e907cSAndroid Build Coastguard Worker  *
8*4d7e907cSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*4d7e907cSAndroid Build Coastguard Worker  *
10*4d7e907cSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*4d7e907cSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*4d7e907cSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4d7e907cSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*4d7e907cSAndroid Build Coastguard Worker  * limitations under the License.
15*4d7e907cSAndroid Build Coastguard Worker  */
16*4d7e907cSAndroid Build Coastguard Worker 
17*4d7e907cSAndroid Build Coastguard Worker #include "Session.h"
18*4d7e907cSAndroid Build Coastguard Worker 
19*4d7e907cSAndroid Build Coastguard Worker #include <android-base/logging.h>
20*4d7e907cSAndroid Build Coastguard Worker 
21*4d7e907cSAndroid Build Coastguard Worker #include "util/CancellationSignal.h"
22*4d7e907cSAndroid Build Coastguard Worker 
23*4d7e907cSAndroid Build Coastguard Worker #undef LOG_TAG
24*4d7e907cSAndroid Build Coastguard Worker #define LOG_TAG "FingerprintVirtualHalSession"
25*4d7e907cSAndroid Build Coastguard Worker 
26*4d7e907cSAndroid Build Coastguard Worker namespace aidl::android::hardware::biometrics::fingerprint {
27*4d7e907cSAndroid Build Coastguard Worker 
onClientDeath(void * cookie)28*4d7e907cSAndroid Build Coastguard Worker void onClientDeath(void* cookie) {
29*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "FingerprintService has died";
30*4d7e907cSAndroid Build Coastguard Worker     Session* session = static_cast<Session*>(cookie);
31*4d7e907cSAndroid Build Coastguard Worker     if (session && !session->isClosed()) {
32*4d7e907cSAndroid Build Coastguard Worker         session->close();
33*4d7e907cSAndroid Build Coastguard Worker     }
34*4d7e907cSAndroid Build Coastguard Worker }
35*4d7e907cSAndroid Build Coastguard Worker 
Session(int sensorId,int userId,std::shared_ptr<ISessionCallback> cb,FakeFingerprintEngine * engine,WorkerThread * worker)36*4d7e907cSAndroid Build Coastguard Worker Session::Session(int sensorId, int userId, std::shared_ptr<ISessionCallback> cb,
37*4d7e907cSAndroid Build Coastguard Worker                  FakeFingerprintEngine* engine, WorkerThread* worker)
38*4d7e907cSAndroid Build Coastguard Worker     : mSensorId(sensorId),
39*4d7e907cSAndroid Build Coastguard Worker       mUserId(userId),
40*4d7e907cSAndroid Build Coastguard Worker       mCb(std::move(cb)),
41*4d7e907cSAndroid Build Coastguard Worker       mEngine(engine),
42*4d7e907cSAndroid Build Coastguard Worker       mWorker(worker),
43*4d7e907cSAndroid Build Coastguard Worker       mScheduledState(SessionState::IDLING),
44*4d7e907cSAndroid Build Coastguard Worker       mCurrentState(SessionState::IDLING) {
45*4d7e907cSAndroid Build Coastguard Worker     CHECK_GE(mSensorId, 0);
46*4d7e907cSAndroid Build Coastguard Worker     CHECK_GE(mUserId, 0);
47*4d7e907cSAndroid Build Coastguard Worker     CHECK(mEngine);
48*4d7e907cSAndroid Build Coastguard Worker     CHECK(mWorker);
49*4d7e907cSAndroid Build Coastguard Worker     CHECK(mCb);
50*4d7e907cSAndroid Build Coastguard Worker 
51*4d7e907cSAndroid Build Coastguard Worker     mDeathRecipient = AIBinder_DeathRecipient_new(onClientDeath);
52*4d7e907cSAndroid Build Coastguard Worker }
53*4d7e907cSAndroid Build Coastguard Worker 
linkToDeath(AIBinder * binder)54*4d7e907cSAndroid Build Coastguard Worker binder_status_t Session::linkToDeath(AIBinder* binder) {
55*4d7e907cSAndroid Build Coastguard Worker     return AIBinder_linkToDeath(binder, mDeathRecipient, this);
56*4d7e907cSAndroid Build Coastguard Worker }
57*4d7e907cSAndroid Build Coastguard Worker 
scheduleStateOrCrash(SessionState state)58*4d7e907cSAndroid Build Coastguard Worker void Session::scheduleStateOrCrash(SessionState state) {
59*4d7e907cSAndroid Build Coastguard Worker     // TODO(b/166800618): call enterIdling from the terminal callbacks and restore these checks.
60*4d7e907cSAndroid Build Coastguard Worker     // CHECK(mScheduledState == SessionState::IDLING);
61*4d7e907cSAndroid Build Coastguard Worker     // CHECK(mCurrentState == SessionState::IDLING);
62*4d7e907cSAndroid Build Coastguard Worker     mScheduledState = state;
63*4d7e907cSAndroid Build Coastguard Worker }
64*4d7e907cSAndroid Build Coastguard Worker 
enterStateOrCrash(SessionState state)65*4d7e907cSAndroid Build Coastguard Worker void Session::enterStateOrCrash(SessionState state) {
66*4d7e907cSAndroid Build Coastguard Worker     CHECK(mScheduledState == state);
67*4d7e907cSAndroid Build Coastguard Worker     mCurrentState = state;
68*4d7e907cSAndroid Build Coastguard Worker     mScheduledState = SessionState::IDLING;
69*4d7e907cSAndroid Build Coastguard Worker }
70*4d7e907cSAndroid Build Coastguard Worker 
enterIdling()71*4d7e907cSAndroid Build Coastguard Worker void Session::enterIdling() {
72*4d7e907cSAndroid Build Coastguard Worker     // TODO(b/166800618): call enterIdling from the terminal callbacks and rethink this conditional.
73*4d7e907cSAndroid Build Coastguard Worker     if (mCurrentState != SessionState::CLOSED) {
74*4d7e907cSAndroid Build Coastguard Worker         mCurrentState = SessionState::IDLING;
75*4d7e907cSAndroid Build Coastguard Worker     }
76*4d7e907cSAndroid Build Coastguard Worker }
77*4d7e907cSAndroid Build Coastguard Worker 
isClosed()78*4d7e907cSAndroid Build Coastguard Worker bool Session::isClosed() {
79*4d7e907cSAndroid Build Coastguard Worker     return mCurrentState == SessionState::CLOSED;
80*4d7e907cSAndroid Build Coastguard Worker }
81*4d7e907cSAndroid Build Coastguard Worker 
generateChallenge()82*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::generateChallenge() {
83*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "generateChallenge";
84*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::GENERATING_CHALLENGE);
85*4d7e907cSAndroid Build Coastguard Worker 
86*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this] {
87*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::GENERATING_CHALLENGE);
88*4d7e907cSAndroid Build Coastguard Worker         mEngine->generateChallengeImpl(mCb.get());
89*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
90*4d7e907cSAndroid Build Coastguard Worker     }));
91*4d7e907cSAndroid Build Coastguard Worker 
92*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
93*4d7e907cSAndroid Build Coastguard Worker }
94*4d7e907cSAndroid Build Coastguard Worker 
revokeChallenge(int64_t challenge)95*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::revokeChallenge(int64_t challenge) {
96*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "revokeChallenge";
97*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::REVOKING_CHALLENGE);
98*4d7e907cSAndroid Build Coastguard Worker 
99*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, challenge] {
100*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::REVOKING_CHALLENGE);
101*4d7e907cSAndroid Build Coastguard Worker         mEngine->revokeChallengeImpl(mCb.get(), challenge);
102*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
103*4d7e907cSAndroid Build Coastguard Worker     }));
104*4d7e907cSAndroid Build Coastguard Worker 
105*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
106*4d7e907cSAndroid Build Coastguard Worker }
107*4d7e907cSAndroid Build Coastguard Worker 
enroll(const keymaster::HardwareAuthToken & hat,std::shared_ptr<common::ICancellationSignal> * out)108*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::enroll(const keymaster::HardwareAuthToken& hat,
109*4d7e907cSAndroid Build Coastguard Worker                                    std::shared_ptr<common::ICancellationSignal>* out) {
110*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "enroll";
111*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::ENROLLING);
112*4d7e907cSAndroid Build Coastguard Worker 
113*4d7e907cSAndroid Build Coastguard Worker     std::promise<void> cancellationPromise;
114*4d7e907cSAndroid Build Coastguard Worker     auto cancFuture = cancellationPromise.get_future();
115*4d7e907cSAndroid Build Coastguard Worker 
116*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, hat, cancFuture = std::move(cancFuture)] {
117*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::ENROLLING);
118*4d7e907cSAndroid Build Coastguard Worker         if (shouldCancel(cancFuture)) {
119*4d7e907cSAndroid Build Coastguard Worker             mCb->onError(Error::CANCELED, 0 /* vendorCode */);
120*4d7e907cSAndroid Build Coastguard Worker         } else {
121*4d7e907cSAndroid Build Coastguard Worker             mEngine->enrollImpl(mCb.get(), hat, cancFuture);
122*4d7e907cSAndroid Build Coastguard Worker         }
123*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
124*4d7e907cSAndroid Build Coastguard Worker     }));
125*4d7e907cSAndroid Build Coastguard Worker 
126*4d7e907cSAndroid Build Coastguard Worker     *out = SharedRefBase::make<CancellationSignal>(std::move(cancellationPromise));
127*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
128*4d7e907cSAndroid Build Coastguard Worker }
129*4d7e907cSAndroid Build Coastguard Worker 
authenticate(int64_t operationId,std::shared_ptr<common::ICancellationSignal> * out)130*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::authenticate(int64_t operationId,
131*4d7e907cSAndroid Build Coastguard Worker                                          std::shared_ptr<common::ICancellationSignal>* out) {
132*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "authenticate";
133*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::AUTHENTICATING);
134*4d7e907cSAndroid Build Coastguard Worker 
135*4d7e907cSAndroid Build Coastguard Worker     std::promise<void> cancPromise;
136*4d7e907cSAndroid Build Coastguard Worker     auto cancFuture = cancPromise.get_future();
137*4d7e907cSAndroid Build Coastguard Worker 
138*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, operationId, cancFuture = std::move(cancFuture)] {
139*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::AUTHENTICATING);
140*4d7e907cSAndroid Build Coastguard Worker         if (shouldCancel(cancFuture)) {
141*4d7e907cSAndroid Build Coastguard Worker             mCb->onError(Error::CANCELED, 0 /* vendorCode */);
142*4d7e907cSAndroid Build Coastguard Worker         } else {
143*4d7e907cSAndroid Build Coastguard Worker             mEngine->authenticateImpl(mCb.get(), operationId, cancFuture);
144*4d7e907cSAndroid Build Coastguard Worker         }
145*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
146*4d7e907cSAndroid Build Coastguard Worker     }));
147*4d7e907cSAndroid Build Coastguard Worker 
148*4d7e907cSAndroid Build Coastguard Worker     *out = SharedRefBase::make<CancellationSignal>(std::move(cancPromise));
149*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
150*4d7e907cSAndroid Build Coastguard Worker }
151*4d7e907cSAndroid Build Coastguard Worker 
detectInteraction(std::shared_ptr<common::ICancellationSignal> * out)152*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::detectInteraction(std::shared_ptr<common::ICancellationSignal>* out) {
153*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "detectInteraction";
154*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::DETECTING_INTERACTION);
155*4d7e907cSAndroid Build Coastguard Worker 
156*4d7e907cSAndroid Build Coastguard Worker     std::promise<void> cancellationPromise;
157*4d7e907cSAndroid Build Coastguard Worker     auto cancFuture = cancellationPromise.get_future();
158*4d7e907cSAndroid Build Coastguard Worker 
159*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, cancFuture = std::move(cancFuture)] {
160*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::DETECTING_INTERACTION);
161*4d7e907cSAndroid Build Coastguard Worker         if (shouldCancel(cancFuture)) {
162*4d7e907cSAndroid Build Coastguard Worker             mCb->onError(Error::CANCELED, 0 /* vendorCode */);
163*4d7e907cSAndroid Build Coastguard Worker         } else {
164*4d7e907cSAndroid Build Coastguard Worker             mEngine->detectInteractionImpl(mCb.get(), cancFuture);
165*4d7e907cSAndroid Build Coastguard Worker         }
166*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
167*4d7e907cSAndroid Build Coastguard Worker     }));
168*4d7e907cSAndroid Build Coastguard Worker 
169*4d7e907cSAndroid Build Coastguard Worker     *out = SharedRefBase::make<CancellationSignal>(std::move(cancellationPromise));
170*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
171*4d7e907cSAndroid Build Coastguard Worker }
172*4d7e907cSAndroid Build Coastguard Worker 
enumerateEnrollments()173*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::enumerateEnrollments() {
174*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "enumerateEnrollments";
175*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::ENUMERATING_ENROLLMENTS);
176*4d7e907cSAndroid Build Coastguard Worker 
177*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this] {
178*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::ENUMERATING_ENROLLMENTS);
179*4d7e907cSAndroid Build Coastguard Worker         mEngine->enumerateEnrollmentsImpl(mCb.get());
180*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
181*4d7e907cSAndroid Build Coastguard Worker     }));
182*4d7e907cSAndroid Build Coastguard Worker 
183*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
184*4d7e907cSAndroid Build Coastguard Worker }
185*4d7e907cSAndroid Build Coastguard Worker 
removeEnrollments(const std::vector<int32_t> & enrollmentIds)186*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::removeEnrollments(const std::vector<int32_t>& enrollmentIds) {
187*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "removeEnrollments, size:" << enrollmentIds.size();
188*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::REMOVING_ENROLLMENTS);
189*4d7e907cSAndroid Build Coastguard Worker 
190*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, enrollmentIds] {
191*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::REMOVING_ENROLLMENTS);
192*4d7e907cSAndroid Build Coastguard Worker         mEngine->removeEnrollmentsImpl(mCb.get(), enrollmentIds);
193*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
194*4d7e907cSAndroid Build Coastguard Worker     }));
195*4d7e907cSAndroid Build Coastguard Worker 
196*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
197*4d7e907cSAndroid Build Coastguard Worker }
198*4d7e907cSAndroid Build Coastguard Worker 
getAuthenticatorId()199*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::getAuthenticatorId() {
200*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "getAuthenticatorId";
201*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::GETTING_AUTHENTICATOR_ID);
202*4d7e907cSAndroid Build Coastguard Worker 
203*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this] {
204*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::GETTING_AUTHENTICATOR_ID);
205*4d7e907cSAndroid Build Coastguard Worker         mEngine->getAuthenticatorIdImpl(mCb.get());
206*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
207*4d7e907cSAndroid Build Coastguard Worker     }));
208*4d7e907cSAndroid Build Coastguard Worker 
209*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
210*4d7e907cSAndroid Build Coastguard Worker }
211*4d7e907cSAndroid Build Coastguard Worker 
invalidateAuthenticatorId()212*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::invalidateAuthenticatorId() {
213*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "invalidateAuthenticatorId";
214*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::INVALIDATING_AUTHENTICATOR_ID);
215*4d7e907cSAndroid Build Coastguard Worker 
216*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this] {
217*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::INVALIDATING_AUTHENTICATOR_ID);
218*4d7e907cSAndroid Build Coastguard Worker         mEngine->invalidateAuthenticatorIdImpl(mCb.get());
219*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
220*4d7e907cSAndroid Build Coastguard Worker     }));
221*4d7e907cSAndroid Build Coastguard Worker 
222*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
223*4d7e907cSAndroid Build Coastguard Worker }
224*4d7e907cSAndroid Build Coastguard Worker 
resetLockout(const keymaster::HardwareAuthToken & hat)225*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::resetLockout(const keymaster::HardwareAuthToken& hat) {
226*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "resetLockout";
227*4d7e907cSAndroid Build Coastguard Worker     scheduleStateOrCrash(SessionState::RESETTING_LOCKOUT);
228*4d7e907cSAndroid Build Coastguard Worker 
229*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, hat] {
230*4d7e907cSAndroid Build Coastguard Worker         enterStateOrCrash(SessionState::RESETTING_LOCKOUT);
231*4d7e907cSAndroid Build Coastguard Worker         mEngine->resetLockoutImpl(mCb.get(), hat);
232*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
233*4d7e907cSAndroid Build Coastguard Worker     }));
234*4d7e907cSAndroid Build Coastguard Worker 
235*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
236*4d7e907cSAndroid Build Coastguard Worker }
237*4d7e907cSAndroid Build Coastguard Worker 
close()238*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::close() {
239*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "close";
240*4d7e907cSAndroid Build Coastguard Worker     // TODO(b/166800618): call enterIdling from the terminal callbacks and restore this check.
241*4d7e907cSAndroid Build Coastguard Worker     // CHECK(mCurrentState == SessionState::IDLING) << "Can't close a non-idling session.
242*4d7e907cSAndroid Build Coastguard Worker     // Crashing.";
243*4d7e907cSAndroid Build Coastguard Worker     mCurrentState = SessionState::CLOSED;
244*4d7e907cSAndroid Build Coastguard Worker     mCb->onSessionClosed();
245*4d7e907cSAndroid Build Coastguard Worker     AIBinder_DeathRecipient_delete(mDeathRecipient);
246*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
247*4d7e907cSAndroid Build Coastguard Worker }
248*4d7e907cSAndroid Build Coastguard Worker 
onPointerDown(int32_t pointerId,int32_t x,int32_t y,float minor,float major)249*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onPointerDown(int32_t pointerId, int32_t x, int32_t y, float minor,
250*4d7e907cSAndroid Build Coastguard Worker                                           float major) {
251*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "onPointerDown";
252*4d7e907cSAndroid Build Coastguard Worker     mEngine->notifyFingerdown();
253*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, pointerId, x, y, minor, major] {
254*4d7e907cSAndroid Build Coastguard Worker         mEngine->onPointerDownImpl(pointerId, x, y, minor, major);
255*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
256*4d7e907cSAndroid Build Coastguard Worker     }));
257*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
258*4d7e907cSAndroid Build Coastguard Worker }
259*4d7e907cSAndroid Build Coastguard Worker 
onPointerUp(int32_t pointerId)260*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onPointerUp(int32_t pointerId) {
261*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "onPointerUp";
262*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this, pointerId] {
263*4d7e907cSAndroid Build Coastguard Worker         mEngine->onPointerUpImpl(pointerId);
264*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
265*4d7e907cSAndroid Build Coastguard Worker     }));
266*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
267*4d7e907cSAndroid Build Coastguard Worker }
268*4d7e907cSAndroid Build Coastguard Worker 
onUiReady()269*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onUiReady() {
270*4d7e907cSAndroid Build Coastguard Worker     LOG(INFO) << "onUiReady";
271*4d7e907cSAndroid Build Coastguard Worker     mWorker->schedule(Callable::from([this] {
272*4d7e907cSAndroid Build Coastguard Worker         mEngine->onUiReadyImpl();
273*4d7e907cSAndroid Build Coastguard Worker         enterIdling();
274*4d7e907cSAndroid Build Coastguard Worker     }));
275*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
276*4d7e907cSAndroid Build Coastguard Worker }
277*4d7e907cSAndroid Build Coastguard Worker 
authenticateWithContext(int64_t operationId,const common::OperationContext &,std::shared_ptr<common::ICancellationSignal> * out)278*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::authenticateWithContext(
279*4d7e907cSAndroid Build Coastguard Worker         int64_t operationId, const common::OperationContext& /*context*/,
280*4d7e907cSAndroid Build Coastguard Worker         std::shared_ptr<common::ICancellationSignal>* out) {
281*4d7e907cSAndroid Build Coastguard Worker     return authenticate(operationId, out);
282*4d7e907cSAndroid Build Coastguard Worker }
283*4d7e907cSAndroid Build Coastguard Worker 
enrollWithContext(const keymaster::HardwareAuthToken & hat,const common::OperationContext &,std::shared_ptr<common::ICancellationSignal> * out)284*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::enrollWithContext(const keymaster::HardwareAuthToken& hat,
285*4d7e907cSAndroid Build Coastguard Worker                                               const common::OperationContext& /*context*/,
286*4d7e907cSAndroid Build Coastguard Worker                                               std::shared_ptr<common::ICancellationSignal>* out) {
287*4d7e907cSAndroid Build Coastguard Worker     return enroll(hat, out);
288*4d7e907cSAndroid Build Coastguard Worker }
289*4d7e907cSAndroid Build Coastguard Worker 
detectInteractionWithContext(const common::OperationContext &,std::shared_ptr<common::ICancellationSignal> * out)290*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::detectInteractionWithContext(
291*4d7e907cSAndroid Build Coastguard Worker         const common::OperationContext& /*context*/,
292*4d7e907cSAndroid Build Coastguard Worker         std::shared_ptr<common::ICancellationSignal>* out) {
293*4d7e907cSAndroid Build Coastguard Worker     return detectInteraction(out);
294*4d7e907cSAndroid Build Coastguard Worker }
295*4d7e907cSAndroid Build Coastguard Worker 
onPointerDownWithContext(const PointerContext & context)296*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onPointerDownWithContext(const PointerContext& context) {
297*4d7e907cSAndroid Build Coastguard Worker     return onPointerDown(context.pointerId, context.x, context.y, context.minor, context.major);
298*4d7e907cSAndroid Build Coastguard Worker }
299*4d7e907cSAndroid Build Coastguard Worker 
onPointerUpWithContext(const PointerContext & context)300*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onPointerUpWithContext(const PointerContext& context) {
301*4d7e907cSAndroid Build Coastguard Worker     return onPointerUp(context.pointerId);
302*4d7e907cSAndroid Build Coastguard Worker }
303*4d7e907cSAndroid Build Coastguard Worker 
onContextChanged(const common::OperationContext &)304*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onContextChanged(const common::OperationContext& /*context*/) {
305*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
306*4d7e907cSAndroid Build Coastguard Worker }
307*4d7e907cSAndroid Build Coastguard Worker 
onPointerCancelWithContext(const PointerContext &)308*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::onPointerCancelWithContext(const PointerContext& /*context*/) {
309*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
310*4d7e907cSAndroid Build Coastguard Worker }
311*4d7e907cSAndroid Build Coastguard Worker 
setIgnoreDisplayTouches(bool)312*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Session::setIgnoreDisplayTouches(bool /*shouldIgnore*/) {
313*4d7e907cSAndroid Build Coastguard Worker     return ndk::ScopedAStatus::ok();
314*4d7e907cSAndroid Build Coastguard Worker }
315*4d7e907cSAndroid Build Coastguard Worker 
316*4d7e907cSAndroid Build Coastguard Worker }  // namespace aidl::android::hardware::biometrics::fingerprint
317