Compare commits

...

2 commits

Author SHA1 Message Date
eb0b95ff86 Merge remote-tracking branch 'origin/main' 2024-12-28 09:09:46 -07:00
94e0d5da92 as a test 2024-12-28 09:09:39 -07:00
3 changed files with 124 additions and 122 deletions

View file

@ -3,4 +3,7 @@
<component name="KtLint plugin">
<ktlintMode>DISTRACT_FREE</ktlintMode>
</component>
<component name="com.nbadal.ktlint.KtlintProjectSettings">
<ktlintMode>DISTRACT_FREE</ktlintMode>
</component>
</project>

View file

@ -16,7 +16,6 @@ import io.ktor.server.plugins.ratelimit.*
import kotlinx.coroutines.runBlocking
import observer.nelle.nelleObserverBackend.helpers.checkCreate
import observer.nelle.nelleObserverBackend.plugins.configureRouting
import kotlin.time.Duration.Companion.minutes
val logger = KotlinLogging.logger("nelle.observer API")

View file

@ -19,7 +19,7 @@ import kotlin.time.Duration.Companion.minutes
var meowTimedOut = true
var beepTimedOut = true
var kaomojiTimedOut = true
var kaomojiTimedOut = false
// function to facilitate the timeout for meows
fun meowTimer() {
@ -67,136 +67,136 @@ fun kaomojiTimer() {
// this is where the fun REST comes in!
fun Application.configureRouting(client: HttpClient) {
routing {
// route all paths of */api
route("/api") {
// meow
route("/meow") {
// get meow timeout
get {
// route all paths of */api
route("/api") {
// meow
route("/meow") {
// get meow timeout
get {
if (meowTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out for some time" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// meow button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getMeow(), instanceDomain)
call.respondText("meowed with bypass")
logger.info { "meowed with bypass" }
} else {
if (meowTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out for some time" }
call.respondText("still sleeping... timed out for some time")
logger.info { "failed meow" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// meow button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getMeow(), instanceDomain)
call.respondText("meowed with bypass")
logger.info { "meowed with bypass" }
} else {
if (meowTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("still sleeping... timed out for some time")
logger.info { "failed meow" }
} else {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getMeow(), instanceDomain)
meowTimer()
call.respondText("meow' sent! timed out for some time")
logger.info { "meowed" }
}
meowTimer()
call.respondText("meow' sent! timed out for some time")
logger.info { "meowed" }
}
}
}
// beep
route("/beep") {
// get beep timeout
get {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// beep button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getBeep(), instanceDomain)
call.respondText("beeped with bypass")
logger.info { "beeped with bypass" }
} else {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("still sleeping...")
logger.info { "failed beeped" }
} else {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getBeep(), instanceDomain)
beepTimer()
call.respondText("beep sent!")
logger.info { "beeped" }
}
}
}
}
// kaomoji
route("/kaomoji") {
// get kamoji timeout
get {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// kaomoji button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getKaomoji(), instanceDomain)
call.respondText("beeped with bypass")
logger.info { "beeped with bypass" }
} else {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("still sleeping...")
logger.info { "failed beeped" }
} else {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getKaomoji(), instanceDomain)
kaomojiTimer()
call.respondText("beep sent!")
logger.info { "beeped" }
}
}
}
}
route("/ntfy") {
get {
}
post {
val formParameters = call.receiveParameters()
val title = formParameters["Title"].toString()
val message = formParameters["Message"].toString()
val attach = formParameters["Attach"].toString()
val click = formParameters["Click"].toString()
call.response.status(HttpStatusCode(201, "Received..."))
call.respondText("Received:: Title: $title, Message: $message, Attachment: $attach, Click: $click")
ntfyMsg(client, ntfyEndpoint, title, message, attach, click)
storeMessage(title, message, attach, click)
}
}
}
// beep
route("/beep") {
// get beep timeout
get {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// beep button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getBeep(), instanceDomain)
call.respondText("beeped with bypass")
logger.info { "beeped with bypass" }
} else {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("still sleeping...")
logger.info { "failed beeped" }
} else {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getBeep(), instanceDomain)
beepTimer()
call.respondText("beep sent!")
logger.info { "beeped" }
}
}
}
}
// kaomoji
route("/kaomoji") {
// get kamoji timeout
get {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("Timed Out")
logger.debug { "timed out" }
} else {
call.response.status(HttpStatusCode(100, "Not Timed Out"))
call.respondText("Not Timed Out")
logger.debug { "not timed out" }
}
}
// kaomoji button
post {
if (call.receiveText() == superSecret) {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getKaomoji(), instanceDomain)
call.respondText("beeped with bypass")
logger.info { "beeped with bypass" }
} else {
if (beepTimedOut) {
call.response.status(HttpStatusCode(423, "Timed Out"))
call.respondText("still sleeping...")
logger.info { "failed beeped" }
} else {
call.response.status(HttpStatusCode(201, "Meow Posted"))
makePost(client, getKaomoji(), instanceDomain)
kaomojiTimer()
call.respondText("beep sent!")
logger.info { "beeped" }
}
}
}
}
route("/ntfy") {
get {
}
post {
val formParameters = call.receiveParameters()
val title = formParameters["Title"].toString()
val message = formParameters["Message"].toString()
val attach = formParameters["Attach"].toString()
val click = formParameters["Click"].toString()
call.response.status(HttpStatusCode(201, "Received..."))
call.respondText("Received:: Title: $title, Message: $message, Attachment: $attach, Click: $click")
ntfyMsg(client, ntfyEndpoint, title, message, attach, click)
storeMessage(title, message, attach, click)
}
}
}
// deprecate
route("/meow") {
get {