Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/avast/scala-server-toolkit

Functional programming toolkit for building server applications in Scala.
https://github.com/avast/scala-server-toolkit

cats-effect functional-programming scala server toolkit

Last synced: 4 days ago
JSON representation

Functional programming toolkit for building server applications in Scala.

Awesome Lists containing this project

README

        

# Scala Server Toolkit

![Build Status](https://github.com/avast/scala-server-toolkit/workflows/Build/badge.svg)
[![Maven Central](https://img.shields.io/maven-central/v/com.avast/sst-bundle-zio-http4s-blaze_2.13)](https://repo1.maven.org/maven2/com/avast/sst-bundle-zio-http4s-blaze_2.13/)
[![Scala Steward badge](https://img.shields.io/badge/Scala_Steward-helping-brightgreen.svg?style=flat&logo=)](https://scala-steward.org)
[![Mergify badge](https://img.shields.io/endpoint.svg?url=https://gh.mergify.io/badges/avast/scala-server-toolkit)](https://mergify.io)

This project is a culmination of years of Scala development at Avast and tries to represent the best practices of Scala server development
we have gained together with tools that allow us to be effective. It is a set of small, flexible and cohesive building blocks that fit
together well and allow you to build reliable server applications.

## Jump Right In

You can use the [official Giter8 template](https://github.com/avast/sst-seed.g8) to get started:

```bash
sbt new avast/sst-seed.g8
```

## Documentation

**[Read it here](https://avast.github.io/scala-server-toolkit)** or you can [deep dive into example code](example/src/main/scala/com/avast/sst/example/Main.scala).

### Articles

* [Introducing Scala Server Toolkit](https://engineering.avast.io/introducing-scala-server-toolkit) (Avast Engineering)
* [SST - Creating HTTP Server](https://engineering.avast.io/scala-server-toolkit-creating-http-server) (Avast Engineering)

### Talks
* [Intro to Scala Server Toolkit](https://www.youtube.com/watch?v=T4xKu2bFUv0) (Functional JVM Meetup, Prague, January 23, 2020)
* [slides](https://speakerdeck.com/jakubjanecek/intro-to-scala-server-toolkit)
* [Scala Server Toolkit: How to Write FP Microservice Step-by-step](https://www.youtube.com/watch?v=mQ6_BOucWJg) (LambdaConf 2020 Global Edition, online, June 23, 2020)
* [slides](https://speakerdeck.com/jakubjanecek/scala-server-toolkit-how-to-write-fp-microservice-step-by-step)

## Design

There are certain design decisions and constraints that are put in place to guide the development of the toolkit and recommended for
the development of your server applications.

* Keep the number of dependencies as low as possible.
* Modular design: small, cohesive, orthogonal and composable components.
* Functional programming.
* Type safe configuration and resource lifecycle.
* No need for dependency injection.
* [Scalazzi Safe Scala Subset](https://slides.yowconference.com/yowwest2014/Morris-ParametricityTypesDocumentationCodeReadability.pdf)

## Issues

Please report issues to [GitHub](https://github.com/avast/scala-server-toolkit/issues). Pull requests are always welcome.

## Versioning

The project follows the [semantic versioning](https://semver.org) schema which means that just by looking at the version you will know
whether to expect compatibility problems or not.

The project values backwards compatibility but it cannot prevent innovation. There will be breaking changes but they will always be properly
versioned and documented.

## Contributing

See [CONTRIBUTING.md](CONTRIBUTING.md).

## Code of Conduct

See [CODE_OF_CONDUCT.md](CODE_OF_CONDUCT.md).

## License

Scala Server Toolkit is licensed under [MIT License](LICENSE).