SysController.java 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775
  1. package com.qmth.distributed.print.api;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.qmth.boot.api.annotation.Aac;
  5. import com.qmth.boot.api.constant.ApiConstant;
  6. import com.qmth.boot.api.exception.ApiException;
  7. import com.qmth.distributed.print.business.bean.params.LoginParam;
  8. import com.qmth.teachcloud.common.bean.result.DictionaryResult;
  9. import com.qmth.distributed.print.business.bean.result.EditResult;
  10. import com.qmth.distributed.print.business.entity.TBSyncTask;
  11. import com.qmth.distributed.print.business.enums.DictionaryEnum;
  12. import com.qmth.distributed.print.business.enums.LoginTypeEnum;
  13. import com.qmth.distributed.print.business.service.*;
  14. import com.qmth.distributed.print.business.util.PdfUtil;
  15. import com.qmth.teachcloud.common.annotation.OperationLogDetail;
  16. import com.qmth.teachcloud.common.bean.auth.AuthBean;
  17. import com.qmth.teachcloud.common.bean.result.LoginResult;
  18. import com.qmth.teachcloud.common.bean.result.UserLoginCheckResult;
  19. import com.qmth.teachcloud.common.config.DictionaryConfig;
  20. import com.qmth.teachcloud.common.contant.SystemConstant;
  21. import com.qmth.teachcloud.common.entity.*;
  22. import com.qmth.teachcloud.common.enums.*;
  23. import com.qmth.teachcloud.common.enums.log.OperationTypeEnum;
  24. import com.qmth.teachcloud.common.service.*;
  25. import com.qmth.teachcloud.common.util.FileUtil;
  26. import com.qmth.teachcloud.common.util.Result;
  27. import com.qmth.teachcloud.common.util.ResultUtil;
  28. import com.qmth.teachcloud.common.util.ServletUtil;
  29. import io.swagger.annotations.*;
  30. import org.apache.commons.collections4.CollectionUtils;
  31. import org.apache.commons.lang3.StringUtils;
  32. import org.slf4j.Logger;
  33. import org.slf4j.LoggerFactory;
  34. import org.springframework.beans.BeanUtils;
  35. import org.springframework.beans.factory.annotation.Value;
  36. import org.springframework.transaction.annotation.Transactional;
  37. import org.springframework.validation.BindingResult;
  38. import org.springframework.web.bind.annotation.*;
  39. import org.springframework.web.multipart.MultipartFile;
  40. import javax.annotation.Resource;
  41. import javax.servlet.http.HttpServletResponse;
  42. import javax.validation.Valid;
  43. import java.io.File;
  44. import java.io.IOException;
  45. import java.io.InputStream;
  46. import java.security.NoSuchAlgorithmException;
  47. import java.util.*;
  48. import java.util.stream.Collectors;
  49. import java.util.stream.Stream;
  50. /**
  51. * @Date: 2021/3/30.
  52. */
  53. @Api(tags = "系统Controller")
  54. @RestController
  55. @RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + SystemConstant.PREFIX_URL_COMMON)
  56. public class SysController {
  57. private final static Logger log = LoggerFactory.getLogger(SysController.class);
  58. @Value("${com.qmth.logging.file-path}")
  59. private String sysLogPath;
  60. @Resource
  61. SysUserService sysUserService;
  62. @Resource
  63. BasicSchoolService basicSchoolService;
  64. @Resource
  65. BasicVerifyCodeService basicVerifyCodeService;
  66. @Resource
  67. DictionaryConfig dictionaryConfig;
  68. @Resource
  69. CommonCacheService commonCacheService;
  70. @Resource
  71. PrintCommonService printCommonService;
  72. @Resource
  73. TBTaskService tbTaskService;
  74. @Resource
  75. BasicAttachmentService basicAttachmentService;
  76. @Resource
  77. SysUserRoleService sysUserRoleService;
  78. @Resource
  79. TeachcloudCommonService teachcloudCommonService;
  80. @Resource
  81. BasicCourseService basicCourseService;
  82. @Resource
  83. BasicSemesterService basicSemesterService;
  84. @Resource
  85. private FileUploadService fileUploadService;
  86. @Resource
  87. TBSyncTaskService tbSyncTaskService;
  88. @Resource
  89. AuthInfoService authInfoService;
  90. @Resource
  91. BasicOperationLogService basicOperationLogService;
  92. @Resource
  93. ConditionService conditionService;
  94. @Resource
  95. BasicTeachClazzService basicTeachClazzService;
  96. @Resource
  97. BasicExamStudentService basicExamStudentService;
  98. /**
  99. * 登录
  100. *
  101. * @param login
  102. * @return
  103. */
  104. @ApiOperation(value = "登录")
  105. @RequestMapping(value = "/login", method = RequestMethod.POST)
  106. @ApiResponses({@ApiResponse(code = 200, message = "用户信息", response = LoginResult.class)})
  107. @Aac(auth = false)
  108. public Result login(@ApiParam(value = "用户信息", required = true) @Valid @RequestBody LoginParam login, BindingResult bindingResult) throws NoSuchAlgorithmException {
  109. if (bindingResult.hasErrors()) {
  110. return ResultUtil.error(bindingResult.getAllErrors().get(0).getDefaultMessage());
  111. }
  112. if (Objects.nonNull(login.getSchoolCode()) && login.getSchoolCode().contains("#")) {
  113. login.setSchoolCode(login.getSchoolCode().substring(0, login.getSchoolCode().indexOf("#")));
  114. }
  115. BasicSchool basicSchool = null;
  116. if (!login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  117. basicSchool = commonCacheService.schoolCache(login.getSchoolCode());
  118. if (Objects.isNull(basicSchool)) {
  119. throw ExceptionResultEnum.SCHOOL_NO_DATA.exception();
  120. }
  121. if (Objects.nonNull(basicSchool.getEnable()) && !basicSchool.getEnable()) {
  122. throw ExceptionResultEnum.SCHOOL_ENABLE.exception();
  123. }
  124. }
  125. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  126. if (Objects.nonNull(basicSchool)) {
  127. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  128. }
  129. // 账号密码登录
  130. List<SysUser> userList = null;
  131. if (LoginTypeEnum.ACCOUNT.name().equals(login.getType())) {
  132. String loginName = login.getLoginName();
  133. String password = login.getPassword();
  134. // 非空校验
  135. if (StringUtils.isBlank(loginName)) {
  136. throw ExceptionResultEnum.ERROR.exception("用户名不能为空");
  137. }
  138. if (StringUtils.isBlank(password)) {
  139. throw ExceptionResultEnum.ERROR.exception("密码不能为空");
  140. }
  141. wrapper.lambda().and(w -> w.eq(SysUser::getLoginName, loginName).or().eq(SysUser::getCode, loginName));
  142. userList = sysUserService.list(wrapper);
  143. //用户不存在
  144. if (userList == null || userList.isEmpty()) {
  145. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  146. }
  147. if (userList.size() > 1) {
  148. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  149. }
  150. SysUser sysUser = userList.get(0);
  151. if (!sysUser.getEnable()) {
  152. throw ExceptionResultEnum.ERROR.exception("用户被禁用");
  153. }
  154. if (!password.equals(userList.get(0).getPassword())) {
  155. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  156. }
  157. //2022.11.10日加入用户/密码模式是否开启短信验证
  158. if (!login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  159. SysConfig sysConfigAccount = commonCacheService.addSysConfigCache(basicSchool.getId(), SystemConstant.ACCOUNT_SMS_VERIFY);
  160. if (Objects.nonNull(sysConfigAccount) && Objects.nonNull(sysConfigAccount.getConfigValue())
  161. && Boolean.valueOf(sysConfigAccount.getConfigValue())) {
  162. // 校验验证码
  163. sysUserService.checkSmsCode(sysUser.getId(), sysUser.getMobileNumber(), login.getCode());
  164. // 如果不是共用验证码再过期
  165. SysConfig sysConfig = commonCacheService.addSysConfigCache(SystemConstant.SMS_NORMAL_CODE);
  166. Optional.ofNullable(sysConfig).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("未配置万能短信验证码"));
  167. if (!sysConfig.getConfigValue().equals(login.getCode())) {
  168. sysUserService.expiredVerifyCode(sysUser.getId(), sysUser.getMobileNumber());
  169. }
  170. }
  171. }
  172. } else if (LoginTypeEnum.PHONE.name().equals(login.getType())) {
  173. String mobileNumber = login.getMobileNumber();
  174. String code = login.getCode();
  175. // 非空校验
  176. if (StringUtils.isBlank(mobileNumber)) {
  177. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  178. }
  179. if (StringUtils.isBlank(code)) {
  180. throw ExceptionResultEnum.ERROR.exception("验证码不能为空");
  181. }
  182. wrapper.lambda().eq(SysUser::getMobileNumber, mobileNumber);
  183. userList = sysUserService.list(wrapper);
  184. //用户不存在
  185. if (userList == null || userList.isEmpty()) {
  186. throw ExceptionResultEnum.ERROR.exception("用户不存在");
  187. }
  188. if (userList.size() > 1) {
  189. throw ExceptionResultEnum.ERROR.exception("查出多个用户");
  190. }
  191. SysUser sysUser = userList.get(0);
  192. // 校验验证码
  193. sysUserService.checkSmsCode(sysUser.getId(), sysUser.getMobileNumber(), code);
  194. // 如果不是共用验证码再过期
  195. SysConfig sysConfig = commonCacheService.addSysConfigCache(SystemConstant.SMS_NORMAL_CODE);
  196. Optional.ofNullable(sysConfig).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("未配置万能短信验证码"));
  197. if (!sysConfig.getConfigValue().equals(login.getCode())) {
  198. sysUserService.expiredVerifyCode(sysUser.getId(), sysUser.getMobileNumber());
  199. }
  200. } else {
  201. throw ExceptionResultEnum.ERROR.exception("登录参数错误");
  202. }
  203. if (login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  204. userList.forEach(o -> {
  205. AuthBean authBean = teachcloudCommonService.getUserAuth(o.getId());
  206. if (Objects.nonNull(authBean) && Objects.nonNull(authBean.getRoleList()) && authBean.getRoleList().size() > 0) {
  207. if (Objects.nonNull(authBean.getSchool())) {
  208. throw ExceptionResultEnum.ERROR.exception("用户无法通过当前页面登录");
  209. }
  210. }
  211. });
  212. }
  213. SysUser sysUser = userList.get(0);
  214. LoginResult loginResult = teachcloudCommonService.login(login.getPassword(), sysUser, AppSourceEnum.SYSTEM);
  215. loginResult.setUiSetting(sysUser.getUiSetting());
  216. try {
  217. basicOperationLogService.saveOperateLogWithNoAuth(sysUser.getSchoolId(), sysUser.getId(), "用户登录", OperationTypeEnum.LOGIN, JSON.toJSONString(login));
  218. } catch (Exception e) {
  219. log.error(e.getMessage());
  220. }
  221. return ResultUtil.ok(loginResult);
  222. }
  223. /**
  224. * 登出
  225. *
  226. * @return
  227. */
  228. @ApiOperation(value = "登出")
  229. @RequestMapping(value = "/logout", method = RequestMethod.POST)
  230. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  231. @OperationLogDetail(detail = "用户登出(注销)", operationType = OperationTypeEnum.LOGOUT)
  232. public Result logout() throws NoSuchAlgorithmException {
  233. SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
  234. teachcloudCommonService.removeUserInfo(sysUser.getId(), false);
  235. return ResultUtil.ok();
  236. }
  237. /**
  238. * 发送验证码
  239. *
  240. * @param loginParam
  241. * @return
  242. */
  243. @ApiOperation(value = "发送验证码")
  244. @RequestMapping(value = "/get_verify_code", method = RequestMethod.POST)
  245. @Aac(auth = false)
  246. public Result getVerifyCode(@RequestBody LoginParam loginParam) {
  247. String mobileNumber = loginParam.getMobileNumber();
  248. if (StringUtils.isBlank(mobileNumber)) {
  249. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  250. }
  251. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  252. if (StringUtils.isNotBlank(loginParam.getSchoolCode())) {
  253. if (loginParam.getSchoolCode().contains("#")) {
  254. loginParam.setSchoolCode(loginParam.getSchoolCode().substring(0, loginParam.getSchoolCode().indexOf("#")));
  255. }
  256. BasicSchool basicSchool = commonCacheService.schoolCache(loginParam.getSchoolCode());
  257. if (Objects.nonNull(basicSchool)) {
  258. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  259. }
  260. }
  261. wrapper.lambda().eq(SysUser::getMobileNumber, mobileNumber);
  262. List<SysUser> userList = sysUserService.list(wrapper);
  263. //用户不存在
  264. if (userList == null || userList.isEmpty()) {
  265. throw ExceptionResultEnum.ERROR.exception("手机号不存在");
  266. }
  267. if (userList.size() > 1) {
  268. throw ExceptionResultEnum.ERROR.exception("手机号绑定了多个用户");
  269. }
  270. SysUser sysUser = userList.get(0);
  271. if (!sysUser.getEnable()) {
  272. throw ExceptionResultEnum.ERROR.exception("手机号被禁用");
  273. }
  274. if (SystemConstant.strNotNull(mobileNumber)) {
  275. basicVerifyCodeService.sendVeirfyCode(mobileNumber, sysUser);
  276. }
  277. int pwdCount = sysUser.getPwdCount();
  278. List<SysRole> sysRoleList = sysUserRoleService.listRoleByUserId(sysUser.getId());
  279. if (sysRoleList.stream().map(SysRole::getType).collect(Collectors.toSet()).contains(RoleTypeEnum.ADMIN)) {
  280. mobileNumber = sysUser.getLoginName() + "(特权用户)";
  281. pwdCount = 1;
  282. }
  283. UserLoginCheckResult userLoginCheckResult = new UserLoginCheckResult(sysUser.getId(), mobileNumber, pwdCount);
  284. return ResultUtil.ok(userLoginCheckResult, "");
  285. }
  286. /**
  287. * 发送验证码
  288. *
  289. * @param loginParam
  290. * @return
  291. */
  292. @ApiOperation(value = "发送验证码")
  293. @RequestMapping(value = "/get_verify_code_by_account", method = RequestMethod.POST)
  294. @Aac(auth = false)
  295. public Object getverifyCodeByAccount(@RequestBody LoginParam loginParam) {
  296. String loginName = loginParam.getLoginName();
  297. String password = loginParam.getPassword();
  298. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  299. if (StringUtils.isNotBlank(loginParam.getSchoolCode())) {
  300. if (loginParam.getSchoolCode().contains("#")) {
  301. loginParam.setSchoolCode(loginParam.getSchoolCode().substring(0, loginParam.getSchoolCode().indexOf("#")));
  302. }
  303. BasicSchool basicSchool = commonCacheService.schoolCache(loginParam.getSchoolCode());
  304. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  305. }
  306. wrapper.lambda().eq(SysUser::getLoginName, loginName);
  307. SysUser user = sysUserService.getOne(wrapper);
  308. //用户不存在
  309. if (Objects.isNull(user)) {
  310. throw ExceptionResultEnum.ERROR.exception("用户不存在");
  311. }
  312. if (!password.equals(user.getPassword())) {
  313. throw ExceptionResultEnum.ERROR.exception("密码错误");
  314. }
  315. String mobileNumber = user.getMobileNumber();
  316. if (Objects.isNull(mobileNumber)) {
  317. throw ExceptionResultEnum.ERROR.exception("用户未绑定手机号码");
  318. }
  319. basicVerifyCodeService.sendVeirfyCode(mobileNumber, user);
  320. return ResultUtil.ok(mobileNumber, "");
  321. }
  322. /**
  323. * 发送验证码(绑定手机号)
  324. *
  325. * @param loginParam
  326. * @return
  327. */
  328. @ApiOperation(value = "发送验证码(绑定手机号)")
  329. @RequestMapping(value = "/get_verify_code_for_bind", method = RequestMethod.POST)
  330. @Aac(auth = false)
  331. public Result getVerifyCodeForBind(@RequestBody LoginParam loginParam) {
  332. String loginName = loginParam.getLoginName();
  333. String password = loginParam.getPassword();
  334. String schoolCode = loginParam.getSchoolCode();
  335. if (Objects.nonNull(schoolCode) && schoolCode.contains("#")) {
  336. schoolCode = schoolCode.substring(0, schoolCode.indexOf("#"));
  337. }
  338. String mobileNumber = loginParam.getMobileNumber();
  339. if (StringUtils.isBlank(schoolCode)) {
  340. throw ExceptionResultEnum.ERROR.exception("学校代码不能为空");
  341. }
  342. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  343. BasicSchool basicSchool = commonCacheService.schoolCache(schoolCode);
  344. if (Objects.isNull(basicSchool)) {
  345. throw ExceptionResultEnum.ERROR.exception("学校不存在");
  346. }
  347. if (StringUtils.isBlank(mobileNumber)) {
  348. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  349. }
  350. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId())
  351. .eq(SysUser::getMobileNumber, mobileNumber);
  352. List<SysUser> userList = sysUserService.list(wrapper);
  353. if (userList != null && userList.size() > 0) {
  354. throw ExceptionResultEnum.ERROR.exception("手机号已使用");
  355. }
  356. // 根据账号/密码取用户ID
  357. if (StringUtils.isBlank(loginName)) {
  358. throw ExceptionResultEnum.ERROR.exception("账号不能为空");
  359. }
  360. if (StringUtils.isBlank(password)) {
  361. throw ExceptionResultEnum.ERROR.exception("密码不能为空");
  362. }
  363. QueryWrapper<SysUser> sysUserQueryWrapper = new QueryWrapper<>();
  364. sysUserQueryWrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId())
  365. .and(w -> w.eq(SysUser::getLoginName, loginName).or().eq(SysUser::getCode, loginName))
  366. .eq(SysUser::getPassword, password);
  367. SysUser sysUser = sysUserService.getOne(sysUserQueryWrapper);
  368. if (sysUser == null) {
  369. throw ExceptionResultEnum.ERROR.exception("用户数据异常");
  370. }
  371. // 发送短信验证码
  372. basicVerifyCodeService.sendVeirfyCode(mobileNumber, sysUser);
  373. int pwdCount = sysUser.getPwdCount();
  374. List<SysRole> sysRoleList = sysUserRoleService.listRoleByUserId(sysUser.getId());
  375. if (sysRoleList.stream().map(SysRole::getType).collect(Collectors.toSet()).contains(RoleTypeEnum.ADMIN)) {
  376. mobileNumber = sysUser.getLoginName() + "(特权用户)";
  377. pwdCount = 1;
  378. }
  379. UserLoginCheckResult userLoginCheckResult = new UserLoginCheckResult(sysUser.getId(), mobileNumber, pwdCount);
  380. return ResultUtil.ok(userLoginCheckResult, "");
  381. }
  382. @ApiOperation(value = "根据机构代码查询机构信息接口")
  383. @RequestMapping(value = "/school/query_by_school_code", method = RequestMethod.POST)
  384. @ApiResponses({@ApiResponse(code = 200, message = "学校信息", response = EditResult.class)})
  385. @Aac(auth = false)
  386. public Result queryBySchoolCode(@ApiParam(value = "机构code") @RequestParam(required = false) String code) {
  387. if (Objects.nonNull(code) && code.contains("#")) {
  388. code = code.substring(0, code.indexOf("#"));
  389. }
  390. Map<String, Object> map = new HashMap<>();
  391. map.put(SystemConstant.VERSION, SystemConstant.VERSION_VALUE);
  392. if (!SystemConstant.ADMIN_CODE_LIST.contains(code.toLowerCase())) {
  393. BasicSchool basicSchool = null;
  394. if (StringUtils.isNotBlank(code)) {
  395. basicSchool = commonCacheService.schoolCache(code);
  396. } else {
  397. List<BasicSchool> basicSchoolList = basicSchoolService.listByDefaultSchool(true);
  398. if (CollectionUtils.isNotEmpty(basicSchoolList)) {
  399. basicSchool = basicSchoolList.get(0);
  400. }
  401. }
  402. Optional.ofNullable(basicSchool).orElseThrow(() -> ExceptionResultEnum.SCHOOL_NO_DATA.exception());
  403. code = basicSchool.getCode();
  404. authInfoService.appHasExpired(code);
  405. SysConfig sysConfig = commonCacheService.addSysConfigCache(basicSchool.getId(), SystemConstant.ACCOUNT_SMS_VERIFY);
  406. SysConfig cardSize = commonCacheService.addSysConfigCache(basicSchool.getId(), SystemConstant.CARD_SIZE_LIST);
  407. map.put(SystemConstant.LOGO, basicSchool.getLogo());
  408. String backgroundImageUrl = null;
  409. if (StringUtils.isNotBlank(basicSchool.getBackgroundImage())) {
  410. try {
  411. backgroundImageUrl = fileUploadService.filePreview(basicSchool.getBackgroundImage());
  412. } catch (Exception e) {
  413. // 不处理,返回null
  414. }
  415. }
  416. map.put("backgroundImageUrl", backgroundImageUrl);
  417. map.put("name", basicSchool.getName());
  418. map.put("accountSmsVerify", Objects.nonNull(sysConfig) ? Boolean.valueOf(sysConfig.getConfigValue()) : false);
  419. // 若为在线激活,则允许手机号登录
  420. map.put("phoneLogin", authInfoService.allowPhoneLogin(basicSchool.getId()));
  421. map.put("schoolCode", code);
  422. // 广药命题界面提示信息
  423. map.put("examTaskInstr", basicSchool.getExamTaskInstr());
  424. map.put("cardSize",Objects.nonNull(cardSize) ? Arrays.asList(
  425. cardSize.getConfigValue().replaceAll("\\[", "").replaceAll("\\]", "").split(", ")) : null);
  426. } else {
  427. SysConfig sysConfig = commonCacheService.addSysConfigCache(SystemConstant.ADMIN_LOGO_URL);
  428. map.put(SystemConstant.LOGO, Objects.nonNull(sysConfig) ? sysConfig.getConfigValue() : null);
  429. map.put("backgroundImageUrl", null);
  430. map.put("name", null);
  431. map.put("accountSmsVerify", false);
  432. // 若为在线激活,则允许手机号登录,超管默认false
  433. map.put("phoneLogin", false);
  434. map.put("schoolCode", SystemConstant.ADMIN_CODE);
  435. }
  436. return ResultUtil.ok(map);
  437. }
  438. @ApiOperation(value = "文件上传接口")
  439. @RequestMapping(value = "/file/upload", method = RequestMethod.POST)
  440. @Transactional
  441. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  442. public Result fileUpload(@ApiParam(value = "上传文件", required = true) @RequestParam MultipartFile file,
  443. @ApiParam(value = "上传文件类型", required = true) @RequestParam UploadFileEnum type) {
  444. BasicAttachment basicAttachment = null;
  445. try {
  446. basicAttachment = printCommonService.saveAttachment(file, ServletUtil.getRequestMd5(), type);
  447. if (Objects.isNull(basicAttachment)) {
  448. throw ExceptionResultEnum.ATTACHMENT_ERROR.exception();
  449. }
  450. } catch (Exception e) {
  451. log.error(SystemConstant.LOG_ERROR, e);
  452. if (Objects.nonNull(basicAttachment)) {
  453. basicAttachmentService.deleteAttachment(basicAttachment);
  454. }
  455. if (e instanceof ApiException) {
  456. ResultUtil.error((ApiException) e, ((ApiException) e).getCode(), e.getMessage());
  457. } else {
  458. ResultUtil.error(e.getMessage());
  459. }
  460. }
  461. return ResultUtil.ok(new EditResult(basicAttachment.getId(), teachcloudCommonService.filePreview(basicAttachment.getPath()), basicAttachment.getPages()));
  462. }
  463. @ApiOperation(value = "考试试卷文件上传接口")
  464. @RequestMapping(value = "/file/exam_paper_upload", method = RequestMethod.POST)
  465. @Transactional
  466. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  467. public Result fileExamPaperUpload(@ApiParam(value = "上传文件", required = true) @RequestParam MultipartFile file,
  468. @ApiParam(value = "上传文件类型", required = true) @RequestParam UploadFileEnum type) {
  469. Map<String, EditResult> resultMap = new HashMap<>();
  470. BasicAttachment basicOriginalAttachment = null;
  471. BasicAttachment basicTranslateAttachment = null;
  472. File pdfOriginalFile = null;
  473. File localTempFile = null;
  474. try {
  475. pdfOriginalFile = FileUtil.multipartFileToFile(file);
  476. PageSizeEnum pageSizeEnum = PdfUtil.getPdfFormat(pdfOriginalFile);
  477. basicOriginalAttachment = printCommonService.saveAttachment(file, ServletUtil.getRequestMd5(), type);
  478. if (Objects.isNull(basicOriginalAttachment)) {
  479. throw ExceptionResultEnum.ATTACHMENT_ERROR.exception();
  480. }
  481. EditResult original = new EditResult(basicOriginalAttachment.getId(), teachcloudCommonService.filePreview(basicOriginalAttachment.getPath()), basicOriginalAttachment.getPages(), pageSizeEnum);
  482. EditResult translate = new EditResult();
  483. BeanUtils.copyProperties(original, translate);
  484. // switch (pageSizeEnum) {
  485. // case A3:
  486. // basicOriginalAttachment = printCommonService.saveAttachment(file, ServletUtil.getRequestMd5(), type);
  487. // if (Objects.isNull(basicOriginalAttachment)) {
  488. // throw ExceptionResultEnum.ATTACHMENT_ERROR.exception();
  489. // }
  490. // original.setId(basicOriginalAttachment.getId());
  491. // original.setUrl(teachcloudCommonService.filePreview(basicOriginalAttachment.getPath()));
  492. // original.setPages(basicOriginalAttachment.getPages());
  493. //
  494. // BeanUtils.copyProperties(original, translate);
  495. // break;
  496. // case A4:
  497. // basicOriginalAttachment = printCommonService.saveAttachment(file, ServletUtil.getRequestMd5(), type);
  498. // if (Objects.isNull(basicOriginalAttachment)) {
  499. // throw ExceptionResultEnum.ATTACHMENT_ERROR.exception();
  500. // }
  501. // original.setId(basicOriginalAttachment.getId());
  502. // original.setUrl(teachcloudCommonService.filePreview(basicOriginalAttachment.getPath()));
  503. // original.setPages(basicOriginalAttachment.getPages());
  504. //
  505. // String destUrl = dictionaryConfig.fssLocalPdfDomain().getConfig() + File.separator + file.getOriginalFilename();
  506. // localTempFile = new File(destUrl);
  507. // OutputStream out = new FileOutputStream(localTempFile);
  508. // PdfUtil.concatPDFs(new FileInputStream(pdfOriginalFile), out, false);
  509. // // File转换成MutipartFile
  510. // FileInputStream inputStream = new FileInputStream(localTempFile);
  511. // MultipartFile multipartFile = new MockMultipartFile(localTempFile.getName(), localTempFile.getName(), ContentType.APPLICATION_OCTET_STREAM.toString(), inputStream);
  512. // basicTranslateAttachment = printCommonService.saveAttachment(multipartFile, DigestUtils.md5Hex(multipartFile.getBytes()), type);
  513. // translate.setId(basicTranslateAttachment.getId());
  514. // translate.setUrl(teachcloudCommonService.filePreview(basicTranslateAttachment.getPath()));
  515. // translate.setPages(basicTranslateAttachment.getPages());
  516. // break;
  517. // default:
  518. // throw ExceptionResultEnum.ERROR.exception("请上传A4或A3格式的试卷文件");
  519. // }
  520. resultMap.put("original", original);
  521. resultMap.put("translate", translate);
  522. } catch (Exception e) {
  523. log.error(SystemConstant.LOG_ERROR, e);
  524. if (Objects.nonNull(basicOriginalAttachment)) {
  525. basicAttachmentService.deleteAttachment(basicOriginalAttachment);
  526. }
  527. if (Objects.nonNull(basicTranslateAttachment)) {
  528. basicAttachmentService.deleteAttachment(basicTranslateAttachment);
  529. }
  530. if (e instanceof ApiException) {
  531. ResultUtil.error((ApiException) e, ((ApiException) e).getCode(), e.getMessage());
  532. } else {
  533. ResultUtil.error(e.getMessage());
  534. }
  535. } finally {
  536. if (Objects.nonNull(localTempFile) && Objects.nonNull(dictionaryConfig.sysDomain()) && dictionaryConfig.sysDomain().isOss()) {
  537. FileUtil.deleteFile(localTempFile);
  538. }
  539. if (Objects.nonNull(pdfOriginalFile) && Objects.nonNull(dictionaryConfig.sysDomain())) {
  540. FileUtil.deleteFile(pdfOriginalFile);
  541. }
  542. }
  543. return ResultUtil.ok(resultMap);
  544. }
  545. @ApiOperation(value = "文件下载接口")
  546. @RequestMapping(value = "/file/download", method = RequestMethod.POST)
  547. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  548. public Result fileDownload(@ApiParam(value = "任务id", required = true) @RequestParam String id,
  549. @ApiParam(value = "下载文件类型", required = true) @RequestParam DownloadFileEnum type) {
  550. String path = null;
  551. if (DownloadFileEnum.SYNC_REPORT.equals(type)) {
  552. TBSyncTask tbSyncTask = tbSyncTaskService.getById(SystemConstant.convertIdToLong(id));
  553. if (Objects.isNull(tbSyncTask)) {
  554. throw ExceptionResultEnum.SYNC_TASK_NO_DATA.exception();
  555. }
  556. path = tbSyncTask.getReportFilePath();
  557. } else {
  558. TBTask tbTask = tbTaskService.getById(Long.parseLong(id));
  559. if (Objects.isNull(tbTask)) {
  560. throw ExceptionResultEnum.TASK_NO_DATA.exception();
  561. }
  562. switch (type) {
  563. case IMPORT_FILE:
  564. path = tbTask.getImportFilePath();
  565. break;
  566. case TASK_REPORT:
  567. path = tbTask.getReportFilePath();
  568. break;
  569. case RESULT:
  570. path = tbTask.getResultFilePath();
  571. break;
  572. case ERROR_FILE:
  573. path = tbTask.getErrorFilePath();
  574. break;
  575. default:
  576. break;
  577. }
  578. }
  579. if (Objects.isNull(path)) {
  580. throw ExceptionResultEnum.PATH_NO_DATA.exception();
  581. }
  582. return ResultUtil.ok(new EditResult(teachcloudCommonService.filePreview(path)));
  583. }
  584. @ApiOperation(value = "文件预览接口")
  585. @RequestMapping(value = "/file/preview", method = RequestMethod.POST)
  586. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  587. public Result filePreview(@ApiParam(value = "附件id", required = false, defaultValue = "") @RequestParam(value = "id", required = false, defaultValue = "") String id) {
  588. if (StringUtils.isBlank(id)) {
  589. throw ExceptionResultEnum.ERROR.exception("没有附件");
  590. } else {
  591. BasicAttachment basicAttachment = basicAttachmentService.getById(Long.parseLong(id));
  592. return ResultUtil.ok(new EditResult(teachcloudCommonService.filePreview(basicAttachment.getPath())));
  593. }
  594. }
  595. @ApiOperation(value = "查询用户权限")
  596. @RequestMapping(value = "/get_menu", method = RequestMethod.POST)
  597. public Result getMenu() {
  598. return ResultUtil.ok(sysUserRoleService.listByUserId());
  599. }
  600. @ApiOperation(value = "获取服务器时间")
  601. @RequestMapping(value = "/get_system_time", method = RequestMethod.POST)
  602. @Aac(auth = false)
  603. public Result getSystemTime() {
  604. return ResultUtil.ok(System.currentTimeMillis());
  605. }
  606. @ApiOperation(value = "共用接口-查询字典")
  607. @RequestMapping(value = "/get_dictionary", method = RequestMethod.POST)
  608. @ApiResponses({@ApiResponse(code = 200, message = "查询成功", response = Result.class)})
  609. public Result findDictionaryList(@ApiParam(value = "学生学院id") @RequestParam(required = false) String collegeId,
  610. @ApiParam(value = "专业id") @RequestParam(required = false) String majorId,
  611. @ApiParam(value = "班级id") @RequestParam(required = false) String clazzId,
  612. @ApiParam(value = "学生id") @RequestParam(required = false) String studentId,
  613. @ApiParam(value = "考试id") @RequestParam(required = false) String examId,
  614. @ApiParam(value = "查询字典对象", required = true) @RequestParam DictionaryEnum dictionaryEnum) {
  615. Long schoolId = SystemConstant.convertIdToLong(ServletUtil.getRequestHeaderSchoolId().toString());
  616. List<DictionaryResult> dictionaryResultList = new ArrayList<>();
  617. switch (dictionaryEnum) {
  618. case SEMESTER:
  619. List<BasicSemester> basicSemesterList = basicSemesterService.list(
  620. new QueryWrapper<BasicSemester>().lambda().eq(BasicSemester::getSchoolId, schoolId).eq(BasicSemester::getEnable, true).orderByDesc(BasicSemester::getCreateTime));
  621. dictionaryResultList = basicSemesterList.stream().map(e -> {
  622. DictionaryResult dictionaryResult = new DictionaryResult();
  623. dictionaryResult.setId(e.getId());
  624. dictionaryResult.setCode(e.getCode());
  625. dictionaryResult.setName(e.getName());
  626. return dictionaryResult;
  627. }).collect(Collectors.toList());
  628. break;
  629. case COLLEGE:
  630. List<SysOrg> sysOrgs = conditionService.listCollege();
  631. dictionaryResultList = sysOrgs.stream().map(e -> {
  632. DictionaryResult dictionaryResult = new DictionaryResult();
  633. dictionaryResult.setId(e.getId());
  634. dictionaryResult.setName(e.getName());
  635. return dictionaryResult;
  636. }).collect(Collectors.toList());
  637. break;
  638. case CLAZZ:
  639. QueryWrapper<BasicTeachClazz> clazzQueryWrapper = new QueryWrapper<>();
  640. clazzQueryWrapper.lambda().eq(BasicTeachClazz::getSchoolId, schoolId).eq(BasicTeachClazz::getExamId, examId);
  641. List<BasicTeachClazz> basicTeachClazzList = basicTeachClazzService.list(clazzQueryWrapper);
  642. List<DictionaryResult> resultBasicClazzList = basicTeachClazzList.stream().map(e -> {
  643. DictionaryResult dictionaryResult = new DictionaryResult();
  644. dictionaryResult.setId(e.getId());
  645. dictionaryResult.setName(e.getClazzName());
  646. return dictionaryResult;
  647. }).collect(Collectors.toList());
  648. dictionaryResultList.addAll(resultBasicClazzList);
  649. break;
  650. case ALL_CLAZZ: //针对归档管理临时处理用
  651. throw ExceptionResultEnum.ERROR.exception("使用枚举[CLAZZ]");
  652. case COURSE: // 考生字典查询课程
  653. dictionaryResultList = basicCourseService.list(
  654. new QueryWrapper<BasicCourse>().lambda().eq(BasicCourse::getSchoolId, schoolId)).stream().flatMap(e -> {
  655. DictionaryResult dictionaryResult = new DictionaryResult();
  656. dictionaryResult.setId(e.getId());
  657. dictionaryResult.setCode(e.getCode());
  658. dictionaryResult.setName(e.getName());
  659. return Stream.of(dictionaryResult);
  660. }).collect(Collectors.toList());
  661. break;
  662. // case STUDENT:
  663. // QueryWrapper<BasicExamStudent> studentQueryWrapper = new QueryWrapper<>();
  664. // studentQueryWrapper.lambda().eq(BasicExamStudent::getSchoolId, schoolId);
  665. // if (SystemConstant.longNotNull(SystemConstant.convertIdToLong(clazzId))) {
  666. // studentQueryWrapper.lambda().eq(BasicExamStudent::getClazzId, clazzId);
  667. // }
  668. // if (SystemConstant.longNotNull(SystemConstant.convertIdToLong(studentId))) {
  669. // studentQueryWrapper.lambda().eq(BasicExamStudent::getId, studentId);
  670. // }
  671. // List<BasicExamStudent> basicExamStudentList = basicExamStudentService.list(studentQueryWrapper);
  672. // dictionaryResultList = basicExamStudentList.stream().map(e -> {
  673. // DictionaryResult dictionaryResult = new DictionaryResult();
  674. // dictionaryResult.setId(e.getId());
  675. // dictionaryResult.setCode(e.getStudentCode());
  676. // dictionaryResult.setName(e.getStudentName());
  677. // return dictionaryResult;
  678. // }).collect(Collectors.toList());
  679. // break;
  680. default:
  681. break;
  682. }
  683. return ResultUtil.ok(dictionaryResultList);
  684. }
  685. /**
  686. * 获取用户阅卷角色
  687. *
  688. * @return
  689. */
  690. @ApiOperation(value = "获取用户阅卷角色")
  691. @RequestMapping(value = "/get_open_role", method = RequestMethod.POST)
  692. public Result getOpenRole() {
  693. SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
  694. // SpecialPrivilegeEnum userSpecialPrivilege = sysUserService.findUserSpecialPrivilegeByUserId(sysUser.getId(), sysUser.getSchoolId());
  695. List list = new ArrayList<>();
  696. // if (!SpecialPrivilegeEnum.UNIDENTIFIED.equals(userSpecialPrivilege)) {
  697. // if (SpecialPrivilegeEnum.COMPOSITE.equals(userSpecialPrivilege)) {
  698. // list.add(SpecialPrivilegeEnum.MARKER);
  699. // } else {
  700. // list.add(userSpecialPrivilege);
  701. // }
  702. // }
  703. return ResultUtil.ok(list);
  704. }
  705. /**
  706. * 下载导入模板
  707. *
  708. * @return
  709. */
  710. @ApiOperation(value = "下载导入模板")
  711. @RequestMapping(value = "/download_import_template", method = RequestMethod.POST)
  712. public void downloadImportTemplate(@RequestParam(value = "type") String type, HttpServletResponse response) throws IOException {
  713. List<String> templateEnums = Stream.of(ImportTemplateEnum.values()).map(m -> m.name()).collect(Collectors.toList());
  714. if (!templateEnums.contains(type)) {
  715. throw ExceptionResultEnum.ERROR.exception("不支持的模板类型");
  716. }
  717. ImportTemplateEnum importTemplateEnum = ImportTemplateEnum.valueOf(type);
  718. InputStream inputStream = FileUtil.getStream("temps/" + importTemplateEnum.getTemplateName());
  719. // 导出
  720. FileUtil.outputFile(response, inputStream, importTemplateEnum.getFileName());
  721. }
  722. @ApiOperation(value = "系统日志下载")
  723. @RequestMapping(value = "/log/download", method = RequestMethod.POST)
  724. @Aac(auth = false)
  725. public void sysLogDownload(HttpServletResponse response) {
  726. FileUtil.outputFile(response, new File(sysLogPath), "sys.log");
  727. }
  728. }