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());
|
}
|
}
|
|
|
}
|