frees-io/freestyle
{ "createdAt": "2016-10-19T22:31:44Z", "defaultBranch": "master", "description": "A cohesive & pragmatic framework of FP centric Scala libraries", "fullName": "frees-io/freestyle", "homepage": "http://frees.io/", "language": "Scala", "name": "freestyle", "pushedAt": "2019-08-13T06:52:17Z", "stargazersCount": 614, "topics": [ "architectural-patterns", "cassandra", "free-monads", "freestyle", "functional-programming", "kafka", "monads", "redis", "rpc", "scala", "spark", "tagless-final" ], "updatedAt": "2025-09-17T20:31:22Z", "url": "https://github.com/frees-io/freestyle"}[comment] !: # (Start Badges)
[comment] !: # (End Badges)
Documentation
Section titled “Documentation”Full documentation available at http://frees.io
Build purely functional applications and libraries
Section titled “Build purely functional applications and libraries”Build stack-safe purely functional applications and libraries that support parallel and sequential computations where declaration is decoupled from interpretation. Freestyle encourages programs built atop Free algebras that are interpreted at the edge of your application ensuring effects are localized and performed in a controlled environment. Applications built with Freestyle can be interpreted to any runtime semantics supported by the interpreter target type.
import freestyle.free._
@free trait Database { def get(id: UserId): FS[User]}
@free trait Cache { def get(id: UserId): FS[User]}
@module trait Persistence { val database: Database val cache: Cache}Automatic Dependency Injection
Section titled “Automatic Dependency Injection”Freestyle includes all the implicit machinery necessary to achieve seamless dependency injection of @free and @module Algebras.
Simply require any of your @free or @module trait as implicits where needed.
def storedUsers[F[_]] (userId: UserId) (implicit persistence: Persistence[F]): FreeS[F, (User, User)] = { import persistence._ for { cachedUser <- cache.get(userId) persistentUser <- database.get(userId) } yield (cachedUser, persistentUser)}Ready to use integrations
Section titled “Ready to use integrations”Freestyle ships with ready to use algebras and convenient syntax extensions covering most of the application concerns such as persistence, configuration, logging, etc.
In addition Freestyle includes commonly used FP effects stack such as option, error, reader, writer, state based on the capabilities of
the target runtime interpreters.
def loadUser[F[_]] (userId: UserId) (implicit doobie: DoobieM[F], logging: LoggingM[F]): FreeS[F, User] = { import doobie.implicits._ for { user <- (sql"SELECT * FROM User WHERE userId = $userId" .query[User] .unique .liftFS[F]) _ <- logging.debug(s"Loaded User: ${user.userId}") } yield user}Modules
Section titled “Modules”-
freestyle - Core module including building blocks for boilerplate free FP programs and apps over Free monads and cats.
-
effects - MTL style effects such as reader, writer, state, error, and more modeled as free algebras.
-
logging - A purely functional logging algebra over Verizon’s Journal.
-
cache - A generic cache with in memory and redis based implementations.
Integrations
Section titled “Integrations”-
fetch - Integration with the Fetch library for efficient data access from heterogenous datasources.
-
fs2 - Integration to run fs2 Streams in Freestyle programs.
-
monix - Instances and utilities to interpret to
monix.eval.Task. -
slick - Embedding of DBIO actions in Freestyle programs.
-
doobie - Embedding of Doobie ConnectionIO actions in Freestyle programs.
-
http - Adapters and marshallers to run the Freestyle program in endpoint return types for akka-http, finch, http4s and play.
Freestyle Artifacts
Section titled “Freestyle Artifacts”Freestyle is compatible with both Scala JVM and Scala.js.
This project supports Scala 2.11 and 2.12. The project is based on scalameta.
To use the project, add the following to your build.sbt:
addCompilerPlugin("org.scalameta" % "paradise" % "3.0.0-M11" cross CrossVersion.full)[comment] !: # (Start Replace)
For Scala.jvm:
// requiredlibraryDependencies += "io.frees" %% "frees-core" % "0.8.2"
// optional - effects and patternslibraryDependencies += "io.frees" %% "frees-effects" % "0.8.2"libraryDependencies += "io.frees" %% "frees-async" % "0.8.2"libraryDependencies += "io.frees" %% "frees-async-cats-effect" % "0.8.2"libraryDependencies += "io.frees" %% "frees-async-guava" % "0.8.2"libraryDependencies += "io.frees" %% "frees-cache" % "0.8.2"libraryDependencies += "io.frees" %% "frees-config" % "0.8.2"libraryDependencies += "io.frees" %% "frees-logging" % "0.8.2"
// optional - integrationslibraryDependencies += "io.frees" %% "frees-cache-redis" % "0.8.2"libraryDependencies += "io.frees" %% "frees-doobie" % "0.8.2"libraryDependencies += "io.frees" %% "frees-fetch" % "0.8.2"libraryDependencies += "io.frees" %% "frees-akka" % "0.8.2"libraryDependencies += "io.frees" %% "frees-finch" % "0.8.2"libraryDependencies += "io.frees" %% "frees-http-client" % "0.8.2"libraryDependencies += "io.frees" %% "frees-http4s" % "0.8.2"libraryDependencies += "io.frees" %% "frees-monix" % "0.8.2"libraryDependencies += "io.frees" %% "frees-play" % "0.8.2"libraryDependencies += "io.frees" %% "frees-slick" % "0.8.2"libraryDependencies += "io.frees" %% "frees-twitter-util" % "0.8.2"For Scala.js:
// requiredlibraryDependencies += "io.frees" %%% "frees-core" % "0.8.2"
// optional - effects and patternslibraryDependencies += "io.frees" %%% "frees-effects" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-async" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-async-cats-effect" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-async-fs2" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-async-monix" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-cache" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-http-client" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-logging" % "0.8.2"
// optional - integrationslibraryDependencies += "io.frees" %%% "frees-fetch" % "0.8.2"libraryDependencies += "io.frees" %%% "frees-monix" % "0.8.2"[comment] !: # (End Replace)
Freestyle Examples
Section titled “Freestyle Examples”- [todolist-lib]!(./modules/examples/todolist-lib).
- [todolist-http-http4s]!(./modules/examples/todolist-http-http4s).
- [todolist-http-finch]!(./modules/examples/todolist-http-finch).
- [slick-example]!(.modules/examples/slick-example).
Commercial Support
Section titled “Commercial Support”47 Degrees offers commercial support for the Freestyle framework and associated technologies. To find out more, visit 47 Degrees’ Open Source Support.
[comment] !: # (Start Copyright)
Copyright
Section titled “Copyright”Freestyle is designed and developed by 47 Degrees
Copyright (C) 2017-2018 47 Degrees. http://47deg.com
[comment] !: # (End Copyright)
