Newer
Older
gitbucket_jkp / build.sbt
@Naoki Takezoe Naoki Takezoe on 30 Apr 2016 7 KB Ready for 4.0 release
  1. val Organization = "gitbucket"
  2. val Name = "gitbucket"
  3. val GitBucketVersion = "4.0.0"
  4. val ScalatraVersion = "2.4.0"
  5. val JettyVersion = "9.3.6.v20151106"
  6.  
  7. lazy val root = (project in file(".")).enablePlugins(SbtTwirl, JettyPlugin)
  8.  
  9. sourcesInBase := false
  10. organization := Organization
  11. name := Name
  12. version := GitBucketVersion
  13. scalaVersion := "2.11.8"
  14.  
  15. // dependency settings
  16. resolvers ++= Seq(
  17. Classpaths.typesafeReleases,
  18. "amateras" at "http://amateras.sourceforge.jp/mvn/",
  19. "sonatype-snapshot" at "https://oss.sonatype.org/content/repositories/snapshots/",
  20. "amateras-snapshot" at "http://amateras.sourceforge.jp/mvn-snapshot/"
  21. )
  22. libraryDependencies ++= Seq(
  23. "org.scala-lang.modules" %% "scala-java8-compat" % "0.7.0",
  24. "org.eclipse.jgit" % "org.eclipse.jgit.http.server" % "4.1.1.201511131810-r",
  25. "org.eclipse.jgit" % "org.eclipse.jgit.archive" % "4.1.1.201511131810-r",
  26. "org.scalatra" %% "scalatra" % ScalatraVersion,
  27. "org.scalatra" %% "scalatra-json" % ScalatraVersion,
  28. "org.json4s" %% "json4s-jackson" % "3.3.0",
  29. "io.github.gitbucket" %% "scalatra-forms" % "1.0.0",
  30. "commons-io" % "commons-io" % "2.4",
  31. "io.github.gitbucket" % "solidbase" % "1.0.0",
  32. "io.github.gitbucket" % "markedj" % "1.0.8",
  33. "org.apache.commons" % "commons-compress" % "1.10",
  34. "org.apache.commons" % "commons-email" % "1.4",
  35. "org.apache.httpcomponents" % "httpclient" % "4.5.1",
  36. "org.apache.sshd" % "apache-sshd" % "1.0.0",
  37. "org.apache.tika" % "tika-core" % "1.11",
  38. "com.typesafe.slick" %% "slick" % "2.1.0",
  39. "com.novell.ldap" % "jldap" % "2009-10-07",
  40. "com.h2database" % "h2" % "1.4.190",
  41. "mysql" % "mysql-connector-java" % "5.1.38",
  42. "org.postgresql" % "postgresql" % "9.4.1208",
  43. "ch.qos.logback" % "logback-classic" % "1.1.1",
  44. "com.zaxxer" % "HikariCP" % "2.4.5",
  45. "com.typesafe" % "config" % "1.3.0",
  46. "com.typesafe.akka" %% "akka-actor" % "2.3.14",
  47. "fr.brouillard.oss.security.xhub" % "xhub4j-core" % "1.0.0",
  48. "com.enragedginger" %% "akka-quartz-scheduler" % "1.4.0-akka-2.3.x" exclude("c3p0","c3p0"),
  49. "org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "provided",
  50. "javax.servlet" % "javax.servlet-api" % "3.1.0" % "provided",
  51. "junit" % "junit" % "4.12" % "test",
  52. "org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
  53. "org.scalaz" %% "scalaz-core" % "7.2.0" % "test"
  54. )
  55.  
  56. // Twirl settings
  57. play.twirl.sbt.Import.TwirlKeys.templateImports += "gitbucket.core._"
  58.  
  59. // Compiler settings
  60. scalacOptions := Seq("-deprecation", "-language:postfixOps", "-Ybackend:GenBCode", "-Ydelambdafy:method", "-target:jvm-1.8")
  61. javacOptions in compile ++= Seq("-target", "8", "-source", "8")
  62. javaOptions in Jetty += "-Dlogback.configurationFile=/logback-dev.xml"
  63. testOptions in Test += Tests.Argument(TestFrameworks.Specs2, "junitxml", "console")
  64. javaOptions in Test += "-Dgitbucket.home=target/gitbucket_home_for_test"
  65. testOptions in Test += Tests.Setup( () => new java.io.File("target/gitbucket_home_for_test").mkdir() )
  66. fork in Test := true
  67. packageOptions += Package.MainClass("JettyLauncher")
  68.  
  69. // Assembly settings
  70. test in assembly := {}
  71. assemblyMergeStrategy in assembly := {
  72. case PathList("META-INF", xs @ _*) =>
  73. (xs map {_.toLowerCase}) match {
  74. case ("manifest.mf" :: Nil) => MergeStrategy.discard
  75. case _ => MergeStrategy.discard
  76. }
  77. case x => MergeStrategy.first
  78. }
  79.  
  80. // JRebel
  81. jrebel.webLinks += (target in webappPrepare).value
  82. jrebel.enabled := System.getenv().get("JREBEL") != null
  83. javaOptions in Jetty ++= Option(System.getenv().get("JREBEL")).toSeq.flatMap { path =>
  84. Seq("-noverify", "-XX:+UseConcMarkSweepGC", "-XX:+CMSClassUnloadingEnabled", s"-javaagent:${path}")
  85. }
  86. jrebelSettings
  87.  
  88. // Create executable war file
  89. val executableConfig = config("executable").hide
  90. Keys.ivyConfigurations += executableConfig
  91. libraryDependencies ++= Seq(
  92. "org.eclipse.jetty" % "jetty-security" % JettyVersion % "executable",
  93. "org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "executable",
  94. "org.eclipse.jetty" % "jetty-continuation" % JettyVersion % "executable",
  95. "org.eclipse.jetty" % "jetty-server" % JettyVersion % "executable",
  96. "org.eclipse.jetty" % "jetty-xml" % JettyVersion % "executable",
  97. "org.eclipse.jetty" % "jetty-http" % JettyVersion % "executable",
  98. "org.eclipse.jetty" % "jetty-servlet" % JettyVersion % "executable",
  99. "org.eclipse.jetty" % "jetty-io" % JettyVersion % "executable",
  100. "org.eclipse.jetty" % "jetty-util" % JettyVersion % "executable"
  101. )
  102.  
  103. val executableKey = TaskKey[File]("executable")
  104. executableKey := {
  105. import org.apache.ivy.util.ChecksumHelper
  106. import java.util.jar.{ Manifest => JarManifest }
  107. import java.util.jar.Attributes.{ Name => AttrName }
  108.  
  109. val workDir = Keys.target.value / "executable"
  110. val warName = Keys.name.value + ".war"
  111.  
  112. val log = streams.value.log
  113. log info s"building executable webapp in ${workDir}"
  114.  
  115. // initialize temp directory
  116. val temp = workDir / "webapp"
  117. IO delete temp
  118.  
  119. // include jetty classes
  120. val jettyJars = Keys.update.value select configurationFilter(name = executableConfig.name)
  121. jettyJars foreach { jar =>
  122. IO unzip (jar, temp, (name:String) =>
  123. (name startsWith "javax/") ||
  124. (name startsWith "org/")
  125. )
  126. }
  127.  
  128. // include original war file
  129. val warFile = (Keys.`package`).value
  130. IO unzip (warFile, temp)
  131.  
  132. // include launcher classes
  133. val classDir = (Keys.classDirectory in Compile).value
  134. val launchClasses = Seq("JettyLauncher.class" /*, "HttpsSupportConnector.class" */)
  135. launchClasses foreach { name =>
  136. IO copyFile (classDir / name, temp / name)
  137. }
  138.  
  139. // zip it up
  140. IO delete (temp / "META-INF" / "MANIFEST.MF")
  141. val contentMappings = (temp.*** --- PathFinder(temp)).get pair relativeTo(temp)
  142. val manifest = new JarManifest
  143. manifest.getMainAttributes put (AttrName.MANIFEST_VERSION, "1.0")
  144. manifest.getMainAttributes put (AttrName.MAIN_CLASS, "JettyLauncher")
  145. val outputFile = workDir / warName
  146. IO jar (contentMappings, outputFile, manifest)
  147.  
  148. // generate checksums
  149. Seq(
  150. "md5" -> "MD5",
  151. "sha1" -> "SHA-1",
  152. "sha256" -> "SHA-256"
  153. )
  154. .foreach { case (extension, algorithm) =>
  155. val checksumFile = workDir / (warName + "." + extension)
  156. Checksums generate (outputFile, checksumFile, algorithm)
  157. }
  158.  
  159. // done
  160. log info s"built executable webapp ${outputFile}"
  161. outputFile
  162. }
  163. /*
  164. Keys.artifact in (Compile, executableKey) ~= {
  165. _ copy (`type` = "war", extension = "war"))
  166. }
  167. addArtifact(Keys.artifact in (Compile, executableKey), executableKey)
  168. */