-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathbuild.sbt
121 lines (109 loc) · 4.93 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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import com.lightbend.cinnamon.sbt.Cinnamon.CinnamonKeys.cinnamon
import com.typesafe.sbt.MultiJvmPlugin.multiJvmSettings
lazy val akkaHttpVersion = "10.6.3"
lazy val akkaVersion = "2.9.5"
lazy val logbackVersion = "1.2.13"
lazy val akkaManagementVersion = "1.5.2"
lazy val akkaCassandraVersion = "1.2.1"
lazy val jacksonVersion = "3.6.6"
lazy val akkaDiagnosticsVersion = "2.1.1"
lazy val akkaR2DBCVersion = "1.2.5"
name := "akka-typed-distributed-state-blog"
ThisBuild / version := "1.2.0"
ThisBuild / organization := "com.lightbend"
ThisBuild / scalaVersion := "2.13.14"
ThisBuild / scalacOptions += "-deprecation"
ThisBuild / resolvers += "Akka library repository".at("https://repo.akka.io/maven")
// we're relying on the new credential file format for lightbend.sbt as described
// here -> https://www.lightbend.com/account/lightbend-platform/credentials, which
// requires a commercial Lightbend Subscription.
val credentialFile = file("./lightbend.sbt")
def doesCredentialExist : Boolean = {
import java.nio.file.Files
val exists = Files.exists(credentialFile.toPath)
println(s"doesCredentialExist: ($credentialFile) " + exists)
exists
}
def commercialDependencies : Seq[ModuleID] = {
import com.lightbend.cinnamon.sbt.Cinnamon.CinnamonKeys.cinnamon
Seq(
// BEGIN: this requires a commercial Lightbend Subscription
Cinnamon.library.cinnamonAkkaHttp,
Cinnamon.library.cinnamonAkka,
Cinnamon.library.cinnamonAkkaGrpc,
Cinnamon.library.cinnamonAkkaPersistence,
Cinnamon.library.cinnamonJvmMetricsProducer,
/* for Elastic Search Sandbox
Cinnamon.library.cinnamonCHMetrics3,
Cinnamon.library.cinnamonCHMetricsElasticsearchReporter,
*/
Cinnamon.library.cinnamonCHMetrics,
Cinnamon.library.cinnamonCHMetricsStatsDReporter,
Cinnamon.library.cinnamonSlf4jEvents,
Cinnamon.library.cinnamonPrometheus,
Cinnamon.library.cinnamonPrometheusHttpServer,
Cinnamon.library.jmxImporter,
)
}
def ossDependencies : Seq[ModuleID] = {
Seq(
"com.typesafe.akka" %% "akka-remote" % akkaVersion,
"com.typesafe.akka" %% "akka-actor-typed" % akkaVersion,
"com.typesafe.akka" %% "akka-http" % akkaHttpVersion,
// "com.typesafe.akka" %% "akka-http2-support" % akkaHttpVersion,
"com.typesafe.akka" %% "akka-http-spray-json" % akkaHttpVersion,
"com.typesafe.akka" %% "akka-http-xml" % akkaHttpVersion,
"com.typesafe.akka" %% "akka-stream" % akkaVersion,
"com.typesafe.akka" %% "akka-cluster-typed" % akkaVersion,
"com.typesafe.akka" %% "akka-cluster-sharding-typed" % akkaVersion,
"com.typesafe.akka" %% "akka-persistence-typed" % akkaVersion,
"com.typesafe.akka" %% "akka-persistence-cassandra" % akkaCassandraVersion,
"com.lightbend.akka" %% "akka-persistence-r2dbc" % akkaR2DBCVersion,
"com.typesafe.akka" %% "akka-multi-node-testkit" % akkaVersion,
"com.typesafe.akka" %% "akka-persistence-query" % akkaVersion,
"com.typesafe.akka" %% "akka-serialization-jackson" % akkaVersion,
"com.typesafe.akka" %% "akka-discovery" % akkaVersion,
"com.typesafe.akka" %% "akka-pki" % akkaVersion,
"com.lightbend.akka.discovery" %% "akka-discovery-kubernetes-api" % akkaManagementVersion,
"com.lightbend.akka.management" %% "akka-management-cluster-bootstrap" % akkaManagementVersion,
"com.lightbend.akka.management" %% "akka-management-cluster-http" % akkaManagementVersion,
//Logback
"com.typesafe.akka" %% "akka-slf4j" % akkaVersion,
"ch.qos.logback" % "logback-classic" % logbackVersion,
// testing
"com.typesafe.akka" %% "akka-http-testkit" % akkaHttpVersion % Test,
"com.typesafe.akka" %% "akka-testkit" % akkaVersion % Test,
"com.typesafe.akka" %% "akka-stream-testkit" % akkaVersion % Test,
"com.typesafe.akka" %% "akka-actor-testkit-typed" % akkaVersion % Test,
"commons-io" % "commons-io" % "2.4" % Test,
// "org.scalatest" %% "scalatest" % "3.0.8" % Test
"org.scalatest" %% "scalatest" % "3.2.19" % "test"
)
}
lazy val root = (project in file("."))
.enablePlugins(DockerPlugin)
.enablePlugins(JavaAppPackaging)
.enablePlugins(if (doesCredentialExist.booleanValue()) Cinnamon else Plugins.empty) // NOTE: Cinnamon requires a commercial Lightbend Subscription
.enablePlugins(MultiJvmPlugin).configs(MultiJvm)
.enablePlugins(AkkaGrpcPlugin)
.settings(multiJvmSettings: _*)
.settings(
Docker / packageName := "akka-typed-blog-distributed-state/cluster",
libraryDependencies ++= {
if (doesCredentialExist.booleanValue()) {
commercialDependencies ++ ossDependencies
}
else {
ossDependencies
}
},
Universal / javaOptions ++= Seq(
"-Dcom.sun.management.jmxremote.port=8090 -Dcom.sun.management.jmxremote.rmi.port=8090 -Djava.rmi.server.hostname=127.0.0.1 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false"
)
)
.settings(
dockerBaseImage := "openjdk:11-slim",
dockerExposedPorts ++= Seq(9200)
)
run / cinnamon := true
fork := true