PermissionController.kt

package io.github.lishangbu.avalon.auth.controller

import io.github.lishangbu.avalon.auth.entity.dto.PermissionSpecification
import io.github.lishangbu.avalon.auth.entity.dto.PermissionView
import io.github.lishangbu.avalon.auth.entity.dto.SavePermissionInput
import io.github.lishangbu.avalon.auth.entity.dto.UpdatePermissionInput
import io.github.lishangbu.avalon.auth.service.PermissionService
import jakarta.validation.Valid
import org.springframework.web.bind.annotation.DeleteMapping
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.ModelAttribute
import org.springframework.web.bind.annotation.PathVariable
import org.springframework.web.bind.annotation.PostMapping
import org.springframework.web.bind.annotation.PutMapping
import org.springframework.web.bind.annotation.RequestBody
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.RestController

/** 权限点控制器。 */
@RequestMapping("/permission")
@RestController
class PermissionController(
    private val permissionService: PermissionService,
) {
    /** 条件查询权限点列表。 */
    @GetMapping("/list")
    fun listPermissions(
        @ModelAttribute specification: PermissionSpecification,
    ): List<PermissionView> = permissionService.listByCondition(specification)

    /** 根据 ID 查询权限点。 */
    @GetMapping("/{id:\\d+}")
    fun getById(
        @PathVariable id: Long,
    ): PermissionView? = permissionService.getById(id)

    /** 新增权限点。 */
    @PostMapping
    fun save(
        @RequestBody @Valid input: SavePermissionInput,
    ): PermissionView = permissionService.save(input)

    /** 更新权限点。 */
    @PutMapping
    fun update(
        @RequestBody @Valid input: UpdatePermissionInput,
    ): PermissionView = permissionService.update(input)

    /** 根据 ID 删除权限点。 */
    @DeleteMapping("/{id:\\d+}")
    fun deleteById(
        @PathVariable id: Long,
    ) {
        permissionService.removeById(id)
    }
}