diff options
author | Ivan Topolnjak <ivantopo@gmail.com> | 2019-01-23 17:12:01 +0100 |
---|---|---|
committer | Ivan Topolnjak <ivantopo@gmail.com> | 2019-01-23 17:12:01 +0100 |
commit | 1db3f5c9c984dabbad7400c0c092942ff04580c0 (patch) | |
tree | fc2ec91cb15afdf217d7520782524060e182f63f /kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala | |
parent | e311df4b3a272f4f160857f718a96ec316a2fc06 (diff) | |
download | Kamon-1db3f5c9c984dabbad7400c0c092942ff04580c0.tar.gz Kamon-1db3f5c9c984dabbad7400c0c092942ff04580c0.tar.bz2 Kamon-1db3f5c9c984dabbad7400c0c092942ff04580c0.zip |
initial work on a embeded status page
Diffstat (limited to 'kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala')
-rw-r--r-- | kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala b/kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala new file mode 100644 index 00000000..c7c480fd --- /dev/null +++ b/kamon-core/src/main/scala/kamon/status/JsonMarshalling.scala @@ -0,0 +1,65 @@ +package kamon.status + +import com.grack.nanojson.JsonWriter +import kamon.module.Module +import kamon.module.Module.Registry +import java.lang.{StringBuilder => JavaStringBuilder} + +import com.typesafe.config.ConfigRenderOptions + + +trait JsonMarshalling[T] { + + /** + * Implementations should append a Json object or array that describes the given instance members and any + * additional information that is expected to be shown in the status mini site. + */ + def toJson(instance: T, builder: JavaStringBuilder): Unit +} + +object JsonMarshalling { + + implicit object ModuleRegistryStatusJsonMarshalling extends JsonMarshalling[Module.Registry.Status] { + override def toJson(instance: Registry.Status, builder: JavaStringBuilder): Unit = { + val array = JsonWriter.on(builder) + .`object`() + .array("modules") + + instance.modules.foreach(m => { + array.`object`() + .value("name", m.name) + .value("description", m.description) + .value("enabled", m.enabled) + .value("started", m.started) + .end() + }) + + array.end().end().done() + } + } + + implicit object BaseInfoJsonMarshalling extends JsonMarshalling[Status.BaseInfo] { + override def toJson(instance: Status.BaseInfo, builder: JavaStringBuilder): Unit = { + val baseConfigJson = JsonWriter.on(builder) + .`object`() + .value("version", instance.version) + .value("config", instance.config.root().render(ConfigRenderOptions.concise())) + + baseConfigJson.`object`("environment") + .value("service", instance.environment.service) + .value("host", instance.environment.host) + .value("instance", instance.environment.instance) + .`object`("tags") + + instance.environment.tags.foreach { + case (key, value) => baseConfigJson.value(key, value) + } + + baseConfigJson + .end() // ends tags + .end() // ends environment + .end() // ends base config + .done() + } + } +}
\ No newline at end of file |