feature #9: Create Voter for Article
This commit is contained in:
@@ -1,11 +1,9 @@
|
||||
package fr.dcproject.routes
|
||||
|
||||
import Paths
|
||||
import io.ktor.application.ApplicationCall
|
||||
import fr.dcproject.security.voter.ArticleVoter
|
||||
import fr.dcproject.security.voter.assertCan
|
||||
import io.ktor.application.call
|
||||
import io.ktor.auth.authenticate
|
||||
import io.ktor.auth.authentication
|
||||
import io.ktor.http.HttpStatusCode
|
||||
import io.ktor.locations.KtorExperimentalLocationsAPI
|
||||
import io.ktor.locations.get
|
||||
import io.ktor.locations.post
|
||||
@@ -13,11 +11,8 @@ import io.ktor.request.receive
|
||||
import io.ktor.response.respond
|
||||
import io.ktor.routing.Route
|
||||
import fr.dcproject.entity.Article as ArticleEntity
|
||||
import fr.dcproject.entity.User as UserEntity
|
||||
import fr.dcproject.repository.Article as ArticleRepository
|
||||
|
||||
val ApplicationCall.user get() = authentication.principal<UserEntity>()
|
||||
|
||||
@KtorExperimentalLocationsAPI
|
||||
fun Route.article(repo: ArticleRepository) {
|
||||
get<Paths.ArticlesRequest> {
|
||||
@@ -29,17 +24,10 @@ fun Route.article(repo: ArticleRepository) {
|
||||
call.respond(it.article)
|
||||
}
|
||||
|
||||
authenticate(optional = true) {
|
||||
post<Paths.PostArticleRequest>() {
|
||||
// TODO replace to voter
|
||||
val user = call.user
|
||||
if (user == null) {
|
||||
call.respond(HttpStatusCode.Unauthorized)
|
||||
} else {
|
||||
val article = call.receive<ArticleEntity>()
|
||||
repo.upsert(article)
|
||||
call.respond(article)
|
||||
}
|
||||
}
|
||||
post<Paths.PostArticleRequest> {
|
||||
call.assertCan(ArticleVoter.Action.CREATE)
|
||||
val article = call.receive<ArticleEntity>()
|
||||
repo.upsert(article)
|
||||
call.respond(article)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user