forked from albuch/sbt-dependency-check
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.sbt
102 lines (86 loc) · 3.13 KB
/
build.sbt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import sbt.{Global, Project, _}
import sbtrelease.ReleasePlugin.autoImport.ReleaseTransformations._
import sbtrelease.ReleasePlugin.autoImport._
import sbtrelease.ReleaseStateTransformations.setNextVersion
organization := "net.vonbuchholtz"
name := "sbt-dependency-check"
val sbtDependencyCheck = (project in file("."))
.enablePlugins(SbtPlugin)
.settings(
libraryDependencies ++= Seq(
"com.google.code.gson" % "gson" % "2.9.0",
"org.owasp" % "dependency-check-core" % "7.1.0"
),
sbtPlugin := true,
dependencyUpdatesFilter -= moduleFilter(organization = "org.scala-lang") | moduleFilter(organization = "org.scala-sbt"),
dependencyUpdatesFailBuild := true,
crossSbtVersions := Vector("1.2.8"),
scriptedLaunchOpts ++= Seq("-Xmx1024M", "-Dplugin.version=" + version.value),
scriptedBufferLog := false
)
ThisBuild / dependencyCheckFailBuildOnCVSS := 11
ThisBuild / dependencyCheckSkipProvidedScope := true
ThisBuild / dependencyCheckFormat := "ALL"
ThisBuild / dependencyCheckSuppressionFiles := Seq(new File("dependency-check-suppressions.xml"))
ThisBuild / publishTo := sonatypePublishToBundle.value
ThisBuild / publishMavenStyle .withRank(KeyRanks.Invisible) := true
sonatypeProfileName := "net.vonbuchholtz"
// To sync with Maven central, you need to supply the following information:
Global / pomExtra := {
<url>https://github.com/albuch/sbt-dependency-check</url>
<licenses>
<license>
<name>Apache License Version 2.0</name>
<url>https://www.apache.org/licenses/LICENSE-2.0.txt</url>
</license>
</licenses>
<scm>
<connection>scm:git:github.com/albuch/sbt-dependency-check</connection>
<developerConnection>scm:git:[email protected]:albuch/sbt-dependency-check</developerConnection>
<url>https://github.com/albuch/sbt-dependency-check</url>
</scm>
<developers>
<developer>
<id>albuch</id>
<name>Alexander v. Buchholtz</name>
<url>https://github.com/albuch/</url>
</developer>
</developers>
}
releaseProcess := Seq[ReleaseStep](
checkSnapshotDependencies,
inquireVersions,
runClean,
releaseStepCommandAndRemaining("^ test"),
releaseStepCommandAndRemaining("^ scripted"),
setReleaseVersion,
commitReleaseVersion,
setReleaseVersionInReadme,
tagRelease,
releaseStepCommandAndRemaining("^ publishSigned"),
releaseStepCommandAndRemaining("sonatypeBundleRelease"),
setNextVersion,
commitNextVersion
//,pushChanges
)
lazy val setReleaseVersionInReadme: ReleaseStep = ReleaseStep(action = { st: State =>
val extracted = Project.extract(st)
val currentV = extracted.get(version)
st.log.info("Setting version to '%s' in README." format currentV)
val file: String = "README.md"
var readme: String = read(file)
readme = readme.replaceAll("(addSbtPlugin\\(\"net.vonbuchholtz\" % \"sbt-dependency-check\" % \")[^\"]+", "$1" + currentV)
write(file, readme)
st
})
def write(path: String, txt: String): Unit = {
import java.nio.charset.StandardCharsets
import java.nio.file.{Files, Paths}
Files.write(Paths.get(path), txt.getBytes(StandardCharsets.UTF_8))
}
def read(path: String): String = {
val source = scala.io.Source.fromFile(path, "UTF-8")
val content = source.mkString
source.close()
content
}