Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leobenkel/laeta
Agnostic service registry with fully typed retrieval
https://github.com/leobenkel/laeta
functional-programming registry scala services typed
Last synced: about 2 months ago
JSON representation
Agnostic service registry with fully typed retrieval
- Host: GitHub
- URL: https://github.com/leobenkel/laeta
- Owner: leobenkel
- License: mit
- Created: 2020-05-28T21:10:38.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-08-12T23:00:56.000Z (5 months ago)
- Last Synced: 2024-10-12T21:43:15.009Z (3 months ago)
- Topics: functional-programming, registry, scala, services, typed
- Language: Scala
- Homepage: https://github.com/leobenkel/laeta
- Size: 86.9 KB
- Stars: 0
- Watchers: 2
- Forks: 2
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Gitter](https://badges.gitter.im/laeta/community.svg)](https://gitter.im/laeta/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
[![release-badge][]][release]
[![maven-central-badge][]][maven-search]
[![CI-CD](https://github.com/leobenkel/Laeta/actions/workflows/ci_cd.yml/badge.svg)](https://github.com/leobenkel/Laeta/actions/workflows/ci_cd.yml)
[![BCH compliance](https://bettercodehub.com/edge/badge/leobenkel/Laeta?branch=master)](https://bettercodehub.com/)
[![Coverage Status](https://coveralls.io/repos/github/leobenkel/Laeta/badge.svg?branch=master)](https://coveralls.io/github/leobenkel/laeta?branch=master)
[![Mutation testing badge](https://badge.stryker-mutator.io/github.com/leobenkel/Laeta/master)](https://stryker-mutator.github.io)[release]: https://github.com/leobenkel/laeta/releases
[release-badge]: https://img.shields.io/github/tag/leobenkel/laeta.svg?label=version&color=blue
[maven-search]: https://search.maven.org/search?q=g:com.leobenkel%20a:laeta*
[leobenkel-github-badge]: https://img.shields.io/badge/-Github-yellowgreen.svg?style=social&logo=GitHub&logoColor=black
[leobenkel-github-link]: https://github.com/leobenkel
[leobenkel-linkedin-badge]: https://img.shields.io/badge/-Linkedin-yellowgreen.svg?style=social&logo=LinkedIn&logoColor=black
[leobenkel-linkedin-link]: https://linkedin.com/in/leobenkel
[leobenkel-personal-badge]: https://img.shields.io/badge/-Website-yellowgreen.svg?style=social&logo=&logoColor=black
[leobenkel-personal-link]: https://leobenkel.com
[leobenkel-patreon-link]: https://www.patreon.com/leobenkel
[leobenkel-patreon-badge]: https://img.shields.io/badge/-Patreon-yellowgreen.svg?style=social&logo=Patreon&logoColor=black
[maven-central-link]: https://maven-badges.herokuapp.com/maven-central/com.leobenkel/laeta_2.11
[maven-central-badge]: https://maven-badges.herokuapp.com/maven-central/com.leobenkel/laeta_2.11/badge.svg# Laeta
Small library to handle registery of services.
Handle collection of Services of arbitrary type and retrieve them fully typed.
[Laeta (wikipedia)](https://en.wikipedia.org/wiki/Laetitia_(goddess))
## Table of Contents
* [How to use?](#how-to-use)
* [Add to build.sbt](#add-to-buildsbt)
* [Setup](#setup)
* [To use](#to-use)
* [Notes](#notes)Created by [gh-md-toc](https://github.com/ekalinin/github-markdown-toc)
## How to use?
### Add to build.sbt
First include the library in your project:
```sbt
libraryDependencies += "com.leobenkel" %% "laeta" % "[VERSION]"
```
With version being: [![maven-central-badge][]][maven-search]### Setup
Live example: [Scastie-0P5GodpCSSmL5Pd8igL0tA](https://scastie.scala-lang.org/0P5GodpCSSmL5Pd8igL0tA) or take a look at the [test example](https://github.com/leobenkel/Laeta/blob/master/Library/src/test/scala/foo/bar/consumer/ServiceTest.scala)
You need two pieces for the compiler to start guiding you:
A service:
```scala
import com.leobenkel.laeta.Servicecase class MyService(override val input: INPUT) extends Service[INPUT, MyService] {
???
}
```And a factory:
```scala
import com.leobenkel.laeta.ServiceFactorycase class MyFactory(override val getInput: Int) extends ServiceFactory[INPUT, MyService] {
lazy override protected val getObject: ServiceConstructor[INPUT, MyService] = MyConstructor
lazy override protected val getType: ServiceType[MyService] = MyGeyKey
}
```This will force you to create:
A constructor:
```scala
object MyConstructor extends ServiceConstructor[INPUT, MyService]
```Your `MyConstructor` should probably have the same name as `case class MyService` so you don't have to implement the `apply` method.
and a Type:
```scala
case object MyGeyKey extends ServiceType[MyService] {}
```### To use
And to use is very simple, you first register all the factories:
```scala
val registryBuilder: RegistryFactories = RegistryFactories()
.register(MyFactory(input))
```and then you seal the registry:
```scala
val registryReady: ServiceCollection = registryBuilder.create
```you can now access any service, anywhere, **typed** !
```scala
val myService = registryReady.getService(MyGeyKey)
```### Notes
It is possible to merge the `ServiceConstructor[INPUT, MyService]` and the `ServiceType[MyService]` for shorter code.
This mean you can replace all the places where we used `MyGeyKey` by `MyConstructor`.
Example on [Scastie-716dNpMORwuJqO9RWED93A](https://scastie.scala-lang.org/716dNpMORwuJqO9RWED93A).