Mobile native Wearable native

Service Application

Service applications are Tizen native applications with no graphical user interface that run in the background. They can be very useful in performing activities (such as getting sensor data in the background) that need to run periodically or continuously, but do not require any user intervention.

Service applications can be explicitly launched by a UI application. They can also be launched conditionally.

The user can check the running service applications in the task switcher; however, no events occur if the user selects a service application from the task switcher. The main menu does not contain icons for service applications. Multiple service applications can be running simultaneously with other service and UI applications.

The following figure and table describe the service application states.

Figure: Running service applications

Running service applications

Table: Service application states
State Description
READY Application is launched.
RUNNING Application runs in the background.
TERMINATED Application is terminated.

Registering Callbacks for Service Application Events

The following table lists the application state change events.

Table: Application states
Callback Description
service_app_create_cb() Used to take necessary actions before the main event loop starts. Place the initialization code (such as setting up the dbus connection) here.
service_app_control_cb() Used to take necessary actions when a service call arrives from another application.
service_app_terminate_cb() Used to take necessary actions when the application is terminating. Release all resources, especially any allocations and shared resources, so that other running applications can fully any shared resources.

The following table lists the system event events.

Table: Application states
Callback Description
service_app_low_memory_cb()

Used to take necessary actions in low memory situations.

Save data in the main memory to a persistent memory or storage, to avoid data loss in case the Tizen platform Low Memory Killer kills your application to get more free memory. Release any cached data in the main memory to secure more free memory.

service_app_low_battery_cb()

Used to take necessary actions in low battery situations.

Save data in the main memory to a persistent memory or storage, to avoid data loss in case the power goes off completely. Stop heavy CPU consumption or power consumption activities to save the remaining power.

Application Attributes

Describe your service application attributes in the manifest file. The attributes determine the application behavior. The following code example illustrates how you can define the attributes:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns="http://tizen.org/ns/packages" package="org.tizen.message" version="0.2.7"
          install-location="internal-only">
   <label>Message</label>
   <description>Message Application</description>
   <service-application appid="org.tizen.message" exec="/usr/apps/org.tizen.message/bin/message"
                   nodisplay="true" multiple="false" type="capp" taskmanage="true">
      <icon>org.tizen.message.png</icon>
      <label>Message</label>
   </service-application>
   <!--Consumer-->
   <service-application component-type="svcapp" auto-restart="true" on-boot="true"
                   appid="org.tizen.message.consumer"
                   exec="/usr/apps/org.tizen.message/bin/msg-consumer-service"
                   nodisplay="true"  multiple="false" type="capp" taskmanage="false">
   </service-application>
</manifest>

Pay specific attention to the following attributes:

  • component-type

    Set your service application component type to svcapp to define the application as a service application.

  • auto-restart

    If set to true, the application restarts whenever it terminates abnormally. If the application is running, it is launched after installing or upgrading the package.

    Note
    This attribute is not supported in Tizen wearable devices.
  • on-boot

    If set to true, the application launches on boot time, and after installing or upgrading the package. The application does not start if this attribute is removed after updating the package.

    Note
    This attribute is not supported in Tizen wearable devices.

The following table defines the behaviors resulting from the attribute combinations:

Table: Attribute combinations
auto-restart on-boot After normal termination On forced close On Reboot After package installation After package update
FALSE FALSE Not launched automatically Not launched automatically Not launched after reboot Not launched Not launched automatically
FALSE TRUE Not launched automatically Not launched automatically Launched automatically after reboot Launched Launched automatically
TRUE FALSE Launched automatically Launched automatically Not launched after reboot Not launched Launched automatically
TRUE TRUE Launched automatically Launched automatically Launched automatically after reboot Launched Launched automatically
Go to top