Claptext, and dependency updates
This commit is contained in:
parent
9f041b8272
commit
5493849d78
6 changed files with 38 additions and 4 deletions
|
@ -14,17 +14,17 @@ import org.gradle.plugin.use.PluginDependencySpec
|
||||||
object Versions {
|
object Versions {
|
||||||
const val com_github_johnrengelman_shadow_gradle_plugin: String = "5.1.0"
|
const val com_github_johnrengelman_shadow_gradle_plugin: String = "5.1.0"
|
||||||
|
|
||||||
const val de_fayard_buildsrcversions_gradle_plugin: String = "0.6.1"
|
const val de_fayard_buildsrcversions_gradle_plugin: String = "0.6.3"
|
||||||
|
|
||||||
const val org_jetbrains_kotlin_jvm_gradle_plugin: String = "1.3.50"
|
const val org_jetbrains_kotlin_jvm_gradle_plugin: String = "1.3.50"
|
||||||
|
|
||||||
const val jackson_module_kotlin: String = "2.10.0.pr3"
|
const val jackson_module_kotlin: String = "2.10.0"
|
||||||
|
|
||||||
const val org_jetbrains_kotlin: String = "1.3.50"
|
const val org_jetbrains_kotlin: String = "1.3.50"
|
||||||
|
|
||||||
const val kotlin_openapi3_dsl: String = "0.20.2"
|
const val kotlin_openapi3_dsl: String = "0.20.2"
|
||||||
|
|
||||||
const val jackson_databind: String = "2.10.0.pr3"
|
const val jackson_databind: String = "2.10.0"
|
||||||
|
|
||||||
const val junit_jupiter: String = "5.5.2"
|
const val junit_jupiter: String = "5.5.2"
|
||||||
|
|
||||||
|
|
|
@ -1,2 +1 @@
|
||||||
rootProject.name = 'slackmemes'
|
rootProject.name = 'slackmemes'
|
||||||
|
|
||||||
|
|
|
@ -54,6 +54,14 @@ fun main() {
|
||||||
logger.info("Uppercase: Received request from ${ctx.req.requestURL}")
|
logger.info("Uppercase: Received request from ${ctx.req.requestURL}")
|
||||||
ctx.json(TextResponse(200, ctx.body().toUpperCase()))
|
ctx.json(TextResponse(200, ctx.body().toUpperCase()))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
post("/api/v1/claptext", documented(document().operation {
|
||||||
|
it.description = "Responds \uD83D\uDC4F with \uD83D\uDC4F the \uD83D\uDC4F claptext \uD83D\uDC4F version"
|
||||||
|
it.summary = "POST \uD83D\uDC4F for \uD83D\uDC4F claptext"
|
||||||
|
}.body<String>().json<TextResponse>("200")) {ctx ->
|
||||||
|
logger.info("Claptext: Received request from ${ctx.req.requestURL}")
|
||||||
|
ctx.json(TextResponse(200, ctx.body().toClapText()))
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -89,6 +97,7 @@ private fun String?.processToCommand(): Commands {
|
||||||
return when (this) {
|
return when (this) {
|
||||||
"/spongemock2" -> Commands.Spongebob
|
"/spongemock2" -> Commands.Spongebob
|
||||||
"/uppercase" -> Commands.Uppercase
|
"/uppercase" -> Commands.Uppercase
|
||||||
|
"/claptext" -> Commands.Claptext
|
||||||
else -> Commands.Error
|
else -> Commands.Error
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -103,6 +112,9 @@ private fun sendResponse(ctx: Context, respObj: RespObj) {
|
||||||
Commands.Uppercase -> {
|
Commands.Uppercase -> {
|
||||||
put("text", respObj.text.toUpperCase()); put("response_type", "in_channel")
|
put("text", respObj.text.toUpperCase()); put("response_type", "in_channel")
|
||||||
}
|
}
|
||||||
|
Commands.Claptext -> {
|
||||||
|
put("text", respObj.text.toClapText()); put("response_type", "in_channel")
|
||||||
|
}
|
||||||
Commands.Error -> {
|
Commands.Error -> {
|
||||||
put("text", respObj.text); put("response_type", "ephemeral")
|
put("text", respObj.text); put("response_type", "ephemeral")
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,4 +14,10 @@ fun String.toSpongemock(): String {
|
||||||
}.joinToString(" ")
|
}.joinToString(" ")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun String.toClapText(): String {
|
||||||
|
return this
|
||||||
|
.split(' ')
|
||||||
|
.joinToString(separator = " 👏 ")
|
||||||
|
}
|
||||||
|
|
||||||
private fun Int.isOdd(): Boolean = this.rem(2) == 0
|
private fun Int.isOdd(): Boolean = this.rem(2) == 0
|
|
@ -11,5 +11,6 @@ data class RespObj(
|
||||||
sealed class Commands {
|
sealed class Commands {
|
||||||
object Spongebob : Commands()
|
object Spongebob : Commands()
|
||||||
object Uppercase : Commands()
|
object Uppercase : Commands()
|
||||||
|
object Claptext : Commands()
|
||||||
object Error : Commands()
|
object Error : Commands()
|
||||||
}
|
}
|
|
@ -62,4 +62,20 @@ internal class TransformationsTest {
|
||||||
|
|
||||||
assertEquals(expected, actual.toSpongemock())
|
assertEquals(expected, actual.toSpongemock())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `Claptext works with multiple words`() {
|
||||||
|
val actual = "Find a dentist in Boston your a grown man"
|
||||||
|
val expected = "Find \uD83D\uDC4F a \uD83D\uDC4F dentist \uD83D\uDC4F in \uD83D\uDC4F Boston \uD83D\uDC4F your \uD83D\uDC4F a \uD83D\uDC4F grown \uD83D\uDC4F man"
|
||||||
|
|
||||||
|
assertEquals(expected, actual.toClapText())
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `Claptext works with one word`() {
|
||||||
|
val actual = "Find"
|
||||||
|
val expected = "Find"
|
||||||
|
|
||||||
|
assertEquals(expected, actual.toClapText())
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue