commit 22/01/2026
This commit is contained in:
129
src/Web/WebUI.kt
129
src/Web/WebUI.kt
@@ -1,12 +1,11 @@
|
||||
package Web
|
||||
|
||||
import Log.LogGetter
|
||||
import config
|
||||
import io.javalin.Javalin
|
||||
import io.javalin.apibuilder.ApiBuilder.before
|
||||
import io.javalin.apibuilder.ApiBuilder.get
|
||||
import io.javalin.apibuilder.ApiBuilder.path
|
||||
import io.javalin.apibuilder.ApiBuilder.post
|
||||
import io.javalin.apibuilder.ApiBuilder.ws
|
||||
import org.tinylog.Logger
|
||||
|
||||
@Suppress("unused")
|
||||
@@ -14,41 +13,57 @@ import org.tinylog.Logger
|
||||
* Start WebUI Server
|
||||
*/
|
||||
class WebUI{
|
||||
// regex untuk date dengan format YYYY-MM-DD
|
||||
private val dateRegex1 = """\d{4}-\d{2}-\d{2}""".toRegex()
|
||||
|
||||
private var app : Javalin = Javalin.create { cfg ->
|
||||
cfg.staticFiles.add("/")
|
||||
cfg.router.apiBuilder {
|
||||
path("/"){
|
||||
get {
|
||||
if (config.WebUsername==it.cookie("username")){
|
||||
Logger.info{"${it.ip()} logged in as ${it.cookie("username")}, forward to home.html"}
|
||||
it.redirect("home.html")
|
||||
} else{
|
||||
Logger.info{"${it.ip()} have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
}
|
||||
}
|
||||
}
|
||||
path("login.html"){
|
||||
post{
|
||||
val username = it.formParam("username")
|
||||
val password = it.formParam("password")
|
||||
if (config.WebUsername==username && config.WebPassword==password) {
|
||||
Logger.info { "${it.ip()} login successful for user $username" }
|
||||
it.cookie("username", username)
|
||||
it.redirect("home.html")
|
||||
} else {
|
||||
Logger.info { "${it.ip()} Login failed for user $username" }
|
||||
it.redirect("/login.html?error=1")
|
||||
}
|
||||
}
|
||||
}
|
||||
path("logout"){
|
||||
get {
|
||||
Logger.info{"${it.ip()} User ${it.cookie("username")} logged out"}
|
||||
it.removeCookie("username")
|
||||
get("/"){
|
||||
if (config.WebUsername==it.cookie("username")){
|
||||
Logger.info{"${it.ip()} logged in as ${it.cookie("username")}, forward to home.html"}
|
||||
it.redirect("home.html")
|
||||
} else{
|
||||
Logger.info{"${it.ip()} have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
}
|
||||
}
|
||||
post("login.html"){
|
||||
val username = it.formParam("username")
|
||||
val password = it.formParam("password")
|
||||
if (config.WebUsername==username && config.WebPassword==password) {
|
||||
Logger.info { "${it.ip()} login successful for user $username" }
|
||||
it.cookie("username", username)
|
||||
it.redirect("home.html")
|
||||
} else {
|
||||
Logger.info { "${it.ip()} Login failed for user $username" }
|
||||
it.redirect("/login.html?error=1")
|
||||
}
|
||||
}
|
||||
|
||||
get("getLogs"){
|
||||
var date = it.queryParam("date")
|
||||
Logger.info{"${it.ip()} User ${it.cookie("username")} requested logs for date: $date"}
|
||||
if (date!=null){
|
||||
if (date.isNotEmpty()){
|
||||
if (dateRegex1.matches(date)){
|
||||
// ketemu format YYYY-MM-DD, convert format ke dd/MM/yyyy
|
||||
val parts = date.split("-")
|
||||
date = "${parts[2]}/${parts[1]}/${parts[0]}"
|
||||
}
|
||||
val logs = LogGetter().getLog(date)
|
||||
if (logs.isNotEmpty()){
|
||||
it.json(logs)
|
||||
} else it.status(404).json(webReply("No logs found for the specified date"))
|
||||
} else it.status(400).json(webReply("Date parameter is empty"))
|
||||
} else it.status(400).json(webReply("Please provide a date"))
|
||||
}
|
||||
|
||||
get("logout"){
|
||||
Logger.info{"${it.ip()} User ${it.cookie("username")} logged out"}
|
||||
it.removeCookie("username")
|
||||
it.redirect("login.html")
|
||||
}
|
||||
|
||||
get("getSetting"){
|
||||
val fd = farmData(config.ActiveMQ_BrokerURL, config.ActiveMQ_Username, config.ActiveMQ_Password, config.ActiveMQ_QueueName)
|
||||
@@ -97,48 +112,26 @@ class WebUI{
|
||||
}
|
||||
}
|
||||
|
||||
path("home.html"){
|
||||
before{
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info {"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
before("home.html"){
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info {"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
|
||||
|
||||
|
||||
ws("/ws"){ ws ->
|
||||
ws.onConnect { wsconnectcontext -> Logger.info { "WebSocket connected: ${wsconnectcontext.sessionId()}"; wsconnectcontext.enableAutomaticPings() } }
|
||||
ws.onClose { wsclosecontext -> Logger.info { "WebSocket closed: ${wsclosecontext.sessionId()}" } }
|
||||
ws.onError { wserrorcontext -> Logger.error { "WebSocket error in session ${wserrorcontext.sessionId()}: ${wserrorcontext.error()?.message}" } }
|
||||
ws.onMessage { wsMessageContext ->
|
||||
// TODO handle incoming messages
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
path("log.html"){
|
||||
before{
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info{"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
before("log.html"){
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info{"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
path("setting.html"){
|
||||
before{
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info{"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
before("setting.html"){
|
||||
if (config.WebUsername!=it.cookie("username")){
|
||||
Logger.info{"${it.ip()} Have not logged in, forward to login.html"}
|
||||
it.redirect("login.html")
|
||||
return@before
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user