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)
}
}