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,36 +18,33 @@ 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) }
|
||||
call.getMembersFromRequest()
|
||||
.let { members ->
|
||||
ac.assert { canRemoveMembers(workgroup, citizenOrNull) }
|
||||
repo.removeMembers(workgroup, members)
|
||||
}.let { members ->
|
||||
call.respond(HttpStatusCode.OK, 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() }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1250,6 +1250,78 @@ paths:
|
||||
description: Workgroup deleted
|
||||
404:
|
||||
description: Workshop not exist or are already deleted
|
||||
/workgroups/{workgroup}/members:
|
||||
parameters:
|
||||
- $ref: '#/components/parameters/workgroup'
|
||||
post:
|
||||
summary: Add members to the workgroup
|
||||
security:
|
||||
- JWTAuth: []
|
||||
tags:
|
||||
- workgroup
|
||||
requestBody:
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
$ref: '#/components/schemas/MembersRequest'
|
||||
responses:
|
||||
201:
|
||||
description: the list of members
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
$ref: '#/components/schemas/MembersResponse'
|
||||
put:
|
||||
summary: Updates ALL members.
|
||||
description: ⚠ PLEASE NOTE ⚠ This request removes all members who are not in request!
|
||||
security:
|
||||
- JWTAuth: []
|
||||
tags:
|
||||
- workgroup
|
||||
requestBody:
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
$ref: '#/components/schemas/MembersRequest'
|
||||
responses:
|
||||
200:
|
||||
description: the list of members
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
$ref: '#/components/schemas/MembersResponse'
|
||||
400:
|
||||
$ref: '#/components/responses/400'
|
||||
delete:
|
||||
summary: Delete members of workgroup
|
||||
security:
|
||||
- JWTAuth: []
|
||||
tags:
|
||||
- workgroup
|
||||
requestBody:
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
description: members of workgroup
|
||||
type: array
|
||||
items:
|
||||
type: object
|
||||
properties:
|
||||
citizen:
|
||||
required:
|
||||
- id
|
||||
properties:
|
||||
id:
|
||||
$ref: '#/components/schemas/UUID'
|
||||
responses:
|
||||
200:
|
||||
description: the list of members
|
||||
content:
|
||||
application/json:
|
||||
schema:
|
||||
$ref: '#/components/schemas/MembersResponse'
|
||||
400:
|
||||
$ref: '#/components/responses/400'
|
||||
|
||||
components:
|
||||
parameters:
|
||||
@@ -2058,7 +2130,6 @@ components:
|
||||
logo:
|
||||
type: string
|
||||
nullable: true
|
||||
|
||||
Workgroup:
|
||||
description: Workgroup
|
||||
type: object
|
||||
@@ -2088,13 +2159,17 @@ components:
|
||||
createdBy:
|
||||
$ref: '#/components/schemas/CitizenCreator'
|
||||
members:
|
||||
$ref: '#/components/schemas/MembersResponse'
|
||||
|
||||
MembersRequest:
|
||||
description: members of workgroup
|
||||
type: array
|
||||
items:
|
||||
type: object
|
||||
properties:
|
||||
citizen:
|
||||
type: object
|
||||
items:
|
||||
required:
|
||||
- id
|
||||
properties:
|
||||
id:
|
||||
$ref: '#/components/schemas/UUID'
|
||||
@@ -2102,6 +2177,31 @@ components:
|
||||
type: array
|
||||
items:
|
||||
type: string
|
||||
enum:
|
||||
- MASTER
|
||||
- MANAGER
|
||||
- EDITOR
|
||||
- REPORTER
|
||||
example: MASTER
|
||||
MembersResponse:
|
||||
description: members of workgroup
|
||||
type: array
|
||||
items:
|
||||
description: Member of workgroup
|
||||
type: object
|
||||
properties:
|
||||
citizen:
|
||||
$ref: '#/components/schemas/CitizenCreator'
|
||||
roles:
|
||||
type: array
|
||||
items:
|
||||
type: string
|
||||
enum:
|
||||
- MASTER
|
||||
- MANAGER
|
||||
- EDITOR
|
||||
- REPORTER
|
||||
example: MASTER
|
||||
|
||||
securitySchemes:
|
||||
JWTAuth:
|
||||
|
||||
@@ -204,8 +204,7 @@ class `Workgroup routes` : BaseTest() {
|
||||
"""
|
||||
[
|
||||
{
|
||||
"citizen": {"id":"87909ba3-2069-431c-9924-219fd8411cf2"},
|
||||
"roles": ["MASTER"]
|
||||
"citizen": {"id":"87909ba3-2069-431c-9924-219fd8411cf2"}
|
||||
}
|
||||
]
|
||||
"""
|
||||
|
||||
Reference in New Issue
Block a user