• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Setting the Security Level of a Distributed File
2
3The security capabilities vary with devices. For example, small embedded devices provide fewer security capabilities than tablets. The security requirements also vary with data. For example, personal health information and bank card information are not expected to be accessed by devices of lower security levels. OpenHarmony provides a complete set of standards for data and device classification and custom data transfer policies for different devices. For details, see [Data Security Labels and Device Security Levels](../database/access-control-by-device-and-data-level.md).
4
5## Available APIs
6
7For details about the APIs, see [ohos.file.securityLabel](../reference/apis/js-apis-file-securityLabel.md).
8
9**Table 1** APIs
10
11| API| Description| Type| Synchronous Programming| Asynchronous Programming|
12| -------- | -------- | -------- | -------- | -------- |
13| setSecurityLabel | Sets a security label for a file.| Method| √ | √ |
14| getSecurityLabel | Obtains the security label of a file.| Method| √ | √ |
15
16> **NOTICE**
17>
18> 1. In distributed networking, a device can view the files that do not match its security level but cannot access them.
19>
20> 2. The default security level of the distributed file system data is S3. Applications can set the security level of files.
21
22## Development Example
23
24Obtain the sandbox path of the file and set the data security label. For details about how to obtain the context in the example, see [Obtaining the Context of UIAbility](../application-models/uiability-usage.md#obtaining-the-context-of-uiability).
25
26
27```ts
28import securityLabel from '@ohos.file.securityLabel';
29
30//Obtain the sandbox path of the file.
31let context =...; // Obtain UIAbilityContext information.
32let pathDir = context.filesDir;
33let filePath = pathDir + '/test.txt';
34
35// Set the data level of the file to S0.
36securityLabel.setSecurityLabel(filePath, 's0').then(() => {
37  console.info('Succeeded in setSecurityLabeling.');
38}).catch((err) => {
39  console.error(`Failed to setSecurityLabel. Code: ${err.code}, message: ${err.message}`);
40});
41```
42