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 #undef LOG_TAG
18*4d7e907cSAndroid Build Coastguard Worker #define LOG_TAG "FaceVirtualHal"
19*4d7e907cSAndroid Build Coastguard Worker
20*4d7e907cSAndroid Build Coastguard Worker #include "Face.h"
21*4d7e907cSAndroid Build Coastguard Worker #include "Session.h"
22*4d7e907cSAndroid Build Coastguard Worker
23*4d7e907cSAndroid Build Coastguard Worker #include "FakeFaceEngine.h"
24*4d7e907cSAndroid Build Coastguard Worker
25*4d7e907cSAndroid Build Coastguard Worker #include <android-base/properties.h>
26*4d7e907cSAndroid Build Coastguard Worker #include <face.sysprop.h>
27*4d7e907cSAndroid Build Coastguard Worker
28*4d7e907cSAndroid Build Coastguard Worker #include <android-base/file.h>
29*4d7e907cSAndroid Build Coastguard Worker #include <android-base/logging.h>
30*4d7e907cSAndroid Build Coastguard Worker #include <android-base/stringprintf.h>
31*4d7e907cSAndroid Build Coastguard Worker
32*4d7e907cSAndroid Build Coastguard Worker using namespace ::android::face::virt;
33*4d7e907cSAndroid Build Coastguard Worker
34*4d7e907cSAndroid Build Coastguard Worker namespace aidl::android::hardware::biometrics::face {
35*4d7e907cSAndroid Build Coastguard Worker
36*4d7e907cSAndroid Build Coastguard Worker const int kSensorId = 4;
37*4d7e907cSAndroid Build Coastguard Worker const int kMaxEnrollmentsPerUser = 5;
38*4d7e907cSAndroid Build Coastguard Worker const bool kHalControlsPreview = true;
39*4d7e907cSAndroid Build Coastguard Worker const std::string kHwComponentId = "faceSensor";
40*4d7e907cSAndroid Build Coastguard Worker const std::string kHardwareVersion = "vendor/model/revision";
41*4d7e907cSAndroid Build Coastguard Worker const std::string kFirmwareVersion = "1.01";
42*4d7e907cSAndroid Build Coastguard Worker const std::string kSerialNumber = "00000001";
43*4d7e907cSAndroid Build Coastguard Worker const std::string kSwComponentId = "matchingAlgorithm";
44*4d7e907cSAndroid Build Coastguard Worker const std::string kSoftwareVersion = "vendor/version/revision";
45*4d7e907cSAndroid Build Coastguard Worker
getSensorProps(std::vector<SensorProps> * return_val)46*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Face::getSensorProps(std::vector<SensorProps>* return_val) {
47*4d7e907cSAndroid Build Coastguard Worker common::ComponentInfo hw_component_info;
48*4d7e907cSAndroid Build Coastguard Worker hw_component_info.componentId = kHwComponentId;
49*4d7e907cSAndroid Build Coastguard Worker hw_component_info.hardwareVersion = kHardwareVersion;
50*4d7e907cSAndroid Build Coastguard Worker hw_component_info.firmwareVersion = kFirmwareVersion;
51*4d7e907cSAndroid Build Coastguard Worker hw_component_info.serialNumber = kSerialNumber;
52*4d7e907cSAndroid Build Coastguard Worker hw_component_info.softwareVersion = "";
53*4d7e907cSAndroid Build Coastguard Worker
54*4d7e907cSAndroid Build Coastguard Worker common::ComponentInfo sw_component_info;
55*4d7e907cSAndroid Build Coastguard Worker sw_component_info.componentId = kSwComponentId;
56*4d7e907cSAndroid Build Coastguard Worker sw_component_info.hardwareVersion = "";
57*4d7e907cSAndroid Build Coastguard Worker sw_component_info.firmwareVersion = "";
58*4d7e907cSAndroid Build Coastguard Worker sw_component_info.serialNumber = "";
59*4d7e907cSAndroid Build Coastguard Worker sw_component_info.softwareVersion = kSoftwareVersion;
60*4d7e907cSAndroid Build Coastguard Worker
61*4d7e907cSAndroid Build Coastguard Worker common::CommonProps commonProps;
62*4d7e907cSAndroid Build Coastguard Worker commonProps.sensorId = kSensorId;
63*4d7e907cSAndroid Build Coastguard Worker commonProps.sensorStrength = FakeFaceEngine::GetSensorStrength();
64*4d7e907cSAndroid Build Coastguard Worker commonProps.maxEnrollmentsPerUser = kMaxEnrollmentsPerUser;
65*4d7e907cSAndroid Build Coastguard Worker commonProps.componentInfo = {std::move(hw_component_info), std::move(sw_component_info)};
66*4d7e907cSAndroid Build Coastguard Worker
67*4d7e907cSAndroid Build Coastguard Worker SensorProps props;
68*4d7e907cSAndroid Build Coastguard Worker props.commonProps = std::move(commonProps);
69*4d7e907cSAndroid Build Coastguard Worker props.sensorType = FakeFaceEngine::GetSensorType();
70*4d7e907cSAndroid Build Coastguard Worker props.halControlsPreview = kHalControlsPreview;
71*4d7e907cSAndroid Build Coastguard Worker props.enrollPreviewWidth = 1080;
72*4d7e907cSAndroid Build Coastguard Worker props.enrollPreviewHeight = 1920;
73*4d7e907cSAndroid Build Coastguard Worker props.enrollTranslationX = 100.f;
74*4d7e907cSAndroid Build Coastguard Worker props.enrollTranslationY = 50.f;
75*4d7e907cSAndroid Build Coastguard Worker props.enrollPreviewScale = 1.f;
76*4d7e907cSAndroid Build Coastguard Worker
77*4d7e907cSAndroid Build Coastguard Worker *return_val = {std::move(props)};
78*4d7e907cSAndroid Build Coastguard Worker return ndk::ScopedAStatus::ok();
79*4d7e907cSAndroid Build Coastguard Worker }
80*4d7e907cSAndroid Build Coastguard Worker
createSession(int32_t sensorId,int32_t userId,const std::shared_ptr<ISessionCallback> & cb,std::shared_ptr<ISession> * return_val)81*4d7e907cSAndroid Build Coastguard Worker ndk::ScopedAStatus Face::createSession(int32_t sensorId, int32_t userId,
82*4d7e907cSAndroid Build Coastguard Worker const std::shared_ptr<ISessionCallback>& cb,
83*4d7e907cSAndroid Build Coastguard Worker std::shared_ptr<ISession>* return_val) {
84*4d7e907cSAndroid Build Coastguard Worker mSession = SharedRefBase::make<Session>(std::make_unique<FakeFaceEngine>(), cb);
85*4d7e907cSAndroid Build Coastguard Worker *return_val = mSession;
86*4d7e907cSAndroid Build Coastguard Worker
87*4d7e907cSAndroid Build Coastguard Worker mSession->linkToDeath(cb->asBinder().get());
88*4d7e907cSAndroid Build Coastguard Worker
89*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << __func__ << ": sensorId:" << sensorId << " userId:" << userId;
90*4d7e907cSAndroid Build Coastguard Worker return ndk::ScopedAStatus::ok();
91*4d7e907cSAndroid Build Coastguard Worker }
92*4d7e907cSAndroid Build Coastguard Worker
dump(int fd,const char **,uint32_t numArgs)93*4d7e907cSAndroid Build Coastguard Worker binder_status_t Face::dump(int fd, const char** /*args*/, uint32_t numArgs) {
94*4d7e907cSAndroid Build Coastguard Worker if (fd < 0) {
95*4d7e907cSAndroid Build Coastguard Worker LOG(ERROR) << __func__ << "fd invalid: " << fd;
96*4d7e907cSAndroid Build Coastguard Worker return STATUS_BAD_VALUE;
97*4d7e907cSAndroid Build Coastguard Worker } else {
98*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << __func__ << " fd:" << fd << "numArgs:" << numArgs;
99*4d7e907cSAndroid Build Coastguard Worker }
100*4d7e907cSAndroid Build Coastguard Worker
101*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "----- FaceVirtualHal::dump -----\n");
102*4d7e907cSAndroid Build Coastguard Worker std::vector<SensorProps> sps(1);
103*4d7e907cSAndroid Build Coastguard Worker getSensorProps(&sps);
104*4d7e907cSAndroid Build Coastguard Worker for (auto& sp : sps) {
105*4d7e907cSAndroid Build Coastguard Worker ::android::base::WriteStringToFd(sp.toString(), fd);
106*4d7e907cSAndroid Build Coastguard Worker }
107*4d7e907cSAndroid Build Coastguard Worker if (mSession != nullptr) {
108*4d7e907cSAndroid Build Coastguard Worker ::android::base::WriteStringToFd(mSession->toString(), fd);
109*4d7e907cSAndroid Build Coastguard Worker } else {
110*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "\nWARNING: no ISession found\n");
111*4d7e907cSAndroid Build Coastguard Worker }
112*4d7e907cSAndroid Build Coastguard Worker
113*4d7e907cSAndroid Build Coastguard Worker fsync(fd);
114*4d7e907cSAndroid Build Coastguard Worker return STATUS_OK;
115*4d7e907cSAndroid Build Coastguard Worker }
116*4d7e907cSAndroid Build Coastguard Worker
handleShellCommand(int in,int out,int err,const char ** args,uint32_t numArgs)117*4d7e907cSAndroid Build Coastguard Worker binder_status_t Face::handleShellCommand(int in, int out, int err, const char** args,
118*4d7e907cSAndroid Build Coastguard Worker uint32_t numArgs) {
119*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << __func__ << " in:" << in << " out:" << out << " err:" << err
120*4d7e907cSAndroid Build Coastguard Worker << " numArgs:" << numArgs;
121*4d7e907cSAndroid Build Coastguard Worker
122*4d7e907cSAndroid Build Coastguard Worker if (numArgs == 0) {
123*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << __func__ << ": available commands";
124*4d7e907cSAndroid Build Coastguard Worker onHelp(out);
125*4d7e907cSAndroid Build Coastguard Worker return STATUS_OK;
126*4d7e907cSAndroid Build Coastguard Worker }
127*4d7e907cSAndroid Build Coastguard Worker
128*4d7e907cSAndroid Build Coastguard Worker for (auto&& str : std::vector<std::string_view>(args, args + numArgs)) {
129*4d7e907cSAndroid Build Coastguard Worker std::string option = str.data();
130*4d7e907cSAndroid Build Coastguard Worker if (option.find("clearconfig") != std::string::npos ||
131*4d7e907cSAndroid Build Coastguard Worker option.find("resetconfig") != std::string::npos) {
132*4d7e907cSAndroid Build Coastguard Worker resetConfigToDefault();
133*4d7e907cSAndroid Build Coastguard Worker }
134*4d7e907cSAndroid Build Coastguard Worker if (option.find("help") != std::string::npos) {
135*4d7e907cSAndroid Build Coastguard Worker onHelp(out);
136*4d7e907cSAndroid Build Coastguard Worker }
137*4d7e907cSAndroid Build Coastguard Worker }
138*4d7e907cSAndroid Build Coastguard Worker
139*4d7e907cSAndroid Build Coastguard Worker return STATUS_OK;
140*4d7e907cSAndroid Build Coastguard Worker }
141*4d7e907cSAndroid Build Coastguard Worker
type2String(FaceSensorType type)142*4d7e907cSAndroid Build Coastguard Worker const char* Face::type2String(FaceSensorType type) {
143*4d7e907cSAndroid Build Coastguard Worker switch (type) {
144*4d7e907cSAndroid Build Coastguard Worker case FaceSensorType::RGB:
145*4d7e907cSAndroid Build Coastguard Worker return "rgb";
146*4d7e907cSAndroid Build Coastguard Worker case FaceSensorType::IR:
147*4d7e907cSAndroid Build Coastguard Worker return "ir";
148*4d7e907cSAndroid Build Coastguard Worker default:
149*4d7e907cSAndroid Build Coastguard Worker return "unknown";
150*4d7e907cSAndroid Build Coastguard Worker }
151*4d7e907cSAndroid Build Coastguard Worker }
152*4d7e907cSAndroid Build Coastguard Worker
strength2String(common::SensorStrength strength)153*4d7e907cSAndroid Build Coastguard Worker const char* Face::strength2String(common::SensorStrength strength) {
154*4d7e907cSAndroid Build Coastguard Worker switch (strength) {
155*4d7e907cSAndroid Build Coastguard Worker case common::SensorStrength::STRONG:
156*4d7e907cSAndroid Build Coastguard Worker return "STRONG";
157*4d7e907cSAndroid Build Coastguard Worker case common::SensorStrength::WEAK:
158*4d7e907cSAndroid Build Coastguard Worker return "WEAK";
159*4d7e907cSAndroid Build Coastguard Worker case common::SensorStrength::CONVENIENCE:
160*4d7e907cSAndroid Build Coastguard Worker return "CONVENIENCE";
161*4d7e907cSAndroid Build Coastguard Worker default:
162*4d7e907cSAndroid Build Coastguard Worker return "unknown";
163*4d7e907cSAndroid Build Coastguard Worker }
164*4d7e907cSAndroid Build Coastguard Worker }
165*4d7e907cSAndroid Build Coastguard Worker
onHelp(int fd)166*4d7e907cSAndroid Build Coastguard Worker void Face::onHelp(int fd) {
167*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "Virtual Face HAL commands:\n");
168*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, " help: print this help\n");
169*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, " resetconfig: reset all configuration to default\n");
170*4d7e907cSAndroid Build Coastguard Worker dprintf(fd, "\n");
171*4d7e907cSAndroid Build Coastguard Worker fsync(fd);
172*4d7e907cSAndroid Build Coastguard Worker }
173*4d7e907cSAndroid Build Coastguard Worker
resetConfigToDefault()174*4d7e907cSAndroid Build Coastguard Worker void Face::resetConfigToDefault() {
175*4d7e907cSAndroid Build Coastguard Worker LOG(INFO) << __func__ << ": reset virtual Face HAL configuration to default";
176*4d7e907cSAndroid Build Coastguard Worker #define RESET_CONFIG_O(__NAME__) \
177*4d7e907cSAndroid Build Coastguard Worker if (FaceHalProperties::__NAME__()) FaceHalProperties::__NAME__(std::nullopt)
178*4d7e907cSAndroid Build Coastguard Worker #define RESET_CONFIG_V(__NAME__) \
179*4d7e907cSAndroid Build Coastguard Worker if (!FaceHalProperties::__NAME__().empty()) FaceHalProperties::__NAME__({std::nullopt})
180*4d7e907cSAndroid Build Coastguard Worker
181*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(type);
182*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(strength);
183*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_V(enrollments);
184*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(enrollment_hit);
185*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_V(features);
186*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(next_enrollment);
187*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(authenticator_id);
188*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(challenge);
189*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout);
190*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(operation_authenticate_fails);
191*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(operation_detect_interaction_fails);
192*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_V(operation_authenticate_latency);
193*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_V(operation_detect_interaction_latency);
194*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_V(operation_enroll_latency);
195*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(operation_authenticate_duration);
196*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(operation_authenticate_error);
197*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(operation_authenticate_acquired);
198*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout_enable);
199*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout_timed_enable);
200*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout_timed_threshold);
201*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout_timed_duration);
202*4d7e907cSAndroid Build Coastguard Worker RESET_CONFIG_O(lockout_permanent_threshold);
203*4d7e907cSAndroid Build Coastguard Worker }
204*4d7e907cSAndroid Build Coastguard Worker
205*4d7e907cSAndroid Build Coastguard Worker } // namespace aidl::android::hardware::biometrics::face
206