package com.lf.server.controller.data.upload; import com.lf.server.annotation.SysLog; import com.lf.server.entity.all.ResponseMsg; import com.lf.server.entity.all.StaticData; import com.lf.server.entity.ctrl.TabMapperEntity; import com.lf.server.entity.ctrl.UploadEntity; import com.lf.server.entity.data.DirEntity; import com.lf.server.entity.data.MetaEntity; import com.lf.server.entity.data.MetaFileEntity; import com.lf.server.entity.sys.UserEntity; import com.lf.server.helper.StringHelper; import com.lf.server.helper.WebHelper; import com.lf.server.service.all.BaseUploadService; import com.lf.server.service.data.DataLoaderService; import com.lf.server.service.data.DataUploadService; import com.lf.server.service.data.DirService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * 数据入库 * @author WWW */ @Api(tags = "数据管理\\数据上传") @RestController @RequestMapping("/dataUpload") public class UploadController extends QueryController { @Autowired protected DataLoaderService dataLoaderService; @Autowired protected BaseUploadService baseUploadService; @Autowired protected DataUploadService dataUploadService; private final static List EXT_LIST = new ArrayList<>(Arrays.asList(".xls", ".xlsx", ".mdb", ".zip")); @SysLog() @ApiOperation(value = "查询路径") @GetMapping(value = "/selectPath") public ResponseMsg selectPath() { try { String pathName = baseUploadService.selectPath(); return success(pathName); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "上传文件") @ApiImplicitParams({ @ApiImplicitParam(name = "path", value = "路径", dataType = "String", paramType = "query") }) @ResponseBody @PostMapping(value = "/uploadFiles") public ResponseMsg uploadFiles(String path, HttpServletRequest req, HttpServletResponse res) { try { List list = baseUploadService.uploadData(null, path, req, res); if (null == list || list.isEmpty()) { return fail("没有找到上传文件", null); } return success(list); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "查询文件") @ApiImplicitParams({ @ApiImplicitParam(name = "path", value = "路径", dataType = "String", paramType = "query") }) @GetMapping(value = "/selectFiles") public ResponseMsg> selectFiles(String path) { try { List list = baseUploadService.selectFiles(path, StaticData.ALL_EXTENSION); return success(list); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "查询文件") @ApiImplicitParams({ @ApiImplicitParam(name = "path", value = "路径", dataType = "String", paramType = "query") }) @GetMapping(value = "/selectFiles2") public ResponseMsg> selectFiles2(String path) { try { List list = baseUploadService.selectFiles(path, null); return success(list); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "删除文件") @ApiImplicitParams({ @ApiImplicitParam(name = "list", value = "实体类集合", dataType = "MetaEntity", paramType = "body") }) @ResponseBody @PostMapping(value = "/deleteFiles") public ResponseMsg deleteFiles(@RequestBody List list, HttpServletRequest req) { try { UserEntity ue = tokenService.getCurrentUser(req); if (ue == null) { return fail("用户未登录", null); } if (null == list || list.isEmpty()) { return fail("没有找到文件", null); } int rows = baseUploadService.deleteFiles(list); return success("成功", rows); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "查询映射") @ApiImplicitParams({ @ApiImplicitParam(name = "path", value = "路径", dataType = "String", paramType = "query", example = "20230109010101"), @ApiImplicitParam(name = "dirid", value = "目录ID", dataType = "Integer", paramType = "query", example = "1"), @ApiImplicitParam(name = "epsgCode", value = "坐标编码", dataType = "String", paramType = "query", example = "EPSG:4490") }) @GetMapping(value = "/selectMappers") public ResponseMsg selectMappers(String path, Integer dirid, String epsgCode) { try { if (StringHelper.isEmpty(path) || StringHelper.isEmpty(epsgCode) || null == dirid) { return fail("路径、目录ID和坐标编码不能为空"); } if (1 > uploadService.selectCount4Coord(epsgCode)) { return fail("坐标编码" + epsgCode + "不存在"); } DirEntity dir = dirService.selectDir(dirid); if (null == dir) { return fail("目录ID=" + dirid + "不存在"); } List list = dataLoaderService.selectMappers(path); return success(list); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "插入文件") @ApiImplicitParams({ @ApiImplicitParam(name = "entity", value = "上传实体类", dataType = "UploadEntity", paramType = "body") }) @ResponseBody @PostMapping(value = "/insertFiles") public ResponseMsg insertFiles(@RequestBody UploadEntity entity, HttpServletRequest req) { try { UserEntity ue = tokenService.getCurrentUser(req); if (ue == null) { return fail("用户未登录", null); } if (null == entity || null == entity.getMetaEntity()) { return fail("元数据信息为空", null); } if (null == entity.getFileEntities() || entity.getFileEntities().isEmpty()) { return fail("没有找到上传文件", null); } MetaEntity me = entity.getMetaEntity(); me.setCreateTime(WebHelper.getCurrentTimestamp()); // me.setBatch(StringHelper.YMDHMS_FORMAT.format(new Date(me.getCreateTime().getTime()))) me.setCreateUser(ue.getId()); int rows = dataUploadService.insertFiles(me, entity.getFileEntities()); return success("成功", rows); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "插入文件") @ApiImplicitParams({ @ApiImplicitParam(name = "entity", value = "上传实体类", dataType = "UploadEntity", paramType = "body") }) @ResponseBody @PostMapping(value = "/insertFiles2") public ResponseMsg insertFiles2(@RequestBody UploadEntity entity, HttpServletRequest req) { try { UserEntity ue = tokenService.getCurrentUser(req); if (ue == null) { return fail("用户未登录", null); } if (null == entity || null == entity.getMetaEntity()) { return fail("元数据信息为空", null); } if (null == entity.getFileEntities() || entity.getFileEntities().isEmpty()) { return fail("没有找到上传文件", null); } MetaEntity me = entity.getMetaEntity(); me.setCreateTime(WebHelper.getCurrentTimestamp()); // me.setBatch(StringHelper.YMDHMS_FORMAT.format(new Date(me.getCreateTime().getTime()))) me.setCreateUser(ue.getId()); dataLoaderService.insertFiles(me, entity.getFileEntities(), entity.getTabEntities()); return success("成功", entity.getTabEntities()); } catch (Exception ex) { return fail(ex.getMessage(), null); } } @SysLog() @ApiOperation(value = "删除元数据") @ApiImplicitParams({ @ApiImplicitParam(name = "ids", value = "ID数组", dataType = "Integer", paramType = "query", example = "1,2") }) @GetMapping(value = "/deleteMetas") public ResponseMsg deleteMetas(@RequestParam List ids) { try { if (ids == null || ids.isEmpty()) { return fail("id数组不能为空", -1); } int count = metaService.deletes(ids); return success(count); } catch (Exception ex) { return fail(ex.getMessage(), -1); } } }