Newer
Older
gitbucket_jkp / build.sbt
  1. val Organization = "io.github.gitbucket"
  2. val Name = "gitbucket"
  3. val GitBucketVersion = "4.14.0"
  4. val ScalatraVersion = "2.5.0"
  5. val JettyVersion = "9.3.19.v20170502"
  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.12.2"
  14.  
  15. // dependency settings
  16. resolvers ++= Seq(
  17. Classpaths.typesafeReleases,
  18. Resolver.jcenterRepo,
  19. "amateras" at "http://amateras.sourceforge.jp/mvn/",
  20. "sonatype-snapshot" at "https://oss.sonatype.org/content/repositories/snapshots/",
  21. "amateras-snapshot" at "http://amateras.sourceforge.jp/mvn-snapshot/"
  22. )
  23. libraryDependencies ++= Seq(
  24. "org.eclipse.jgit" % "org.eclipse.jgit.http.server" % "4.7.0.201704051617-r",
  25. "org.eclipse.jgit" % "org.eclipse.jgit.archive" % "4.7.0.201704051617-r",
  26. "org.scalatra" %% "scalatra" % ScalatraVersion,
  27. "org.scalatra" %% "scalatra-json" % ScalatraVersion,
  28. "org.json4s" %% "json4s-jackson" % "3.5.1",
  29. "io.github.gitbucket" %% "scalatra-forms" % "1.1.0",
  30. "commons-io" % "commons-io" % "2.5",
  31. "io.github.gitbucket" % "solidbase" % "1.0.2",
  32. "io.github.gitbucket" % "markedj" % "1.0.12",
  33. "org.apache.commons" % "commons-compress" % "1.13",
  34. "org.apache.commons" % "commons-email" % "1.4",
  35. "org.apache.httpcomponents" % "httpclient" % "4.5.3",
  36. "org.apache.sshd" % "apache-sshd" % "1.4.0" exclude("org.slf4j","slf4j-jdk14"),
  37. "org.apache.tika" % "tika-core" % "1.14",
  38. "com.github.takezoe" %% "blocking-slick-32" % "0.0.8",
  39. "joda-time" % "joda-time" % "2.9.9",
  40. "com.novell.ldap" % "jldap" % "2009-10-07",
  41. "com.h2database" % "h2" % "1.4.195",
  42. "org.mariadb.jdbc" % "mariadb-java-client" % "2.0.3",
  43. "org.postgresql" % "postgresql" % "42.0.0",
  44. "ch.qos.logback" % "logback-classic" % "1.2.3",
  45. "com.zaxxer" % "HikariCP" % "2.6.1",
  46. "com.typesafe" % "config" % "1.3.1",
  47. "com.typesafe.akka" %% "akka-actor" % "2.5.0",
  48. "fr.brouillard.oss.security.xhub" % "xhub4j-core" % "1.0.0",
  49. "com.github.bkromhout" % "java-diff-utils" % "2.1.1",
  50. "org.cache2k" % "cache2k-all" % "1.0.0.CR1",
  51. "com.enragedginger" %% "akka-quartz-scheduler" % "1.6.0-akka-2.4.x" exclude("c3p0","c3p0"),
  52. "net.coobird" % "thumbnailator" % "0.4.8",
  53. "org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "provided",
  54. "javax.servlet" % "javax.servlet-api" % "3.1.0" % "provided",
  55. "junit" % "junit" % "4.12" % "test",
  56. "org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
  57. "org.mockito" % "mockito-core" % "2.7.22" % "test",
  58. "com.wix" % "wix-embedded-mysql" % "2.1.4" % "test",
  59. "ru.yandex.qatools.embed" % "postgresql-embedded" % "2.0" % "test"
  60. )
  61.  
  62. // Compiler settings
  63. scalacOptions := Seq("-deprecation", "-language:postfixOps", "-opt:l:method")
  64. javacOptions in compile ++= Seq("-target", "8", "-source", "8")
  65. javaOptions in Jetty += "-Dlogback.configurationFile=/logback-dev.xml"
  66.  
  67. // Test settings
  68. //testOptions in Test += Tests.Argument("-l", "ExternalDBTest")
  69. javaOptions in Test += "-Dgitbucket.home=target/gitbucket_home_for_test"
  70. testOptions in Test += Tests.Setup( () => new java.io.File("target/gitbucket_home_for_test").mkdir() )
  71. fork in Test := true
  72.  
  73. // Packaging options
  74. packageOptions += Package.MainClass("JettyLauncher")
  75.  
  76. // Assembly settings
  77. test in assembly := {}
  78. assemblyMergeStrategy in assembly := {
  79. case PathList("META-INF", xs @ _*) =>
  80. (xs map {_.toLowerCase}) match {
  81. case ("manifest.mf" :: Nil) => MergeStrategy.discard
  82. case _ => MergeStrategy.discard
  83. }
  84. case x => MergeStrategy.first
  85. }
  86.  
  87. // JRebel
  88. Seq(jrebelSettings: _*)
  89.  
  90. jrebel.webLinks += (target in webappPrepare).value
  91. jrebel.enabled := System.getenv().get("JREBEL") != null
  92. javaOptions in Jetty ++= Option(System.getenv().get("JREBEL")).toSeq.flatMap { path =>
  93. Seq("-noverify", "-XX:+UseConcMarkSweepGC", "-XX:+CMSClassUnloadingEnabled", s"-javaagent:${path}")
  94. }
  95.  
  96. // Create executable war file
  97. val executableConfig = config("executable").hide
  98. Keys.ivyConfigurations += executableConfig
  99. libraryDependencies ++= Seq(
  100. "org.eclipse.jetty" % "jetty-security" % JettyVersion % "executable",
  101. "org.eclipse.jetty" % "jetty-webapp" % JettyVersion % "executable",
  102. "org.eclipse.jetty" % "jetty-continuation" % JettyVersion % "executable",
  103. "org.eclipse.jetty" % "jetty-server" % JettyVersion % "executable",
  104. "org.eclipse.jetty" % "jetty-xml" % JettyVersion % "executable",
  105. "org.eclipse.jetty" % "jetty-http" % JettyVersion % "executable",
  106. "org.eclipse.jetty" % "jetty-servlet" % JettyVersion % "executable",
  107. "org.eclipse.jetty" % "jetty-io" % JettyVersion % "executable",
  108. "org.eclipse.jetty" % "jetty-util" % JettyVersion % "executable"
  109. )
  110.  
  111. val executableKey = TaskKey[File]("executable")
  112. executableKey := {
  113. import java.util.jar.{ Manifest => JarManifest }
  114. import java.util.jar.Attributes.{ Name => AttrName }
  115.  
  116. val workDir = Keys.target.value / "executable"
  117. val warName = Keys.name.value + ".war"
  118.  
  119. val log = streams.value.log
  120. log info s"building executable webapp in ${workDir}"
  121.  
  122. // initialize temp directory
  123. val temp = workDir / "webapp"
  124. IO delete temp
  125.  
  126. // include jetty classes
  127. val jettyJars = Keys.update.value select configurationFilter(name = executableConfig.name)
  128. jettyJars foreach { jar =>
  129. IO unzip (jar, temp, (name:String) =>
  130. (name startsWith "javax/") ||
  131. (name startsWith "org/")
  132. )
  133. }
  134.  
  135. // include original war file
  136. val warFile = (Keys.`package`).value
  137. IO unzip (warFile, temp)
  138.  
  139. // include launcher classes
  140. val classDir = (Keys.classDirectory in Compile).value
  141. val launchClasses = Seq("JettyLauncher.class" /*, "HttpsSupportConnector.class" */)
  142. launchClasses foreach { name =>
  143. IO copyFile (classDir / name, temp / name)
  144. }
  145.  
  146. // zip it up
  147. IO delete (temp / "META-INF" / "MANIFEST.MF")
  148. val contentMappings = (temp.*** --- PathFinder(temp)).get pair relativeTo(temp)
  149. val manifest = new JarManifest
  150. manifest.getMainAttributes put (AttrName.MANIFEST_VERSION, "1.0")
  151. manifest.getMainAttributes put (AttrName.MAIN_CLASS, "JettyLauncher")
  152. val outputFile = workDir / warName
  153. IO jar (contentMappings, outputFile, manifest)
  154.  
  155. // generate checksums
  156. Seq(
  157. "md5" -> "MD5",
  158. "sha1" -> "SHA-1",
  159. "sha256" -> "SHA-256"
  160. )
  161. .foreach { case (extension, algorithm) =>
  162. val checksumFile = workDir / (warName + "." + extension)
  163. Checksums generate (outputFile, checksumFile, algorithm)
  164. }
  165.  
  166. // done
  167. log info s"built executable webapp ${outputFile}"
  168. outputFile
  169. }
  170. publishTo := {
  171. val nexus = "https://oss.sonatype.org/"
  172. if (version.value.trim.endsWith("SNAPSHOT")) Some("snapshots" at nexus + "content/repositories/snapshots")
  173. else Some("releases" at nexus + "service/local/staging/deploy/maven2")
  174. }
  175. publishMavenStyle := true
  176. pomIncludeRepository := { _ => false }
  177. pomExtra := (
  178. <url>https://github.com/gitbucket/gitbucket</url>
  179. <licenses>
  180. <license>
  181. <name>The Apache Software License, Version 2.0</name>
  182. <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
  183. </license>
  184. </licenses>
  185. <scm>
  186. <url>https://github.com/gitbucket/gitbucket</url>
  187. <connection>scm:git:https://github.com/gitbucket/gitbucket.git</connection>
  188. </scm>
  189. <developers>
  190. <developer>
  191. <id>takezoe</id>
  192. <name>Naoki Takezoe</name>
  193. <url>https://github.com/takezoe</url>
  194. </developer>
  195. <developer>
  196. <id>shimamoto</id>
  197. <name>Takako Shimamoto</name>
  198. <url>https://github.com/shimamoto</url>
  199. </developer>
  200. <developer>
  201. <id>tanacasino</id>
  202. <name>Tomofumi Tanaka</name>
  203. <url>https://github.com/tanacasino</url>
  204. </developer>
  205. <developer>
  206. <id>mrkm4ntr</id>
  207. <name>Shintaro Murakami</name>
  208. <url>https://github.com/mrkm4ntr</url>
  209. </developer>
  210. <developer>
  211. <id>nazoking</id>
  212. <name>nazoking</name>
  213. <url>https://github.com/nazoking</url>
  214. </developer>
  215. <developer>
  216. <id>McFoggy</id>
  217. <name>Matthieu Brouillard</name>
  218. <url>https://github.com/McFoggy</url>
  219. </developer>
  220. </developers>
  221. )