From efa9badcd03400b5ca2e2c25db05532b7759925b Mon Sep 17 00:00:00 2001 From: Annie_wang Date: Sat, 28 May 2022 18:01:35 +0800 Subject: [PATCH] update docs Signed-off-by: Annie_wang --- en/device-dev/driver/Readme-EN.md | 15 +- .../driver-peripherals-user-auth-des.md | 558 ++++++++++++++++++ .../driver/figures/process-of-using-pin.png | Bin 0 -> 11848 bytes .../driver/figures/user_auth_architecture.png | Bin 0 -> 20580 bytes .../user_auth_service_and_driver_api.png | Bin 0 -> 29891 bytes 5 files changed, 568 insertions(+), 5 deletions(-) create mode 100644 en/device-dev/driver/driver-peripherals-user-auth-des.md create mode 100644 en/device-dev/driver/figures/process-of-using-pin.png create mode 100644 en/device-dev/driver/figures/user_auth_architecture.png create mode 100644 en/device-dev/driver/figures/user_auth_service_and_driver_api.png diff --git a/en/device-dev/driver/Readme-EN.md b/en/device-dev/driver/Readme-EN.md index 0f88055fd9..881906735d 100644 --- a/en/device-dev/driver/Readme-EN.md +++ b/en/device-dev/driver/Readme-EN.md @@ -43,12 +43,17 @@ - [UART](driver-platform-uart-des.md) - [Watchdog](driver-platform-watchdog-des.md) - Peripheral Driver Usage + - [Audio](driver-peripherals-audio-des.md) + - [Camera](driver-peripherals-camera-des.md) + - [Face_auth](driver-peripherals-face_auth-des.md) - [LCD](driver-peripherals-lcd-des.md) - - [Touchscreen](driver-peripherals-touch-des.md) + - [Light](driver-peripherals-light-des.md) + - [Pin_auth](driver-peripherals-pinauth-des.md) - [Sensor](driver-peripherals-sensor-des.md) - - [WLAN](driver-peripherals-external-des.md) - - [Audio](driver-peripherals-audio-des.md) + - [Touchscreen](driver-peripherals-touch-des.md) - [USB](driver-peripherals-usb-des.md) - - [Camera](driver-peripherals-camera-des.md) + - [User_auth](driver-peripherals-user-auth-des.md) - [Vibrator](driver-peripherals-vibrator-des.md) - - [Light](driver-peripherals-light-des.md) + - [WLAN](driver-peripherals-external-des.md) + + \ No newline at end of file diff --git a/en/device-dev/driver/driver-peripherals-user-auth-des.md b/en/device-dev/driver/driver-peripherals-user-auth-des.md new file mode 100644 index 0000000000..90b42987be --- /dev/null +++ b/en/device-dev/driver/driver-peripherals-user-auth-des.md @@ -0,0 +1,558 @@ +# User_auth + +## Overview + +### Function + +User authentication is indispensable in identity authentication scenarios, such as device unlocking, payment, and app logins. The user authentication framework (User_auth) manages the mappings between user identities and authentication credential templates in a unified manner. It schedules executors implemented by basic authentication services (including PIN authentication and facial recognition) to register user authentication credentials, delete credentials, obtain related information, and complete authentication. The figure below shows the architecture of user authentication. + +The User_auth driver is developed based on the Hardware Driver Foundation (HDF). It shields hardware differences and provides stable user authentication capabilities for apps and account management system ability (SA). It supports user credential management, authentication information enrollment, authentication scheme generation, and authentication executor information management. + +**Figure 1** User authentication architecture + +![image](figures/user_auth_architecture.png "User authentication architecture") + +### Basic Concepts +The identity authentication consists of the User_auth framework and basic authentication services (including PIN authentication and facial recognition). It supports basic functions such as setting and deleting user credentials and performing authentication. + +- Authentication credential information + + An authentication credential template is generated when a user sets a password or enrolls facial information. The credential information consists of the user identity information and credential template information. The authentication is successful when the credential data generated matches the credential template information. + +- Authentication credential template + + The authentication credential template is generated and stored by the authentication service when a user sets the authentication credential. The template information needs to be compared with the authentication data generated during authentication to complete identity authentication. Each template has an ID to index a set of template information files. + +- Executor + + The executor collects, processes, stores, and compares data for authentication. Each authentication service provides the executor capabilities, which are scheduled by User_auth to implement basic capabilities. + +- Executor role + + - ​ Executor: independently completes the entire process of credential registration and identity authentication. The executor can collect, process, store, and compare data to complete the authentication. + + - ​ Collector: only collects data during user authentication. It needs to work with the authenticator to complete user authentication. + + - ​ Authenticator: processes data, obtains the stored credential template, and compares it with the authentication information generated. + +- Executor type + + The authentication algorithm varies depending on the authentication mode and device used. Different executor types are defined based on the supported algorithm type or the device in use. + +- Executor security level + + Certain security level is required for the execution environment of an executor. For example, the executor security level is low for an operation performed without access control and high for an operation performed in a Trusted Execution Environment (TEE). + +- User_auth public key & executor public key + + To ensure user data security and authentication result accuracy, measures must be taken to protect the integrity of the key information exchanged between User_auth and basic authentication services. Public keys must be exchanged when the executor provided by a basic authentication service interworks with User_auth. + + - The executor uses the User_auth public key to verify scheduling instructions. For example, if a face image template is locked, the related facial authentication capability cannot be used. The instruction for unlocking the face image template must be verified before being executed. + + - User_auth uses the executor public key to verify the authentication result accuracy and the integrity of the information exchanged with the executor. + + +- Authentication result trust level + + The trust level of the authentication result varies, depending on the authentication mode and the security level of the authentication execution environment. + +- Authentication scheme + + An authentication scheme contains information about the authentication mode, trust level of the authentication result, executor, and credential. + +- Scheduling information + + Scheduling information includes the executor information and credential template information required by the executor to process requests. User_auth schedules the executor to implement basic authentication capabilities. + +- SA + + SAs are loaded by the System Ability Manager service to provide basic system capabilities for the OpenHarmony system. + +- Kit + + The kit provides basic application programming interfaces (APIs) for third-party applications. + +- Inner API + + Inner API is an API provided by OpenHarmony for system applications. + +### Working Principles + +The User_auth driver shields the differences of security devices and environments. It provides unified interface for the User_auth service to implement management of authentication executors and credentials as well as authentication scheme generation. +You can develop drivers to call Hardware Device Interface (HDI) APIs based on the HDF and the chip you use. + +**Figure 2** User_auth service and User_auth driver APIs + +![image](figures/user_auth_service_and_driver_api.png "interaction between the uin_auth service and driver") + +### Constraints + +The User_auth driver must be implemented in a TEE to ensure secure storage of user credential information and trustworthiness of user authentication results. + +## Development Guidelines + +### When to Use + +The User_auth driver provides stable user credential management, authentication session management, and executor information management capabilities for the User_auth service to ensure successful PIN authentication and biometric recognition on devices. + +### Available APIs + +**Table 1** Available APIs + +| API | Description | +| ------------------------------------------------------------ | ------------------------------------------------------------ | +| Init() | Initializes cached information. | +| AddExecutor(const ExecutorRegisterInfo& info, uint64_t& index, std::vector& publicKey,
std::vector& templateIds) | Adds an executor to obtain the authentication capability. | +| DeleteExecutor(uint64_t index) | Deletes an executor. | +| OpenSession(int32_t userId, std::vector& challenge) | Opens a session for authentication credential management. | +| CloseSession(int32_t userId) | Closes a session for authentication credential management. | +| BeginEnrollment(int32_t userId, const std::vector& authToken, const EnrollParam& param,
ScheduleInfo& info) | Enrolls the user authentication credential. If a user has enrolled a PIN, the new PIN enrolled will replace the old PIN.| +| UpdateEnrollmentResult(int32_t userId, const std::vector& scheduleResult, uint64_t& credentialId,
CredentialInfo& oldInfo) | Updates the data to complete this enrollment. | +| CancelEnrollment(int32_t userId) | Cancels an enrollment operation. | +| DeleteCredential(int32_t userId, uint64_t credentialId, const std::vector& authToken,
CredentialInfo& info) | Deletes credential information based on the specified **credentialId**. | +| DeleteUser(int32_t userId, const std::vector& authToken,
std::vector& deletedInfos) | Deletes a user PIN from User_auth. | +| EnforceDeleteUser(int32_t userId, std::vector& deletedInfos) | Forcibly deletes a user. This API will be called when a user is deleted from the system. | +| GetCredential(int32_t userId, AuthType authType, std::vector& infos) | Obtains user credential information by authentication type. | +| GetSecureInfo(int32_t userId, uint64_t& secureUid, std::vector& infos) | Obtains the secure user ID and the enrolled tag ID of each authentication type. | +| BeginAuthentication(uint64_t contextId, const AuthSolution& param,
std::vector& scheduleInfos) | Starts an authentication to generate the authentication scheme and scheduling information. | +| UpdateAuthenticationResult(uint64_t contextId, const std::vector& scheduleResult,
AuthResultInfo& info) | Updates the authentication result to evaluate the authentication scheme. | +| CancelAuthentication(uint64_t contextId) | Cancels an authentication. | +| BeginIdentification(uint64_t contextId, AuthType authType, const std::vector& challenge,
uint32_t executorId, ScheduleInfo& scheduleInfo) | Starts an identification to generate the identification scheme and scheduling information. | +| UpdateIdentificationResult(uint64_t contextId, const std::vector& scheduleResult,
IdentifyResultInfo& info) | Updates the identification result to evaluate the identification scheme. | +| CancelIdentification(uint64_t contextId) | Cancel an identification. | +| GetAuthTrustLevel(int32_t userId, AuthType authType, uint32_t& authTrustLevel) | Obtains the authentication trust level of the specified authentication type. | +| GetValidSolution(int32_t userId, const std::vector& authTypes, uint32_t authTrustLevel,
std::vector& validTypes) | Obtains the valid authentication scheme based on the authentication trust level for a user. | + +### How to Develop + +The following uses the Hi3516DV300 platform as an example to demonstrate how to develop the User_auth driver.
The directory structure is as follows: + +```undefined +// drivers/peripheral/user_auth +├── BUILD.gn # Build script +├── bundle.json # Module description file +└── hdi_service # User_auth driver implementation + ├── BUILD.gn # Build script + ├── module # Implementation of functionalities + └── service + ├── user_auth_interface_driver.cpp # User_auth driver entry + └── user_auth_interface_service.cpp # Implementation of the APIs for obtaining the executor list +``` + +The development procedure is as follows: + +1. Develop the User_auth driver based on the HDF. The **Bind()**, **Init()**, **Release()**, and **Dispatch()** functions are used. For details about the code, see [user_auth_interface_driver.cpp](https://gitee.com/openharmony/drivers_peripheral/blob/master/user_auth/hdi_service/service/user_auth_interface_driver.cpp). + + ```c++ + // Create the IRemoteObject object by using the custom HdfUserAuthInterfaceHost object, which consists of the IoService object and HDI service. + struct HdfUserAuthInterfaceHost { + struct IDeviceIoService ioService; + OHOS::sptr stub; + }; + + // Enable the IPC service to call the response API. + static int32_t UserAuthInterfaceDriverDispatch(struct HdfDeviceIoClient *client, int cmdId, struct HdfSBuf *data, + struct HdfSBuf *reply) + { + auto *hdfUserAuthInterfaceHost = CONTAINER_OF(client->device->service, struct HdfUserAuthInterfaceHost, ioService); + + OHOS::MessageParcel *dataParcel = nullptr; + OHOS::MessageParcel *replyParcel = nullptr; + OHOS::MessageOption option; + + if (SbufToParcel(data, &dataParcel) != HDF_SUCCESS) { + HDF_LOGE("%{public}s:invalid data sbuf object to dispatch", __func__); + return HDF_ERR_INVALID_PARAM; + } + if (SbufToParcel(reply, &replyParcel) != HDF_SUCCESS) { + HDF_LOGE("%{public}s:invalid reply sbuf object to dispatch", __func__); + return HDF_ERR_INVALID_PARAM; + } + + return hdfUserAuthInterfaceHost->stub->SendRequest(cmdId, *dataParcel, *replyParcel, option); + } + + // Initialize the HdfUserAuthInterfaceDriver object. + int HdfUserAuthInterfaceDriverInit(struct HdfDeviceObject *deviceObject) + { + HDF_LOGI("HdfUserAuthInterfaceDriverInit enter"); + OHOS::UserIAM::Common::Init(); + return HDF_SUCCESS; + } + + // Bind the service provided by the User_auth driver to the HDF. + int HdfUserAuthInterfaceDriverBind(struct HdfDeviceObject *deviceObject) + { + HDF_LOGI("HdfUserAuthInterfaceDriverBind enter"); + + auto *hdfUserAuthInterfaceHost = new (std::nothrow) HdfUserAuthInterfaceHost; + if (hdfUserAuthInterfaceHost == nullptr) { + HDF_LOGE("%{public}s: failed to create create HdfUserAuthInterfaceHost object", __func__); + return HDF_FAILURE; + } + + hdfUserAuthInterfaceHost->ioService.Dispatch = UserAuthInterfaceDriverDispatch; + hdfUserAuthInterfaceHost->ioService.Open = NULL; + hdfUserAuthInterfaceHost->ioService.Release = NULL; + + auto serviceImpl = IUserAuthInterface::Get(true); + if (serviceImpl == nullptr) { + HDF_LOGE("%{public}s: failed to get of implement service", __func__); + return HDF_FAILURE; + } + + hdfUserAuthInterfaceHost->stub = OHOS::HDI::ObjectCollector::GetInstance().GetOrNewObject(serviceImpl, + IUserAuthInterface::GetDescriptor()); + if (hdfUserAuthInterfaceHost->stub == nullptr) { + HDF_LOGE("%{public}s: failed to get stub object", __func__); + return HDF_FAILURE; + } + + deviceObject->service = &hdfUserAuthInterfaceHost->ioService; + return HDF_SUCCESS; + } + + // Release resources of the User_auth driver. + void HdfUserAuthInterfaceDriverRelease(struct HdfDeviceObject *deviceObject){ + HDF_LOGI("HdfUserAuthInterfaceDriverRelease enter"); + auto *hdfUserAuthInterfaceHost = CONTAINER_OF(deviceObject->service, struct HdfUserAuthInterfaceHost, ioService); + delete hdfUserAuthInterfaceHost; + } + + // Register the User_auth driver entry data structure object. + struct HdfDriverEntry g_userAuthInterfaceDriverEntry = { + .moduleVersion = 1, + .moduleName = "user_auth_device_driver", + .Bind = HdfUserAuthInterfaceDriverBind, + .Init = HdfUserAuthInterfaceDriverInit, + .Release = HdfUserAuthInterfaceDriverRelease, + }; + + // Call HDF_INIT to register the driver entry with the HDF. When loading the driver, the HDF calls the Bind() function and then the Init() function. If the Init() function fails to be called, the HDF will call Release() to release driver resources and exit the driver model. + #ifndef __cplusplus + extern "C" { + #endif + HDF_INIT(g_userAuthInterfaceDriverEntry); + #ifndef __cplusplus + } + #endif + ``` + +2. Register the executor. For details about the code, see [user_auth_interface_service.cpp](https://gitee.com/openharmony/drivers_peripheral/blob/master/user_auth/hdi_service/service/user_auth_interface_service.cpp). + + ```c++ + // Add an executor. + int32_t UserAuthInterfaceService::AddExecutor(const ExecutorRegisterInfo& info, uint64_t& index, + std::vector& publicKey, std::vector& templateIds) + { + GlobalLock(); + ExecutorInfoHal executorInfoHal; + CopyExecutorInfo(info, executorInfoHal); + int32_t ret = RegisterExecutor(&executorInfoHal, &index); + GlobalUnLock(); + return ret; + } + + // Delete the executor. + int32_t UserAuthInterfaceService::DeleteExecutor(uint64_t index) + { + return UnRegisterExecutor(index); + } + ``` + +3. Enroll user authentication data. For details about the code, see [user_auth_interface_service.cpp](https://gitee.com/openharmony/drivers_peripheral/blob/master/user_auth/hdi_service/service/user_auth_interface_service.cpp). + + ```c++ + // Open a session for authentication credential management. + int32_t UserAuthInterfaceService::OpenSession(int32_t userId, std::vector& challenge) + { + GlobalLock(); + uint64_t challengeU64 = 0; + int32_t ret = OpenEditSession(userId, &challengeU64); + challenge.resize(sizeof(uint64_t)); + if (memcpy_s(&challenge[0], challenge.size(), &challengeU64, sizeof(uint64_t)) != EOK) { + IAM_LOGE("challengeU64 copy failed"); + return RESULT_BAD_COPY; + } + GlobalUnLock(); + return ret; + } + + // Close the session for authentication credential management. + int32_t UserAuthInterfaceService::CloseSession(int32_t userId) + { + GlobalLock(); + int32_t ret = CloseEditSession(); + GlobalUnLock(); + return ret; + } + + // Start an authentication to generate enrollment and scheduling information. + int32_t UserAuthInterfaceService::BeginEnrollment(int32_t userId, const std::vector& authToken, + const EnrollParam& param, ScheduleInfo& info) + { + IAM_LOGI("start"); + GlobalLock(); + if (authToken.size() != sizeof(UserAuthTokenHal) && param.authType != PIN) { + IAM_LOGE("authToken len is invalid"); + GlobalUnLock(); + return RESULT_BAD_PARAM; + } + PermissionCheckParam checkParam; + if (authToken.size() == sizeof(UserAuthTokenHal) && + memcpy_s(checkParam.token, AUTH_TOKEN_LEN, &authToken[0], authToken.size()) != EOK) { + GlobalUnLock(); + return RESULT_BAD_COPY; + } + checkParam.authType = param.authType; + checkParam.userId = userId; + checkParam.authSubType = (uint64_t)param.executorType; + CoAuthSchedule scheduleInfo; + int32_t ret = CheckEnrollPermission(checkParam, &scheduleInfo.scheduleId); + if (ret != RESULT_SUCCESS) { + IAM_LOGE("check permission failed"); + GlobalUnLock(); + return ret; + } + ret = GetCoAuthSchedule(&scheduleInfo); + if (ret != RESULT_SUCCESS) { + IAM_LOGE("get schedule info failed"); + GlobalUnLock(); + return ret; + } + if (!CopyScheduleInfo(&scheduleInfo, &info)) { + IAM_LOGE("copy schedule info failed"); + ret = RESULT_BAD_COPY; + } + GlobalUnLock(); + return ret; + } + + // Cancel the enrollment operation. + int32_t UserAuthInterfaceService::CancelEnrollment(int32_t userId) + { + IAM_LOGI("start"); + BreakOffCoauthSchedule(userId); + return RESULT_SUCCESS; + } + + // Update the enrolled credential information. + int32_t UserAuthInterfaceService::UpdateEnrollmentResult(int32_t userId, const std::vector& scheduleResult, + uint64_t& credentialId, CredentialInfo& oldInfo) + { + IAM_LOGI("start"); + GlobalLock(); + if (scheduleResult.size() == 0) { + IAM_LOGE("enrollToken is invalid"); + GlobalUnLock(); + return RESULT_BAD_PARAM; + } + Buffer *scheduleResultBuffer = CreateBufferByData(&scheduleResult[0], scheduleResult.size()); + if (scheduleResultBuffer == nullptr) { + IAM_LOGE("scheduleTokenBuffer is null"); + GlobalUnLock(); + return RESULT_NO_MEMORY; + } + bool isUpdate; + int32_t ret = GetIsUpdate(&isUpdate); + if (ret != RESULT_SUCCESS) { + IAM_LOGE("get isUpdate failed"); + return ret; + } + if (isUpdate) { + CredentialInfoHal oldCredentialHal; + ret = UpdateCredentialFunc(scheduleResultBuffer, &credentialId, &oldCredentialHal); + oldInfo.authType = static_cast(oldCredentialHal.authType); + oldInfo.credentialId = oldCredentialHal.credentialId; + oldInfo.templateId = oldCredentialHal.templateId; + oldInfo.executorType = static_cast(oldCredentialHal.authSubType); + oldInfo.executorId = 0; + oldInfo.index = 0; + } else { + ret = AddCredentialFunc(scheduleResultBuffer, &credentialId); + } + DestoryBuffer(scheduleResultBuffer); + GlobalUnLock(); + return ret; + } + ``` + +4. Perform the authentication. For details about the code, see [user_auth_interface_service.cpp](https://gitee.com/openharmony/drivers_peripheral/blob/master/user_auth/hdi_service/service/user_auth_interface_service.cpp). + + ```c++ + // Create an HDI service object. + extern "C" IUserAuthInterface *UserAuthInterfaceImplGetInstance(void) + { + auto userAuthInterfaceService = new (std::nothrow) UserAuthInterfaceService(); + if (userAuthInterfaceService == nullptr) { + IAM_LOGE("userAuthInterfaceService is nullptr"); + return nullptr; + } + return userAuthInterfaceService; + } + + // Start an authentication to generate the authentication scheme and scheduling information. + int32_t UserAuthInterfaceService::BeginAuthentication(uint64_t contextId, const AuthSolution& param, + std::vector& infos) + { + IAM_LOGI("start"); + if (param.challenge.size() != sizeof(uint64_t)) { + IAM_LOGE("challenge copy failed"); + return RESULT_BAD_PARAM; + } + GlobalLock(); + CoAuthSchedule *schedulesGet = nullptr; + uint32_t scheduleIdNum = 0; + AuthSolutionHal solutionIn; + solutionIn.contextId = contextId; + solutionIn.userId = param.userId; + solutionIn.authType = static_cast(param.authType); + solutionIn.authTrustLevel = param.authTrustLevel; + if (memcpy_s(&solutionIn.challenge, sizeof(uint64_t), ¶m.challenge[0], + param.challenge.size()) != EOK) { + IAM_LOGE("challenge copy failed"); + GlobalUnLock(); + return RESULT_BAD_COPY; + } + int32_t ret = GenerateSolutionFunc(solutionIn, &schedulesGet, &scheduleIdNum); + if (ret != RESULT_SUCCESS) { + IAM_LOGE("generate solution failed"); + GlobalUnLock(); + return ret; + } + for (uint32_t i = 0; i < scheduleIdNum; i++) { + ScheduleInfo temp; + if (!CopyScheduleInfo(schedulesGet + i, &temp)) { + infos.clear(); + ret = RESULT_GENERAL_ERROR; + break; + } + infos.push_back(temp); + } + free(schedulesGet); + GlobalUnLock(); + return ret; + } + + // Update the authentication result to evaluate the authentication scheme. + int32_t UserAuthInterfaceService::UpdateAuthenticationResult(uint64_t contextId, + const std::vector& scheduleResult, AuthResultInfo& info) + { + IAM_LOGI("start"); + GlobalLock(); + if (scheduleResult.size() == 0) { + IAM_LOGE("param is invalid"); + info.result = RESULT_BAD_PARAM; + GlobalUnLock(); + return RESULT_BAD_PARAM; + } + Buffer *scheduleResultBuffer = CreateBufferByData(&scheduleResult[0], scheduleResult.size()); + if (scheduleResultBuffer == nullptr) { + IAM_LOGE("scheduleTokenBuffer is null"); + info.result = RESULT_GENERAL_ERROR; + GlobalUnLock(); + return RESULT_NO_MEMORY; + } + UserAuthTokenHal authTokenHal; + info.result = RequestAuthResultFunc(contextId, scheduleResultBuffer, &authTokenHal); + if (info.result != RESULT_SUCCESS) { + IAM_LOGE("execute func failed"); + DestoryBuffer(scheduleResultBuffer); + GlobalUnLock(); + return info.result; + } + info.token.resize(sizeof(UserAuthTokenHal)); + if (memcpy_s(&info.token[0], info.token.size(), &authTokenHal, sizeof(authTokenHal)) != EOK) { + IAM_LOGE("copy authToken failed"); + DestoryBuffer(scheduleResultBuffer); + GlobalUnLock(); + return RESULT_BAD_COPY; + } + DestoryBuffer(scheduleResultBuffer); + GlobalUnLock(); + return RESULT_SUCCESS; + } + + // Cancel the authentication. + int32_t UserAuthInterfaceService::CancelAuthentication(uint64_t contextId) + { + IAM_LOGI("start"); + GlobalLock(); + uint32_t scheduleIdNum = 0; + int32_t ret = CancelContextFunc(contextId, nullptr, &scheduleIdNum); + if (ret != RESULT_SUCCESS) { + IAM_LOGE("execute func failed"); + GlobalUnLock(); + return ret; + } + GlobalUnLock(); + return RESULT_SUCCESS; + } + ``` + +### Verification + +Use the [User Authentication APIs](../../application-dev/reference/apis/js-apis-useriam-userauth.md) to develop a JavaScript application and verify the application on the Hi3516DV300 platform. The sample code for verifying the authentication and authentication cancellation is as follows: + +```js +// API version 8 +import userIAM_userAuth from '@ohos.userIAM.userAuth'; +let auth = new userIAM_userAuth.UserAuth(); + +export default { + getVersion() { + console.info("start get version"); + let version = this.auth.getVersion(); + console.info("auth version = " + version); + }, + + startAuth() { + console.info("start auth"); + this.auth.auth(null, userIAM_userAuth.UserAuthType.FACE, userIAM_userAuth.AuthTrustLevel.ATL1, { + onResult: (result, extraInfo) => { + try { + console.info("auth onResult result = " + result); + console.info("auth onResult extraInfo = " + JSON.stringify(extraInfo)); + if (result == 'SUCCESS') { + // Add the logic to be executed when the authentication is successful. + } else { + // Add the logic to be executed when the authentication fails. + } + } catch (e) { + console.info("auth onResult error = " + e); + } + }, + + onAcquireInfo: (module, acquire, extraInfo) => { + try { + console.info("auth onAcquireInfo module = " + module); + console.info("auth onAcquireInfo acquire = " + acquire); + console.info("auth onAcquireInfo extraInfo = " + JSON.stringify(extraInfo)); + } catch (e) { + console.info("auth onAcquireInfo error = " + e); + } + } + }); + }, + + cancelAuth() { + console.info("start cancel auth"); + // Obtain contextId using auth(). + let contextId = auth.auth(null, userIAM_userAuth.UserAuthType.FACE, userIAM_userAuth.AuthTrustLevel.ATL1, { + onResult: (result, extraInfo) => { + console.info("auth onResult result = " + result); + }, + + onAcquireInfo: (module, acquire, extraInfo) => { + console.info("auth onAcquireInfo module = " + module); + } + }); + let cancelCode = this.auth.cancel(contextId); + if (cancelCode == userIAM_userAuth.Result.SUCCESS) { + console.info("cancel auth success"); + } else { + console.error("cancel auth fail"); + } + } +} +``` diff --git a/en/device-dev/driver/figures/process-of-using-pin.png b/en/device-dev/driver/figures/process-of-using-pin.png new file mode 100644 index 0000000000000000000000000000000000000000..581bcf6f4233251d80c77c0ec3c6ec76bbdd4162 GIT binary patch literal 11848 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
tA@gW1h63> zR!$I=AK>{NyJialg7XE(FpOtx33d#=@ib?|>_p6gv+j}-x&~%hWFm%8edpcN7S3oTmijj1AAAhtiH z_zt0ft(^rF0}R_7KNh{;b=WO(UF>gtW?tv|!fmCkbIJAz=`3wWORMbX5Xy{28e$x^VCC+|;;+L>?2o#{=j< z55xV%xw!;ioi+y5#dQr;$%*p%POyQJ4Ka4!AU7s2)QSgb_b@q#SJ2H~uvegZSnco+ zX^8iS%d5H)e#2tjRis-%l*QFMEnYYE`%mprnnOU(WVr!!>WLwe0CNj)hNQ>h8mewF z>%avRRvx8aOzz0n4&0UI46n6y&oQ~d(p@FVk@$Wm9?f9zU+FSXm)r);=f|cYpH>)V zlVsQuHfvs1UoSO1Oe+-*B(4~L+cdpZvsRhHQr`a`x{QQXzY`)zpi04ofM_hP%@#Hg z!cKe)(R=%0MjG8MPTWP0bS9asD}t1%--A~fH#e%ZIwxPBlCu-VuKB&aZ%4|#^I)!| z$DgWlV~%ICvebKTmtBSuod%zOEx4Q){6lp2(YvfBz8$ElSV+U&H?VrX7A=IP_w1Cn zwar-Ky)NC(kr$`l#J-Dx?X7@(}mZD+*BjP>O0%68N>bucb zxNnEa$+lM=Sh(Ldbgv^h%o-V zZ7$-|>Ik$E5IeQm*Xu+a#3420$Ca^p4I)Z8L2JNEqSfhC=Qom>kW<`UAuGHr64}FL z>b?%^3kyV&6n|~^x@qZ9!mqGa197;oy^><_Taznb`1{BX6Jq@V9X*Ku>xjjEGz76$ zFS2a(Gdq{#LmIy8K7wBrec`u5|E}lZQk9Mdpye#I*ws{o29(X0ScZ&lG`gEAefq$e z5SvL`l5EmslKW`$^-%l%LtR1xtW|Kc93$4v@F}nQ+wri5VN=?V2xGs&c3&PZ4dD#Q zNcnqq6RTl64SL*u+MK60=KmnCbR$8E$B)|g2&DdY5op};?Op?#8WmRD8o0 zW>%*`pc>_F$TQjx6YtmoD<|g)&@=GYxZ<=M2kjG}?GOJ**dIZ8|8B3;^8wY||G0_y j4+8wR7v19CKB2+7aMHE#iaG-0gC5+|xm%(7=*7PQ%!>*< literal 0 HcmV?d00001 diff --git a/en/device-dev/driver/figures/user_auth_architecture.png b/en/device-dev/driver/figures/user_auth_architecture.png new file mode 100644 index 0000000000000000000000000000000000000000..08dfa16e0015682b20f51767dbdcb4da299842fc GIT binary patch literal 20580 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 E0nLCG5&!@I literal 0 HcmV?d00001 -- GitLab