Application profiles


Running lein new luminus myapp will create an application using the default profile template. However, if you would like to attach further functionality to your template you can append profile hints for the extended functionality.

Currently, the following profiles are supported

  • +cljs - adds ClojureScript support to the project along with an example
  • +cucumber - a profile for cucumber with clj-webdriver
  • +h2 - adds models.db namespace and H2 db dependencies
  • +postgres - adds models.db namespace and add PostreSQL dependencies
  • +mysql - adds models.db namespace and add MySQL dependencies
  • +mongodb - adds models.db namespace and MongoDB dependencies
  • +site - creates an application with registration and authentication setup, uses bootstrap and h2 when database is not specified
  • +dailycred - it adds support for dailycred, when used together with +site it configures the application to authenticate with dailycred
  • +http-kit - adds HTTP Kit support to the project

To add a profile simply pass it as an argument after your application name, eg:

lein new luminus myapp +cljs

You can also mix multiple profiles when creating the application, eg:

lein new luminus myapp +site +postgres

In case two profiles generate the same files, the latest one will overwrite the files from the preceding profiles.

HTTP Kit notes

HTTP Kit is an embedded server that can be used as a drop in replacement for Jetty. Unlike Jetty, HTTP Kit is not supported via lein-ring. This means that you need to run it using:

lein run

To allow hot code reloading you need to pass the -dev option to the server. You can also pass it a number to specify a custom port. By default the server runs on port 8080.

Build a runnable HTTP Kit jar for production use:

lein uberjar