diff --git a/en/application-dev/task-management/Readme-EN.md b/en/application-dev/task-management/Readme-EN.md
index f4b1d6d548e5e739daf352ddf16a8df310a47d05..8f5c8d904521a8188079239092ffd5b88a58b955 100644
--- a/en/application-dev/task-management/Readme-EN.md
+++ b/en/application-dev/task-management/Readme-EN.md
@@ -5,9 +5,9 @@
- [Transient Task Development](transient-task-dev-guide.md)
- [Continuous Task Development](continuous-task-dev-guide.md)
- [Work Scheduler Development](work-scheduler-dev-guide.md)
+ - [WorkSchedulerExtensionAbility Development](workscheduler-extensionability.md)
- [Efficiency Resource Request Development](efficiency-resources-apply-dev-guide.md)
- Agent-Powered Scheduled Reminder
- [Agent-Powered Reminder Overview](reminder-agent-overview.md)
- - [Agent-Powered Reminder Development](reminder-agent-development.md)
-
+ - [Agent-Powered Reminder Development](reminder-agent-development.md)
\ No newline at end of file
diff --git a/en/application-dev/task-management/background-task-overview.md b/en/application-dev/task-management/background-task-overview.md
index 201c666ad7cc65b1ab2ef865070562fa6b433bab..dc7e7e3eda37f3fe62e70114a1804cfa0bffdc65 100644
--- a/en/application-dev/task-management/background-task-overview.md
+++ b/en/application-dev/task-management/background-task-overview.md
@@ -1,26 +1,26 @@
# Background Task Management Overview
Frequent activities of background applications cause user devices to consume power quickly and respond slowly. To meet performance and power consumption requirements, the system allows applications in the background to execute only activities within the specifications. Activities beyond the specifications are suspended by default, and resources allocated to them will be reclaimed when the available resources are insufficient.
-If an application or a service module running in the background has a service to continue, it can request a [transient task](#transient-tasks) to delay the suspension or a [continuous task](#continuous-tasks) to prevent the suspension. If an application needs to execute a non-real-time task when running in the background, it can request a [Work Scheduler Task](#work-scheduler-tasks). A privileged application can also request [efficiency resources](#efficiency-resources) for more flexibility.
+If an application or a service module running in the background has a service to continue, it can request a [transient task](#transient-tasks) to delay the suspension or a [continuous task](#continuous-tasks) to prevent the suspension. If an application needs to execute a non-real-time task when running in the background, it can request a [Work Scheduler task](#work-scheduler-tasks). A privileged application can also request [efficiency resources](#efficiency-resources) for more flexibility.
## Background Task Types
For more targeted management of background applications, OpenHarmony classifies background tasks into the following types and provides an extended resource request mode:
-**No background task**: An application or service module does not need further processing when switched to the background.
+- **No background task**: An application or service module does not need further processing when switched to the background.
-**Transient task**: If an application or service module has an urgent, short task that must continue in the background until it is completed, such as data compression, the application or service module can request a transient task for delayed suspension.
+- **Transient task**: If an application or service module has an urgent, short task that must continue in the background until it is completed, such as data compression, the application or service module can request a transient task for delayed suspension.
-**Continuous task**: If an application or service module has a user-initiated, perceivable task that needs to run in an extended period of time in the background, it can request a continuous task so that it will not be suspended. Examples of continuous tasks include music playback, navigation, device connection, and VoIP.
+- **Continuous task**: If an application or service module has a user-initiated, perceivable task that needs to run in an extended period of time in the background, it can request a continuous task so that it will not be suspended. Examples of continuous tasks include music playback, navigation, device connection, and VoIP.
-**Work Scheduler task**: The Work Scheduler provides a mechanism for applications to execute non-real-time tasks when the system is idle. If the preset conditions are met, the tasks will be placed in the execution queue and scheduled when the system is idle.
+- **Work Scheduler task**: The Work Scheduler provides a mechanism for applications to execute non-real-time tasks when the system is idle. If the preset conditions are met, the tasks will be placed in the execution queue and scheduled when the system is idle.
-**Efficiency resources**: If an application needs to ensure that it will not be suspended within a period of time or can normally use certain system resources when it is suspended, it can request efficiency resources, including CPU, WORK_SCHEDULER, software, and hardware resources. Different types of efficiency resources come with different privileges. For example, the CPU resources enable an application or process to keep running without being suspended, and the WORK_SCHEDULER resources allow for more task execution time before the application or process is suspended.
+- **Efficiency resources**: If an application needs to ensure that it will not be suspended within a period of time or can normally use certain system resources when it is suspended, it can request efficiency resources, including CPU, WORK_SCHEDULER, software, and hardware resources. Different types of efficiency resources come with different privileges. For example, the CPU resources enable an application or process to keep running without being suspended, and the WORK_SCHEDULER resources allow for more task execution time before the application or process is suspended.
## Selecting a Background Task
-![Background Task Selection](public_sys-resources/bgtask_choice.png)
+![Background Task Selection](figures/bgtask_choice.png)
## Transient Tasks
@@ -51,17 +51,17 @@ OpenHarmony provides 9 background modes for services that require continuous tas
**Table 1** Background modes for continuous tasks
-| Background Mode| Description| Hint in Notification Panel| Remarks|
-| -------- | -------- | -------- | -------- |
-| dataTransfer | Data transfer through the network or peer device, such as download, backup, share, and transfer| A data transfer task is running.| - |
-| audioPlayback | Audio output| An audio playback task is running.| - |
-| audioRecording | Audio input| A recording task is running.| - |
-| location | Positioning and navigation| A positioning task is running.| - |
-| bluetoothInteraction | Bluetooth transmission| A Bluetooth-related task is running.| - |
-| multiDeviceConnection | Distributed interconnection| A distributed task is running.| - |
-| wifiInteraction | WLAN transmission| A WLAN-related task is running.| System API, which is available only to system applications|
-| voip | Voice and video calls over VoIP| A call-related task is running.| System API, which is available only to system applications|
-| taskKeeping | Computing task| A computing task is running| Effective only for specific devices|
+| Background Mode | Description | Hint in Notification Panel | Remarks |
+| --------------------- | ------------------------- | ------------ | ------------------------- |
+| dataTransfer | Data transfer through the network or peer device, such as download, backup, share, and transfer| A data transfer task is running. | - |
+| audioPlayback | Audio output | An audio playback task is running. | - |
+| audioRecording | Audio input | A recording task is running. | - |
+| location | Positioning and navigation | A positioning task is running. | - |
+| bluetoothInteraction | Bluetooth transmission | A Bluetooth-related task is running. | - |
+| multiDeviceConnection | Distributed interconnection | A distributed task is running. | - |
+| wifiInteraction | WLAN transmission | A WLAN-related task is running.| System API, which is available only to system applications|
+| voip | Voice and video calls over VoIP | A call-related task is running. | System API, which is available only to system applications|
+| taskKeeping | Computing task | A computing task is running | Effective only for specific devices |
### Restrictions on Using Continuous Tasks
- If a user triggers a perceivable task, such as broadcasting and navigation, the corresponding background mode is triggered. When the task is started, the system forcibly displays a notification to the user.
@@ -80,15 +80,15 @@ The use of the Work Scheduler must comply with the following restrictions and ru
- **Timeout**: The Work Scheduler callback can run only within the specified period of time. After the timeout, the callback automatically stops. The default timeout duration is 2 minutes. System applications can request [efficiency resources](efficiency-resources-apply-dev-guide.md) to obtain a longer duration (20 minutes in the charging state and 10 minutes in the non-charging state).
- **Execution frequency**: The system controls the execution frequency of Work Scheduler tasks based on the activity level of their respective applications. If an application has applied for the WORK_SCHEDULER resources through the efficiency resource API, the execution frequency is not limited within the validity period of the resources.
- | Application Group | Work Scheduler Task Execution Frequency |
- | --------------------|------------------------- |
- | Active| At a minimum interval of 2 hours|
- | Used every day| At a minimum interval of 4 hours|
- | Frequently used| At a minimum interval of 24 hours|
- | Infrequently used| At a minimum interval of 48 hours|
- | Restricted| Prohibited|
- | Unused| Prohibited|
- | [Exemption group for efficiency resources](../reference/apis/js-apis-backgroundTaskManager.md#resourcetype9) | Unlimited|
+ | Application Group | Work Scheduler Task Execution Frequency|
+ | ---------------------------------------- | ---------- |
+ | Active | At a minimum interval of 2 hours |
+ | Used every day | At a minimum interval of 4 hours |
+ | Frequently used | At a minimum interval of 24 hours |
+ | Infrequently used | At a minimum interval of 48 hours |
+ | Restricted | Prohibited |
+ | Unused | Prohibited |
+ | [Exemption group for efficiency resources](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#resourcetype)| Unlimited |
- **WorkInfo setting**
@@ -110,25 +110,21 @@ An application or process is assigned the privileges associated with the obtaine
* With the TIMER resources, the application can use the timer to execute precise scheduled tasks.
* With the hardware resources, the application can still be woken up by related services to execute tasks when it is suspended in the background.
+
**Table 2** Efficiency resource types
-| Name | Value | Description |
-| ----------------------- | ---- | --------------------- |
-| CPU | 1 | CPU resources, which prevent the application from being suspended. |
-| COMMON_EVENT | 2 | A type of software resources, which prevent common events from being proxied when the application is suspended. |
-| TIMER | 4 | A type of software resources, which prevent timers from being proxied when the application is suspended. |
-| WORK_SCHEDULER | 8 | WORK_SCHEDULER resources, which ensure that the application has more time to execute the task. |
-| BLUETOOTH | 16 | A type of hardware resources, which prevent Bluetooth resources from being proxied when the application is suspended. |
-| GPS | 32 | A type of hardware resources, which prevent GPS resources from being proxied when the application is suspended. |
-| AUDIO | 64 | A type of hardware resources, which prevent audio resources from being proxied when the application is suspended.|
+| Name | Value | Description |
+| -------------- | ---- | ------------------- |
+| CPU | 1 | CPU resources, which prevent the application from being suspended. |
+| COMMON_EVENT | 2 | A type of software resources, which prevent common events from being proxied when the application is suspended. |
+| TIMER | 4 | A type of software resources, which prevent timers from being proxied when the application is suspended. |
+| WORK_SCHEDULER | 8 | WORK_SCHEDULER resources, which ensure that the application has more time to execute the task. |
+| BLUETOOTH | 16 | A type of hardware resources, which prevent Bluetooth resources from being proxied when the application is suspended. |
+| GPS | 32 | A type of hardware resources, which prevent GPS resources from being proxied when the application is suspended.|
+| AUDIO | 64 | A type of hardware resources, which prevent audio resources from being proxied when the application is suspended. |
### Restrictions on Using Efficiency Resources
- Applications or processes are responsible for requesting and releasing efficiency resources. A process can release the resources requested by itself, whereas an application can release the resources requested by both itself and its processes. For example, an application requests CPU resources, and its process requests CPU and WORK_SCHEDULER resources. If the application initiates CPU resource release, the CPU resources requested by the process are also released. However, the WORK_SCHEDULER resources are not released. If the process initiates CPU resource release, the CPU resources requested by the application are retained until being released by the application.
-
- If persistent resources and non-persistent resources of the same type are requested, the persistent resources overwrite the non-persistent resources and they will not be released upon a timeout. For example, if an application first requests 10-second CPU resources and then requests persistent CPU resources at the 5th second, the CPU resources become persistent and will not be released at the tenth second. If the application releases the CPU resources at the 8th second, both types of CPU resources are released.
-
- The WORK_SCHEDULER resources can be requested and released by applications, but not by processes.
-
- To use efficiency resources, an application must first submit a request to the application center to obtain corresponding privileges.
-
-
diff --git a/en/application-dev/task-management/continuous-task-dev-guide.md b/en/application-dev/task-management/continuous-task-dev-guide.md
index 5ec27a6e13200619e34ef88c0dd00e501b11cb20..b278a686e4267d7b62d123c2f6f2c338a9278ab7 100644
--- a/en/application-dev/task-management/continuous-task-dev-guide.md
+++ b/en/application-dev/task-management/continuous-task-dev-guide.md
@@ -3,7 +3,7 @@
## When to Use
If an application has a perceivable task that needs to run in an extended period of time in the background, it can request a continuous task so that it will not be suspended. Examples of continuous tasks include music playback, navigation, device connection, and VoIP.
-There is no time limit for a continuous task running in the background. To prevent abuse, the system limits the number of continuous tasks that can be requested. It also attaches a notification to the task so that the task is perceivable. In addition, the system verifies whether the application is actually executing the continuous task.
+There is no time limit for a continuous task running in the background. To prevent abuse, the system limits the number of continuous tasks that can be requested. It also attaches a notification to each of the tasks so that the tasks are perceivable. In addition, the system verifies whether the application is actually executing a continuous task.
## Available APIs
@@ -15,7 +15,7 @@ There is no time limit for a continuous task running in the background. To preve
| stopBackgroundRunning(context: Context): Promise<void> | Cancels the continuous task. |
-For details about **wantAgent**, see [WantAgent](../reference/apis/js-apis-wantAgent.md).
+For details about **wantAgent**, see [WantAgent](../reference/apis/js-apis-app-ability-wantAgent.md).
**Table 2** Background modes
@@ -34,152 +34,9 @@ For details about **wantAgent**, see [WantAgent](../reference/apis/js-apis-wantA
## How to Develop
-### Development on the FA Model
+### Development in the Stage Model
-For details about how to use the Service ability in the FA model, see [Service Ability Development](../ability/fa-serviceability.md).
-
-If an application does not need to interact with a continuous task in the background, you can use **startAbility()** to start the Service ability. In the **onStart** callback of the Service ability, call **startBackgroundRunning()** to declare that the Service ability needs to run in the background for a long time. After the task execution is complete, call **stopBackgroundRunning()** to release resources.
-
-If an application needs to interact with a continuous task in the background (for example, an application related to music playback), you can use **connectAbility()** to start and connect to the Service ability. After obtaining the proxy of the Service ability, the application can communicate with the Service ability and control the request and cancellation of continuous tasks.
-
-1. Create an API version 8 project. Then right-click the project directory and choose **New > Ability > Service Ability** to create a Service ability. Configure the continuous task permission (**ohos.permission.KEEP_BACKGROUND_RUNNING**) and background mode type in the **config.json** file, with the ability type set to **service**.
-
-```
-"module": {
- "package": "com.example.myapplication",
- "abilities": [
- {
- "backgroundModes": [
- "dataTransfer",
- "location"
- ], // Background mode
- "type": "service" // The ability type is service.
- }
- ],
- "reqPermissions": [
- {
- "name": "ohos.permission.KEEP_BACKGROUND_RUNNING" // Continuous task permission
- }
- ]
-}
-```
-
-2. Call the APIs for requesting and canceling a continuous task in the Service ability.
-
-```js
-import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
-import featureAbility from '@ohos.ability.featureAbility';
-import wantAgent from '@ohos.wantAgent';
-import rpc from "@ohos.rpc";
-
-function startContinuousTask() {
- let wantAgentInfo = {
- // List of operations to be executed after the notification is clicked.
- wants: [
- {
- bundleName: "com.example.myapplication",
- abilityName: "com.example.myapplication.MainAbility"
- }
- ],
- // Type of the operation to perform after the notification is clicked.
- operationType: wantAgent.OperationType.START_ABILITY,
- // Custom request code.
- requestCode: 0,
- // Execution attribute of the operation to perform after the notification is clicked.
- wantAgentFlags: [wantAgent.WantAgentFlags.UPDATE_PRESENT_FLAG]
- };
-
- // Obtain the WantAgent object by using the getWantAgent API of the wantAgent module.
- wantAgent.getWantAgent(wantAgentInfo).then((wantAgentObj) => {
- try {
- backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
- backgroundTaskManager.BackgroundMode.DATA_TRANSFER, wantAgentObj).then(() => {
- console.info("Operation startBackgroundRunning succeeded");
- }).catch((err) => {
- console.error("Operation startBackgroundRunning failed Cause: " + err);
- });
- } catch (error) {
- console.error(`Operation startBackgroundRunning failed. code is ${error.code} message is ${error.message}`);
- }
- });
-}
-
-function stopContinuousTask() {
- try {
- backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext()).then(() => {
- console.info("Operation stopBackgroundRunning succeeded");
- }).catch((err) => {
- console.error("Operation stopBackgroundRunning failed Cause: " + err);
- });
- } catch (error) {
- console.error(`Operation stopBackgroundRunning failed. code is ${error.code} message is ${error.message}`);
- }
-}
-
-async function processAsyncJobs() {
- // Execute the continuous task.
-
- // After the continuous task is complete, call the API to release resources.
- stopContinuousTask();
-}
-
-let mMyStub;
-
-class MyStub extends rpc.RemoteObject {
- constructor(des) {
- if (typeof des === 'string') {
- super(des);
- } else {
- return null;
- }
- }
- onRemoteRequest(code, data, reply, option) {
- console.log('ServiceAbility onRemoteRequest called');
- // The meaning of code is user-defined.
- if (code === 1) {
- // Receive the request code for requesting a continuous task.
- startContinuousTask();
- // Execute the continuous task.
- } else if (code === 2) {
- // Receive the request code for canceling the continuous task.
- stopContinuousTask();
- } else {
- console.log('ServiceAbility unknown request code');
- }
- return true;
- }
-}
-
-export default {
- onStart(want) {
- console.info('ServiceAbility onStart');
- mMyStub = new MyStub("ServiceAbility-test");
- // Call the API to start the task.
- startContinuousTask();
- processAsyncJobs();
- },
- onStop() {
- console.info('ServiceAbility onStop');
- },
- onConnect(want) {
- console.info('ServiceAbility onConnect');
- return mMyStub;
- },
- onReconnect(want) {
- console.info('ServiceAbility onReconnect');
- },
- onDisconnect() {
- console.info('ServiceAbility onDisconnect');
- },
- onCommand(want, restart, startId) {
- console.info('ServiceAbility onCommand');
- }
-};
-```
-
-### Development on the Stage Model
-
-For details about the stage model, see [Stage Model Overview](../ability/stage-brief.md).
+For details about the stage model, see [Stage Model Development Overview](../application-models/stage-model-development-overview.md).
1. Create an API version 9 project. Then right-click the project directory and choose **New > Ability** to create an ability. Configure the continuous task permission (ohos.permission.KEEP_BACKGROUND_RUNNING) and background mode type in the **module.json5** file.
@@ -201,10 +58,10 @@ For details about the stage model, see [Stage Model Overview](../ability/stage-b
}
```
-2. If an application needs to execute a continuous task for its own, include the execution logic in the Page ability. This is because an application cannot use **startAbilityByCall** to create and run its own ability in the background due to the restriction of ability startup controls. For details about how to use an ability in the stage model, see [Ability Development](../ability/stage-ability.md).
+2. If an application needs to execute a continuous task for its own, include the execution logic in the Page ability. This is because an application cannot use **startAbilityByCall** to create and run its own ability in the background due to the restriction of ability startup controls. For details, see [UIAbility Component Overview](../application-models/uiability-overview.md).
```ts
-import wantAgent from '@ohos.wantAgent';
+import wantAgent from '@ohos.app.ability.wantAgent';
import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
@Entry
@@ -220,7 +77,7 @@ struct Index {
wants: [
{
bundleName: "com.example.myapplication",
- abilityName: "com.example.myapplication.MainAbility",
+ abilityName: "EntryAbility",
}
],
// Type of the operation to perform after the notification is clicked.
@@ -290,14 +147,14 @@ struct Index {
}
```
-3. If a continuous task needs to be executed in the background for another application or on another device, you can create and run an ability in the background in Call mode. For details, see [Call Development](../ability/stage-call.md).
+3. If a continuous task needs to be executed in the background for another application or on another device, you can create and run an ability in the background in Call mode. For details, see [Using Ability Call (Intra-Device)](../application-models/uiability-intra-device-interaction.md#using-ability-call-to-implement-uiability-interaction) and [Using Ability Call (Inter-Device)](../application-models/hop-multi-device-collaboration.md#using-cross-device-ability-call).
```ts
-import Ability from '@ohos.application.Ability'
+import UIAbility from '@ohos.app.ability.UIAbility';
import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
-import wantAgent from '@ohos.wantAgent';
+import wantAgent from '@ohos.app.ability.wantAgent';
-const MSG_SEND_METHOD: string = 'CallSendMsg'
+const MSG_SEND_METHOD: string = 'CallSendMsg';
let mContext = null;
@@ -307,7 +164,7 @@ function startContinuousTask() {
wants: [
{
bundleName: "com.example.myapplication",
- abilityName: "com.example.myapplication.MainAbility",
+ abilityName: "EntryAbility",
}
],
// Type of the operation to perform after the notification is clicked.
@@ -381,7 +238,7 @@ function sendMsgCallback(data) {
return new MySequenceable(10, "Callee test");
}
-export default class BgTaskAbility extends Ability {
+export default class BgTaskAbility extends UIAbility {
onCreate(want, launchParam) {
console.info("[Demo] BgTaskAbility onCreate")
this.callee.on("test", sendMsgCallback);
@@ -421,3 +278,146 @@ export default class BgTaskAbility extends Ability {
}
};
```
+
+### Development in the FA Model
+
+For details about how to use the ServiceAbility in the FA model, see [ServiceAbility Component Overview](../application-models/serviceability-overview.md).
+
+If an application does not need to interact with a continuous task in the background, you can use **startAbility()** to start the Service ability. In the **onStart** callback of the Service ability, call **startBackgroundRunning()** to declare that the Service ability needs to run in the background for a long time. After the task execution is complete, call **stopBackgroundRunning()** to release resources.
+
+If an application needs to interact with a continuous task in the background (for example, an application related to music playback), you can use **connectAbility()** to start and connect to the Service ability. After obtaining the proxy of the Service ability, the application can communicate with the Service ability and control the request and cancellation of continuous tasks.
+
+1. Create an API version 8 project. Then right-click the project directory and choose **New > Ability > Service Ability** to create a Service ability. Configure the continuous task permission (**ohos.permission.KEEP_BACKGROUND_RUNNING**) and background mode type in the **config.json** file, with the ability type set to **service**.
+
+```json
+"module": {
+ "package": "com.example.myapplication",
+ "abilities": [
+ {
+ "backgroundModes": [
+ "dataTransfer",
+ "location"
+ ], // Background mode
+ "type": "service" // The ability type is service.
+ }
+ ],
+ "reqPermissions": [
+ {
+ "name": "ohos.permission.KEEP_BACKGROUND_RUNNING" // Continuous task permission
+ }
+ ]
+}
+```
+
+2. Call the APIs for requesting and canceling a continuous task in the Service ability.
+
+```js
+import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
+import featureAbility from '@ohos.ability.featureAbility';
+import wantAgent from '@ohos.app.ability.wantAgent';
+import rpc from "@ohos.rpc";
+
+function startContinuousTask() {
+ let wantAgentInfo = {
+ // List of operations to be executed after the notification is clicked.
+ wants: [
+ {
+ bundleName: "com.example.myapplication",
+ abilityName: "EntryAbility"
+ }
+ ],
+ // Type of the operation to perform after the notification is clicked.
+ operationType: wantAgent.OperationType.START_ABILITY,
+ // Custom request code.
+ requestCode: 0,
+ // Execution attribute of the operation to perform after the notification is clicked.
+ wantAgentFlags: [wantAgent.WantAgentFlags.UPDATE_PRESENT_FLAG]
+ };
+
+ // Obtain the WantAgent object by using the getWantAgent API of the wantAgent module.
+ wantAgent.getWantAgent(wantAgentInfo).then((wantAgentObj) => {
+ try {
+ backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
+ backgroundTaskManager.BackgroundMode.DATA_TRANSFER, wantAgentObj).then(() => {
+ console.info("Operation startBackgroundRunning succeeded");
+ }).catch((err) => {
+ console.error("Operation startBackgroundRunning failed Cause: " + err);
+ });
+ } catch (error) {
+ console.error(`Operation startBackgroundRunning failed. code is ${error.code} message is ${error.message}`);
+ }
+ });
+}
+
+function stopContinuousTask() {
+ try {
+ backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext()).then(() => {
+ console.info("Operation stopBackgroundRunning succeeded");
+ }).catch((err) => {
+ console.error("Operation stopBackgroundRunning failed Cause: " + err);
+ });
+ } catch (error) {
+ console.error(`Operation stopBackgroundRunning failed. code is ${error.code} message is ${error.message}`);
+ }
+}
+
+async function processAsyncJobs() {
+ // Execute the continuous task.
+
+ // After the continuous task is complete, call the API to release resources.
+ stopContinuousTask();
+}
+
+let mMyStub;
+
+class MyStub extends rpc.RemoteObject {
+ constructor(des) {
+ if (typeof des === 'string') {
+ super(des);
+ } else {
+ return null;
+ }
+ }
+ onRemoteRequest(code, data, reply, option) {
+ console.log('ServiceAbility onRemoteRequest called');
+ // The meaning of code is user-defined.
+ if (code === 1) {
+ // Receive the request code for requesting a continuous task.
+ startContinuousTask();
+ // Execute the continuous task.
+ } else if (code === 2) {
+ // Receive the request code for canceling the continuous task.
+ stopContinuousTask();
+ } else {
+ console.log('ServiceAbility unknown request code');
+ }
+ return true;
+ }
+}
+
+export default {
+ onStart(want) {
+ console.info('ServiceAbility onStart');
+ mMyStub = new MyStub("ServiceAbility-test");
+ // Call the API to start the task.
+ startContinuousTask();
+ processAsyncJobs();
+ },
+ onStop() {
+ console.info('ServiceAbility onStop');
+ },
+ onConnect(want) {
+ console.info('ServiceAbility onConnect');
+ return mMyStub;
+ },
+ onReconnect(want) {
+ console.info('ServiceAbility onReconnect');
+ },
+ onDisconnect() {
+ console.info('ServiceAbility onDisconnect');
+ },
+ onCommand(want, restart, startId) {
+ console.info('ServiceAbility onCommand');
+ }
+};
+```
diff --git a/en/application-dev/task-management/figures/WorkSchedulerExtensionAbility.png b/en/application-dev/task-management/figures/WorkSchedulerExtensionAbility.png
new file mode 100644
index 0000000000000000000000000000000000000000..627a88f515e8a4ba1beb40e3242fd3521cb39494
Binary files /dev/null and b/en/application-dev/task-management/figures/WorkSchedulerExtensionAbility.png differ
diff --git a/en/application-dev/task-management/public_sys-resources/bgtask_choice.png b/en/application-dev/task-management/figures/bgtask_choice.png
similarity index 100%
rename from en/application-dev/task-management/public_sys-resources/bgtask_choice.png
rename to en/application-dev/task-management/figures/bgtask_choice.png
diff --git a/en/application-dev/task-management/reminder-agent-development.md b/en/application-dev/task-management/reminder-agent-development.md
index c749a9f4cc9615e836e2163632390b8821e55072..c9a23f6422aef7a2b2709b00d21b9c7e129496f4 100644
--- a/en/application-dev/task-management/reminder-agent-development.md
+++ b/en/application-dev/task-management/reminder-agent-development.md
@@ -5,16 +5,16 @@
The agent-powered reminder feature provides APIs for publishing background reminders. You can call these APIs to create scheduled reminders for countdown timers, calendar events, and alarm clocks. The APIs are encapsulated in the [reminderAgentManager](../reference/apis/js-apis-reminderAgentManager.md) class.
-**Table 1** Major APIs in reminderAgentManager
+ **Table 1** Major APIs in reminderAgentManager
-| API | Description |
-| ------------------------------------------------------------ | ------------------------------------------------------------ |
-| publishReminder(reminderReq: ReminderRequest, callback: AsyncCallback<number>): void
publishReminder(reminderReq: ReminderRequest): Promise<number> | Publishes a scheduled reminder.
The maximum number of valid notifications (excluding expired ones that will not pop up again) is 30 for one application and 2000 for the entire system. |
-| cancelReminder(reminderId: number, callback: AsyncCallback<void>): void
cancelReminder(reminderId: number): Promise<void> | Cancels a specified reminder. (The value of **reminderId** is obtained from the return value of **publishReminder**.) |
-| getValidReminders(callback: AsyncCallback<Array<ReminderRequest>>): void
getValidReminders(): Promise<Array<ReminderRequest>> | Obtains all valid reminders set by the current application. |
-| cancelAllReminders(callback: AsyncCallback<void>): void
cancelAllReminders(): Promise<void> | Cancels all reminders set by the current application. |
-| addNotificationSlot(slot: NotificationSlot, callback: AsyncCallback<void>): void
addNotificationSlot(slot: NotificationSlot): Promise<void> | Registers a **NotificationSlot** instance to be used by the reminder. |
-| removeNotificationSlot(slotType: notification.SlotType, callback: AsyncCallback<void>): void
removeNotificationSlot(slotType: notification.SlotType): Promise<void> | Removes a **NotificationSlot** instance of a specified type. |
+| API | Description |
+| ---------------------------------------- | ---------------------------------------- |
+| publishReminder(reminderReq: ReminderRequest, callback: AsyncCallback<number>): void
publishReminder(reminderReq: ReminderRequest): Promise<number> | Publishes a scheduled reminder.
The maximum number of valid notifications (excluding expired ones that will not pop up again) is 30 for one application
and 2000 for the entire system.|
+| cancelReminder(reminderId: number, callback: AsyncCallback<void>): void
cancelReminder(reminderId: number): Promise<void> | Cancels a specified reminder. (The value of **reminderId** is obtained from the return value of **publishReminder**.)|
+| getValidReminders(callback: AsyncCallback<Array<ReminderRequest>>): void
getValidReminders(): Promise<Array<ReminderRequest>> | Obtains all valid reminders set by the current application. |
+| cancelAllReminders(callback: AsyncCallback<void>): void
cancelAllReminders(): Promise<void> | Cancels all reminders set by the current application. |
+| addNotificationSlot(slot: NotificationSlot, callback: AsyncCallback<void>): void
addNotificationSlot(slot: NotificationSlot): Promise<void> | Registers a **NotificationSlot** instance to be used by the reminder. |
+| removeNotificationSlot(slotType: notification.SlotType, callback: AsyncCallback<void>): void
removeNotificationSlot(slotType: notification.SlotType): Promise<void> | Removes a **NotificationSlot** instance of a specified type. |
## How to Develop
@@ -51,9 +51,9 @@ The agent-powered reminder feature provides APIs for publishing background remin
pkgName: 'com.example.myapplication',
abilityName: 'EntryAbility'
},
- title:'this is title', // Reminder title.
- content:'this is content', // Reminder content.
- expiredContent:'This reminder has expired', // Content to be displayed after the reminder expires.
+ title: 'this is title', // Reminder title.
+ content: 'this is content', // Reminder content.
+ expiredContent: 'this reminder has expired', // Content to be displayed after the reminder expires.
notificationId: 100, // Notification ID used by the reminder. If there are reminders with the same notification ID, the later one will overwrite the earlier one.
slotType: notificationManager.SlotType.SOCIAL_COMMUNICATION // Type of the slot used by the reminder.
}
@@ -94,10 +94,10 @@ The agent-powered reminder feature provides APIs for publishing background remin
ringDuration: 5, // Ringing duration, in seconds.
snoozeTimes: 2, // Number of reminder snooze times.
timeInterval: 5, // Reminder snooze interval, in seconds.
- title:'this is title', // Reminder title.
+ title: 'this is title', // Reminder title.
content:'this is content', // Reminder content.
- expiredContent:'This reminder has expired', // Content to be displayed after the reminder expires.
- snoozeContent:'remind later', // Content to be displayed when the reminder is snoozed.
+ expiredContent: 'this reminder has expired', // Content to be displayed after the reminder expires.
+ snoozeContent: 'remind later', // Content to be displayed when the reminder is snoozed.
notificationId: 100, // Notification ID used by the reminder. If there are reminders with the same notification ID, the later one will overwrite the earlier one.
slotType: notificationManager.SlotType.SOCIAL_COMMUNICATION // Type of the slot used by the reminder.
}
@@ -131,10 +131,10 @@ The agent-powered reminder feature provides APIs for publishing background remin
ringDuration: 5, // Ringing duration, in seconds.
snoozeTimes: 2, // Number of reminder snooze times.
timeInterval: 5, // Reminder snooze interval, in seconds.
- title:'this is title', // Reminder title.
- content:'this is content', // Reminder content.
- expiredContent:'This reminder has expired', // Content to be displayed after the reminder expires.
- snoozeContent:'remind later', // Content to be displayed when the reminder is snoozed.
+ title: 'this is title', // Reminder title.
+ content: 'this is content', // Reminder content.
+ expiredContent: 'this reminder has expired', // Content to be displayed after the reminder expires.
+ snoozeContent: 'remind later', // Content to be displayed when the reminder is snoozed.
notificationId: 99, // Notification ID used by the reminder. If there are reminders with the same notification ID, the later one will overwrite the earlier one.
slotType: notificationManager.SlotType.SOCIAL_COMMUNICATION // Type of the slot used by the reminder.
}
@@ -175,7 +175,3 @@ The agent-powered reminder feature provides APIs for publishing background remin
console.log("cancelReminder code: " + error.code + ", message: " + error.message);
};
```
-
-
-
-
\ No newline at end of file
diff --git a/en/application-dev/task-management/transient-task-dev-guide.md b/en/application-dev/task-management/transient-task-dev-guide.md
index b1e815fc68a485cb88f24b2c18b64f2658133196..a83ba2094138e2271f55758484f483a9a7ddbaed 100644
--- a/en/application-dev/task-management/transient-task-dev-guide.md
+++ b/en/application-dev/task-management/transient-task-dev-guide.md
@@ -2,12 +2,11 @@
## When to Use
-By default, an application can run for 6 to 12 seconds after it switches to the background but before being suspended. If an application requires more time to execute an important task, it can call the **requestSuspendDelay** API to delay the suspension.
+By default, an application can run for a period of 6 to 12 seconds after it switches to the background. When this period expires, the application is suspended. If an application requires more time to execute an important task, it can call the **requestSuspendDelay** API to request a transient task to delay the suspension.
-It is recommended that an application calls the **requestSuspendDelay** API before executing any time-consuming task, rather than when it is already running in the background.
-The calling of the **requestSuspendDelay** API when the application is running in the foreground does not affect the transient task quota of the application.
+You are advised not to call the [requestSuspendDelay()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagerrequestsuspenddelay) method to apply for delayed suspension after the application is running in the background. Instead, you need to call this interface to declare the execution time of the extended application to the system before performing any time-consuming operation. It is recommended that an application calls [requestSuspendDelay()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagerrequestsuspenddelay) when it is running in the foreground, so as not to affect the transient task quota of the application.
-Each application has a daily time quota for transient tasks. Therefore, after the time-consuming task finishes execution, the application should cancel the transient task in a timely manner.
+An application can obtain the remaining duration before being suspended by calling [getRemainingDelayTime()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagergetremainingdelaytimecallback). Each application has a daily time quota for transient tasks. Therefore, after the time-consuming task finishes execution, the application should call [cancelSuspendDelay()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagercancelsuspenddelay) to cancel the transient task in a timely manner.
Typical time-consuming tasks include saving status data to the local database, opening and processing a large file, and synchronizing data to the cloud server.
@@ -19,67 +18,74 @@ Typical time-consuming tasks include saving status data to the local database, o
| API | Description |
| ---------------------------------------- | ---------------------------------------- |
-| requestSuspendDelay(reason: string, callback: Callback<void>): [DelaySuspendInfo](../reference/apis/js-apis-backgroundTaskManager.md#delaysuspendinfo) | Requests delayed suspension after the application switches to the background.
The default duration value of delayed suspension is 3 minutes when the battery level is normal and 1 minute when the battery level is low.|
+| requestSuspendDelay(reason: string, callback: Callback<void>): [DelaySuspendInfo](../reference/apis/js-apis-backgroundTaskManager.md#delaysuspendinfo)| Requests delayed suspension after the application switches to the background.
The default duration of delayed suspension is 3 minutes when the battery level is normal and 1 minute when the battery level is low.|
| getRemainingDelayTime(requestId: number): Promise<number> | Obtains the remaining duration before the application is suspended.
This API uses a promise to return the result. |
| cancelSuspendDelay(requestId: number): void | Cancels the suspension delay. |
## How to Develop
-1. When an application needs to execute a time-consuming task, call the API to request a transient task. After the time-consuming task finishes execution, call the API to cancel the transient task.
+When an application needs to execute a time-consuming task in the background, call the API to request a transient task. After the time-consuming task finishes execution, call the API to cancel the transient task.
```js
-import backgroundTaskManager from '@ohos.backgroundTaskManager';
+import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
-let delayInfo;
-let id;
+let id; // ID of the suspension delay request.
+let delayTime; // Remaining duration for the suspension delay request.
// Request a suspension delay.
function requestSuspendDelay() {
- let myReason = 'test requestSuspendDelay';
- delayInfo = backgroundTaskManager.requestSuspendDelay(myReason, () => {
- console.info("Request suspension delay will time out.");
- // The callback in invoked to notify the application that the suspension delay request is about to time out. The application needs to perform some cleanup and annotation operations.
- });
-
+ let myReason = 'test requestSuspendDelay'; // Reason for the suspension delay request.
+
+ try {
+ let delayInfo = backgroundTaskManager.requestSuspendDelay(myReason, () => {
+ // The callback is invoked to notify the application that the suspension delay request is about to time out. The application needs to perform some cleanup and annotation operations and cancels the transient task.
+ console.info("[backgroundTaskManager] Request suspension delay will time out.");
+ backgroundTaskManager.cancelSuspendDelay(id);
+ })
id = delayInfo.requestId;
- console.info("requestId is: " + id);
+ delayTime = delayInfo.actualDelayTime;
+ console.info("[backgroundTaskManager] The requestId is: " + id);
+ console.info("[backgroundTaskManager]The actualDelayTime is: " + delayTime);
+ } catch (error) {
+ console.error(`[backgroundTaskManager] requestSuspendDelay failed. code is ${error.code} message is ${error.message}`);
+ }
}
// Obtain the remaining duration before the application is suspended.
-function getRemainingDelayTime() {
- let delayTime = 0;
- backgroundTaskManager.getRemainingDelayTime(id).then((res) => {
- console.log('promise => Operation getRemainingDelayTime succeeded. Data: ' + JSON.stringify(res));
- delayTime = res;
- }).catch((err) => {
- console.log('promise => Operation getRemainingDelayTime failed. Cause: ' + err.code);
- });
- return delayTime;
+async function getRemainingDelayTime() {
+ try {
+ await backgroundTaskManager.getRemainingDelayTime(id).then(res => {
+ console.log('[backgroundTaskManager] promise => Operation getRemainingDelayTime succeeded. Data: ' + JSON.stringify(res));
+ }).catch(error => {
+ console.error(`[backgroundTaskManager] promise => Operation getRemainingDelayTime failed. code is ${error.code} message is ${error.message}`);
+ })
+ } catch (error) {
+ console.error(`[backgroundTaskManager] promise => Operation getRemainingDelayTime failed. code is ${error.code} message is ${error.message}`);
+ }
}
// Cancel the suspension delay.
function cancelSuspendDelay() {
- backgroundTaskManager.cancelSuspendDelay(id);
+ backgroundTaskManager.cancelSuspendDelay(id);
}
-function performingLongRunningTask() {
- // Before executing the time-consuming task, call the API to request a transient task to delay the suspension.
- requestSuspendDelay();
-
- // Obtain the available time quota through the getRemainingDelayTime() API.
- let delayTime = getRemainingDelayTime();
+async function performingLongRunningTask() {
+ // Before executing a time-consuming task, call the API to request a transient task to delay the suspension.
+ requestSuspendDelay();
- if (delayTime < 0) {// If the time is less than a certain value, cancel the time-consuming operation.
- // Handle the scenario where the time quota is insufficient.
+ // If required, obtain the available time quota through the getRemainingDelayTime() API.
+ await getRemainingDelayTime();
- cancelSuspendDelay();
- return;
- }
+ if (delayTime < 0) {// If the time is less than a certain value, cancel the time-consuming task.
+ // Handle the scenario where the time quota is insufficient.
+ cancelSuspendDelay();
+ return;
+ }
- // Execute the time-consuming task.
+ // Execute the time-consuming task.
- // After the time-consuming task is executed, call the API to cancel the transient task.
- cancelSuspendDelay();
+ // After the time-consuming task is executed, call the API to cancel the transient task.
+ cancelSuspendDelay();
}
```
diff --git a/en/application-dev/task-management/work-scheduler-dev-guide.md b/en/application-dev/task-management/work-scheduler-dev-guide.md
index 6ab36ea5da66af894ddec3c21aba7eb7cc37e926..845423ee6fa93a39d5ac93cbd8856f0ec0e49c23 100644
--- a/en/application-dev/task-management/work-scheduler-dev-guide.md
+++ b/en/application-dev/task-management/work-scheduler-dev-guide.md
@@ -2,7 +2,7 @@
## When to Use
-If your application needs to execute a non-real-time task or a persistent task, for example, data learning, you can harness the Work Scheduler mechanism, which will schedule the task based on the storage space, power consumption, temperature, and more when the preset conditions are met. For details about the restrictions, see [Restrictions on Using Work Scheduler](./background-task-overview.md#restrictions-on-using-work-scheduler).
+If your application needs to execute a non-real-time task or a persistent task, for example, data learning, you can harness the Work Scheduler mechanism, which will schedule the task based on the storage space, power consumption, temperature, and more when the preset conditions are met. Your application must implement the callbacks provided by [WorkSchedulerExtensionAbility](./workscheduler-extensionability.md) for Work Scheduler tasks. For details about the restrictions, see [Restrictions on Using Work Scheduler](./background-task-overview.md#restrictions-on-using-work-scheduler).
## Available APIs
@@ -14,21 +14,21 @@ startWork(work: WorkInfo): void; | Starts a Work Scheduler task.
stopWork(work: WorkInfo, needCancel?: boolean): void; | Stops a Work Scheduler task.
getWorkStatus(workId: number, callback: AsyncCallback\): void;| Obtains the status of a Work Scheduler task. This API uses an asynchronous callback to return the result.
getWorkStatus(workId: number): Promise\; | Obtains the status of a Work Scheduler task. This API uses a promise to return the result.
-obtainAllWorks(callback: AsyncCallback\): Array\;| Obtains Work Scheduler tasks. This API uses an asynchronous callback to return the result.
-obtainAllWorks(): Promise>;| Obtains Work Scheduler tasks. This API uses a promise to return the result.
-stopAndClearWorks(): void;| Stops and clears Work Scheduler tasks.
+obtainAllWorks(callback: AsyncCallback\): Array\;| Obtains all the Work Scheduler tasks. This API uses an asynchronous callback to return the result.
+obtainAllWorks(): Promise>;| Obtains all the Work Scheduler tasks. This API uses a promise to return the result.
+stopAndClearWorks(): void;| Stops and clears all the Work Scheduler tasks.
isLastWorkTimeOut(workId: number, callback: AsyncCallback\): boolean;| Checks whether the last execution of the specified task has timed out. This API uses an asynchronous callback to return the result. It is applicable to repeated tasks.
isLastWorkTimeOut(workId: number): Promise\;| Checks whether the last execution of the specified task has timed out. This API uses a promise to return the result. It is applicable to repeated tasks.
**Table 2** WorkInfo parameters
-For details about the constraints on configuring **WorkInfo**, see [Restrictions on Using Work Scheduler](./background-task-overview.md#restrictions-on-using-work-scheduler).
+For details about the restriction on configuring **WorkInfo**, see [Restrictions on Using Work Scheduler](./background-task-overview.md#restrictions-on-using-work-scheduler).
Name| Type|Description
---------------------------------------------------------|-----------------------------------------|---------------------------------------------------------
-workId| number | Work ID. Mandatory.
-bundleName| string | Name of the Work Scheduler task bundle. Mandatory.
-abilityName| string | Name of the component to be notified by a Work Scheduler callback. Mandatory.
+workId| number | ID of the Work Scheduler task. Mandatory.
+bundleName| string | Bundle name of the Work Scheduler task. Mandatory.
+abilityName| string | Name of the ability to be notified by a Work Scheduler callback. Mandatory.
networkType | [NetworkType](../reference/apis/js-apis-resourceschedule-workScheduler.md#networktype) | Network type.
isCharging| boolean | Whether the device is charging.
chargerType| [ChargingType](../reference/apis/js-apis-resourceschedule-workScheduler.md#chargingtype) | Charging type.
@@ -42,26 +42,27 @@ parameters | {[key: string]: any} |Carried parameters.
**Table 3** Work Scheduler callbacks
-Name | Description
+API | Description
---------------------------------------------------------|-----------------------------------------
-onWorkStart(work: WorkInfo): void | Triggered when the Work Scheduler task starts.
-onWorkStop(work: WorkInfo): void | Triggered when the Work Scheduler task stops.
+onWorkStart(work: WorkInfo): void | Called when the Work Scheduler task starts.
+onWorkStop(work: WorkInfo): void | Called when the Work Scheduler task stops.
### How to Develop
1. Import the modules.
- Import the **workScheduler** package to implement registration:
-```js
-import workScheduler from '@ohos.resourceschedule.workScheduler';
-```
+ Import the **workScheduler** module.
+
+ ```js
+ import workScheduler from '@ohos.resourceschedule.workScheduler';
+ ```
- Import the **WorkSchedulerExtensionAbility** package to implement callback:
-```js
-import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility';
-```
+ Import the **WorkSchedulerExtensionAbility** module.
+ ```js
+ import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility';
+ ```
-2. Develop an Extension ability to execute a Work Scheduler task. For details about the Extension ability, see [ExtensionAbility Mechanism](../ability/stage-brief.md#extensionability-mechanism).
+2. Develop an ExtensionAbility to execute a Work Scheduler task. For details about the ExtensionAbility, see [ExtensionAbility Component Overview](../application-models/extensionability-overview.md) and [WorkSchedulerExtensionAbility Development](./workscheduler-extensionability.md).
```ts
import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility';
@@ -77,7 +78,7 @@ export default class MyExtension extends WorkSchedulerExtensionAbility {
```
-3. Register a Work Scheduler task.
+3. Start a Work Scheduler task.
```ts
import workScheduler from '@ohos.resourceschedule.workScheduler';
@@ -105,7 +106,7 @@ try{
```
-4. Cancel the Work Scheduler task.
+4. Stop the Work Scheduler task.
```ts
import workScheduler from '@ohos.resourceschedule.workScheduler';
@@ -152,7 +153,7 @@ try{
```
-6. Obtain all Work Scheduler tasks.
+6. Obtain all the Work Scheduler tasks.
```ts
try{
@@ -168,7 +169,7 @@ try{
}
```
-7. Stop and clear Work Scheduler tasks.
+7. Stop and clear all the Work Scheduler tasks.
```ts
try{
@@ -179,7 +180,7 @@ try{
}
```
-8. Check whether the last execution has timed out.
+8. Check whether the last execution of a specified Work Scheduler task has timed out.
```ts
try{
diff --git a/en/application-dev/task-management/workscheduler-extensionability.md b/en/application-dev/task-management/workscheduler-extensionability.md
new file mode 100644
index 0000000000000000000000000000000000000000..b2df1601a6608c6bb3c4dd10ce257a2c02284bc6
--- /dev/null
+++ b/en/application-dev/task-management/workscheduler-extensionability.md
@@ -0,0 +1,196 @@
+# WorkSchedulerExtensionAbility Development
+
+If your application needs to execute a non-real-time task or a persistent task, you can harness the Work Scheduler mechanism, which will schedule the task when the preset conditions (including the network type, charging type, storage status, battery status, and timing status) are met.
+
+**WorkSchedulerExtensionAbility** provides callbacks for Work Scheduler tasks. When a Work Scheduler task starts or stops, these callbacks are invoked to process your service logic.
+
+## Working Principles
+
+Figure 1 shows the working principle of Work Scheduler.
+
+**Figure 1** Work Scheduler working principle
+
+![WorkSchedulerExtensionAbility](figures/WorkSchedulerExtensionAbility.png)
+
+An application starts, stops, and obtains Work Scheduler tasks through the [workScheduler APIs](../reference/apis/js-apis-resourceschedule-workScheduler.md).
+
+The application service layer detects and determines the conditions. If the preset conditions are met, the application service layer calls back the **WorkSchedulerExtensionAbility** object to start the application and triggers the **onWorkStart** and **onWorkStop** callbacks.
+
+## Available APIs
+
+The **WorkSchedulerExtensionAbility** class has the following APIs. For details, see [WorkSchedulerExtensionAbility](../reference/apis/js-apis-WorkSchedulerExtensionAbility.md).
+
+| Name| Description|
+| -------- | -------- |
+| onWorkStart(work: workScheduler.WorkInfo): void | Called when the Work Scheduler task starts.|
+| onWorkStop(work: workScheduler.WorkInfo): void | Called when the Work Scheduler task stops.|
+
+## How to Develop
+
+To create a WorkScheduler project in DevEco Studio, perform the following steps:
+
+- [Implement callbacks for Work Scheduler](#implementing-callbacks-for-work-scheduler): Develop the callbacks provided by **WorkSchedulerExtensionAbility**.
+
+- [Implement Work Scheduler](#implementing-work-scheduler): Develop the [workScheduler APIs] to implement functions such as starting or stopping Work Scheduler tasks.
+
+- [Set the configuration file](#setting-the-configuration-file): Set the configuration file **module.json5**.
+
+### Implementing Callbacks for Work Scheduler
+
+1. Create a module named **library** in the root directory of the project, with the **Ohos Library** template selected.
+
+2. In the **./library/src/main/ets** directory under **library**, create an ArkTS file named **workAbility.ets** and implement the callbacks for Work Scheduler.
+
+ Import the module.
+
+ ```ts
+ import WorkSchedulerExtensionAbility from '@ohos.WorkSchedulerExtensionAbility'
+ ```
+
+ Implement the lifecycle callbacks for the WorkSchedulerExtensionAbility.
+
+ ```ts
+ export default class workAbility extends WorkSchedulerExtensionAbility {
+ // Callback invoked when the Work Scheduler task starts.
+ onWorkStart(workInfo) {
+ console.log(`onWorkStart CommonEvent publish start ${JSON.stringify(workInfo)}`)
+ // Publish an upgrade notification.
+ let notificationRequest = notification.getNotificationContentBasic('upgrade', upgradeMessage, '')
+ notification.publish(notificationRequest, (err) => {
+ if (err) {
+ console.log(`onWorkStart notification publish err ${JSON.stringify(err)}`)
+ }
+ console.log(`onWorkStart notification publish success`)
+ })
+ }
+
+ // Callback invoked when the Work Scheduler task stops.
+ onWorkStop(workInfo) {
+ // Publish an upgrade completion notification.
+ let notificationRequest = notification.getNotificationContentBasic('upgrade', 'upgrade success', '')
+ notification.publish(notificationRequest, (err) => {
+ if (err) {
+ console.log(`onWorkStop notification publish err ${JSON.stringify(err)}`)
+ }
+ console.log(`onWorkStop notification publish success`)
+ })
+ }
+ }
+ ```
+
+3. In the **./entry/src/main/ets** directory under the **entry** module of the project, create a directory named **workAbility**. In the **workAbility** directory, create an ArkTS file named **WorkTest.ets** and implement the callbacks for Work Scheduler.
+
+Import the module.
+
+ ```ts
+ import { workAbility } from '@ohos/library'
+ ```
+
+Inherit from **workAbility** and implement the lifecycle callbacks for the WorkSchedulerExtensionAbility.
+
+ ```ts
+ export default class WorkTest extends workAbility {
+ onWorkStart(workInfo) {
+ console.log(`onWorkStartTest start ${JSON.stringify(workInfo)}`)
+ super.onWorkStart(workInfo)
+ }
+
+ onWorkStopTest(workInfo) {
+ super.onWorkStop(workInfo)
+ console.log(`onWorkStop value`)
+ }
+ }
+ ```
+
+### Implementing Work Scheduler
+
+1. In the **./library/src/main/ets** directory under **library**, create a TypeScript file named **DelayWork.ts**, and implement the Work Scheduler APIs.
+
+ Import the module.
+
+ ```ts
+ import workScheduler from '@ohos.resourceschedule.workScheduler'
+ ```
+
+ Encapsulate the APIs for starting and stopping Work Scheduler tasks.
+
+ ```ts
+ export default class DelayWork {
+ private workInfo = {
+ workId: 1,
+ networkType: workScheduler.NetworkType.NETWORK_TYPE_WIFI,
+ bundleName: '',
+ abilityName: ''
+ }
+ // Start the Work Scheduler task.
+ startWork(bundleName: string, abilityName: string) {
+ this.workInfo.bundleName = bundleName
+ this.workInfo.abilityName = abilityName
+ try {
+ workScheduler.startWork(this.workInfo)
+ console.log(`startWork success`)
+ } catch (error) {
+ Logger.error(TAG, `startWork startwork failed. code is ${error.code} message is ${error.message}`)
+ prompt.showToast({
+ message: `${error.message}`
+ })
+ }
+ }
+
+ // Stop the Work Scheduler task.
+ stopWork(bundleName: string, abilityName: string) {
+ this.workInfo.bundleName = bundleName
+ this.workInfo.abilityName = abilityName
+ workScheduler.stopWork(this.workInfo, false)
+ console.log(`stopWork`)
+ }
+ }
+ ```
+
+2. In the **./entry/src/main/ets/pages/index.ets** directory under the **entry** module of the project, add the **Upgrade** button, which, when being clicked, will call the API encapsulated in **library** to start the Work Scheduler task.
+
+ Import the module.
+
+ ```ts
+ import { workAbility } from '@ohos/library'
+ ```
+
+ Add the **Upgrade** button, which, when being clicked, will call the API encapsulated in **library** to start the Work Scheduler task. In the API, **bundleName** and **abilityName** are passed in, where the value of **abilityName** is **WorkTest**.
+
+ ```ts
+ Button($r('app.string.upgrade'))
+ .width('60%')
+ .height(40)
+ .fontSize(30)
+ .onClick(() => {
+ this.work.startWork('ohos.samples.workscheduler', 'WorkTest')
+ })
+ ```
+
+ When the component is destructed, it calls the API to stop the Work Scheduler task.
+
+ ```ts
+ aboutToDisappear() {
+ this.work.stopWork('ohos.samples.workscheduler', 'WorkTest')
+ }
+ ```
+
+### Setting the Configuration File
+
+1. Register the WorkSchedulerExtensionAbility in the [module.json5 file](../quick-start/module-configuration-file.md) under the **entry** module. Set **type** to **workScheduler** and **srcEntrance** to the code path of the WorkSchedulerExtensionAbility component.
+
+ ```json
+ {
+ "module": {
+ "extensionAbilities": [
+ {
+ "name": "WorkTest",
+ "srcEntrance": "./ets/workAbility/WorkTest.ets",
+ "label": "$string:WorkSchedulerExtensionAbility_label",
+ "description": "$string:WorkSchedulerExtensionAbility_desc",
+ "type": "workScheduler"
+ }
+ ]
+ }
+ }
+ ```