frees-io / freestyle

A cohesive & pragmatic framework of FP centric Scala libraries
http://frees.io/
Apache License 2.0
615 stars 50 forks source link
architectural-patterns cassandra free-monads freestyle functional-programming kafka monads redis rpc scala spark tagless-final

Build Status codecov.io Maven Central Latest version License Join the chat at https://gitter.im/47deg/freestyle GitHub Issues Scala.js

A Cohesive & Pragmatic Framework of FP centric Scala libraries

Documentation

Full documentation available at http://frees.io

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

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

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

Integrations

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)

For Scala.jvm:

// required
libraryDependencies += "io.frees" %% "frees-core"               % "0.8.2"

// optional - effects and patterns
libraryDependencies += "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 - integrations
libraryDependencies += "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:

// required
libraryDependencies += "io.frees" %%% "frees-core"              % "0.8.2"

// optional - effects and patterns
libraryDependencies += "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 - integrations
libraryDependencies += "io.frees" %%% "frees-fetch"             % "0.8.2"
libraryDependencies += "io.frees" %%% "frees-monix"             % "0.8.2"

Freestyle Examples

Commercial Support

47 Degrees offers commercial support for the Freestyle framework and associated technologies. To find out more, visit 47 Degrees' Open Source Support.

Copyright

Freestyle is designed and developed by 47 Degrees

Copyright (C) 2017-2018 47 Degrees. http://47deg.com