SysController.java 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849
  1. package com.qmth.distributed.print.api;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.qmth.boot.api.annotation.Aac;
  4. import com.qmth.boot.api.constant.ApiConstant;
  5. import com.qmth.boot.api.exception.ApiException;
  6. import com.qmth.distributed.print.business.bean.params.LoginParam;
  7. import com.qmth.distributed.print.business.bean.result.DictionaryResult;
  8. import com.qmth.distributed.print.business.bean.result.EditResult;
  9. import com.qmth.teachcloud.common.entity.BasicExamStudent;
  10. import com.qmth.teachcloud.common.entity.BasicTeachClazz;
  11. import com.qmth.distributed.print.business.entity.TBSyncTask;
  12. import com.qmth.distributed.print.business.enums.DictionaryEnum;
  13. import com.qmth.distributed.print.business.enums.LoginTypeEnum;
  14. import com.qmth.distributed.print.business.service.*;
  15. import com.qmth.distributed.print.business.util.PdfUtil;
  16. import com.qmth.teachcloud.common.annotation.OperationLogDetail;
  17. import com.qmth.teachcloud.common.bean.auth.AuthBean;
  18. import com.qmth.teachcloud.common.bean.result.LoginResult;
  19. import com.qmth.teachcloud.common.bean.result.UserLoginCheckResult;
  20. import com.qmth.teachcloud.common.config.DictionaryConfig;
  21. import com.qmth.teachcloud.common.contant.SystemConstant;
  22. import com.qmth.teachcloud.common.entity.*;
  23. import com.qmth.teachcloud.common.enums.*;
  24. import com.qmth.teachcloud.common.enums.log.CustomizedOperationTypeEnum;
  25. import com.qmth.teachcloud.common.enums.log.SystemEnum;
  26. import com.qmth.teachcloud.common.enums.userPush.SpecialPrivilegeEnum;
  27. import com.qmth.teachcloud.common.service.*;
  28. import com.qmth.teachcloud.common.util.FileUtil;
  29. import com.qmth.teachcloud.common.util.Result;
  30. import com.qmth.teachcloud.common.util.ResultUtil;
  31. import com.qmth.teachcloud.common.util.ServletUtil;
  32. import io.swagger.annotations.*;
  33. import org.apache.commons.collections4.CollectionUtils;
  34. import org.apache.commons.lang3.StringUtils;
  35. import org.slf4j.Logger;
  36. import org.slf4j.LoggerFactory;
  37. import org.springframework.beans.BeanUtils;
  38. import org.springframework.beans.factory.annotation.Value;
  39. import org.springframework.transaction.annotation.Transactional;
  40. import org.springframework.validation.BindingResult;
  41. import org.springframework.web.bind.annotation.*;
  42. import org.springframework.web.multipart.MultipartFile;
  43. import javax.annotation.Resource;
  44. import javax.servlet.http.HttpServletResponse;
  45. import javax.validation.Valid;
  46. import java.io.File;
  47. import java.io.IOException;
  48. import java.io.InputStream;
  49. import java.security.NoSuchAlgorithmException;
  50. import java.util.*;
  51. import java.util.stream.Collectors;
  52. import java.util.stream.Stream;
  53. /**
  54. * @Date: 2021/3/30.
  55. */
  56. @Api(tags = "系统Controller")
  57. @RestController
  58. @RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + SystemConstant.PREFIX_URL_COMMON)
  59. public class SysController {
  60. private final static Logger log = LoggerFactory.getLogger(SysController.class);
  61. @Value("${com.qmth.logging.file-path}")
  62. private String sysLogPath;
  63. @Resource
  64. SysUserService sysUserService;
  65. @Resource
  66. BasicSchoolService basicSchoolService;
  67. @Resource
  68. BasicVerifyCodeService basicVerifyCodeService;
  69. @Resource
  70. DictionaryConfig dictionaryConfig;
  71. @Resource
  72. CommonCacheService commonCacheService;
  73. @Resource
  74. PrintCommonService printCommonService;
  75. @Resource
  76. TBTaskService tbTaskService;
  77. @Resource
  78. BasicAttachmentService basicAttachmentService;
  79. @Resource
  80. SysUserRoleService sysUserRoleService;
  81. @Resource
  82. TeachcloudCommonService teachcloudCommonService;
  83. @Resource
  84. BasicMajorService basicMajorService;
  85. @Resource
  86. BasicCourseService basicCourseService;
  87. @Resource
  88. BasicSemesterService basicSemesterService;
  89. @Resource
  90. private FileUploadService fileUploadService;
  91. @Resource
  92. TBSyncTaskService tbSyncTaskService;
  93. @Resource
  94. AuthInfoService authInfoService;
  95. @Resource
  96. BasicOperationLogService basicOperationLogService;
  97. @Resource
  98. ConditionService conditionService;
  99. @Resource
  100. BasicTeachClazzService basicTeachClazzService;
  101. @Resource
  102. BasicExamStudentService basicExamStudentService;
  103. /**
  104. * 登录
  105. *
  106. * @param login
  107. * @return
  108. */
  109. @ApiOperation(value = "登录")
  110. @RequestMapping(value = "/login", method = RequestMethod.POST)
  111. @ApiResponses({@ApiResponse(code = 200, message = "用户信息", response = LoginResult.class)})
  112. @Aac(auth = false)
  113. public Result login(@ApiParam(value = "用户信息", required = true) @Valid @RequestBody LoginParam login, BindingResult bindingResult) throws NoSuchAlgorithmException {
  114. if (bindingResult.hasErrors()) {
  115. return ResultUtil.error(bindingResult.getAllErrors().get(0).getDefaultMessage());
  116. }
  117. if (Objects.nonNull(login.getSchoolCode()) && login.getSchoolCode().contains("#")) {
  118. login.setSchoolCode(login.getSchoolCode().substring(0, login.getSchoolCode().indexOf("#")));
  119. }
  120. BasicSchool basicSchool = null;
  121. if (!login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  122. basicSchool = commonCacheService.schoolCache(login.getSchoolCode());
  123. if (Objects.isNull(basicSchool)) {
  124. throw ExceptionResultEnum.SCHOOL_NO_DATA.exception();
  125. }
  126. if (Objects.nonNull(basicSchool.getEnable()) && !basicSchool.getEnable()) {
  127. throw ExceptionResultEnum.SCHOOL_ENABLE.exception();
  128. }
  129. }
  130. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  131. if (Objects.nonNull(basicSchool)) {
  132. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  133. }
  134. // 账号密码登录
  135. List<SysUser> userList = null;
  136. if (LoginTypeEnum.ACCOUNT.name().equals(login.getType())) {
  137. String loginName = login.getLoginName();
  138. String password = login.getPassword();
  139. // 非空校验
  140. if (StringUtils.isBlank(loginName)) {
  141. throw ExceptionResultEnum.ERROR.exception("用户名不能为空");
  142. }
  143. if (StringUtils.isBlank(password)) {
  144. throw ExceptionResultEnum.ERROR.exception("密码不能为空");
  145. }
  146. wrapper.lambda().and(w -> w.eq(SysUser::getLoginName, loginName).or().eq(SysUser::getCode, loginName));
  147. userList = sysUserService.list(wrapper);
  148. //用户不存在
  149. if (userList == null || userList.isEmpty()) {
  150. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  151. }
  152. if (userList.size() > 1) {
  153. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  154. }
  155. SysUser sysUser = userList.get(0);
  156. if (!sysUser.getEnable()) {
  157. throw ExceptionResultEnum.ERROR.exception("用户被禁用");
  158. }
  159. if (!password.equals(userList.get(0).getPassword())) {
  160. throw ExceptionResultEnum.ERROR.exception("用户名或密码错误");
  161. }
  162. //2022.11.10日加入用户/密码模式是否开启短信验证
  163. if (!login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  164. SysConfig sysConfigAccount = commonCacheService.addSysConfigCache(basicSchool.getId(), SystemConstant.ACCOUNT_SMS_VERIFY);
  165. if (Objects.nonNull(sysConfigAccount) && Objects.nonNull(sysConfigAccount.getConfigValue())
  166. && Boolean.valueOf(sysConfigAccount.getConfigValue())) {
  167. // 校验验证码
  168. sysUserService.checkSmsCode(sysUser.getId(), sysUser.getMobileNumber(), login.getCode());
  169. // 如果不是共用验证码再过期
  170. SysConfig sysConfig = commonCacheService.addSysConfigCache(SystemConstant.SMS_NORMAL_CODE);
  171. Optional.ofNullable(sysConfig).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("未配置万能短信验证码"));
  172. if (!sysConfig.getConfigValue().equals(login.getCode())) {
  173. sysUserService.expiredVerifyCode(sysUser.getId(), sysUser.getMobileNumber());
  174. }
  175. }
  176. }
  177. } else if (LoginTypeEnum.PHONE.name().equals(login.getType())) {
  178. String mobileNumber = login.getMobileNumber();
  179. String code = login.getCode();
  180. // 非空校验
  181. if (StringUtils.isBlank(mobileNumber)) {
  182. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  183. }
  184. if (StringUtils.isBlank(code)) {
  185. throw ExceptionResultEnum.ERROR.exception("验证码不能为空");
  186. }
  187. wrapper.lambda().eq(SysUser::getMobileNumber, mobileNumber);
  188. userList = sysUserService.list(wrapper);
  189. //用户不存在
  190. if (userList == null || userList.isEmpty()) {
  191. throw ExceptionResultEnum.ERROR.exception("用户不存在");
  192. }
  193. if (userList.size() > 1) {
  194. throw ExceptionResultEnum.ERROR.exception("查出多个用户");
  195. }
  196. SysUser sysUser = userList.get(0);
  197. // 校验验证码
  198. sysUserService.checkSmsCode(sysUser.getId(), sysUser.getMobileNumber(), code);
  199. // 如果不是共用验证码再过期
  200. SysConfig sysConfig = commonCacheService.addSysConfigCache(SystemConstant.SMS_NORMAL_CODE);
  201. Optional.ofNullable(sysConfig).orElseThrow(() -> ExceptionResultEnum.ERROR.exception("未配置万能短信验证码"));
  202. if (!sysConfig.getConfigValue().equals(login.getCode())) {
  203. sysUserService.expiredVerifyCode(sysUser.getId(), sysUser.getMobileNumber());
  204. }
  205. } else {
  206. throw ExceptionResultEnum.ERROR.exception("登录参数错误");
  207. }
  208. if (login.getSchoolCode().equalsIgnoreCase(SystemConstant.ADMIN_CODE)) {
  209. userList.forEach(o -> {
  210. AuthBean authBean = teachcloudCommonService.getUserAuth(o.getId());
  211. if (Objects.nonNull(authBean) && Objects.nonNull(authBean.getRoleList()) && authBean.getRoleList().size() > 0) {
  212. if (Objects.nonNull(authBean.getSchool())) {
  213. throw ExceptionResultEnum.ERROR.exception("用户无法通过当前页面登录");
  214. }
  215. }
  216. });
  217. }
  218. SysUser sysUser = userList.get(0);
  219. LoginResult loginResult = teachcloudCommonService.login(login.getPassword(), sysUser, AppSourceEnum.SYSTEM);
  220. loginResult.setUiSetting(sysUser.getUiSetting());
  221. try {
  222. basicOperationLogService.saveOperateLogWithNoAuth(sysUser.getSchoolId(), sysUser.getOrgId(), sysUser.getId(), "用户登录", CustomizedOperationTypeEnum.LOGIN, SystemEnum.DISTRIBUTED_PRINT);
  223. } catch (Exception e) {
  224. log.error(e.getMessage());
  225. }
  226. return ResultUtil.ok(loginResult);
  227. }
  228. /**
  229. * 登出
  230. *
  231. * @return
  232. */
  233. @ApiOperation(value = "登出")
  234. @RequestMapping(value = "/logout", method = RequestMethod.POST)
  235. @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
  236. @OperationLogDetail(detail = "用户登出(注销)", customizedOperationType = CustomizedOperationTypeEnum.LOGOUT)
  237. public Result logout() throws NoSuchAlgorithmException {
  238. SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
  239. teachcloudCommonService.removeUserInfo(sysUser.getId(), false);
  240. return ResultUtil.ok();
  241. }
  242. /**
  243. * 发送验证码
  244. *
  245. * @param loginParam
  246. * @return
  247. */
  248. @ApiOperation(value = "发送验证码")
  249. @RequestMapping(value = "/get_verify_code", method = RequestMethod.POST)
  250. @Aac(auth = false)
  251. public Result getVerifyCode(@RequestBody LoginParam loginParam) {
  252. String mobileNumber = loginParam.getMobileNumber();
  253. if (StringUtils.isBlank(mobileNumber)) {
  254. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  255. }
  256. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  257. if (StringUtils.isNotBlank(loginParam.getSchoolCode())) {
  258. if (loginParam.getSchoolCode().contains("#")) {
  259. loginParam.setSchoolCode(loginParam.getSchoolCode().substring(0, loginParam.getSchoolCode().indexOf("#")));
  260. }
  261. BasicSchool basicSchool = commonCacheService.schoolCache(loginParam.getSchoolCode());
  262. if (Objects.nonNull(basicSchool)) {
  263. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  264. }
  265. }
  266. wrapper.lambda().eq(SysUser::getMobileNumber, mobileNumber);
  267. List<SysUser> userList = sysUserService.list(wrapper);
  268. //用户不存在
  269. if (userList == null || userList.isEmpty()) {
  270. throw ExceptionResultEnum.ERROR.exception("手机号不存在");
  271. }
  272. if (userList.size() > 1) {
  273. throw ExceptionResultEnum.ERROR.exception("手机号绑定了多个用户");
  274. }
  275. SysUser sysUser = userList.get(0);
  276. if (!sysUser.getEnable()) {
  277. throw ExceptionResultEnum.ERROR.exception("手机号被禁用");
  278. }
  279. if (SystemConstant.strNotNull(mobileNumber)) {
  280. basicVerifyCodeService.sendVeirfyCode(mobileNumber, sysUser);
  281. }
  282. int pwdCount = sysUser.getPwdCount();
  283. List<SysRole> sysRoleList = sysUserRoleService.listRoleByUserId(sysUser.getId());
  284. if (sysRoleList.stream().map(SysRole::getType).collect(Collectors.toSet()).contains(RoleTypeEnum.ADMIN)) {
  285. mobileNumber = sysUser.getLoginName() + "(特权用户)";
  286. pwdCount = 1;
  287. }
  288. UserLoginCheckResult userLoginCheckResult = new UserLoginCheckResult(sysUser.getId(), mobileNumber, pwdCount);
  289. return ResultUtil.ok(userLoginCheckResult, "");
  290. }
  291. /**
  292. * 发送验证码
  293. *
  294. * @param loginParam
  295. * @return
  296. */
  297. @ApiOperation(value = "发送验证码")
  298. @RequestMapping(value = "/get_verify_code_by_account", method = RequestMethod.POST)
  299. @Aac(auth = false)
  300. public Object getverifyCodeByAccount(@RequestBody LoginParam loginParam) {
  301. String loginName = loginParam.getLoginName();
  302. String password = loginParam.getPassword();
  303. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  304. if (StringUtils.isNotBlank(loginParam.getSchoolCode())) {
  305. if (loginParam.getSchoolCode().contains("#")) {
  306. loginParam.setSchoolCode(loginParam.getSchoolCode().substring(0, loginParam.getSchoolCode().indexOf("#")));
  307. }
  308. BasicSchool basicSchool = commonCacheService.schoolCache(loginParam.getSchoolCode());
  309. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId());
  310. }
  311. wrapper.lambda().eq(SysUser::getLoginName, loginName);
  312. SysUser user = sysUserService.getOne(wrapper);
  313. //用户不存在
  314. if (Objects.isNull(user)) {
  315. throw ExceptionResultEnum.ERROR.exception("用户不存在");
  316. }
  317. if (!password.equals(user.getPassword())) {
  318. throw ExceptionResultEnum.ERROR.exception("密码错误");
  319. }
  320. String mobileNumber = user.getMobileNumber();
  321. if (Objects.isNull(mobileNumber)) {
  322. throw ExceptionResultEnum.ERROR.exception("用户未绑定手机号码");
  323. }
  324. basicVerifyCodeService.sendVeirfyCode(mobileNumber, user);
  325. return ResultUtil.ok(mobileNumber, "");
  326. }
  327. /**
  328. * 发送验证码(绑定手机号)
  329. *
  330. * @param loginParam
  331. * @return
  332. */
  333. @ApiOperation(value = "发送验证码(绑定手机号)")
  334. @RequestMapping(value = "/get_verify_code_for_bind", method = RequestMethod.POST)
  335. @Aac(auth = false)
  336. public Result getVerifyCodeForBind(@RequestBody LoginParam loginParam) {
  337. String loginName = loginParam.getLoginName();
  338. String password = loginParam.getPassword();
  339. String schoolCode = loginParam.getSchoolCode();
  340. if (Objects.nonNull(schoolCode) && schoolCode.contains("#")) {
  341. schoolCode = schoolCode.substring(0, schoolCode.indexOf("#"));
  342. }
  343. String mobileNumber = loginParam.getMobileNumber();
  344. if (StringUtils.isBlank(schoolCode)) {
  345. throw ExceptionResultEnum.ERROR.exception("学校代码不能为空");
  346. }
  347. QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
  348. BasicSchool basicSchool = commonCacheService.schoolCache(schoolCode);
  349. if (Objects.isNull(basicSchool)) {
  350. throw ExceptionResultEnum.ERROR.exception("学校不存在");
  351. }
  352. if (StringUtils.isBlank(mobileNumber)) {
  353. throw ExceptionResultEnum.ERROR.exception("手机号不能为空");
  354. }
  355. wrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId())
  356. .eq(SysUser::getMobileNumber, mobileNumber);
  357. List<SysUser> userList = sysUserService.list(wrapper);
  358. if (userList != null && userList.size() > 0) {
  359. throw ExceptionResultEnum.ERROR.exception("手机号已使用");
  360. }
  361. // 根据账号/密码取用户ID
  362. if (StringUtils.isBlank(loginName)) {
  363. throw ExceptionResultEnum.ERROR.exception("账号不能为空");
  364. }
  365. if (StringUtils.isBlank(password)) {
  366. throw ExceptionResultEnum.ERROR.exception("密码不能为空");
  367. }
  368. QueryWrapper<SysUser> sysUserQueryWrapper = new QueryWrapper<>();
  369. sysUserQueryWrapper.lambda().eq(SysUser::getSchoolId, basicSchool.getId())
  370. .and(w -> w.eq(SysUser::getLoginName, loginName).or().eq(SysUser::getCode, loginName))
  371. .eq(SysUser::getPassword, password);
  372. SysUser sysUser = sysUserService.getOne(sysUserQueryWrapper);
  373. if (sysUser == null) {
  374. throw ExceptionResultEnum.ERROR.exception("用户数据异常");
  375. }
  376. // 发送短信验证码
  377. basicVerifyCodeService.sendVeirfyCode(mobileNumber, sysUser);
  378. int pwdCount = sysUser.getPwdCount();
  379. List<SysRole> sysRoleList = sysUserRoleService.listRoleByUserId(sysUser.getId());
  380. if (sysRoleList.stream().map(SysRole::getType).collect(Collectors.toSet()).contains(RoleTypeEnum.ADMIN)) {
  381. mobileNumber = sysUser.getLoginName() + "(特权用户)";
  382. pwdCount = 1;
  383. }
  384. UserLoginCheckResult userLoginCheckResult = new UserLoginCheckResult(sysUser.getId(), mobileNumber, pwdCount);
  385. return ResultUtil.ok(userLoginCheckResult, "");
  386. }
  387. @ApiOperation(value = "根据机构代码查询机构信息接口")
  388. @RequestMapping(value = "/school/query_by_school_code", method = RequestMethod.POST)
  389. @ApiResponses({@ApiResponse(code = 200, message = "学校信息", response = EditResult.class)})
  390. @Aac(auth = false)
  391. public Result queryBySchoolCode(@ApiParam(value = "机构code") @RequestParam(required = false) String code) {
  392. if (Objects.nonNull(code) && code.contains("#")) {
  393. code = code.substring(0, code.indexOf("#"));
  394. }
  395. Map<String, Object> map = new HashMap<>();
  396. map.put(SystemConstant.VERSION, SystemConstant.VERSION_VALUE);
  397. if (!SystemConstant.ADMIN_CODE.equalsIgnoreCase(code)) {
  398. BasicSchool basicSchool = null;
  399. if (StringUtils.isNotBlank(code)) {
  400. basicSchool = commonCacheService.schoolCache(code);
  401. } else {
  402. List<BasicSchool> basicSchoolList = basicSchoolService.listByDefaultSchool(true);
  403. if (CollectionUtils.isNotEmpty(basicSchoolList)) {
  404. basicSchool = basicSchoolList.get(0);
  405. }
  406. }
  407. Optional.ofNullable(basicSchool).orElseThrow(() -> ExceptionResultEnum.SCHOOL_NO_DATA.exception());
  408. code = basicSchool.getCode();
  409. authInfoService.appHasExpired(code);
  410. SysConfig sysConfig = commonCacheService.addSysConfigCache(basicSchool.getId(), SystemConstant.ACCOUNT_SMS_VERIFY);
  411. map.put(SystemConstant.LOGO, basicSchool.getLogo());
  412. String backgroundImageUrl = null;
  413. if (StringUtils.isNotBlank(basicSchool.getBackgroundImage())) {
  414. try {
  415. backgroundImageUrl = fileUploadService.filePreview(basicSchool.getBackgroundImage());
  416. } catch (Exception e) {
  417. // 不处理,返回null
  418. }
  419. }
  420. map.put("backgroundImageUrl", backgroundImageUrl);
  421. map.put("name", basicSchool.getName());
  422. map.put("accountSmsVerify", Objects.nonNull(sysConfig) ? Boolean.valueOf(sysConfig.getConfigValue()) : false);
  423. // 若为在线激活,则允许手机号登录
  424. map.put("phoneLogin", authInfoService.allowPhoneLogin(basicSchool.getId()));
  425. map.put("schoolCode", code);
  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_code", method = RequestMethod.POST)
  608. public Result getCode(@ApiParam(value = "编码类型", required = true) @RequestParam SystemCodeEnum type) {
  609. SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
  610. String number = teachcloudCommonService.getSysIncrCode(type, sysUser);
  611. return ResultUtil.ok((Object) number);
  612. }
  613. @ApiOperation(value = "共用接口-查询字典")
  614. @RequestMapping(value = "/get_dictionary", method = RequestMethod.POST)
  615. @ApiResponses({@ApiResponse(code = 200, message = "查询成功", response = Result.class)})
  616. public Result findDictionaryList(@ApiParam(value = "学生学院id") @RequestParam(required = false) String collegeId,
  617. @ApiParam(value = "专业id") @RequestParam(required = false) String majorId,
  618. @ApiParam(value = "班级id") @RequestParam(required = false) String clazzId,
  619. @ApiParam(value = "学生id") @RequestParam(required = false) String studentId,
  620. @ApiParam(value = "考试id") @RequestParam(required = false) String examId,
  621. @ApiParam(value = "查询字典对象", required = true) @RequestParam DictionaryEnum dictionaryEnum) {
  622. Long schoolId = SystemConstant.convertIdToLong(ServletUtil.getRequestHeaderSchoolId().toString());
  623. List<DictionaryResult> dictionaryResultList = new ArrayList<>();
  624. switch (dictionaryEnum) {
  625. case SEMESTER:
  626. List<BasicSemester> basicSemesterList = basicSemesterService.list(
  627. new QueryWrapper<BasicSemester>().lambda().eq(BasicSemester::getSchoolId, schoolId).eq(BasicSemester::getEnable, true).orderByDesc(BasicSemester::getCreateTime));
  628. dictionaryResultList = basicSemesterList.stream().map(e -> {
  629. DictionaryResult dictionaryResult = new DictionaryResult();
  630. dictionaryResult.setId(e.getId());
  631. dictionaryResult.setCode(e.getCode());
  632. dictionaryResult.setName(e.getName());
  633. return dictionaryResult;
  634. }).collect(Collectors.toList());
  635. break;
  636. case COLLEGE:
  637. List<SysOrg> sysOrgs = conditionService.listCollege();
  638. dictionaryResultList = sysOrgs.stream().map(e -> {
  639. DictionaryResult dictionaryResult = new DictionaryResult();
  640. dictionaryResult.setId(e.getId());
  641. dictionaryResult.setName(e.getName());
  642. return dictionaryResult;
  643. }).collect(Collectors.toList());
  644. break;
  645. // case COLLEGE:
  646. // if (Objects.nonNull(semesterId)) {
  647. // QueryWrapper<BasicExam> basicExamQueryWrapper = new QueryWrapper<>();
  648. // basicExamQueryWrapper.lambda().eq(BasicExam::getSemesterId, SystemConstant.convertIdToLong(semesterId));
  649. // List<BasicExam> basicExamList = basicExamService.list(basicExamQueryWrapper);
  650. // if (Objects.nonNull(basicExamList) && basicExamList.size() > 0) {
  651. // List<Long> examIdList = basicExamList.stream().map(BaseEntity::getId).collect(Collectors.toList());
  652. // QueryWrapper<ExamPrintPlan> examPrintPlanQueryWrapper = new QueryWrapper<>();
  653. // examPrintPlanQueryWrapper.lambda().in(ExamPrintPlan::getExamId, examIdList);
  654. // List<ExamPrintPlan> examPrintPlanList = examPrintPlanService.list(examPrintPlanQueryWrapper);
  655. // if (Objects.nonNull(examPrintPlanList) && examPrintPlanList.size() > 0) {
  656. // Set<Long> orgIdSet = examPrintPlanList.stream().map(ExamPrintPlan::getOrgId).collect(Collectors.toSet());
  657. // QueryWrapper<SysOrg> sysOrgQueryWrapper = new QueryWrapper<>();
  658. // sysOrgQueryWrapper.lambda().in(SysOrg::getId, orgIdSet);
  659. // List<SysOrg> sysOrgList = sysOrgService.list(sysOrgQueryWrapper);
  660. // List<SysOrg> newSysOrgList = new ArrayList<>(sysOrgList);
  661. // for (SysOrg s : sysOrgList) {
  662. // if (s.getType() == OrgTypeEnum.SCHOOL) {
  663. // newSysOrgList.addAll(sysOrgService.findByConnectByRootOrgId(s.getId()));
  664. // } else if (s.getType() == OrgTypeEnum.TEACHING_ROOM || s.getType() == OrgTypeEnum.FACULTY || s.getType() == OrgTypeEnum.PRINTING_HOUSE) {
  665. // newSysOrgList.addAll(sysOrgService.findByConnectByParentId(s.getId(), true, false));
  666. // }
  667. // }
  668. // Map<Long, SysOrg> sysOrgMap = new LinkedHashMap<>();
  669. // for (SysOrg s : newSysOrgList) {
  670. // if (s.getType() == OrgTypeEnum.COLLEGE) {
  671. // sysOrgMap.put(s.getId(), s);
  672. // }
  673. // }
  674. // List<DictionaryResult> finalDictionaryResultList = dictionaryResultList;
  675. // sysOrgMap.forEach((k, v) -> {
  676. // DictionaryResult dictionaryResult = new DictionaryResult();
  677. // dictionaryResult.setId(v.getId());
  678. // dictionaryResult.setCode(v.getCode());
  679. // dictionaryResult.setName(v.getName());
  680. // finalDictionaryResultList.add(dictionaryResult);
  681. // });
  682. // }
  683. // }
  684. // } else {
  685. // List<SysOrg> sysOrgList = sysOrgService.list(new QueryWrapper<SysOrg>().lambda().eq(SysOrg::getSchoolId, schoolId).eq(SysOrg::getEnable, true));
  686. // dictionaryResultList = sysOrgList.stream().map(e -> {
  687. // DictionaryResult dictionaryResult = new DictionaryResult();
  688. // dictionaryResult.setId(e.getId());
  689. // dictionaryResult.setCode(e.getCode());
  690. // dictionaryResult.setName(e.getName());
  691. // return dictionaryResult;
  692. // }).collect(Collectors.toList());
  693. // }
  694. // break;
  695. case MAJOR:
  696. QueryWrapper<BasicMajor> majorQueryWrapper = new QueryWrapper<>();
  697. majorQueryWrapper.lambda().eq(BasicMajor::getSchoolId, schoolId).eq(BasicMajor::getEnable, true);
  698. if (SystemConstant.longNotNull(SystemConstant.convertIdToLong(collegeId))) {
  699. majorQueryWrapper.lambda().eq(BasicMajor::getBelongOrgId, collegeId);
  700. }
  701. List<BasicMajor> basicMajorList = basicMajorService.list(majorQueryWrapper);
  702. dictionaryResultList = basicMajorList.stream().map(e -> {
  703. DictionaryResult dictionaryResult = new DictionaryResult();
  704. dictionaryResult.setId(e.getId());
  705. dictionaryResult.setCode(e.getCode());
  706. dictionaryResult.setName(e.getName());
  707. return dictionaryResult;
  708. }).collect(Collectors.toList());
  709. break;
  710. case CLAZZ:
  711. QueryWrapper<BasicTeachClazz> clazzQueryWrapper = new QueryWrapper<>();
  712. clazzQueryWrapper.lambda().eq(BasicTeachClazz::getSchoolId, schoolId).eq(BasicTeachClazz::getExamId, examId);
  713. List<BasicTeachClazz> basicTeachClazzList = basicTeachClazzService.list(clazzQueryWrapper);
  714. List<DictionaryResult> resultBasicClazzList = basicTeachClazzList.stream().map(e -> {
  715. DictionaryResult dictionaryResult = new DictionaryResult();
  716. dictionaryResult.setId(e.getId());
  717. dictionaryResult.setName(e.getClazzName());
  718. return dictionaryResult;
  719. }).collect(Collectors.toList());
  720. dictionaryResultList.addAll(resultBasicClazzList);
  721. break;
  722. case ALL_CLAZZ: //针对归档管理临时处理用
  723. throw ExceptionResultEnum.ERROR.exception("使用枚举[CLAZZ]");
  724. case COURSE: // 考生字典查询课程
  725. dictionaryResultList = basicCourseService.list(
  726. new QueryWrapper<BasicCourse>().lambda().eq(BasicCourse::getSchoolId, schoolId)).stream().flatMap(e -> {
  727. DictionaryResult dictionaryResult = new DictionaryResult();
  728. dictionaryResult.setId(e.getId());
  729. dictionaryResult.setCode(e.getCode());
  730. dictionaryResult.setName(e.getName());
  731. return Stream.of(dictionaryResult);
  732. }).collect(Collectors.toList());
  733. break;
  734. case STUDENT:
  735. QueryWrapper<BasicExamStudent> studentQueryWrapper = new QueryWrapper<>();
  736. studentQueryWrapper.lambda().eq(BasicExamStudent::getSchoolId, schoolId);
  737. if (SystemConstant.longNotNull(SystemConstant.convertIdToLong(clazzId))) {
  738. studentQueryWrapper.lambda().eq(BasicExamStudent::getClazzId, clazzId);
  739. }
  740. if (SystemConstant.longNotNull(SystemConstant.convertIdToLong(studentId))) {
  741. studentQueryWrapper.lambda().eq(BasicExamStudent::getId, studentId);
  742. }
  743. List<BasicExamStudent> basicExamStudentList = basicExamStudentService.list(studentQueryWrapper);
  744. dictionaryResultList = basicExamStudentList.stream().map(e -> {
  745. DictionaryResult dictionaryResult = new DictionaryResult();
  746. dictionaryResult.setId(e.getId());
  747. dictionaryResult.setCode(e.getStudentCode());
  748. dictionaryResult.setName(e.getStudentName());
  749. return dictionaryResult;
  750. }).collect(Collectors.toList());
  751. break;
  752. default:
  753. break;
  754. }
  755. return ResultUtil.ok(dictionaryResultList);
  756. }
  757. /**
  758. * 获取用户阅卷角色
  759. *
  760. * @return
  761. */
  762. @ApiOperation(value = "获取用户阅卷角色")
  763. @RequestMapping(value = "/get_open_role", method = RequestMethod.POST)
  764. public Result getOpenRole() {
  765. SysUser sysUser = (SysUser) ServletUtil.getRequestUser();
  766. SpecialPrivilegeEnum userSpecialPrivilege = sysUserService.findUserSpecialPrivilegeByUserId(sysUser.getId(), sysUser.getSchoolId());
  767. List<SpecialPrivilegeEnum> list = new ArrayList<>();
  768. if (!SpecialPrivilegeEnum.UNIDENTIFIED.equals(userSpecialPrivilege)) {
  769. if (SpecialPrivilegeEnum.COMPOSITE.equals(userSpecialPrivilege)) {
  770. list.add(SpecialPrivilegeEnum.MARKER);
  771. } else {
  772. list.add(userSpecialPrivilege);
  773. }
  774. }
  775. return ResultUtil.ok(list);
  776. }
  777. /**
  778. * 下载导入模板
  779. *
  780. * @return
  781. */
  782. @ApiOperation(value = "下载导入模板")
  783. @RequestMapping(value = "/download_import_template", method = RequestMethod.POST)
  784. public void downloadImportTemplate(@RequestParam(value = "type") String type, HttpServletResponse response) throws IOException {
  785. List<String> templateEnums = Stream.of(ImportTemplateEnum.values()).map(m -> m.name()).collect(Collectors.toList());
  786. if (!templateEnums.contains(type)) {
  787. throw ExceptionResultEnum.ERROR.exception("不支持的模板类型");
  788. }
  789. ImportTemplateEnum importTemplateEnum = ImportTemplateEnum.valueOf(type);
  790. InputStream inputStream = FileUtil.getStream("temps/" + importTemplateEnum.getTemplateName());
  791. // 导出
  792. FileUtil.outputFile(response, inputStream, importTemplateEnum.getFileName());
  793. }
  794. @ApiOperation(value = "系统日志下载")
  795. @RequestMapping(value = "/log/download", method = RequestMethod.POST)
  796. @Aac(auth = false)
  797. public void sysLogDownload(HttpServletResponse response) {
  798. FileUtil.outputFile(response, new File(sysLogPath), "sys.log");
  799. }
  800. }