1.依賴狀態枚舉
/**
* status enum
*/
public enum Status {
SUCCESS(0, "success", "成功"),
INTERNAL_SERVER_ERROR_ARGS(10000, "Internal Server Error: {0}", "服務端異常: {0}"),
REQUEST_PARAMS_NOT_VALID_ERROR(10001, "request parameter {0} is not valid", "請求參數[{0}]無效"),
CREATE_JOB_FAILED(10002, "create job failed", "創建任務失敗"),
JOB_NOT_EXISTS(10005, "job {0} not exists", "任務{0}不存在"),
SCENE_NOT_EXISTS(10055, "scene {0} not exists", "場景{0}不存在"),
UPDATE_SCENE_ERROR(10056, "update scene error", "場景更新失敗"),
DELETE_PROJECT_ERROR_JOBS_NOT_NULL(10137, "please delete the job in project first!", "請先刪除全部Job"),
STOP_JOB_FAILED(10007, "stop job failed", "停止任務失敗"),
EXECUTE_JOB_FAILED(10008, "execute job failed", "執行任務失敗"),
QUERY_JOB_FAILED(10009, "query job failed", "查詢任務失敗"),
QUERY_JOB_NODE_FAILED(40001, "query job node failed", "查詢任務節點失敗"),
STOP_JOB_NODE_FAILED(40002, "stop job node failed", "停止任務節點失敗"),
JOB_NODE_NOT_RUNNING(40003, "job node {0} is not running", "任務節點{0}已停止"),
DELETE_JOB_FAILED(10003, "query job failed", "刪除任務失敗"),
RELEASE_JOB_FAILED(40000, "release job failed", "上線任務失敗"),
JOB_STATUS_FAILED(10006, "job status failed", "任務狀態異常"),
JOB_HAS_RUNNING_INSTANCE(10061, "job {0} has running instance", "任務{0}已經提交過,請勿重復提交"),
JOB_NOT_ONLINE(10060, "job {0} not online", "任務{0}未上線"),
JOB_NOT_RUNNING(10062, "job {0} not running", "任務{0}為運行"),
USER_NAME_NULL(10004,"user name is null", "用戶名不能為空"),
USER_NOT_EXIST(10010, "user {0} not exists", "用戶[{0}]不存在"),
USER_NAME_PASSWD_ERROR(10013,"user name or password error", "用戶名或密碼錯誤"),
LOGIN_SESSION_FAILED(10014,"create session failed!", "創建session失敗"),
LOGIN_SUCCESS(10042,"login success", "登錄成功"),
IP_IS_EMPTY(10125,"ip is empty", "IP地址不能為空"),
PROJECT_ALREADY_EXISTS(10019, "project {0} already exists", "項目名稱[{0}]已存在"),
JOB_NOT_ALLOWED_EDIT(10020, "job {0} online not allowed edit", "項目名稱[{0}]已存在"),
CREATE_PROJECT_ERROR(10048,"create project error", "創建項目錯誤"),
PROJECT_NOT_FOUNT(10018, "project {0} not found ", "項目[{0}]不存在"),
UPDATE_PROJECT_ERROR(10046,"update project error", "更新項目信息錯誤"),
UPDATE_JOB_ERROR(10107,"update job error", "更新Job信息錯誤"),
UPDATE_NODE_ERROR(10108,"update node {0} error", "更新Node {0} 信息錯誤"),
USER_NO_OPERATION_PERM(30001, "user has no operation privilege", "當前用戶沒有操作權限"),
DELETE_PROJECT_ERROR(10050,"delete project error", "刪除項目錯誤"),
DELETE_JOB_ERROR(10055,"delete job error", "刪除Job錯誤"),
TARGET_KEYWORD_ERROR(10051,"target app {0} keyword error", "目標應用 {0} 關鍵字未配置"),
TARGET_ERROR(10054,"target error", "目標配置錯誤"),
CREATE_PROJECT_USER_ERROR(10052,"create project user error", "創建項目關聯用戶錯誤"),
DEL_PROJECT_USER_ERROR(10053,"del project user error", "刪除項目關系錯誤"),
USER_NO_OPERATION_PROJECT_PERM(30002, "user {0} is not has project {1} permission", "當前用戶[{0}]沒有[{1}]項目的操作權限"),
START_JOB_ERROR(50014,"start job error", "運行任務失敗"),
STOP_JOB_ERROR(50015,"stop job error", "停止任務失敗"),
STOP_JOB_NODE_ERROR(50016,"stop job node error", "停止任務節點失敗"),
QUERY_JOB_NODE_LIST_ERROR(50017,"query job node list error", "查詢任務節點失敗"),
QUERY_JOB_LIST_ERROR(50018,"query job list error", "查詢任務失敗"),
QUERY_APP_LIST_ERROR(50019,"query app list error", "查詢APP失敗"),
QUERY_INSTANCE_LIST_ERROR(50020,"query instance list error", "查詢實例失敗"),
UPDATE_APP_KEYWORD_FAILED(50021,"update app {0} keyword error", "更新應用 {0} 關鍵字失敗"),
DELETE_RE_APP_ERROR(50022,"delete app error", "刪除授權失敗"),
UPDATE_APP_KEYWORD_ERROR(50021,"update app keyword error", "更新應用關鍵字失敗"),
CLIENT_DEPLOY_ERROR(60001,"client deploy error", "客戶端部署失敗"),
JOB_IDS_IS_EMPTY(60002,"job ids is empty", "請求的ids為空"),
QUERY_APP_NO_PERMISSION(60003,"query all app no permission", "沒有權限查詢所有app"),
QUERY_PROJECT_NO_PERMISSION(60004,"query all project no permission", "沒有權限查詢所有項目"),
APP_IDS_IS_EMPTY(60005,"app id is null", "傳入的appId為空"),
;
private final int code;
private final String enMsg;
private final String zhMsg;
private Status(int code, String enMsg, String zhMsg) {
this.code = code;
this.enMsg = enMsg;
this.zhMsg = zhMsg;
}
public int getCode() {
return this.code;
}
public String getMsg() {
if (Locale.SIMPLIFIED_CHINESE.getLanguage().equals(LocaleContextHolder.getLocale().getLanguage())) {
return this.zhMsg;
} else {
return this.enMsg;
}
}
}
2.基礎controller,封裝統一返回,包含success方法,error方法
public class BaseController {
/**
* get ip address in the http request
*
* @param request http servlet request
* @return client ip address
*/
public static String getClientIpAddress(HttpServletRequest request) {
String clientIp = request.getHeader(HTTP_X_FORWARDED_FOR);
if (StringUtils.isNotEmpty(clientIp) && !clientIp.equalsIgnoreCase(HTTP_HEADER_UNKNOWN)) {
int index = clientIp.indexOf(COMMA);
if (index != -1) {
return clientIp.substring(0, index);
} else {
return clientIp;
}
}
clientIp = request.getHeader(HTTP_X_REAL_IP);
if (StringUtils.isNotEmpty(clientIp) && !clientIp.equalsIgnoreCase(HTTP_HEADER_UNKNOWN)) {
return clientIp;
}
return request.getRemoteAddr();
}
/**
* return data list
*
* @param result result code
* @return result code
*/
public Result returnDataList(Map<String, Object> result) {
Status status = (Status) result.get(Constants.STATUS);
if (status == Status.SUCCESS) {
String msg = Status.SUCCESS.getMsg();
Object datalist = result.get(Constants.DATA_LIST);
return success(msg, datalist);
} else {
Integer code = status.getCode();
String msg = (String) result.get(Constants.MSG);
return error(code, msg);
}
}
/**
* success
*
* @return success result code
*/
public Result success() {
Result result = new Result();
result.setCode(Status.SUCCESS.getCode());
result.setMsg(Status.SUCCESS.getMsg());
return result;
}
/**
* success does not need to return data
*
* @param msg success message
* @return success result code
*/
public Result success(String msg) {
Result result = new Result();
result.setCode(Status.SUCCESS.getCode());
result.setMsg(msg);
return result;
}
public Result returnDataListPaging(Map<String, Object> result) {
Status status = (Status) result.get(Constants.STATUS);
if (status == Status.SUCCESS) {
result.put(Constants.MSG, Status.SUCCESS.getMsg());
PageInfo<Object> pageInfo = (PageInfo<Object>) result.get(Constants.DATA_LIST);
return success(pageInfo.getLists(), pageInfo.getCurrentPage(), pageInfo.getTotalCount(),
pageInfo.getTotalPage());
} else {
Integer code = status.getCode();
String msg = (String) result.get(Constants.MSG);
return error(code, msg);
}
}
/**
* return data no paging
*
* @param msg success message
* @param list data list
* @return success result code
*/
public Result success(String msg, Object list) {
return getResult(msg, list);
}
/**
* return data no paging
*
* @param list success
* @return success result code
*/
public Result success(Object list) {
return getResult(Status.SUCCESS.getMsg(), list);
}
/**
* return the data use Map format, for example, passing the value of key, value, passing a value
* eg. "/user/add" then return user name: zhangsan
*
* @param msg message
* @param object success object data
* @return success result code
*/
public Result success(String msg, Map<String, Object> object) {
return getResult(msg, object);
}
/**
* return data with paging
*
* @param totalList success object list
* @param currentPage current page
* @param total total
* @param totalPage total page
* @return success result code
*/
public Result success(Object totalList, Integer currentPage,
Integer total, Integer totalPage) {
Result result = new Result();
result.setCode(Status.SUCCESS.getCode());
result.setMsg(Status.SUCCESS.getMsg());
Map<String, Object> map = new HashMap<>(4);
map.put(Constants.TOTAL_LIST, totalList);
map.put(Constants.CURRENT_PAGE, currentPage);
map.put(Constants.TOTAL_PAGE, totalPage);
map.put(Constants.TOTAL, total);
result.setData(map);
return result;
}
/**
* error handle
*
* @param code result code
* @param msg result message
* @return error result code
*/
public Result error(Integer code, String msg) {
Result result = new Result();
result.setCode(code);
result.setMsg(msg);
return result;
}
/**
* put message to map
*
* @param result result
* @param status status
* @param statusParams object messages
*/
protected void putMsg(Map<String, Object> result, Status status, Object... statusParams) {
result.put(Constants.STATUS, status);
if (statusParams != null && statusParams.length > 0) {
result.put(Constants.MSG, MessageFormat.format(status.getMsg(), statusParams));
} else {
result.put(Constants.MSG, status.getMsg());
}
}
/**
* put message to result object
*
* @param result result
* @param status status
* @param statusParams status parameters
*/
protected void putMsg(Result result, Status status, Object... statusParams) {
result.setCode(status.getCode());
if (statusParams != null && statusParams.length > 0) {
result.setMsg(MessageFormat.format(status.getMsg(), statusParams));
} else {
result.setMsg(status.getMsg());
}
}
/**
* get result
* @param msg message
* @param list object list
* @return result code
*/
private Result getResult(String msg, Object list) {
Result result = new Result();
result.setCode(Status.SUCCESS.getCode());
result.setMsg(msg);
result.setData(list);
return result;
}
}
3.統計封裝對象Result
public class Result<T> {
/**
* status
*/
private Integer code;
/**
* message
*/
private String msg;
/**
* data
*/
private T data;
public Result() {
}
public Result(Integer code, String msg) {
this.code = code;
this.msg = msg;
}
private Result(T data) {
this.code = 0;
this.data = data;
}
private Result(Status status) {
if (status != null) {
this.code = status.getCode();
this.msg = status.getMsg();
}
}
/**
* Call this function if there is success
*
* @param data data
* @param <T> type
* @return resule
*/
public static <T> Result<T> success(T data) {
return new Result<>(data);
}
/**
* Call this function if there is any error
*
* @param status status
* @return result
*/
public static Result error(Status status) {
return new Result(status);
}
/**
* Call this function if there is any error
*
* @param status status
* @param args args
* @return result
*/
public static Result errorWithArgs(Status status, Object... args) {
return new Result(status.getCode(), MessageFormat.format(status.getMsg(), args));
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public T getData() {
return data;
}
public void setData(T data) {
this.data = data;
}
@Override
public String toString() {
return "Status{" +
"code='" + code + '\'' +
", msg='" + msg + '\'' +
", data=" + data +
'}';
}
}
4.基礎service,封裝統一的業務邏輯,權限,數據
public class BaseService {
/**
* check admin
*
* @param user input user
* @return ture if administrator, otherwise return false
*/
protected boolean isAdmin(ChaosUser user) {
return user.getUserType() == UserType.ADMIN_USER;
}
/**
* check admin
*
* @param loginUser login user
* @param result result code
* @return true if administrator, otherwise false
*/
protected boolean checkAdmin(ChaosUser loginUser, Map<String, Object> result) {
//only admin can operate
if (!isAdmin(loginUser)) {
putMsg(result, Status.USER_NO_OPERATION_PERM);
return true;
}
return false;
}
/**
* put message to map
*
* @param result result code
* @param status status
* @param statusParams status message
*/
protected void putMsg(Map<String, Object> result, Status status, Object... statusParams) {
result.put(Constants.STATUS, status);
if (statusParams != null && statusParams.length > 0) {
result.put(Constants.MSG, MessageFormat.format(status.getMsg(), statusParams));
} else {
result.put(Constants.MSG, status.getMsg());
}
}
/**
* put message to result object
*
* @param result result code
* @param status status
* @param statusParams status message
*/
protected void putMsg(Result result, Status status, Object... statusParams) {
result.setCode(status.getCode());
if (statusParams != null && statusParams.length > 0) {
result.setMsg(MessageFormat.format(status.getMsg(), statusParams));
} else {
result.setMsg(status.getMsg());
}
}
/**
* get cookie info by name
* @param request request
* @param name 'sessionId'
* @return get cookie info
*/
public static Cookie getCookie(HttpServletRequest request, String name) {
Cookie[] cookies = request.getCookies();
if (cookies != null && cookies.length > 0) {
for (Cookie cookie : cookies) {
if (StringUtils.isNotEmpty(name) && name.equalsIgnoreCase(cookie.getName())) {
return cookie;
}
}
}
return null;
}
protected boolean hasPerm(ChaosUser operateUser, int groupId, List<Integer> currentGroupIds){
return isAdmin(operateUser) || currentGroupIds.contains(groupId);
}
protected boolean hasPerm(ChaosUser operateUser, String createUserName){
return operateUser.getUsername().equalsIgnoreCase(createUserName) || isAdmin(operateUser);
}
}
5.基於BaseController 寫自己的業務controller
@RestController
@RequestMapping("projects/user")
@Api(tags = "用戶授權管理")
public class ProjectUserController extends BaseController {
private static final Logger logger = LoggerFactory.getLogger(ProjectUserController.class);
@Resource
ProjectUserService projectUserService;
/**
* 添加場景
*/
@ApiOperation(value = "添加權限", notes = "添加權限")
@PostMapping("/perm/add")
public Result addProjectUser(@ApiIgnore @RequestAttribute(value = Constants.SESSION_USER) ChaosUser loginUser,
@RequestParam(value = "userNames") String userErp,
@RequestParam(value = "projectId") int projectId) {
logger.info("user {}, add perm user:{} projectId:{}", loginUser.getUsername(), userErp, projectId);
Map<String, Object> result = projectUserService.addBatch(loginUser, userErp, projectId);
return returnDataList(result);
}
/**
* 添加場景
*/
@ApiOperation(value = "查詢權限", notes = "查詢權限")
@GetMapping("/perm/list")
public Result listProjectUser(@ApiIgnore @RequestAttribute(value = Constants.SESSION_USER) ChaosUser loginUser) {
logger.info("user {}, query perm list", loginUser.getUsername());
Map<String, Object> result = projectUserService.listProjectUser();
return returnDataList(result);
}
/**
* 添加場景
*/
@ApiOperation(value = "刪除權限", notes = "刪除權限")
@DeleteMapping("/perm/del/{id}")
public Result delProjectUser(@ApiIgnore @RequestAttribute(value = Constants.SESSION_USER) ChaosUser loginUser,
@ApiParam(name = "id", value = "主鍵id", required = true) @PathVariable("id") int id) {
logger.info("user {}, query perm list", loginUser.getUsername());
Map<String, Object> result = projectUserService.delProjectUser(id);
return returnDataList(result);
}
@ApiOperation(value = "查詢全部用戶", notes = "查詢全部用戶")
@GetMapping("/all")
public Result queryAllUser(@ApiIgnore @RequestAttribute(value = Constants.SESSION_USER) ChaosUser loginUser) {
logger.info("user {}, query all user list", loginUser.getUsername());
Map<String, Object> result = projectUserService.listAllUser();
return returnDataList(result);
}
}
6.基於BaseService編寫自己的業務service
@Service
public class ProjectUserService extends BaseService {
private static final Logger logger = LoggerFactory.getLogger(ProjectUserService.class);
@Resource
ProjectUserMapper projectUserMapper;
@Resource
private ChaosLoginErpMapper loginErpMapper;
/**
* 添加權限
* @param loginUser
* @param userErp
* @param projectId
* @return
*/
public Map<String,Object> addProjectUser(ChaosUser loginUser, String userErp, int projectId){
Map<String, Object> result = Maps.newHashMap();
QueryWrapper<ProjectUser> queryWrapper = Wrappers.query();
queryWrapper.eq(ProjectUser.USER_NAME,userErp);
queryWrapper.eq(ProjectUser.PROJECT_ID,projectId);
List<ProjectUser> list = projectUserMapper.selectList(queryWrapper);
if (CollectionUtils.isEmpty(list)){
boolean permStatus = generateProjectUser(loginUser,userErp,projectId);
if (!permStatus){
putMsg(result,Status.CREATE_PROJECT_USER_ERROR,Status.CREATE_PROJECT_USER_ERROR.getMsg());
}else{
putMsg(result,Status.SUCCESS);
}
}else{
putMsg(result,Status.SUCCESS);
}
return result;
}
@Transactional
public Map<String, Object> addBatch(ChaosUser loginUser, String erps, int projectId) {
Map<String, Object> result = Maps.newHashMap();
projectUserMapper.deleteByProjectId(projectId);
if (StringUtils.isEmpty(erps)) {
putMsg(result, Status.SUCCESS);
return result;
}
String[] erpArray = erps.split(COMMA);
for (String s : erpArray) {
generateProjectUser(loginUser, s, projectId);
}
putMsg(result,Status.SUCCESS);
return result;
}
public boolean generateProjectUser(ChaosUser loginUser,String userErp,int projectId){
ProjectUser projectUser = new ProjectUser();
projectUser.setUserName(userErp);
projectUser.setProjectId(projectId);
projectUser.setCreateTime(new Date());
projectUser.setUpdateTime(new Date());
projectUser.setCreateUser(loginUser.getUsername());
projectUser.setUpdateUser(loginUser.getUsername());
return projectUserMapper.insert(projectUser) > 0;
}
/**
* 列出用戶權限
* @return
*/
public Map<String,Object> listProjectUser(){
Map<String,Object> result = Maps.newHashMap();
// List<ProjectUser> list = projectUserMapper.selectList(null);
List<ProjectUser> list = projectUserMapper.queryProjectUser();
putMsg(result,Status.SUCCESS);
result.put(Constants.DATA_LIST,list);
return result;
}
public Map<String,Object> listAllUser(){
Map<String,Object> result = Maps.newHashMap();
// List<ProjectUser> list = projectUserMapper.selectList(null);
List<ChaosLoginErp> list = loginErpMapper.selectList(null);
putMsg(result,Status.SUCCESS);
result.put(Constants.DATA_LIST,list);
return result;
}
public Map<String,Object> delProjectUser(int id){
Map<String,Object> result = Maps.newHashMap();
boolean delStatus = projectUserMapper.deleteById(id) > 0 ? true: false;
if (!delStatus){
putMsg(result,Status.DEL_PROJECT_USER_ERROR,Status.DEL_PROJECT_USER_ERROR.getMsg());
}else{
putMsg(result,Status.SUCCESS);
}
return result;
}
}