1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
package com.vci.web.controller;
 
import com.vci.constant.FrameWorkLangCodeConstant;
import com.vci.dto.OsLifeCycleDTO;
import com.vci.starter.web.annotation.log.VciBusinessLog;
import com.vci.starter.web.exception.VciBaseException;
import com.vci.starter.web.pagemodel.BaseQueryObject;
import com.vci.starter.web.pagemodel.BaseResult;
import com.vci.starter.web.pagemodel.DataGrid;
import com.vci.pagemodel.OsERVO;
import com.vci.pagemodel.OsLifeCycleVO;
import com.vci.starter.web.util.ControllerUtil;
import com.vci.starter.web.util.LocalFileUtil;
import com.vci.starter.web.util.VciBaseUtil;
import com.vci.web.service.OsLifeCycleServiceI;
import com.vci.starter.web.util.Lcm.Func;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
 
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.IOException;
import java.util.Date;
import java.util.List;
 
/**
 * 生命周期的控制器
 * @author weidy
 * @date 2022-3-26
 */
@RequestMapping("/lifeCycleController")
@RestController
public class OsLifeCycleController {
 
    /**
     * 生命周期的服务
     */
    @Autowired
    private OsLifeCycleServiceI lifeCycleService;
 
    /**
     * 日志
     */
    private Logger logger = LoggerFactory.getLogger(getClass());
 
    /**
     * 生命周期列表
     * @param baseQueryObject 基础查询对象,包含分页和查询
     * @return 生命周期的对象
     */
    @GetMapping("/gridLifeCycle")
    public DataGrid<OsLifeCycleVO> gridLifeCycle(BaseQueryObject baseQueryObject){
        return lifeCycleService.gridLifeCycle(baseQueryObject);
    }
 
    /**
     * 生命周期的链接线
     * @param id 编号
     * @return ER图内容
     */
    @GetMapping("/listLinesPic")
    public BaseResult<OsERVO> listLinesPic(String id){
        return BaseResult.success(lifeCycleService.listLinesPic(id));
    }
 
    /**
     * 查询应用范围
     * @param lifeCycleName 版本规则英文名称
     * @return
     */
    @GetMapping("/getUsedLifeCycleList")
    public BaseResult getUsedLifeCycleList(String lifeCycleName){
        try {
            return BaseResult.dataList(lifeCycleService.getUsedLifeCycleList(lifeCycleName));
        }catch (Exception e) {
            e.printStackTrace();
            String exceptionMessage = "版本规则应用范围查询时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            logger.error(exceptionMessage);
            return BaseResult.fail(exceptionMessage);
        }
    }
 
    /**
     * 添加单条生命周期
     * @param osLifeCycleVO
     * @return 列表的内容
     */
    @PostMapping( "/addLifeCycle")
    @VciBusinessLog(operateName = "添加生命周期")
    public BaseResult addLifeCycle(@RequestBody OsLifeCycleVO osLifeCycleVO) {
        try {
            return lifeCycleService.addLifeCycle(osLifeCycleVO) ? BaseResult.success("生命周期添加成功!"):BaseResult.fail("生命周期添加失败!");
        }catch (Exception e) {
            e.printStackTrace();
            String exceptionMessage = "添加生命周期时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            logger.error(exceptionMessage);
            return BaseResult.fail(exceptionMessage);
        }
    }
 
    /**
     * 修改单条生命周期
     * @param osLifeCycleVO
     * @return 列表的内容
     */
    @PutMapping( "/updateLifeCycle")
    @VciBusinessLog(operateName = "修改生命周期")
    public BaseResult updateLifeCycle(@RequestBody OsLifeCycleVO osLifeCycleVO) {
        try {
            return lifeCycleService.updateLifeCycle(osLifeCycleVO) ? BaseResult.success("生命周期修改成功!"):BaseResult.fail("生命周期修改失败!");
        }catch (Exception e) {
            e.printStackTrace();
            String exceptionMessage = "修改生命周期时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            logger.error(exceptionMessage);
            return BaseResult.fail(exceptionMessage);
        }
    }
 
    /**
     * 删除生命周期
     * @param lifeCycleDTOS
     * @return 列表的内容
     */
    @DeleteMapping( "/deleteLifeCycles")
    @VciBusinessLog(operateName = "删除生命周期")
    public BaseResult deleteLifeCycles(@RequestBody List<OsLifeCycleDTO> lifeCycleDTOS) {
        try {
            return lifeCycleService.deleteLifeCycles(lifeCycleDTOS) ? BaseResult.success("生命周期删除成功!"):BaseResult.fail("生命周期删除失败!");
        }catch (Exception e) {
            e.printStackTrace();
            String exceptionMessage = "删除生命周期时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            logger.error(exceptionMessage);
            return BaseResult.fail(exceptionMessage);
        }
    }
 
    /**
     * 导出选中的生命周期
     * @param exportFileName 导出的文件名
     * @param lcNames 需要导出的生命周期英文名称
     * @param response
     */
    @GetMapping( "/exportLifeCycles")
    @VciBusinessLog(operateName = "导出生命周期")
    public void exportLifeCycles(String exportFileName,String lcNames, HttpServletResponse response){
        try {
            String excelPath = lifeCycleService.exportLifeCycles(exportFileName,lcNames,false);
            ControllerUtil.writeFileToResponse(response,excelPath);
        } catch (Exception e) {
            String msg = "导出生命周期时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            try {
                //出错时
                e.printStackTrace();
                ControllerUtil.writeDataToResponse(response,"error_" + Func.format(new Date(),"yyyy-MM-dd HHmmss.sss") + ".txt", StringUtils.isNotBlank(msg)?msg.getBytes():new byte[0],null);
            } catch (IOException ioException) {
                ioException.printStackTrace();
            }
        }
    }
 
    /**
     * 下载生命周期导入模板
     * @param exportFileName
     * @param response
     */
    @GetMapping( "/downloadLifeCycleTemplate")
    @VciBusinessLog(operateName = "下载生命周期导入模板")
    public void downloadLifeCycleTemplate(String exportFileName, HttpServletResponse response){
        try {
            String excelPath = lifeCycleService.downloadLifeCycleTemplate(exportFileName);
            ControllerUtil.writeFileToResponse(response,excelPath);
        } catch (Exception e) {
            String msg = "下载生命周期导入模板时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            try {
                //出错时
                e.printStackTrace();
                ControllerUtil.writeDataToResponse(response,"error_" + Func.format(new Date(),"yyyy-MM-dd HHmmss.sss") + ".txt", StringUtils.isNotBlank(msg)?msg.getBytes():new byte[0],null);
            } catch (IOException ioException) {
                ioException.printStackTrace();
            }
        }
    }
 
    /**
     * 导入生命周期
     * @param file
     * @return
     */
    @PostMapping("/importLifeCycles")
    @VciBusinessLog(operateName = "导入生命周期")
    public BaseResult importLifeCycles(MultipartFile file){
        String excelFileName = LocalFileUtil.getDefaultTempFolder() + File.separator + LocalFileUtil.getFileNameForIE(file.getOriginalFilename());
        File file1 = new File(excelFileName);
        try {
            file.transferTo(new File(excelFileName));
            if (file != null) {
                return lifeCycleService.importLifeCycles(file1);
            } else {
                return BaseResult.fail(FrameWorkLangCodeConstant.IMPORT_FAIL, new String[]{"无导入的文件"});
            }
        }catch (Throwable e) {
            throw new VciBaseException(VciBaseUtil.getExceptionMessage(e),new String[0],e);
        }finally {
            file1.delete();
        }
    }
 
    /**
     * 查询所有跃迁事件key
     * @return
     */
    @GetMapping("/getLCEventKeys")
    public BaseResult getLCEventKeys(){
        try {
            return BaseResult.dataList(lifeCycleService.getLCEventKeys());
        }catch (Exception e) {
            e.printStackTrace();
            String exceptionMessage = "跃迁事件查询时出现错误,原因:" + VciBaseUtil.getExceptionMessage(e);
            logger.error(exceptionMessage);
            return BaseResult.fail(exceptionMessage);
        }
    }
 
}