Test openapi schema of route /workgroup/*/members
This commit is contained in:
@@ -7,6 +7,7 @@ import fr.dcproject.component.citizen.database.CitizenRef
|
||||
import fr.dcproject.component.workgroup.WorkgroupAccessControl
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupRepository
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupWithMembersI
|
||||
import fr.dcproject.component.workgroup.routes.toOutput
|
||||
import io.ktor.application.ApplicationCall
|
||||
import io.ktor.application.call
|
||||
import io.ktor.http.HttpStatusCode
|
||||
@@ -22,8 +23,8 @@ import java.util.UUID
|
||||
object AddMemberToWorkgroup {
|
||||
@Location("/workgroups/{workgroupId}/members")
|
||||
class WorkgroupsMembersRequest(val workgroupId: UUID) : KoinComponent {
|
||||
class Input : MutableList<Input.Item> by mutableListOf() {
|
||||
class Item(val citizen: CitizenRef, roles: List<String> = emptyList()) {
|
||||
class Input : MutableList<Input.Member> by mutableListOf() {
|
||||
class Member(val citizen: CitizenRef, roles: List<String> = emptyList()) {
|
||||
val roles: List<WorkgroupWithMembersI.Member.Role> = roles.map {
|
||||
WorkgroupWithMembersI.Member.Role.valueOf(it)
|
||||
}
|
||||
@@ -48,7 +49,10 @@ object AddMemberToWorkgroup {
|
||||
ac.assert { canAddMembers(workgroup, citizenOrNull) }
|
||||
repo.addMembers(workgroup, members)
|
||||
}.let { members ->
|
||||
call.respond(HttpStatusCode.Created, members)
|
||||
call.respond(
|
||||
HttpStatusCode.Created,
|
||||
members.toOutput()
|
||||
)
|
||||
}
|
||||
} ?: call.respond(HttpStatusCode.NotFound)
|
||||
}
|
||||
|
||||
@@ -7,6 +7,7 @@ import fr.dcproject.component.citizen.database.CitizenRef
|
||||
import fr.dcproject.component.workgroup.WorkgroupAccessControl
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupRepository
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupWithMembersI
|
||||
import fr.dcproject.component.workgroup.routes.toOutput
|
||||
import io.ktor.application.ApplicationCall
|
||||
import io.ktor.application.call
|
||||
import io.ktor.http.HttpStatusCode
|
||||
@@ -17,37 +18,34 @@ import io.ktor.response.respond
|
||||
import io.ktor.routing.Route
|
||||
import org.koin.core.KoinComponent
|
||||
import java.util.UUID
|
||||
import fr.dcproject.component.workgroup.routes.members.DeleteMembersOfWorkgroup.WorkgroupsMembersRequest.Input as Input
|
||||
|
||||
@KtorExperimentalLocationsAPI
|
||||
object DeleteMembersOfWorkgroup {
|
||||
@Location("/workgroups/{workgroupId}/members")
|
||||
class WorkgroupsMembersRequest(val workgroupId: UUID) : KoinComponent {
|
||||
class Input : MutableList<Input.Item> by mutableListOf() {
|
||||
class Item(val citizen: CitizenRef, roles: List<String> = emptyList()) {
|
||||
val roles: List<WorkgroupWithMembersI.Member.Role> = roles.map {
|
||||
WorkgroupWithMembersI.Member.Role.valueOf(it)
|
||||
}
|
||||
}
|
||||
class Input : MutableList<Input.Member> by mutableListOf() {
|
||||
class Member(val citizen: CitizenRef)
|
||||
}
|
||||
}
|
||||
|
||||
private suspend fun ApplicationCall.getMembersFromRequest(): List<WorkgroupWithMembersI.Member<CitizenRef>> = receiveOrBadRequest<WorkgroupsMembersRequest.Input>().map {
|
||||
WorkgroupWithMembersI.Member(
|
||||
citizen = it.citizen,
|
||||
roles = it.roles
|
||||
)
|
||||
}
|
||||
private suspend fun ApplicationCall.getMembersFromRequest(): List<WorkgroupWithMembersI.Member<CitizenRef>> =
|
||||
receiveOrBadRequest<Input>().map { WorkgroupWithMembersI.Member(it.citizen) }
|
||||
|
||||
fun Route.deleteMemberOfWorkgroup(repo: WorkgroupRepository, ac: WorkgroupAccessControl) {
|
||||
/* Delete members of workgroup */
|
||||
delete<WorkgroupsMembersRequest> {
|
||||
repo.findById(it.workgroupId)?.let { workgroup ->
|
||||
call.getMembersFromRequest().let { members ->
|
||||
ac.assert { canView(workgroup, citizenOrNull) }
|
||||
repo.removeMembers(workgroup, members)
|
||||
}.let { members ->
|
||||
call.respond(HttpStatusCode.OK, members)
|
||||
}
|
||||
call.getMembersFromRequest()
|
||||
.let { members ->
|
||||
ac.assert { canRemoveMembers(workgroup, citizenOrNull) }
|
||||
repo.removeMembers(workgroup, members)
|
||||
}.let { members ->
|
||||
call.respond(
|
||||
HttpStatusCode.OK,
|
||||
members.toOutput()
|
||||
)
|
||||
}
|
||||
} ?: call.respond(HttpStatusCode.NotFound)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -7,6 +7,7 @@ import fr.dcproject.component.citizen.database.CitizenRef
|
||||
import fr.dcproject.component.workgroup.WorkgroupAccessControl
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupRepository
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupWithMembersI
|
||||
import fr.dcproject.component.workgroup.routes.toOutput
|
||||
import io.ktor.application.ApplicationCall
|
||||
import io.ktor.application.call
|
||||
import io.ktor.http.HttpStatusCode
|
||||
@@ -46,7 +47,10 @@ object UpdateMemberOfWorkgroup {
|
||||
ac.assert { canUpdateMembers(workgroup, citizenOrNull) }
|
||||
repo.updateMembers(workgroup, members)
|
||||
}.let { members ->
|
||||
call.respond(HttpStatusCode.OK, members)
|
||||
call.respond(
|
||||
HttpStatusCode.OK,
|
||||
members.toOutput()
|
||||
)
|
||||
}
|
||||
} ?: call.respond(HttpStatusCode.NotFound)
|
||||
}
|
||||
|
||||
@@ -1,11 +1,13 @@
|
||||
package fr.dcproject.component.workgroup.routes
|
||||
|
||||
import fr.dcproject.common.response.toOutput
|
||||
import fr.dcproject.component.citizen.database.CitizenCreator
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupForView
|
||||
import fr.dcproject.component.workgroup.database.WorkgroupWithMembersI
|
||||
import org.joda.time.DateTime
|
||||
import java.util.UUID
|
||||
|
||||
fun WorkgroupForView<*>.toOutput(): Any = this.let { w ->
|
||||
fun WorkgroupForView<CitizenCreator>.toOutput(): Any = this.let { w ->
|
||||
object {
|
||||
val id: UUID = w.id
|
||||
val name: String = w.name
|
||||
@@ -14,20 +16,7 @@ fun WorkgroupForView<*>.toOutput(): Any = this.let { w ->
|
||||
val anonymous: Boolean = w.anonymous
|
||||
val createdAt: DateTime = w.createdAt
|
||||
val createdBy: Any = w.createdBy.toOutput()
|
||||
val members: Any = w.members.map { m ->
|
||||
object {
|
||||
val citizen: Any = object {
|
||||
val id: UUID = m.citizen.id
|
||||
val name: Any = m.citizen.name.let { n ->
|
||||
object {
|
||||
val firstName: String = n.firstName
|
||||
val lastName: String = n.lastName
|
||||
}
|
||||
}
|
||||
}
|
||||
val roles: List<String> = m.roles.map { it.toString() }
|
||||
}
|
||||
}
|
||||
val members: Any = w.members.toOutput()
|
||||
}
|
||||
}
|
||||
|
||||
@@ -40,3 +29,12 @@ fun WorkgroupForView<*>.toOutputListing(): Any = this.let { w ->
|
||||
val createdAt: DateTime = w.createdAt
|
||||
}
|
||||
}
|
||||
|
||||
fun List<WorkgroupWithMembersI.Member<CitizenCreator>>.toOutput(): Any {
|
||||
return this.map { m ->
|
||||
object {
|
||||
val citizen: Any = m.citizen.toOutput()
|
||||
val roles: List<String> = m.roles.map { it.toString() }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user