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());
}
//鍒ゆ柇琛ㄥ悕鏄惁姝e父
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());
}
//鍒ゆ柇琛ㄥ悕鏄惁姝e父
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());
}
}
}