/bifrost

Primary LanguageJava

Bifrost - Elasticsearch subscriptions service

Http GET

Json formatted log lines

Path: /

Query parameters:

  • matchFilters: comma separated key:value pairs used for exact matching
  • prefixFilters: comma separated key:value pairs used for prefix matching
  • afterLine: urlencoded json serialized Line object having at least the timestamp and id fields
  • direction: ASC|DESC
  • maxLines: integer of max returned lines

* key:value query: key is a field name, value is a matching string, for 'OR' matching multiple values can be defined with '|'

Plain text log lines

Path: /text

Query parameters

  • matchFilters: comma separated key:value pairs used for exact matching

  • prefixFilters: comma separated key:value pairs used for prefix matching

  • afterLine: urlencoded json serialized Line object having at least the timestamp and id fields

  • direction: ASC|DESC

  • maxLines: integer of max returned lines

  • follow: true|false keep the connection open for getting new lines

  • timeoutProbeString: when a string is defined the server is sending given string as a connection probe, the string is printed within the logs

* key:value query: key is a field name, value is a matching string, for 'OR' matching multiple values can be defined with '|'

Log messages checksum

Path: /metadata

Same query parameters as for the Json formatted log lines.

Examples query

curl "http://host.com/text/\
?maxLines=1000\
&matchFilters=mdc.processContext.keyword:build-448,level.keyword:INFO\
&prefixFilters=loggerName.keyword:org.jboss.pnc._userlog_.build-log"

#response
{
  "logger" : "org.jboss.pnc._userlog_.build-log",
  "last" : false,
  "id" : "log#AW0_yHCckFSN2lTD2LUF",
  "timestamp" : "2019-09-17T15:12:43.495Z",
  "message" : "Quick brown fox jumps over the lazy dog."
}

Websocket

Socket path: /socket

Get over websocket

To get the lines over websocket, send the "request" message to the websocket:

{
  "method":"GET-LINES",
  "id":1,
  "params":
  {
    "maxLines":"10",
    "matchFilters":"",
    "prefixFilters":"",
    "afterLine":null,
    "direction":"ASC",
    "class":"class org.jboss.pnc.bifrost.endpoint.websocket.GetLinesDto"
  }
  ,"jsonrpc":"2.0"
}

Subscribe to new log lines

To subscribe to new lines over websocket, send the "request" message to the websocket, lines are send as WebSocket Binary message

{
  "method":"SUBSCRIBE",
  "id":2,
  "params":
  {
    "matchFilters":"",
    "prefixFilters":"",
    "class":"class org.jboss.pnc.bifrost.endpoint.websocket.SubscribeDto"
  }
  ,"jsonrpc":"2.0"
}

* matchFilter and prefixFilter follow the same pattern as in http get requests described above

Unsubscribe

To subscribe to new lines over websocket, send the "request" message to the websocket, lines are send as WebSocket Binary message

{
  "method":"UNSUBSCRIBE",
  "id":3,
  "params":
  {
    "subscriptionTopic":"",
    "class":"class org.jboss.pnc.bifrost.endpoint.websocket.UnSubscribeDto"
  }
  ,"jsonrpc":"2.0"
}

* a subscription topic is returned from the subscribe action