Skip to content
This repository was archived by the owner on Aug 18, 2020. It is now read-only.

Commit 3924225

Browse files
committed
Merge branch 'develop' into feature/129-streamelements-connector
2 parents d5c2816 + f1d9d36 commit 3924225

12 files changed

+132
-7
lines changed

build.sbt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -125,7 +125,7 @@ import org.codeoverflow.chatoverflow.build.GUIUtility
125125
import org.codeoverflow.chatoverflow.build.deployment.DeploymentUtility
126126
import org.codeoverflow.chatoverflow.build.plugins.{PluginUtility, PluginCreateWizard}
127127

128-
create := new PluginCreateWizard(streams.value.log).createPluginTask(pluginFolderNames.value)
128+
create := new PluginCreateWizard(streams.value.log).createPluginTask(pluginFolderNames.value, PluginCreateWizard.getApiVersion.value)
129129
fetch := new PluginUtility(streams.value.log).fetchPluginsTask(pluginFolderNames.value, pluginBuildFileName.value,
130130
pluginTargetFolderNames.value, apiProjectPath.value)
131131
copy := new PluginUtility(streams.value.log).copyPluginsTask(pluginFolderNames.value, pluginTargetFolderNames.value, scalaMajorVersion)

build/src/main/scala/org/codeoverflow/chatoverflow/build/plugins/PluginCreateWizard.scala

Lines changed: 38 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -5,9 +5,12 @@ import java.io.File
55
import org.codeoverflow.chatoverflow.build.BuildUtils
66
import org.codeoverflow.chatoverflow.build.BuildUtils.withTaskInfo
77
import org.codeoverflow.chatoverflow.build.plugins.PluginCreateWizard.askForInput
8+
import sbt.Keys._
89
import sbt.internal.util.ManagedLogger
10+
import sbt.{Def, Task}
911

1012
import scala.annotation.tailrec
13+
import scala.util.Try
1114

1215
class PluginCreateWizard(logger: ManagedLogger) {
1316

@@ -16,7 +19,7 @@ class PluginCreateWizard(logger: ManagedLogger) {
1619
*
1720
* @param pluginFolderNames All folder names, containing plugin source code. Defined in build.sbt.
1821
*/
19-
def createPluginTask(pluginFolderNames: List[String]): Unit = {
22+
def createPluginTask(pluginFolderNames: List[String], apiVersion: Option[(Int, Int)]): Unit = {
2023
withTaskInfo("CREATE PLUGIN", logger) {
2124

2225
// Plugin folders have to be defined in the build.sbt file first
@@ -66,12 +69,18 @@ class PluginCreateWizard(logger: ManagedLogger) {
6669

6770
// In case we couldn't figure out the api version, maybe because the api project didn't exist, we ask the user for it.
6871
val api = {
69-
val validate = (s: String) => s.nonEmpty && s.forall(_.isDigit) // not empty and must be a valid number
70-
val major = askForInput("Please specify the current major version of the api. Check api/build.sbt for it.",
72+
// not empty and must be a valid number, can be skipped if a default is available
73+
val validate = (s: String) => s.nonEmpty && s.forall(_.isDigit) || apiVersion.isDefined
74+
val major = askForInput("Please specify the major version of the api. " +
75+
(if (apiVersion.isEmpty) "Check api/build.sbt for it."
76+
else s"Default is the current version (${apiVersion.get._1})."),
7177
"Major api version", validate, "Api version must be a number")
72-
val minor = askForInput("Please specify the current minor version of the api. Check api/build.sbt for it.",
78+
val minor = askForInput(s"Please specify the minor version of the api. " +
79+
(if (apiVersion.isEmpty) "Check api/build.sbt for it."
80+
else s"Default is the current version (${apiVersion.get._2})."),
7381
"Minor api version", validate, "Api version must be a number")
74-
(major.toInt, minor.toInt)
82+
83+
(if (major.isEmpty) apiVersion.get._1 else major.toInt, if (minor.isEmpty) apiVersion.get._2 else minor.toInt)
7584
}
7685

7786
// Plugin metadata
@@ -155,4 +164,28 @@ object PluginCreateWizard {
155164
if (input.isEmpty) default
156165
else input
157166
}
167+
168+
/**
169+
* Gets the version of the api, if loaded by sbt.
170+
*
171+
* @return a tuple with major and minor version
172+
*/
173+
def getApiVersion: Def.Initialize[Task[Option[(Int, Int)]]] = Def.task {
174+
val apiVersion: Option[String] = Def.taskDyn {
175+
val apiProject = buildStructure.value.allProjectRefs.find(_.project == "apiProject")
176+
if (apiProject.isDefined)
177+
Def.task[Option[String]] {
178+
Some((apiProject.get / version).value)
179+
}
180+
else
181+
Def.task[Option[String]] {
182+
None // Api hasn't been loaded, probably not fetched
183+
}
184+
}.value
185+
186+
apiVersion.flatMap(ver => Try {
187+
val parts = ver.split("[.-]") // Also split at '-' to get rid of suffixes like -SNAPSHOT
188+
(parts.head.toInt, parts(1).toInt)
189+
}.toOption)
190+
}
158191
}

deployment-files/plugin-dev/build.sbt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -45,7 +45,7 @@ apiProjectPath := "api"
4545

4646
import org.codeoverflow.chatoverflow.build.plugins.{PluginCreateWizard, PluginUtility}
4747

48-
create := new PluginCreateWizard(streams.value.log).createPluginTask(pluginFolderNames.value)
48+
create := new PluginCreateWizard(streams.value.log).createPluginTask(pluginFolderNames.value, PluginCreateWizard.getApiVersion.value)
4949
fetch := new PluginUtility(streams.value.log).fetchPluginsTask(pluginFolderNames.value, pluginBuildFileName.value,
5050
pluginTargetFolderNames.value, apiProjectPath.value)
5151
copy := new PluginUtility(streams.value.log).copyPluginsTask(pluginFolderNames.value, pluginTargetFolderNames.value, scalaMajorVersion)
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>Discord</display>
3+
<description>The discord service allows you to connect to a discord text channel to get a list of recent messages, react on new, edited or deleted messages as well as reactions. You can also send messages, files or even fancy embeds.</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/Discord</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>File</display>
3+
<description>The file service allows you to perform file operations in the data folder. These operations include reading and writing to the data folder and creating sub-folders.</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/File</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>Sample</display>
3+
<description>The Sample service is just an expample on how a connector should look like.</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/Sample</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>Serial</display>
3+
<description>The Serial service allows you to communicate with a device that is connected to your PC over a serial port. The most common example is exchanging data with an arduino over USB.</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/Serial</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>Tipeeestream</display>
3+
<description>By using the TipeeeStream service you can react on donations, subscriptions and follows in your stream. Just listen to the events provided by the TipeeeStream event input.</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/Tipeeestream</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
<connector>
2+
<display>Twitch Chat</display>
3+
<description>The Twitch chat service allows plugins to connect to a channels chat by using IRC. They can get a List of recent messages, listen for new messages or send messages to the chat</description>
4+
<wiki>https://github.com/codeoverflow-org/chatoverflow/wiki/Twitch-Chat</wiki>
5+
<icon48>
6+

7+
</icon48>
8+
</connector>

src/main/scala/org/codeoverflow/chatoverflow/ui/web/rest/DTOs.scala

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,8 @@ object DTOs {
2121

2222
case class Types(pluginTypes: Seq[PluginType], requirementTypes: RequirementTypes, connectorTypes: Seq[String])
2323

24+
case class ConnectorMetadata(found: Boolean, displayName: String, description: String, wikiUrl: String, icon: String)
25+
2426
case class RequirementTypes(input: Seq[String], output: Seq[String], parameter: Seq[String])
2527

2628
case class APIAndSpecificType(interface: String, implementation: String, connector: String, found: Boolean)

0 commit comments

Comments
 (0)