/spray-slick-swagger

A simple rest api which shows the integration of spray, slick 3 and swagger

Primary LanguageJavaScriptApache License 2.0Apache-2.0

SpraySlickSwagger

The Spray Slick Swagger is a very simple rest api in Spray showing one way of using spray with slick 3 library for database access, and spray-swagger for documentation the routes in spray.

It supports the following features:

  • Spray-json to parse json
  • Swagger to document routes and json
  • (Removed in v 0.0.2) Data access layer composed by data access Akka actors.
  • Models as case classes and slick models, independent from database driver and profile (Go slick3)
  • Multiple database types configured in properties file (h2 and postgresql for instance)
  • Cake pattern for DI
  • Routes Tested using specs2
  • Data Access Actor Tested using scalatest

Utils:

  • Typesafe config for property management
  • Typesafe Scala Logging (LazyLogging)

The project was thought to be used as an activator template.

#Running

The database pre-configured is an h2, so you just have to:

    $ sbt run

#Testing

To run all tests (routes and persistence tests):

    $ sbt test

#Credits

I believe that this combination is one of the greatest ways to make a scalable api. To make this template, I just mixed the tutorials and templates from spray and slick, so credits for spray and slick. And for the really great work from gettyimages in making the swagger magic possible in spray.