/* * 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.desk.controller; import com.baomidou.mybatisplus.core.metadata.IPage; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import com.github.xiaoymin.knife4j.annotations.ApiSort; import io.swagger.annotations.*; import lombok.AllArgsConstructor; import org.springblade.common.utils.arg; import org.springblade.core.boot.ctrl.BladeController; 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.tenant.annotation.TenantDS; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springblade.modules.FTP.FtpUtil; import org.springblade.modules.desk.entity.Notice; import org.springblade.modules.desk.service.INoticeService; import org.springblade.modules.desk.vo.NoticeVO; import org.springblade.modules.desk.wrapper.NoticeWrapper; import org.springblade.modules.system.entity.Dept; import org.springblade.modules.system.service.IDeptService; import org.springframework.web.bind.annotation.*; import springfox.documentation.annotations.ApiIgnore; import java.text.SimpleDateFormat; import java.util.Date; import java.util.List; import java.util.Map; /** * 控制器 * * @author Chill */ @TenantDS @RestController @RequestMapping(AppConstant.APPLICATION_DESK_NAME + "/notice") @AllArgsConstructor @ApiSort(2) @Api(value = "用户博客", tags = "博客接口") public class NoticeController extends BladeController { private final INoticeService noticeService; private final IDeptService iDeptService; /** * 详情 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入notice") public R detail(Notice notice) { Notice detail = noticeService.getOne(Condition.getQueryWrapper(notice)); return R.data(NoticeWrapper.build().entityVO(detail)); } /** * 分页 */ @GetMapping("/list") @ApiImplicitParams({ @ApiImplicitParam(name = "category", value = "公告类型", paramType = "query", dataType = "integer"), @ApiImplicitParam(name = "title", value = "公告标题", paramType = "query", dataType = "string") }) @ApiOperationSupport(order = 2) @ApiOperation(value = "分页", notes = "传入notice") public R> list(@ApiIgnore @RequestParam Map notice, Query query) { IPage pages = noticeService.page(Condition.getPage(query), Condition.getQueryWrapper(notice, Notice.class)); return R.data(NoticeWrapper.build().pageVO(pages)); } /** * 多表联合查询自定义分页 */ @GetMapping("/page") @ApiImplicitParams({ @ApiImplicitParam(name = "category", value = "公告类型", paramType = "query", dataType = "integer"), @ApiImplicitParam(name = "title", value = "公告标题", paramType = "query", dataType = "string") }) @ApiOperationSupport(order = 3) @ApiOperation(value = "分页", notes = "传入notice") public R> page(@ApiIgnore NoticeVO notice, Query query) { IPage pages = noticeService.selectNoticePage(Condition.getPage(query), notice); return R.data(pages); } /** * 新增 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入notice") public R save(@RequestBody Notice notice) { return R.status(noticeService.save(notice)); } /** * 修改 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入notice") public R update(@RequestBody Notice notice) { return R.status(noticeService.updateById(notice)); } /** * 新增或修改 */ @PostMapping("/submit") @ApiOperationSupport(order = 6) @ApiOperation(value = "新增或修改", notes = "传入notice") public R submit(@RequestBody Notice notice){ boolean status = false; if (null==notice.getId()) { //新增 status = noticeService.save(notice); notice.setIsDeleted(0); //数据同步 String s1 = "insert into blade_notice(id,title,category,release_time,content,create_user,create_dept,create_time,is_deleted,dept_id,cover_url,type) " + "values(" + "'" + notice.getId() + "'" + "," + "'" + notice.getTitle() + "'" + "," + "'" + notice.getCategory() + "'" + "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(notice.getReleaseTime()) + "'" + "," + "'" + notice.getContent() + "'" + "," + "'" + notice.getCreateUser() + "'" + "," + "'" + notice.getCreateDept() + "'" + "," + "'" + new SimpleDateFormat("yyyy-MM-dd").format(notice.getCreateTime()) + "'" + "," + "'" + notice.getIsDeleted() + "'" + "," + "'" + notice.getDeptId() + "'" + "," + "'" + notice.getCoverUrl() + "'" + "," + "'" +notice.getType() + "'" + ")"; FtpUtil.sqlFileUpload(s1); }else { //修改 status = noticeService.updateById(notice); //内网同步 String s1 = "update blade_notice set title = " + "'" + notice.getTitle() + "'" + ",category = " + "'" + notice.getCategory() + "'" + ",release_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(notice.getReleaseTime()) + "'" + ",content = " + "'" + notice.getContent() + "'" + ",create_user = " + "'" + notice.getCreateUser() + "'" + ",create_dept = " + "'" + notice.getCreateDept() + "'" + ",create_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(notice.getCreateTime()) + "'" + ",is_deleted = " + "'" + notice.getIsDeleted() + "'" + ",dept_id = " + "'" + notice.getDeptId() + "'" + ",cover_url = " + "'" + notice.getCoverUrl() + "'" + ",type = " + "'" + notice.getType() + "'" + " " +"where id = " + "'" + notice.getId() + "'"; FtpUtil.sqlFileUpload(s1); } return R.status(status); } /** * 删除 */ @PostMapping("/remove") @ApiOperationSupport(order = 7) @ApiOperation(value = "逻辑删除", notes = "传入notice") public R remove(@ApiParam(value = "主键集合") @RequestParam String ids) throws Exception { //内网删除 List list = Func.toLongList(ids); list.forEach(id ->{ //内网同步 String s1 = "delete from blade_notice where id = " + "'" + id + "'"; FtpUtil.sqlFileUpload(s1); }); boolean temp = noticeService.deleteLogic(Func.toLongList(ids)); return R.status(temp); } }