Base server on Javalin for easy future development
This commit is contained in:
parent
294b08297f
commit
24e50c26c4
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -3,7 +3,7 @@
|
||||||
server/build
|
server/build
|
||||||
server/.gradle
|
server/.gradle
|
||||||
server/userDatabase
|
server/userDatabase
|
||||||
server/messageHistory
|
server/chatHistory
|
||||||
client-cli/build
|
client-cli/build
|
||||||
client-cli/.gradle
|
client-cli/.gradle
|
||||||
client-cli/.chookpen.profile
|
client-cli/.chookpen.profile
|
||||||
|
|
|
@ -24,6 +24,8 @@ tasks.withType<Jar> {
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
testImplementation(kotlin("test"))
|
testImplementation(kotlin("test"))
|
||||||
|
implementation("io.javalin:javalin:6.3.0")
|
||||||
|
implementation("org.slf4j:slf4j-simple:2.0.16")
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.test {
|
tasks.test {
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package xyz.maxwellj.chookpen
|
package xyz.maxwellj.chookpen
|
||||||
|
|
||||||
|
import io.javalin.Javalin
|
||||||
|
|
||||||
import com.sun.net.httpserver.HttpExchange
|
import com.sun.net.httpserver.HttpExchange
|
||||||
import com.sun.net.httpserver.HttpHandler
|
import com.sun.net.httpserver.HttpHandler
|
||||||
import com.sun.net.httpserver.HttpServer
|
import com.sun.net.httpserver.HttpServer
|
||||||
|
@ -9,211 +11,298 @@ import java.io.File
|
||||||
import java.io.BufferedReader
|
import java.io.BufferedReader
|
||||||
|
|
||||||
fun main(args: Array<String>) {
|
fun main(args: Array<String>) {
|
||||||
// Crete a server and start listening for arguments
|
val app = Javalin.create()
|
||||||
val server = HttpServer.create(InetSocketAddress(8000), 0)
|
.get("/") { ctx -> ctx.result("dingus") }
|
||||||
server.createContext("/test", ServerTester())
|
.get("/api/send/{content}") { ctx -> ctx.result(handleSentMessage(ctx.pathParam("content")))}
|
||||||
server.createContext("/api", ApiHandler())
|
.get("/api/createaccount/{content}") { ctx -> ctx.result(createAccount(ctx.pathParam("content")))}
|
||||||
server.createContext("/api/createAccount", CreateAccount())
|
.get("/api/syncmessages/{content}") { ctx -> ctx.result(syncMessages(ctx.pathParam("content")))}
|
||||||
server.executor = null
|
.get("/api/authkey/{content}") { ctx -> ctx.result(authKey(ctx.pathParam("content")))}
|
||||||
server.start()
|
.start(7070)
|
||||||
println("Server has started on port 8000")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class ServerTester : HttpHandler {
|
fun handleSentMessage(inputData: String): String {
|
||||||
override fun handle(t: HttpExchange) {
|
println("API request recieved: $inputData")
|
||||||
val response = "Testing, testing, 1, 2, 3... Somehow this is going to make it to production one day"
|
// Parse data sent to the server by client
|
||||||
t.sendResponseHeaders(200, response.length.toLong())
|
var username = ""
|
||||||
val os = t.responseBody
|
var token = ""
|
||||||
os.write(response.toByteArray())
|
var message = ""
|
||||||
println("Test request recieved!")
|
var dataType = ""
|
||||||
os.close()
|
var isParsingData = 0
|
||||||
}
|
for (char in inputData) {
|
||||||
}
|
val character = char
|
||||||
|
if (character == ':') {
|
||||||
class ApiHandler : HttpHandler {
|
isParsingData = 1
|
||||||
override fun handle(t: HttpExchange) {
|
} else if (isParsingData == 1) {
|
||||||
println("Request recieved...")
|
if (character == '}') {
|
||||||
// Get the data
|
isParsingData = 0
|
||||||
val path = t.requestURI.path
|
dataType = ""
|
||||||
val inputData = path.substringAfter("/api/")
|
} else if (character != '{') {
|
||||||
println("API request recieved: $inputData")
|
if (dataType == "username") {
|
||||||
|
username += character
|
||||||
// Parse data sent to the server by client
|
} else if (dataType == "token") {
|
||||||
var username = ""
|
token += character
|
||||||
var token = ""
|
} else if (dataType == "message") {
|
||||||
var message = ""
|
message += character
|
||||||
var dataType = ""
|
|
||||||
var isParsingData = 0
|
|
||||||
for (char in inputData) {
|
|
||||||
val character = char
|
|
||||||
if (character == ':') {
|
|
||||||
isParsingData = 1
|
|
||||||
} else if (isParsingData == 1) {
|
|
||||||
if (character == '}') {
|
|
||||||
isParsingData = 0
|
|
||||||
dataType = ""
|
|
||||||
} else if (character != '{') {
|
|
||||||
if (dataType == "username") {
|
|
||||||
username += character
|
|
||||||
} else if (dataType == "token") {
|
|
||||||
token += character
|
|
||||||
} else if (dataType == "message") {
|
|
||||||
message += character
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
dataType += character
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
dataType += character
|
||||||
}
|
}
|
||||||
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
}
|
||||||
var lineNumber = 1
|
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
||||||
var userLine = ""
|
var lineNumber = 1
|
||||||
|
var userLine = ""
|
||||||
|
|
||||||
// Search the user database to find required information about the user
|
// Search the user database to find required information about the user
|
||||||
userDatabaseParser.forEachLine { line ->
|
userDatabaseParser.forEachLine { line ->
|
||||||
if (line.contains(username)) {
|
if (line.contains(username)) {
|
||||||
userLine = line
|
userLine = line
|
||||||
}
|
|
||||||
lineNumber++
|
|
||||||
}
|
}
|
||||||
userDatabaseParser.close()
|
lineNumber++
|
||||||
|
}
|
||||||
|
userDatabaseParser.close()
|
||||||
|
|
||||||
if (userLine == "") {
|
if (userLine == "") {
|
||||||
val response = "That account does not exist on this server."
|
return("That account does not exist on this server.")
|
||||||
t.sendResponseHeaders(403, response.length.toLong())
|
}
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
os.close()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
var usernameInDatabase = ""
|
var usernameInDatabase = ""
|
||||||
var tokenInDatabase = ""
|
var tokenInDatabase = ""
|
||||||
var currentStage = 0
|
var currentStage = 0
|
||||||
for (char in userLine) {
|
for (char in userLine) {
|
||||||
if (char == ':') {
|
if (char == ':') {
|
||||||
currentStage ++
|
currentStage ++
|
||||||
}
|
|
||||||
if (currentStage == 0) {
|
|
||||||
usernameInDatabase += char
|
|
||||||
} else if (currentStage == 1) {
|
|
||||||
tokenInDatabase += char
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
tokenInDatabase = tokenInDatabase.replace(":", "")
|
if (currentStage == 0) {
|
||||||
if (token != tokenInDatabase) {
|
usernameInDatabase += char
|
||||||
val response = "Invalid token! Please try putting in your password right"
|
} else if (currentStage == 1) {
|
||||||
t.sendResponseHeaders(403, response.length.toLong())
|
tokenInDatabase += char
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
os.close()
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
// Make the message to respond to the client
|
}
|
||||||
val chatHistoryView = File("chatHistory")
|
tokenInDatabase = tokenInDatabase.replace(":", "")
|
||||||
var fullMessage = ""
|
if (token != tokenInDatabase) {
|
||||||
if (message != "") {
|
return("Invalid token! Please try putting in your password right")
|
||||||
fullMessage = "${chatHistoryView.readText()}$username: $message"
|
}
|
||||||
// Add the client's message to the chat history
|
// Make the message to respond to the client
|
||||||
val chatHistory = File("chatHistory")
|
val chatHistoryView = File("chatHistory")
|
||||||
chatHistory.appendText("$username: $message ${System.lineSeparator()}")
|
var fullMessage = ""
|
||||||
message = ""
|
if (message != "") {
|
||||||
} else {
|
fullMessage = "${chatHistoryView.readText()}$username: $message"
|
||||||
fullMessage = "${chatHistoryView.readText()}"
|
// Add the client's message to the chat history
|
||||||
}
|
val chatHistory = File("chatHistory")
|
||||||
val response = if (inputData.isNotEmpty()) {
|
chatHistory.appendText("$username: $message ${System.lineSeparator()}")
|
||||||
fullMessage
|
message = ""
|
||||||
} else {
|
return("Success")
|
||||||
"No data provided"
|
} else {
|
||||||
}
|
return("No data provided")
|
||||||
|
|
||||||
// Send the message to the client
|
|
||||||
t.sendResponseHeaders(200, response.length.toLong())
|
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
println("API request handled: $inputData")
|
|
||||||
os.close()
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class CreateAccount : HttpHandler {
|
|
||||||
override fun handle(t: HttpExchange) {
|
fun syncMessages(inputData: String): String {
|
||||||
val path = t.requestURI.path
|
println("API request recieved: $inputData")
|
||||||
val inputData = path.substringAfter("/api/createAccount/")
|
// Parse data sent to the server by client
|
||||||
println("Account creation request recieved: $inputData")
|
var username = ""
|
||||||
|
var token = ""
|
||||||
// Parse data sent to the server by client
|
var dataType = ""
|
||||||
var username = ""
|
var isParsingData = 0
|
||||||
var token = ""
|
for (char in inputData) {
|
||||||
var message = ""
|
val character = char
|
||||||
var dataType = ""
|
if (character == ':') {
|
||||||
var isParsingData = 0
|
isParsingData = 1
|
||||||
for (char in inputData) {
|
} else if (isParsingData == 1) {
|
||||||
val character = char
|
if (character == '}') {
|
||||||
if (character == ':') {
|
isParsingData = 0
|
||||||
isParsingData = 1
|
dataType = ""
|
||||||
} else if (isParsingData == 1) {
|
} else if (character != '{') {
|
||||||
if (character == '}') {
|
if (dataType == "username") {
|
||||||
isParsingData = 0
|
username += character
|
||||||
dataType = ""
|
} else if (dataType == "token") {
|
||||||
} else if (character != '{') {
|
token += character
|
||||||
if (dataType == "username") {
|
|
||||||
username += character
|
|
||||||
} else if (dataType == "token") {
|
|
||||||
token += character
|
|
||||||
} else if (dataType == "message") {
|
|
||||||
message += character
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
dataType += character
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
dataType += character
|
||||||
}
|
}
|
||||||
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
|
||||||
var lineNumber = 1
|
|
||||||
var userExists = 0
|
|
||||||
|
|
||||||
// Search the user database to find required information about the user
|
|
||||||
userDatabaseParser.forEachLine { line ->
|
|
||||||
if (line.contains(username)) {
|
|
||||||
val response = "That username already exists on the server! Please choose a different username"
|
|
||||||
t.sendResponseHeaders(422, response.length.toLong())
|
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
os.close()
|
|
||||||
userExists = 1
|
|
||||||
}
|
|
||||||
lineNumber++
|
|
||||||
}
|
|
||||||
userDatabaseParser.close()
|
|
||||||
if (userExists == 1) {return}
|
|
||||||
println("$username:$token")
|
|
||||||
|
|
||||||
if (username == "") {
|
|
||||||
val response = "Please input a username"
|
|
||||||
t.sendResponseHeaders(422, response.length.toLong())
|
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
os.close()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if (token == "") {
|
|
||||||
val response = "Please input a password"
|
|
||||||
t.sendResponseHeaders(422, response.length.toLong())
|
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
os.close()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val userDatabaseFile = File("userDatabase")
|
|
||||||
userDatabaseFile.appendText("${System.lineSeparator()}$username:$token")
|
|
||||||
val response = "Creating account was successful!"
|
|
||||||
t.sendResponseHeaders(200, response.length.toLong())
|
|
||||||
val os = t.responseBody
|
|
||||||
os.write(response.toByteArray())
|
|
||||||
println("")
|
|
||||||
os.close()
|
|
||||||
}
|
}
|
||||||
|
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
||||||
|
var lineNumber = 1
|
||||||
|
var userLine = ""
|
||||||
|
|
||||||
|
// Search the user database to find required information about the user
|
||||||
|
userDatabaseParser.forEachLine { line ->
|
||||||
|
if (line.contains(username)) {
|
||||||
|
userLine = line
|
||||||
|
}
|
||||||
|
lineNumber++
|
||||||
|
}
|
||||||
|
userDatabaseParser.close()
|
||||||
|
|
||||||
|
if (userLine == "") {
|
||||||
|
return("Account not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
var usernameInDatabase = ""
|
||||||
|
var tokenInDatabase = ""
|
||||||
|
var currentStage = 0
|
||||||
|
for (char in userLine) {
|
||||||
|
if (char == ':') {
|
||||||
|
currentStage ++
|
||||||
|
}
|
||||||
|
if (currentStage == 0) {
|
||||||
|
usernameInDatabase += char
|
||||||
|
} else if (currentStage == 1) {
|
||||||
|
tokenInDatabase += char
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tokenInDatabase = tokenInDatabase.replace(":", "")
|
||||||
|
if (token != tokenInDatabase) {
|
||||||
|
return("Invalid token")
|
||||||
|
}
|
||||||
|
// Send back message history
|
||||||
|
val chatHistoryView = File("chatHistory")
|
||||||
|
return(chatHistoryView.readText())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun createAccount(inputData: String): String {
|
||||||
|
println("Account creation request recieved: $inputData")
|
||||||
|
// Parse data sent to the server by client
|
||||||
|
var username = ""
|
||||||
|
var token = ""
|
||||||
|
var message = ""
|
||||||
|
var dataType = ""
|
||||||
|
var isParsingData = 0
|
||||||
|
for (char in inputData) {
|
||||||
|
val character = char
|
||||||
|
if (character == ':') {
|
||||||
|
isParsingData = 1
|
||||||
|
} else if (isParsingData == 1) {
|
||||||
|
if (character == '}') {
|
||||||
|
isParsingData = 0
|
||||||
|
dataType = ""
|
||||||
|
} else if (character != '{') {
|
||||||
|
if (dataType == "username") {
|
||||||
|
username += character
|
||||||
|
} else if (dataType == "token") {
|
||||||
|
token += character
|
||||||
|
} else if (dataType == "message") {
|
||||||
|
message += character
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
dataType += character
|
||||||
|
}
|
||||||
|
}
|
||||||
|
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
||||||
|
var lineNumber = 1
|
||||||
|
var userExists = 0
|
||||||
|
|
||||||
|
// Search the user database to find required information about the user
|
||||||
|
var response = ""
|
||||||
|
userDatabaseParser.forEachLine { line ->
|
||||||
|
if (line.contains(username)) {
|
||||||
|
response = "Username already exists"
|
||||||
|
}
|
||||||
|
lineNumber++
|
||||||
|
}
|
||||||
|
if (response != "") {
|
||||||
|
return(response)
|
||||||
|
}
|
||||||
|
userDatabaseParser.close()
|
||||||
|
if (username == "") {
|
||||||
|
return("No username")
|
||||||
|
}
|
||||||
|
|
||||||
|
if (token == "") {
|
||||||
|
return("No token")
|
||||||
|
}
|
||||||
|
|
||||||
|
val userDatabaseFile = File("userDatabase")
|
||||||
|
userDatabaseFile.appendText("${System.lineSeparator()}$username:$token")
|
||||||
|
return("Success")
|
||||||
|
}
|
||||||
|
fun authKey(inputData: String): String {
|
||||||
|
println("API request recieved: $inputData")
|
||||||
|
|
||||||
|
// Parse data sent to the server by client
|
||||||
|
var username = ""
|
||||||
|
var token = ""
|
||||||
|
var authKey = ""
|
||||||
|
var dataType = ""
|
||||||
|
var isParsingData = 0
|
||||||
|
for (char in inputData) {
|
||||||
|
val character = char
|
||||||
|
if (character == ':') {
|
||||||
|
isParsingData = 1
|
||||||
|
} else if (isParsingData == 1) {
|
||||||
|
if (character == '}') {
|
||||||
|
isParsingData = 0
|
||||||
|
dataType = ""
|
||||||
|
} else if (character != '{') {
|
||||||
|
if (dataType == "username") {
|
||||||
|
username += character
|
||||||
|
} else if (dataType == "token") {
|
||||||
|
token += character
|
||||||
|
} else if (dataType == "authkey") {
|
||||||
|
authKey += character
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
dataType += character
|
||||||
|
}
|
||||||
|
}
|
||||||
|
val userDatabaseParser = BufferedReader(File("userDatabase").reader())
|
||||||
|
var lineNumber = 1
|
||||||
|
var userLine = ""
|
||||||
|
|
||||||
|
// Search the user database to find required information about the user
|
||||||
|
userDatabaseParser.forEachLine { line ->
|
||||||
|
if (line.contains(username)) {
|
||||||
|
userLine = line
|
||||||
|
}
|
||||||
|
lineNumber++
|
||||||
|
}
|
||||||
|
userDatabaseParser.close()
|
||||||
|
|
||||||
|
if (userLine == "") {
|
||||||
|
return("Account not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
var usernameInDatabase = ""
|
||||||
|
var tokenInDatabase = ""
|
||||||
|
var currentStage = 0
|
||||||
|
for (char in userLine) {
|
||||||
|
if (char == ':') {
|
||||||
|
currentStage ++
|
||||||
|
}
|
||||||
|
if (currentStage == 0) {
|
||||||
|
usernameInDatabase += char
|
||||||
|
} else if (currentStage == 1) {
|
||||||
|
tokenInDatabase += char
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tokenInDatabase = tokenInDatabase.replace(":", "")
|
||||||
|
if (token != tokenInDatabase) {
|
||||||
|
return("Invalid token")
|
||||||
|
}
|
||||||
|
if (authKey == "") {
|
||||||
|
return("No auth key provided")
|
||||||
|
}
|
||||||
|
// Make the message to respond to the client
|
||||||
|
val chatHistoryView = File("chatHistory")
|
||||||
|
var fullMessage = ""
|
||||||
|
if (authKey != "") {
|
||||||
|
fullMessage = "encryptionKey:$username:$authKey"
|
||||||
|
authKey = ""
|
||||||
|
} else {
|
||||||
|
fullMessage = "${chatHistoryView.readText()}"
|
||||||
|
}
|
||||||
|
val response = if (inputData.isNotEmpty()) {
|
||||||
|
fullMessage
|
||||||
|
} else {
|
||||||
|
"No data provided"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Send the message to the client
|
||||||
|
return("Success")
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user