Remove converter for Constitution
This commit is contained in:
@@ -2,24 +2,30 @@ package fr.dcproject.component.constitution.routes
|
||||
|
||||
import fr.dcproject.component.auth.citizenOrNull
|
||||
import fr.dcproject.component.constitution.ConstitutionAccessControl
|
||||
import fr.dcproject.component.constitution.ConstitutionRef
|
||||
import fr.dcproject.component.constitution.ConstitutionRepository
|
||||
import fr.dcproject.security.assert
|
||||
import io.ktor.application.call
|
||||
import io.ktor.features.NotFoundException
|
||||
import io.ktor.locations.KtorExperimentalLocationsAPI
|
||||
import io.ktor.locations.Location
|
||||
import io.ktor.locations.get
|
||||
import io.ktor.response.respond
|
||||
import io.ktor.routing.Route
|
||||
import fr.dcproject.component.constitution.Constitution as ConstitutionEntity
|
||||
import java.util.UUID
|
||||
|
||||
@KtorExperimentalLocationsAPI
|
||||
object GetConstitution {
|
||||
@Location("/constitutions/{constitution}")
|
||||
class GetConstitutionRequest(val constitution: ConstitutionEntity)
|
||||
class GetConstitutionRequest(constitution: UUID) {
|
||||
val constitution = ConstitutionRef(constitution)
|
||||
}
|
||||
|
||||
fun Route.getConstitution(ac: ConstitutionAccessControl) {
|
||||
fun Route.getConstitution(ac: ConstitutionAccessControl, constitutionRepo: ConstitutionRepository) {
|
||||
get<GetConstitutionRequest> {
|
||||
ac.assert { canView(it.constitution, citizenOrNull) }
|
||||
call.respond(it.constitution)
|
||||
val constitution = constitutionRepo.findById(it.constitution.id) ?: throw NotFoundException("Unable to find constitution ${it.constitution.id}")
|
||||
ac.assert { canView(constitution, citizenOrNull) }
|
||||
call.respond(constitution)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user