package com.product.admin.controller; import java.lang.reflect.Method; import java.util.Date; import javax.servlet.http.HttpServletRequest; import com.product.admin.config.CmnConst; import com.product.admin.config.SystemCode; import com.product.admin.service.PasswordSecurityService; import com.product.admin.service.idel.IPasswordSecurityService; import com.product.common.lang.StringUtils; import com.product.core.permission.PermissionService; import com.product.core.spring.context.SpringBeanUtil; import com.product.module.sys.config.SystemErrorCode; import com.product.util.BaseUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import com.product.core.config.CoreConst; import com.product.core.controller.support.AbstractBaseController; import com.product.core.entity.FieldSetEntity; import com.product.core.entity.RequestParameterEntity; import com.product.core.exception.BaseException; import com.product.core.spring.context.SpringMVCContextHolder; import com.product.module.sys.version.ApiVersion; /** * Copyright LX-BASE * * @Title: PasswordSecurityController * @Project: LX-BASE-SERVER * @Date: 2020-05-30 17:29 * @Author: ZhouJie * @Description: 密码安全设置 */ @RestController @RequestMapping("/api/passwordsecurity") public class PasswordSecurityController extends AbstractBaseController { @Autowired private PasswordSecurityService passwordSecurityService; /** * 数据权限验证 */ @Autowired PermissionService permissionService; /** * @Date: 2020-05-30 13:52 * @Author: ZhouJie * @Description: 查看密码安全强度信息 */ @RequestMapping(value = "/list-pwdsecurity/{version}", method = RequestMethod.POST) @ApiVersion(1) public String listPwdSecurityInfo(HttpServletRequest request) { try { FieldSetEntity fse = null; Object bean = request.getAttribute(CoreConst.API_POST_REQUEST_DATA); if (bean != null) { RequestParameterEntity reqp = (RequestParameterEntity) bean; fse = reqp.getFormData(); } if (bean == null || fse == null) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); } //判断表名是否正常 if (!CmnConst.PRODUCT_SYS_PASSWORD_SECURITY.equals(fse.getTableName())) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText()); return this.error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText()); } Object systemOrgLevelsService = SpringBeanUtil.getBean("systemOrgLevelsService"); if (systemOrgLevelsService != null && systemOrgLevelsService.getClass() != null) { Class classz = systemOrgLevelsService.getClass(); Method listOrgLevels = classz.getMethod("listOrgLevels", FieldSetEntity.class); if (listOrgLevels != null) { fse.setValue(CmnConst.ORG_LEVEL_TYPE, 0); fse.setValue(CmnConst.CLIENT_UUID, SpringMVCContextHolder.getCurrentUser().getClient_uuid()); Object invoke = listOrgLevels.invoke(systemOrgLevelsService, fse); return BaseUtil.success(invoke, null); } } return OK_List(new FieldSetEntity()); } catch (BaseException e) { e.printStackTrace(); SpringMVCContextHolder.getSystemLogger().error(e); return this.error(e.getCode(), e.getMessageInfo()); } catch (Exception e) { e.printStackTrace(); SpringMVCContextHolder.getSystemLogger().error(e); return this.error(SystemCode.SYSTEM_PASSWORD_SECURITY_FIND_FAIL.getValue(), SystemCode.SYSTEM_PASSWORD_SECURITY_FIND_FAIL.getText()); } } /** * @Date: 2020-05-30 13:52 * @Author: ZhouJie * @Description: 查看密码安全强度信息 */ @RequestMapping(value = "/find-pwdsecurity/{version}", method = RequestMethod.POST) @ApiVersion(1) public String findPwdSecurityInfo(HttpServletRequest request) { try { FieldSetEntity fse = null; Object bean = request.getAttribute(CoreConst.API_POST_REQUEST_DATA); if (bean != null) { RequestParameterEntity reqp = (RequestParameterEntity) bean; fse = reqp.getFormData(); } if (bean == null || fse == null) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); } //判断表名是否正常 if (!CmnConst.PRODUCT_SYS_PASSWORD_SECURITY.equals(fse.getTableName())) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText()); return this.error(SystemCode.SYSTEM_TABLE_NODATA.getValue(), SystemCode.SYSTEM_TABLE_NODATA.getText()); } String org_level_uuid = fse.getString(CmnConst.UUID); //判断当前security_uuid是否存在 //周杰 2020年12月17日 上午11:16 if (StringUtils.isEmpty(org_level_uuid)) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); } //数据操作的权限验证 if (!permissionService.validDataPermission(CmnConst.PRODUCT_SYS_PASSWORD_SECURITY, fse.getUUID(), CoreConst.DATA_PERMISSION_VALID_TYPE_USER)) { SpringMVCContextHolder.getSystemLogger().error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText()); return this.error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText()); } FieldSetEntity fs = passwordSecurityService.findPwdSecurityInfo(org_level_uuid); return OK_List(fs); } catch (BaseException e) { SpringMVCContextHolder.getSystemLogger().error(e); return this.error(e.getCode(), e.getMessageInfo()); } catch (Exception e) { SpringMVCContextHolder.getSystemLogger().error(e); return this.error(SystemCode.SYSTEM_PASSWORD_SECURITY_FIND_FAIL.getValue(), SystemCode.SYSTEM_PASSWORD_SECURITY_FIND_FAIL.getText()); } } /** * @Date: 2020-05-30 13:52 * @Author: ZhouJie * @Description: 修改密码强度设置信息 */ @RequestMapping(value = "/update-pwdsecurity/{version}", method = RequestMethod.POST) @ApiVersion(1) public String updatePwdSecurity(HttpServletRequest request) { FieldSetEntity fse = null; try { Object bean = request.getAttribute(CoreConst.API_POST_REQUEST_DATA); if (bean != null) { RequestParameterEntity reqp = (RequestParameterEntity) bean; fse = reqp.getFormData(); } //判断传参是否为空 if (bean == null || fse == null) { SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText()); } fse.setValue("created_by", SpringMVCContextHolder.getCurrentUser().getUser_id());// 获取登录帐号 fse.setValue("created_utc_datetime", new Date());// 创建时间 //增加创建者和创建时间 fse.setValue("updated_by", SpringMVCContextHolder.getCurrentUser().getUser_id());//获取登录帐号 fse.setValue("updated_utc_datetime", new Date());//创建时间 //判断新增、修改 if ("security_uuid_01".equals(fse.getString("uuid"))) { IPasswordSecurityService service = (IPasswordSecurityService) getProxyInstance(passwordSecurityService); //新增密码强度 String newuuid = service.addSecurity(fse); if (!StringUtils.isEmpty(newuuid)) { return OK_Add(newuuid); } SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FUNCTION_ADD_FAIL.getValue(), SystemCode.SYSTEM_FUNCTION_ADD_FAIL.getText()); return error(SystemCode.SYSTEM_FUNCTION_ADD_FAIL.getValue(), SystemCode.SYSTEM_FUNCTION_ADD_FAIL.getText()); } //数据操作的权限验证 if (!permissionService.validDataPermission(CmnConst.PRODUCT_SYS_PASSWORD_SECURITY, fse.getUUID(), CoreConst.DATA_PERMISSION_VALID_TYPE_USER)) { SpringMVCContextHolder.getSystemLogger().error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText()); return this.error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText()); } //修改密码强度 IPasswordSecurityService service = (IPasswordSecurityService) getProxyInstance(passwordSecurityService); boolean success = service.updateSecurity(fse); if (success) { return OK(); } SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getValue(), SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getText()); return error(SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getValue(), SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getText()); } catch (BaseException e) { SpringMVCContextHolder.getSystemLogger().error(e); return this.error(e.getCode(), e.getMessageInfo()); } catch (Exception e) { SpringMVCContextHolder.getSystemLogger().error(e); return this.error(SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getValue(), SystemCode.SYSTEM_PASSWORD_SECURITY_UPDATE_FAIL.getText()); } } }