blob: 97dc4690befe8fc82cceff866fc3ce03e2e56dc4 [file] [log] [blame]
/*
* 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.
*/
#include "BiometricsFace.h"
namespace android::hardware::biometrics::face::implementation {
using android::hardware::biometrics::face::V1_0::FaceError;
using android::hardware::biometrics::face::V1_0::OptionalUint64;
// Arbitrary value.
constexpr uint64_t kDeviceId = 123;
// Arbitrary value.
constexpr uint64_t kAuthenticatorId = 987;
// Not locked out.
constexpr uint64_t kLockoutDuration = 0;
BiometricsFace::BiometricsFace() : mRandom(std::mt19937::default_seed) {}
// Methods from IBiometricsFace follow.
Return<void> BiometricsFace::setCallback(const sp<IBiometricsFaceClientCallback>& clientCallback,
setCallback_cb _hidl_cb) {
mClientCallback = clientCallback;
_hidl_cb({Status::OK, kDeviceId});
return Void();
}
Return<Status> BiometricsFace::setActiveUser(int32_t userId, const hidl_string& storePath) {
if (userId < 0 || storePath.empty() || std::string(storePath).find("/data") != 0) {
return Status::ILLEGAL_ARGUMENT;
}
mUserId = userId;
mClientCallback->onLockoutChanged(kLockoutDuration);
return Status::OK;
}
Return<void> BiometricsFace::generateChallenge(uint32_t /* challengeTimeoutSec */,
generateChallenge_cb _hidl_cb) {
std::uniform_int_distribution<uint64_t> dist;
_hidl_cb({Status::OK, dist(mRandom)});
return Void();
}
Return<Status> BiometricsFace::enroll(const hidl_vec<uint8_t>& /* hat */, uint32_t /* timeoutSec */,
const hidl_vec<Feature>& /* disabledFeatures */) {
// hat can never be valid in this implementation.
mClientCallback->onError(kDeviceId, mUserId, FaceError::UNABLE_TO_PROCESS, 0 /* vendorCode */);
return Status::OK;
}
Return<Status> BiometricsFace::revokeChallenge() {
return Status::OK;
}
Return<Status> BiometricsFace::setFeature(Feature /* feature */, bool /* enabled */,
const hidl_vec<uint8_t>& /* hat */,
uint32_t /* faceId */) {
// hat can never be valid in this implementation.
return Status::ILLEGAL_ARGUMENT;
}
Return<void> BiometricsFace::getFeature(Feature /* feature */, uint32_t /* faceId */,
getFeature_cb _hidl_cb) {
// hat can never be valid in this implementation.
_hidl_cb({Status::ILLEGAL_ARGUMENT, false});
return Void();
}
Return<void> BiometricsFace::getAuthenticatorId(getAuthenticatorId_cb _hidl_cb) {
_hidl_cb({Status::OK, kAuthenticatorId});
return Void();
}
Return<Status> BiometricsFace::cancel() {
mClientCallback->onError(kDeviceId, mUserId, FaceError::CANCELED, 0 /* vendorCode */);
return Status::OK;
}
Return<Status> BiometricsFace::enumerate() {
mClientCallback->onEnumerate(kDeviceId, {}, mUserId);
return Status::OK;
}
Return<Status> BiometricsFace::remove(uint32_t /* faceId */) {
return Status::OK;
}
Return<Status> BiometricsFace::authenticate(uint64_t /* operationId */) {
mClientCallback->onError(kDeviceId, mUserId, FaceError::HW_UNAVAILABLE, 0 /* vendorCode */);
return Status::OK;
}
Return<Status> BiometricsFace::userActivity() {
return Status::OK;
}
Return<Status> BiometricsFace::resetLockout(const hidl_vec<uint8_t>& /* hat */) {
return Status::OK;
}
} // namespace android::hardware::biometrics::face::implementation