Apps

Apps API allows you to control some aspects of your LaMetric Time device that is related to apps that are running on it. For example, you will be able to switch between apps as well as configure alarm, control timers, radio and more.

Endpoints

Method Path Description
GET /api/v2/device/apps Returns the list of installed apps
PUT /api/v2/device/apps/next Switches to next app
PUT /api/v2/device/apps/prev Switches to previous app
GET /api/v2/device/apps/:package Returns info about installed app identified by package name
POST /api/v2/device/apps/:package/widgets/:id/actions Sends application specific action to a widget
PUT /api/v2/device/apps/:package/widgets/:id/activate Activates specific widget (app instance)

Get List of Apps

URL /api/v2/device/apps
Method GET
Authorization basic
API Version 2.1.0

Description

Returns apps currently installed on LaMetric Time. Each app is identified by package name. Device can run multiple instances of an app. These instances are called widgets. There are at least one widget (instance) running for each app.

Response

{
    "<package1>" : {
      "package": "<package1>",
      "vendor" : "<vendor>",
      "version" : "<version>",
      "version_code" : "<version_code>",
      "widgets" : {
        "<widget_uuid>" : {
          "index":<position>,
          "package": "<package1>",
          "visible": <bool>    // since API 2.3.0
        }
      },
      "actions" : {
        "<action1>" : {
          "<action_name1>" : {
               "<param1>" : {
                  "data_type" : "<bool|int|string">,
                  "name" : "<param name">,
                  "format": "<regexp">,
                  "required": <bool>
               }
          }
        }
      }
    },
    ...
    "<package_n>" : <app_object_n>
}

Please refer to /api/v2/device/apps/:package for more details on Application object.

Example

Request

REST:

GET https://<device ip address>:4343/api/v2/device/apps

Accept: application/json

cURL:

$ curl -X GET -u "dev" -k -H "Accept: application/json" \
  https://<device ip address>:4343/api/v2/device/apps
$ Enter host password for user 'dev': <device api key>

Response

{
    "com.lametric.clock": {
        "package": "com.lametric.clock",
        "vendor": "LaMetric",
        "version": "1.0.19",
        "version_code": "31",
        "actions": {
            "clock.alarm": {
                "enabled": {
                  "data_type": "bool",
                  "name": "enabled",
                  "required": false
                },
                "time": {
                  "data_type": "string",
                  "format": "[0-9]{2}:[0-9]{2}(?::[0-9]{2})?",
                  "name": "time",
                  "required": false
                },
                "wake_with_radio": {
                  "data_type": "bool",
                  "name": "wake_with_radio",
                  "required": false
                }
            }
        },
        "widgets": {
              "08b8eac21074f8f7e5a29f2855ba8060": {
                  "index": 0,
                  "package": "com.lametric.clock",
                  "visible": true
              }
        }
    },
    "com.lametric.countdown": {
        ...
    },
    "com.lametric.radio": {
        ...
    },
    "com.lametric.stopwatch": {
        ...
    },
    "com.lametric.weather": {
        ...
    }
}

Switch to Next App

URL /api/v2/device/apps/next
Method PUT
Authorization basic
API Version 2.1.0

Description

Allows to switch to the next app on LaMetric Time. App order is controlled by the user via LaMetric Time app.

Body

Does not require body.

Response

{
    "success": {
        "data" {},
        "path": "<endpoint>"
    }
}

or

{
    "errors" : [
      {
        "message" : "<Error message>"
      }
    ]
}

Example

Request

REST:

PUT https://<device ip address>:4343/api/v2/device/apps/next

cURL:

$ curl -X PUT -u "dev" -H "Accept: application/json"-k \
  https://<device ip address>:4343/api/v2/device/apps/next
$ Enter host password for user 'dev': <device api key>

Response:

{
    "success": {
        "data": {},
        "path": "/api/v2/device/apps/next"
    }
}

Switch to Previous App

URL /api/v2/device/apps/prev
Method PUT
Authorization basic
API Version 2.1.0

Description

Allows to switch to the previous app on LaMetric Time. App order is controlled by the user via LaMetric Time app.

Body

Does not require body.

Response

{
    "success": {
        "data" {},
        "path": "<endpoint>"
    }
}

or

{
    "errors" : [
      {
        "message" : "<Error message>"
      }
    ]
}

Example

Request

REST:

PUT https://<device ip address>:4343/api/v2/device/apps/prev

cURL:

$ curl -X PUT -u "dev" -H "Accept: application/json" -k \
  https://<device ip address>:4343/api/v2/device/apps/prev
$ Enter host password for user 'dev': <device api key>

Response

{
    "success": {
        "data": {},
        "path": "/api/v2/device/apps/prev"
    }
}

Get Specific App Details

URL /api/v2/device/apps/:package
Method GET
Authorization basic
API Version 2.1.0

Description

Returns information about currently installed app identified by the package.

Response

{
    "package": "<string>",
    "vendor": "<string>",
    "version": "<x.x.x>",
    "version_code": "<version code>",
    "actions": {
        "<action_id>": {
            "<parameter_id>": {
              "data_type": "[bool, int, string]",
              "name": "<string>",
              "required": <boolean>,
              "format": "<regexp>"
            }
        }
    },
    "widgets": {
          "<uuid>": {
              "index": <order no>,
              "package": "<string>",
              "visible": <bool>   // since API 2.3.0
          }
    }
}
Application Object
Field Type Description
package String Unique identifier of LaMetric Time native app.
vendor String Name of the app creator
version String Version in format “<major>.<minor>.<patch>”. For example 2.0.0 or 2.0.1
version_code String Version as number, like 1, 2, 3. Useful for easy comparison
actions Map Map of actions this app supports. For example, clock support action that allows to configure alarm.
widgets Map Map of Widgets. Widget is an instance of an app. For example, if you clone Clock app, you’ll get two widgets representing each clock instance.
Parameter Object
Field Type Description
data_type String One of [bool, int, string]
name String Name of the parameter
required Boolean true if parameter is required or false otherwise
format String Optional. Regext that defines the format of string parameter.
Widget Object
Field Type Description
index Integer Position of the widget when switching between them with buttons or API. Can be -1.
package String Id of the LaMetric Time app this widget is an instance of
visible Boolean Since API 2.3.0. True if widget is currently displayed on the screen, false otherwise.

Example

Request

REST:

GET https://<device ip address>:4343/api/v2/device/apps/com.lametric.clock

Accept: application/json

cURL:

$ curl -X GET -u "dev" -H "Accept: application/json" -k \
  https://<device ip address>:4343/api/v2/device/apps/com.lametric.clock
$ Enter host password for user 'dev': <device api key>

Response:

{
    "package": "com.lametric.clock",
    "vendor": "LaMetric",
    "version": "1.0.19",
    "version_code": "31",
    "actions": {
        "clock.alarm": {
            "enabled": {
              "data_type": "bool",
              "name": "enabled",
              "required": false
            },
            "time": {
              "data_type": "string",
              "format": "[0-9]{2}:[0-9]{2}(?::[0-9]{2})?",
              "name": "time",
              "required": false
            },
            "wake_with_radio": {
              "data_type": "bool",
              "name": "wake_with_radio",
              "required": false
            }
        }
    },
    "widgets": {
          "08b8eac21074f8f7e5a29f2855ba8060": {
              "index": 0,
              "package": "com.lametric.clock",
              "visible": true
          }
    }
}

Interact With Running Widgets

URL /api/v2/device/apps/:package/widgets/:id/actions
Method POST
Authorization basic
API Version 2.1.0

Description

Using this endpoint you can control LaMetric Time apps. Each app provides its own set of actions you can use. For example, you can start or stop radio playback, start, pause, reset timers, configure alarm clock etc. To execute an action just send an Action object in the body of the request to the endpoint like this:

{
  "id" : "<action_id>",
  "params": {},
  "activate": true|false
}

Parameter “activate” controls whether widget should become visible when the action is invoked.

Here are some actions of preinstalled apps:

App Name Package Action Id
Alarm Clock com.lametric.clock
clock.alarm - configure alarm clock
clock.clockface - sets or updates a clock face
Radio com.lametric.radio
radio.play - start playback
radio.stop - stop playback
radio.next - next radio station
radio.prev - previous radio station
Timer com.lametric.countdown
countdown.configure - set time
countdown.start - starts countdown
countdown.pause - pauses countdown
countdown.reset - resets timer
Stopwatch com.lametric.stopwatch
stopwatch.start - starts stopwatch
stopwatch.pause - pauses stopwatch
stopwatch.reset - resets stopwatch
Weather com.lametric.weather
weather.forecast - displays weather forecast

Some actions have parameters, for example clock.alarm, clock.clockface and countdown.configure.

Action “clock.alarm”

{
  "id":"clock.alarm",
  "params": {
    "enabled":true,
    "time":"10:00:00",
    "wake_with_radio":false
  }
}
Parameter Format Description
enabled Boolean Optional. Activates the alarm if set to true, deactivates otherwise.
time String Optional. Local time in format “HH:mm:ss”.
wake_with_radio Boolean Optional. If true, radio will be activated when alarm goes off.

Action “clock.clockface”

{
  "id":"clock.clockface",
  "params": {
    "icon":"",
    "type" : "custom"
  },
  "activate": true
}
Parameter Format Description
icon String Optional. Icon data in format “data:image/png;base64,<base64 encoded png binary>” or “data:image/gif;base64,<base64 encoded gif binary>”
type String Optional. Specifies the clockface type. Possible values are “weather”, “page_a_day”, “custom” and “none”.

Action “countdown.configure”

{
  "id":"countdown.configure",
  "params": {
    "duration":1800,
    "start_now":false
  }
}
Parameter Format Description
duration Integer Optional. Time in seconds.
start_now Boolean Optional. If set to true countdown will start immediately.

Body

{
  "id" : "<action_id>",
  "params": {
     "key": "value"
  }
}

Response

{
  "success": {
    "data": {},
    "path": "/api/v2/device/apps/<package>/widgets/<widget_id>/actions"
  }
}

Example

This request starts radio playback.

Request

REST:

POST https://<device ip addess>:4343/api/v2/device/apps/com.lametric.radio/widgets/589ed1b3fcdaa5180bf4848e55ba8061/actions

Content-Type: application/json

{ "id": "radio.play" }

cURL:

$ curl -X POST -u "dev" -H "Content-Type: application/json" -k \
  -d '{ "id":"radio.play"}' \
  https://<device ip addess>:4343/api/v2/device/apps/com.lametric.radio/widgets/589ed1b3fcdaa5180bf4848e55ba8061/actions
$ Enter host password for  user 'dev': <device api key>

Response

{
  "success": {
    "data": {},
    "path": "/api/v2/device/apps/com.lametric.radio/widgets/589ed1b3fcdaa5180bf4848e55ba8061/actions"
  }
}

Activate Specific Widget

URL /api/v2/device/apps/:package/widgets/:id/activate
Method PUT
Authorization basic
API Version 2.1.0

Description

Allows to make any widget visible using widget id.

Body

Does not require body.

Example

Request

REST:

PUT https://<device ip address>:4343/api/v2/device/apps/com.lametric.clock/widgets/08b8eac21074f8f7e5a29f2855ba8060/activate

Accept: application/json

cURL:

$ curl -X PUT -u "dev" -H "Accept: application/json" \
  https://<device ip address>:4343/api/v2/device/apps/com.lametric.clock/widgets/08b8eac21074f8f7e5a29f2855ba8060/activate
$ Enter host password for  user 'dev': <device api key>

Response

{
  "success" : {
    "data" : {},
    "path" : "/api/v2/device/apps/com.lametric.clock/widgets/08b8eac21074f8f7e5a29f2855ba8060/activate"
  }
}