This is an SBT plugin that provides an interface to the JOOQ code generation tool (http://www.jooq.org). The plugin is compatible with SBT 0.11.3+ and Scala 2.9.1+.
The current version of the plugin is 1.6
-
Add jooq-sbt-plugin to your
project/plugins.sbt
:resolvers += "sean8223 Releases" at "https://github.com/sean8223/repository/raw/master/releases" addSbtPlugin("sean8223" %% "jooq-sbt-plugin" % CURRENT_PLUGIN_VERSION) // see above
-
In your
build.sbt
, do the following:-
Inject the plugin settings into your build definition:
seq(jooqSettings:_*)
This will also add the JOOQ libraries to your application's compile
libraryDependencies
. -
Add your database driver to your list of
libraryDependencies
with "jooq" scope:libraryDependencies += "mysql" % "mysql-connector-java" % "5.1.22" % "jooq"
-
Configure options for your environment:
jooqOptions := Seq("jdbc.driver" -> "com.mysql.jdbc.Driver", "jdbc.url" -> "jdbc:mysql://localhost:3306/fnord", "jdbc.user" -> "fnord", "jdbc.password" -> "fnord", "generator.database.name" -> "org.jooq.util.mysql.MySQLDatabase", "generator.database.inputSchema" -> "fnord", "generator.target.packageName" -> "com.myproject.jooq")
-
The plugin exposes several settings:
-
jooq-options (
jooqOptions
in build.sbt): aSeq[Tuple2[String, String]]
containing configuration properties for the JOOQ code generator. These will be transformed into paths into the XML configuration file; for example, the option"jdbc.driver" -> "com.mysql.jdbc.Driver"
will be merged into the<configuration>
document as:<configuration> <jdbc> <driver>com.mysql.jdbc.Driver</driver> </jdbc> </configuration>
Refer to http://www.jooq.org/doc/3.0/manual/code-generation/codegen-configuration/ for a complete description of JOOQ's configuration options.
-
jooq-config-file: an
Option[File]
that allows you to supply a specific JOOQ XML configuration file to the plugin. Set it like this:jooqConfigFile := Some(new java.io.File("/path/to/your/file")
This will override the
jooq-options
setting if present. This file now allows for users to pass templatable values using the Java Minimal Template Engine. Refer to https://code.google.com/p/jmte/ for a complete description of how to use JMTE. -
jooq-config-template-values: an
Option[()=>Map[String, AnyRef]]
that allows you to supply a specify a map of string keys and corresponding values to be sustituted into a specified jooqConfigFile. Set it like this:
jooqConfigTemplateValues := Some(() => {
val envFile = baseDirectory.value / ".env"
if (envFile.isFile){
IO.load(System.getProperties, envFile)
}
val conf = ConfigFactory.parseFile(new File("conf/development.conf")).resolve()
JavaConversions.mapAsScalaMap(conf.getObject("db.default").unwrapped()).toMap
})
-
jooq-output-directory (
jooqOutputDirectory
in build.sbt): aFile
indicating where JOOQ should deposit the source files it generates. By default, this is set to the value ofcompile:source-managed
+ "/java" (usually target/scala-version/src_managed/main/java), but it can be changed to suit your project layout as needed. -
jooq-version (
jooqVersion
in build.sbt): aString
indicating the version of JOOQ to use. The JOOQ libraries at this version will also be imported into your project's compile scope. The default value is 3.2.1, but the plugin is known to work with the 2.x series of JOOQ as well (e.g. 2.6.1). -
jooq-log-level (
jooqLogLevel
in build.sbt): aString
controlling the the verbosity of code generator's logging. It defaults to "info", which still produces a fair amount of output. Setting it to "error" will effectively silence it, except in the case of problems. Other values include "warn" and "debug".
And provides a single task:
- jooq:codegen: Runs the code generator.
The plugin also attaches to the compile:compile
task (by way of
compile-source-generators
) and will run prior to compile if doesn't see any
*.java
files in the directory indicated by jooq-output-directory
(e.g. if
you run clean
).
If you are using JOOQ in conjunction with other plugins (e.g. flyway-sbt-plugin)
and need to force the codegen task to run before other tasks (e.g. flyway:migrate
), you
can use SBT's <<=
operator to establish dependencies between them. For example:
(codegen in JOOQ) <<= (migrate in Flyway)
Add this to your build.sbt
file after you have imported and configured jooqSettings
.
It is possible to generate code for multiple databases, although it requires a more complicated project structure. You'll need to follow the guidelines for setting up a multi-project SBT build.
For example, consider the following project structure, that defines three modules: common code, and JOOQ code generated for two different database types (e.g. Oracle and MySQL):
myproject/
project/
plugins.sbt
MyProject.scala
myproject-jooq-oracle/
build.sbt
myproject-jooq-mysql/
build.sbt
myproject-common/
build.sbt
To accomplish this:
-
At the root of your project, create the standard
project
directory and place aplugins.sbt
(as described in Quick Start) and a Scala-based build definition (namedMyProject.scala
in this example). -
In
MyProject.scala
, define a root project that aggregates the three subprojects. For example:object MyProject extends Build { lazy val root = project.in(file(".")) aggregate(myProjectJooqOracle, myProjectJooqMySQL, myProjectCommon) lazy val myProjectJooqOracle = project in file ("jooq-oracle") lazy val myProjectJooqMySQL = project in file ("jooq-mysql") lazy val myProjectCommon = project.in(file("common")).dependsOn(myProjectJooqOracle, myProjectJooqMySQL) }
-
In the
build.sbt
in each of the JOOQ sub-modules, vary the properties as needed to generate code for that database type. Each sub-module will have its ownjooqOptions
that you can use to control how the code is generated. You will also specify the required database drivers in that module'slibraryDependencies
withjooq
scope as above.
Refer to the SBT documentation for more thorough examples of multi-project build files.
- 1.0: Initial release
- 1.1: Fixed error in which
jooqOutputDirectory
was incorrectly being set tosourceManaged
rather thansourceManaged in Compile
- 1.2: Added
unmanagedJars in Compile
to themanagedClasspath
used by the plugin to facilitate use of proprietary drivers that might not be accessible via Ivy/Maven repos. - 1.3: Changed default JOOQ version to 3.2.1 (previous default was 2.6.1)
- 1.4: Changed default JOOQ version to 3.3.1 (previous default was 3.2.1)
- 1.5: Added
jooqConfigFile
option to allow for handcrafted JOOQ configurations beyond what can be specified injooqOptions
- 1.6: Merged pull request #14 to support templatization of JOOQ config files -- thanks to triplec1988 for this enhancement!