From 14c2872dac62d2311001b1c569826043d12a9408 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BC=A0=E7=BF=94?= Date: Thu, 12 Mar 2026 07:44:06 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=B7=BB=E5=8A=A0SysConfigHandler?= =?UTF-8?q?=E7=B3=BB=E7=BB=9F=E9=85=8D=E7=BD=AEAPI?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../sys/handler/config/SysConfigHandler.java | 64 +++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 novalon-manage-api/manage-sys/src/main/java/cn/novalon/manage/sys/handler/config/SysConfigHandler.java diff --git a/novalon-manage-api/manage-sys/src/main/java/cn/novalon/manage/sys/handler/config/SysConfigHandler.java b/novalon-manage-api/manage-sys/src/main/java/cn/novalon/manage/sys/handler/config/SysConfigHandler.java new file mode 100644 index 0000000..d38ec7f --- /dev/null +++ b/novalon-manage-api/manage-sys/src/main/java/cn/novalon/manage/sys/handler/config/SysConfigHandler.java @@ -0,0 +1,64 @@ +package cn.novalon.manage.sys.handler.config; + +import cn.novalon.manage.sys.core.domain.SysConfig; +import cn.novalon.manage.sys.core.service.ISysConfigService; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; +import reactor.core.publisher.Flux; +import reactor.core.publisher.Mono; + +@RestController +@RequestMapping("/api/config") +public class SysConfigHandler { + + private final ISysConfigService configService; + + public SysConfigHandler(ISysConfigService configService) { + this.configService = configService; + } + + @GetMapping + public Flux getAllConfigs() { + return configService.findAll(); + } + + @GetMapping("/{id}") + public Mono> getConfigById(@PathVariable Long id) { + return configService.findById(id) + .map(ResponseEntity::ok) + .defaultIfEmpty(ResponseEntity.notFound().build()); + } + + @GetMapping("/key/{configKey}") + public Mono> getConfigByKey(@PathVariable String configKey) { + return configService.findByConfigKey(configKey) + .map(ResponseEntity::ok) + .defaultIfEmpty(ResponseEntity.notFound().build()); + } + + @PostMapping + public Mono> createConfig(@RequestBody SysConfig config) { + return configService.save(config) + .map(c -> ResponseEntity.status(HttpStatus.CREATED).body(c)); + } + + @PutMapping("/{id}") + public Mono> updateConfig(@PathVariable Long id, @RequestBody SysConfig config) { + return configService.findById(id) + .flatMap(existing -> { + existing.setConfigName(config.getConfigName()); + existing.setConfigValue(config.getConfigValue()); + existing.setConfigType(config.getConfigType()); + return configService.save(existing); + }) + .map(ResponseEntity::ok) + .defaultIfEmpty(ResponseEntity.notFound().build()); + } + + @DeleteMapping("/{id}") + public Mono> deleteConfig(@PathVariable Long id) { + return configService.deleteById(id) + .then(Mono.just(ResponseEntity.noContent().build())); + } +}