Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/geirolz/sbt-service-info

A small companion of sbt-buildinfo to add more service-specific informations.
https://github.com/geirolz/sbt-service-info

information sbt sbt-plugin scala

Last synced: 24 days ago
JSON representation

A small companion of sbt-buildinfo to add more service-specific informations.

Awesome Lists containing this project

README

        

## SBT Service Info

[![CICD](https://github.com/geirolz/sbt-service-info/actions/workflows/cicd.yml/badge.svg)](https://github.com/geirolz/sbt-service-info/actions/workflows/cicd.yml)
[![Scala Steward](https://img.shields.io/badge/Scala_Steward-helping-blue.svg?style=flat&logo=)](https://gitlab.com/moneyfarm-tech/sandbox/steward)
[![Mergify Status](https://img.shields.io/endpoint.svg?url=https://gh.mergify.io/badges/geirolz/sbt-service-info&style=flat)](https://mergify.io)

This plugin adds custom keys to [sbt-buildinfo](https://github.com/sbt/sbt-buildinfo) to have more information about the microservice.
Settings are typed to improve readability and consistency.

## How to use
Add this to your project `plugins.sbt` file
```sbt
addSbtPlugin("com.github.geirolz" % "sbt-service-info" % "0.0.1")
```

And then enable the plugin to your project in the `build.sbt` file with
```sbt
lazy val myProject = (project in file("."))
.enablePlugins(BuildInfoPlugin, ServiceInfoPlugin)
```

## Keys
- `serviceBoundedContext` = Specify service bounded context info, default `unknown`.
- `serviceProcessingPurpose` = Specify service processing purpose, can be `OLTP` or `OLAP` default `unknown`.
- `serviceTags` = Specify service useful tags, default `Nil`
- `serviceTagsIncludeDependencies` = Boolean to specify if automatic add tags related to service dependencies or not, default `true`.
- `serviceTagsIncludeDependenciesVersions` = When `serviceTagsIncludeDependencies` is true this flag specify if add dependencies version in the tags or not, default `true`

## N.B.
In your `build.sbt` file where you declare yours `buildInfoKeys` mind to use `++=` instead of `:=`.
Otherwise, the keys set by this plugin will be overloaded by yours

Example
```sbt
buildInfoKeys ++= List[BuildInfoKey](
name,
description,
version,
scalaVersion,
sbtVersion,
buildInfoBuildNumber
)
```