package com.java110.user.cmd.user;
|
|
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONObject;
|
import com.java110.core.annotation.Java110Cmd;
|
import com.java110.core.context.ICmdDataFlowContext;
|
import com.java110.core.event.cmd.Cmd;
|
import com.java110.core.event.cmd.CmdEvent;
|
import com.java110.dto.store.StoreDto;
|
import com.java110.dto.user.UserDto;
|
import com.java110.intf.store.IStoreV1InnerServiceSMO;
|
import com.java110.intf.user.IPrivilegeGroupV1InnerServiceSMO;
|
import com.java110.intf.user.IUserV1InnerServiceSMO;
|
import com.java110.service.context.DataQuery;
|
import com.java110.service.smo.IQueryServiceSMO;
|
import com.java110.utils.exception.CmdException;
|
import com.java110.utils.util.Assert;
|
import com.java110.utils.util.StringUtil;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.http.HttpStatus;
|
import org.springframework.http.ResponseEntity;
|
|
import java.util.List;
|
|
@Java110Cmd(serviceCode = "query.store.privilegeGroup")
|
public class QueryStorePrivilegeGroupCmd extends Cmd {
|
|
@Autowired
|
private IStoreV1InnerServiceSMO storeV1InnerServiceSMOImpl;
|
|
@Autowired
|
private IQueryServiceSMO queryServiceSMOImpl;
|
|
@Autowired
|
private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
|
|
@Override
|
public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
|
}
|
|
@Override
|
public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
|
String userId = context.getReqHeaders().get("user-id");
|
String storeId = context.getReqHeaders().get("store-id");
|
String communityId = context.getReqHeaders().get("communityId");
|
if (StringUtil.isEmpty(userId)) {
|
userId = reqJson.getString("userId");
|
}
|
// 判断是不是管理员,管理员反馈 物业 的所角色
|
UserDto userDto = new UserDto();
|
userDto.setUserId(userId);
|
userDto.setPage(1);
|
userDto.setRow(1);
|
List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
|
Assert.listOnlyOne(userDtos, "用户不存在");
|
String storeTypeCd = "";
|
if (!reqJson.containsKey("storeTypeCd") || StringUtil.isEmpty(reqJson.getString("storeTypeCd"))) {
|
StoreDto storeDto = new StoreDto();
|
storeDto.setStoreId(storeId);
|
storeDto.setPage(1);
|
storeDto.setRow(1);
|
List<StoreDto> storeDtos = storeV1InnerServiceSMOImpl.queryStores(storeDto);
|
Assert.listOnlyOne(storeDtos, "商户不存在");
|
storeTypeCd = storeDtos.get(0).getStoreTypeCd();
|
} else {
|
storeTypeCd = reqJson.getString("storeTypeCd");
|
}
|
DataQuery dataQuery = new DataQuery();
|
dataQuery.setServiceCode("query.store.privilegeGroup");
|
JSONObject param = new JSONObject();
|
param.put("storeId", storeId);
|
param.put("storeTypeCd", storeTypeCd);
|
// modify by 吴学文 ,这块设计我感觉不合理呢,如果 我是物业公司管理员 我分配了 A小区管理员 张三 B小区管理李四,
|
// 那么李四就没法再添加角色权限 因为他们添加的权限默认没有关联小区 所以显示不出来 别人认为这个就是个bug
|
// if(!UserDto.LEVEL_CD_ADMIN.equals(userDtos.get(0).getLevelCd())){
|
// param.put("communityId", communityId);
|
// }
|
dataQuery.setRequestParams(param);
|
queryServiceSMOImpl.commonQueryService(dataQuery);
|
ResponseEntity<String> privilegeGroup = dataQuery.getResponseEntity();
|
if (privilegeGroup.getStatusCode() != HttpStatus.OK) {
|
context.setResponseEntity(privilegeGroup);
|
return;
|
}
|
JSONObject privilegeGroupObj = JSONObject.parseObject(privilegeGroup.getBody().toString());
|
Assert.jsonObjectHaveKey(privilegeGroupObj, "privilegeGroups", "查询菜单未返回privilegeGroups节点");
|
JSONArray privilegeGroups = privilegeGroupObj.getJSONArray("privilegeGroups");
|
context.setResponseEntity(new ResponseEntity<String>(privilegeGroups.toJSONString(), HttpStatus.OK));
|
}
|
}
|