openhab-core/bundles/org.openhab.core.io.rest.log
Wouter Born be69d2254e Use !isEmpty() instead of "size() > 0" or "size() != 0" (#1155)
* Use !isEmpty() instead of "size() > 0" or "size() != 0"

!isEmpty() expresses the intent more clearly and is therefore preferred.
Counting the number of elements can also be an expensive operation e.g. when using linked lists.

Co-Authored-By: Christoph Weitkamp <github@christophweitkamp.de>
Signed-off-by: Wouter Born <github@maindrain.net>
2019-10-21 09:00:52 +02:00
..
src/main/java/org/eclipse/smarthome/io/rest/log/internal Use !isEmpty() instead of "size() > 0" or "size() != 0" (#1155) 2019-10-21 09:00:52 +02:00
.classpath mavenize openHAB and integrate mavenized ESH repository (#467) 2019-01-28 13:07:31 +01:00
.project mavenize openHAB and integrate mavenized ESH repository (#467) 2019-01-28 13:07:31 +01:00
NOTICE Updated NOTICE files to openHAB (#578) 2019-02-15 10:46:18 +01:00
pom.xml Fixed POM XML Shema Definition path (#1119) 2019-10-12 08:52:16 +02:00
README.md Replaces 'Eclipse SmartHome' with 'openHAB' in text (#581) 2019-02-15 10:46:37 +01:00

FORMAT: 1A

openHAB UI Logging Bundle

This Bundle provides a resource at the REST API to enable a consumer to fetch the set log levels. It also receives log messages which will be logged to the server's log. The last logged messages by this API can be requested to be displayed in UIs.

Meta: This document is in normal markdown format, but also compatible to Apiary for automatic doc generation and API testing.

Log levels [/rest/log/levels]

Get enabled log levels [GET]

This depends on the current log settings at the backend.

  • Response 200 (application/json)

      {
          "warn": true,
          "error": true,
          "debug": true,
          "info": true
      }
    

Log [/rest/log]

Send log message [POST]

  • Request (application/json)

    • Attributes

      • severity (enum[string], required) - The severity of the log message

        • Members
          • error
          • warn
          • info
          • debug
      • url (string, optional) - The URL where the log event ocurred.

      • message (string, optional) - The message to log.

    • Body

        {
            "severity" : "error",
            "url" : "http://exmple.org/",
            "message" : "A test message"
        }
      
  • Response 200

  • Response 403 (application/json)

    • Attributes

      • error (string)
      • severity (string)
    • Body

        {
             "error": "Your log severity is not supported.",
             "severity": "info"
        }
      

Log [/rest/log/{limit}]

Get last log messages [GET]

Return the last log entries received by /rest/log/.

  • Parameters

    • limit (number, optional) - Limit the amount of messages.

      On invalid input, limit is set to it's default.

      • Default: 500
  • Response 200 (application/json)

    • Attributes

      • timestamp (number) - UTC milliseconds from the epoch.

        In JavaScript, you can use this value for constructing a Date.

      • severity (enum[string])

        • Members
          • error
          • warn
          • info
          • debug
      • url (string)

      • message (string)

    • Body

        [
          {
            "timestamp": 1450531459479,
            "severity": "error",
            "url": "http://example.com/page1",
            "message": "test 5"
          },
          {
            "timestamp": 1450531459655,
            "severity": "error",
            "url": "http://example.com/page1",
            "message": "test 6"
          },
          {
            "timestamp": 1450531460038,
            "severity": "error",
            "url": "http://example.com/page2",
            "message": "test 7"
          }
        ]