1# Security 2 3 4 5## Introduction 6 7The security subsystem provides capabilities to protect the application and user data security of OpenHarmony. It implements application integrity verification, application permission management, device authentication, OpenHarmony Universal KeyStore (HUKS) management, and data transfer management. 8 9## Architecture 10 11**Figure 1** Security architecture 12 13 14![](figures/security_architecture.png) 15 16- Interface layer: provides APIs, some of which are available only for system applications. 17- Application permission management: provides permission management for the Application Framework subsystem and provides APIs for applications to apply for permissions and query the permission authorization status. 18- Application integrity verification: provides capabilities to verify the code integrity before an application is installed or run. 19- Device authentication: provides key agreement and trusted device management capabilities for the devices in a distributed network. 20 21- HUKS management: provides key management for basic device authentication. 22 23- Data transfer management: provides API definitions related to data transfer management and control. 24 25## Directory Structure 26 27``` 28/base/security 29├── appverify # Application integrity verification 30├── dataclassification # Data transfer management 31├── device_auth # Device authentication 32├── huks # Key management 33└── permission # Permission management 34``` 35 36## Constraints 37 38- The current version provides local application permission management, but not distributed application permission management (which uses the stub mode for joint debugging of distributed services). 39- Device authentication includes authentication of devices with the same account and peer-to-peer device authentication. The current version supports only the peer-to-peer device authentication. The authentication of devices with the same account uses the stub mode for joint debugging of distributed services. 40- The certificates used for application integrity verification are specific to OpenHarmony. The corresponding public key certificate and private key are preset in the OpenHarmony code repositories to provide offline signing and signature verification. The public key certificate and the corresponding private key must be replaced in OpenHarmony commercial versions. 41 42## Usage 43 44**Application Permission Management** 45 46The applications and system services in OpenHarmony run in independent sandbox directory. Both processes and data are isolated from each other to ensure application data security. However, the services or applications also need to provide APIs to implement specific functionality. To access these APIs across processes, the applications in other sandbox directories need permissions. 47 48Application permission management provides a mechanism for defining permissions, allowing permissions to be defined for sensitive APIs of a system service or application. Other applications cannot access the sensitive APIs without permission. 49 50Application permission management also allows an application to request permissions that are defined by the system or other applications. Upon obtaining the permissions, the application can access the sensitive APIs. 51 52In addition, application permission management allows users to view and manage the permission authorization status. 53 54**Application Integrity Verification** 55 56The security subsystem provides signing and signature verification for applications to be installed and applications in runtime to ensure that all applications running on OpenHarmony come from a known and approved source and have not been tampered with. 57 58After developing an application and generating a package for installation, you must sign the installation package to prevent it from being tampered with after release. The OpenHarmony application integrity verification module provides a signing tool hapsigner, specifications for generating a signing certificate, and the public key certificate for you to sign your application package. A public key certificate and the corresponding private key are preset in OpenHarmony to easy your operation. Note that you must replace the public key certificate and private key in your commercial version of OpenHarmony. 59 60The OpenHarmony Application Framework subsystem is responsible for application installation. Upon receiving an application installation package, the Application Framework subsystem parses the signature of the installation package, and verifies the signature using the application integrity verification APIs. The application can be installed only after the verification is successful. During the verification, the application integrity verification module uses the preset public key certificate to verify the signature. 61 62The application integrity verification module also provides integrity check for applications in runtime, including the kernel-mode code signature verification and code integrity measurement. During application development, you can sign your code as required. When the application is installed, the OpenHarmony Application Framework subsystem calls the application integrity verification API to enable code signing for the application. Once code signing is enabled, the source, code owner, and code integrity of the application will be verified when the application is started to run. 63 64**Device Authentication and HUKS** 65 66A unified device binding and authentication solution that covers 1+8+N devices is available. Generally, device authentication is used in cross-device communication implemented by DSoftBus, rather than directly interacting with applications. Device authentication provides the following functionalities: 67 68- Building and maintaining unified trust relationship for a group of devices using different accounts. Devices with different accounts can set up a local trust group after a trust relationship is built by certain means such as scanning a QR code. Services can call APIs to query the group information. 69 70- Implementing unified device authentication. A unified authentication solution is provided to discover devices and perform connection authentication and key agreement for encrypted, end-to-end sessions through DSoftBus for the devices in a trust group. 71 72- Providing credentials for device authentication and algorithms for key agreement via the HUKS. 73 74**Data Transfer Management** 75 76In OpenHarmony, the data transfer management module provides cross-device data transfer management and control policies for distributed services. 77 78The data transfer management module provides APIs to offer cross-device data transfer policies and obtain the highest risk level of data to be sent to the peer device. 79 80## Repositories Involved 81 82Security subsystem 83 84[security_dataclassification](https://gitee.com/openharmony/security_dataclassification) 85 86[security_access_token](https://gitee.com/openharmony/security_access_token) 87 88[security_huks](https://gitee.com/openharmony/security_huks) 89 90[security_selinux](https://gitee.com/openharmony/security_selinux) 91 92[security](https://gitee.com/openharmony/security) 93 94[security_device_auth](https://gitee.com/openharmony/security_device_auth) 95 96[security_permission_lite](https://gitee.com/openharmony/security_permission_lite) 97 98[security_device_security_level](https://gitee.com/openharmony/security_device_security_level) 99 100[security_appverify](https://gitee.com/openharmony/security_appverify) 101 102[security_itrustee_ree_lite](https://gitee.com/openharmony/security_itrustee_ree_lite) 103 104[security_code_signature](https://gitee.com/openharmony/security_code_signature) 105