SNRK-83: changed decomposition and moved main to test/
This commit is contained in:
parent
b4423e8bba
commit
ff7b02d98a
@ -11,6 +11,7 @@ import io.ktor.server.response.*
|
|||||||
import io.ktor.server.http.content.*
|
import io.ktor.server.http.content.*
|
||||||
import kotlinx.html.*
|
import kotlinx.html.*
|
||||||
import io.ktor.server.routing.*
|
import io.ktor.server.routing.*
|
||||||
|
import kotlinx.css.html
|
||||||
import java.nio.file.Path
|
import java.nio.file.Path
|
||||||
import space.kscience.snark.storage.Directory
|
import space.kscience.snark.storage.Directory
|
||||||
import space.kscience.snark.storage.local.localStorage
|
import space.kscience.snark.storage.local.localStorage
|
||||||
@ -24,11 +25,13 @@ public interface DataHolder {
|
|||||||
|
|
||||||
fun init() : Directory
|
fun init() : Directory
|
||||||
fun represent(): String
|
fun represent(): String
|
||||||
|
//will be HTML later
|
||||||
}
|
}
|
||||||
class LocalDataHolder: DataHolder {
|
class LocalDataHolder: DataHolder {
|
||||||
private var source: Path? = null
|
private var source: Path? = null
|
||||||
private var response: String = ""
|
private var response: String = ""
|
||||||
override fun init(): Directory {
|
override fun init(): Directory {
|
||||||
|
source?.toFile()?.deleteRecursively()
|
||||||
source = createTempDirectory()
|
source = createTempDirectory()
|
||||||
return localStorage(source!!)
|
return localStorage(source!!)
|
||||||
}
|
}
|
||||||
@ -50,11 +53,29 @@ class LocalDataHolder: DataHolder {
|
|||||||
response
|
response
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fun main() {
|
|
||||||
val dataHolder: DataHolder = LocalDataHolder()
|
public class SNARKServer(val dataHolder: DataHolder, val port: Int): Runnable {
|
||||||
embeddedServer(Netty, 9090) {
|
private suspend fun renderGet(call: ApplicationCall) {
|
||||||
routing {
|
call.respondText(dataHolder.represent())
|
||||||
get("/") {
|
}
|
||||||
|
private suspend fun renderUpload(call: ApplicationCall) {
|
||||||
|
val multipartData = call.receiveMultipart()
|
||||||
|
val tmp = createTempFile(suffix=".zip")
|
||||||
|
multipartData.forEachPart { part ->
|
||||||
|
when (part) {
|
||||||
|
is PartData.FileItem -> {
|
||||||
|
val fileBytes = part.streamProvider().readBytes()
|
||||||
|
tmp.writeBytes(fileBytes)
|
||||||
|
}
|
||||||
|
else -> {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
part.dispose()
|
||||||
|
}
|
||||||
|
unzip(tmp.toPath().toString(), dataHolder.init())
|
||||||
|
call.respondText("File is successfully uploaded")
|
||||||
|
}
|
||||||
|
private suspend fun renderMainPage(call: ApplicationCall) {
|
||||||
call.respondHtml(HttpStatusCode.OK) {
|
call.respondHtml(HttpStatusCode.OK) {
|
||||||
head {
|
head {
|
||||||
title {
|
title {
|
||||||
@ -82,26 +103,19 @@ fun main() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
override fun run() {
|
||||||
|
embeddedServer(Netty, port) {
|
||||||
|
routing {
|
||||||
|
get("/") {
|
||||||
|
renderMainPage(call)
|
||||||
|
}
|
||||||
post("/upload") {
|
post("/upload") {
|
||||||
val multipartData = call.receiveMultipart()
|
renderUpload(call)
|
||||||
val tmp = createTempFile(suffix=".zip")
|
|
||||||
multipartData.forEachPart { part ->
|
|
||||||
when (part) {
|
|
||||||
is PartData.FileItem -> {
|
|
||||||
val fileBytes = part.streamProvider().readBytes()
|
|
||||||
tmp.writeBytes(fileBytes)
|
|
||||||
}
|
|
||||||
else -> {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
part.dispose()
|
|
||||||
}
|
|
||||||
unzip(tmp.toPath().toString(), dataHolder.init())
|
|
||||||
call.respondText("File is successfully uploaded")
|
|
||||||
}
|
}
|
||||||
get("/data") {
|
get("/data") {
|
||||||
call.respondText(dataHolder.represent())
|
renderGet(call)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}.start(wait = true)
|
}.start(wait = true)
|
||||||
}
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
package space.kscience.snark.ktor
|
||||||
|
|
||||||
|
fun main() {
|
||||||
|
SNARKServer(LocalDataHolder(), 9090).run()
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user