|
|
@@ -0,0 +1,135 @@
|
|
|
+/*
|
|
|
+ * Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
|
|
|
+ *
|
|
|
+ * Redistribution and use in source and binary forms, with or without
|
|
|
+ * modification, are permitted provided that the following conditions are met:
|
|
|
+ *
|
|
|
+ * Redistributions of source code must retain the above copyright notice,
|
|
|
+ * this list of conditions and the following disclaimer.
|
|
|
+ * Redistributions in binary form must reproduce the above copyright
|
|
|
+ * notice, this list of conditions and the following disclaimer in the
|
|
|
+ * documentation and/or other materials provided with the distribution.
|
|
|
+ * Neither the name of the dreamlu.net developer nor the names of its
|
|
|
+ * contributors may be used to endorse or promote products derived from
|
|
|
+ * this software without specific prior written permission.
|
|
|
+ * Author: Chill 庄骞 (smallchill@163.com)
|
|
|
+ */
|
|
|
+package org.springblade.modules.resource.controller;
|
|
|
+
|
|
|
+import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
+import io.swagger.annotations.Api;
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
+import io.swagger.annotations.ApiParam;
|
|
|
+import lombok.AllArgsConstructor;
|
|
|
+import org.springblade.core.boot.ctrl.BladeController;
|
|
|
+import org.springblade.core.cache.utils.CacheUtil;
|
|
|
+import org.springblade.core.launch.constant.AppConstant;
|
|
|
+import org.springblade.core.mp.support.Condition;
|
|
|
+import org.springblade.core.mp.support.Query;
|
|
|
+import org.springblade.core.secure.utils.SecureUtil;
|
|
|
+import org.springblade.core.tool.api.R;
|
|
|
+import org.springblade.core.tool.utils.Func;
|
|
|
+import org.springblade.modules.resource.builder.OssBuilder;
|
|
|
+import org.springblade.modules.resource.entity.Oss;
|
|
|
+import org.springblade.modules.resource.entity.OssVO;
|
|
|
+import org.springblade.modules.resource.service.IOssService;
|
|
|
+import org.springblade.modules.resource.wrapper.OssWrapper;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import javax.validation.Valid;
|
|
|
+
|
|
|
+import static org.springblade.core.cache.constant.CacheConstant.SYS_CACHE;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 控制器
|
|
|
+ *
|
|
|
+ * @author BladeX
|
|
|
+ * @since 2019-05-26
|
|
|
+ */
|
|
|
+@RestController
|
|
|
+@AllArgsConstructor
|
|
|
+@RequestMapping(AppConstant.APPLICATION_RESOURCE_NAME + "/oss")
|
|
|
+@Api(value = "对象存储接口", tags = "接口")
|
|
|
+public class OssController extends BladeController {
|
|
|
+
|
|
|
+ private IOssService ossService;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 详情
|
|
|
+ */
|
|
|
+ @GetMapping("/detail")
|
|
|
+ @ApiOperation(value = "详情", notes = "传入oss", position = 1)
|
|
|
+ public R<OssVO> detail(Oss oss) {
|
|
|
+ Oss detail = ossService.getOne(Condition.getQueryWrapper(oss));
|
|
|
+ return R.data(OssWrapper.build().entityVO(detail));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 分页
|
|
|
+ */
|
|
|
+ @GetMapping("/list")
|
|
|
+ @ApiOperation(value = "分页", notes = "传入oss", position = 2)
|
|
|
+ public R<IPage<OssVO>> list(Oss oss, Query query) {
|
|
|
+ IPage<Oss> pages = ossService.page(Condition.getPage(query), Condition.getQueryWrapper(oss));
|
|
|
+ return R.data(OssWrapper.build().pageVO(pages));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 自定义分页
|
|
|
+ */
|
|
|
+ @GetMapping("/page")
|
|
|
+ @ApiOperation(value = "分页", notes = "传入oss", position = 3)
|
|
|
+ public R<IPage<OssVO>> page(OssVO oss, Query query) {
|
|
|
+ IPage<OssVO> pages = ossService.selectOssPage(Condition.getPage(query), oss);
|
|
|
+ return R.data(pages);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 新增
|
|
|
+ */
|
|
|
+ @PostMapping("/save")
|
|
|
+ @ApiOperation(value = "新增", notes = "传入oss", position = 4)
|
|
|
+ public R save(@Valid @RequestBody Oss oss) {
|
|
|
+ return R.status(ossService.save(oss));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 修改
|
|
|
+ */
|
|
|
+ @PostMapping("/update")
|
|
|
+ @ApiOperation(value = "修改", notes = "传入oss", position = 5)
|
|
|
+ public R update(@Valid @RequestBody Oss oss) {
|
|
|
+ return R.status(ossService.updateById(oss));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 新增或修改
|
|
|
+ */
|
|
|
+ @PostMapping("/submit")
|
|
|
+ @ApiOperation(value = "新增或修改", notes = "传入oss", position = 6)
|
|
|
+ public R submit(@Valid @RequestBody Oss oss) {
|
|
|
+ return R.status(ossService.saveOrUpdate(oss));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 删除
|
|
|
+ */
|
|
|
+ @PostMapping("/remove")
|
|
|
+ @ApiOperation(value = "逻辑删除", notes = "传入ids", position = 7)
|
|
|
+ public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
|
|
|
+ return R.status(ossService.deleteLogic(Func.toLongList(ids)));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 启用
|
|
|
+ */
|
|
|
+ @PostMapping("/enable")
|
|
|
+ @ApiOperation(value = "配置启用", notes = "传入id", position = 7)
|
|
|
+ public R enable(@ApiParam(value = "主键", required = true) @RequestParam Long id) {
|
|
|
+ CacheUtil.evict(SYS_CACHE, OssBuilder.OSS_CODE, SecureUtil.getTenantCode());
|
|
|
+ return R.status(ossService.enable(id));
|
|
|
+ }
|
|
|
+
|
|
|
+}
|