This is the assignment for Homework 4.3 of the M101J MongoDB online course translated to Scala and Play Framework.
This project uses the official MongoDB Scala driver Casbah.
The integration of Casbah into Play is done by the MongoDB Salat Plugin for the Play Framework. We don't use the ORM features of this plugin, only the connection management.
You actually don't need to implement anything this week. The assignment is to optimize the blog's performance. You don't even need the blog running to pass the validation. Just follow the instructions from the official assignment page.
I only updated the blog application to bring the Scala/Play version up to par with the original Java/Spark version
This project uses the Cake Pattern to glue together the application - specifically the BlogController
to the DAOs.
You don't actually need to understand the whole application, although I encourage you to dig into it.
And if you look at the code, you will notice that this project does not properly separate the MVC layers. Passing MongoDB-specific objects created by the database driver (model) to templates (view) is not something you want to do in a real-world application. Fixing this design problem however, would require additional work and would introduce more differences from the original Java/Spark version.
This project is provided "as is". It has not been properly tested and there is no official support for it provided by anyone (especially not by 10gen). It is intended for M101J's students interested in Scala and it will most likely be harder to pass the course using this instead of the official Java + Spark version.
Last but not least: Do not publicly disclose solutions to the course's homeworks.