Object/Class

kadai.log.log4j

JsonLayout

Related Docs: class JsonLayout | package log4j

Permalink

object JsonLayout extends Serializable

JsonLayout is an alternate layout that outputs each line as a JSON object. It does not attempt to produce a file that contains valid JSON however, and would need additional processing to turn this series of distinct objects into a well formed JSON array. It is specifically designed for processing each log message as a separate JSON object.

To use it, you simply need to log JsonMessage objects, which you can easily produce by mixing in the JsonLogging trait, importing JsonLogging._ and having an argonaut.EncodeJson[Foo] in scope for the Foo object you want to log. This EncodeJson instance is then used to control the format of the log output.

If you do not have an EncodeJson for the message object, then it will fall back to a String representation given by the Show[Foo] instance in scope.

Usage:

import argonaut._, Argonaut._

trait Foo { def bar: Bar }
object Foo extends JsonLogging {
  import JsonLogging._

  def foozle(foo: Foo) =
    info(foo)

  implicit val FooEncoder: EncodeJson[Foo] =
    // assuming there is already an EncodeJson[Bar]
    EncodeJson { foo =>
      ("foobar" := foo.bar) ->: Json.jEmptyObject
    }
    // results in {"foo":{"bar":"..."}}
}

see http://argonaut.io/doc/codec/ for more details on how to build an EncodeJson

Linear Supertypes
Serializable, Serializable, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. JsonLayout
  2. Serializable
  3. Serializable
  4. AnyRef
  5. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. object Printers

    Permalink
  5. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  6. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. def createLayout(printer: String, charset: String): JsonLayout

    Permalink
    Annotations
    @PluginFactory()
  8. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  11. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  12. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  13. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  15. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  16. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  17. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  18. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  19. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  20. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Serializable

Inherited from Serializable

Inherited from AnyRef

Inherited from Any

Ungrouped