| | |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.java110.core.annotation.Java110Cmd; |
| | | import com.java110.core.annotation.Java110Transactional; |
| | | import com.java110.core.context.DataFlowContext; |
| | | import com.java110.core.context.CmdContextUtils; |
| | | import com.java110.core.context.ICmdDataFlowContext; |
| | | import com.java110.core.event.cmd.Cmd; |
| | | import com.java110.core.event.cmd.CmdEvent; |
| | | import com.java110.core.factory.AuthenticationFactory; |
| | | import com.java110.core.factory.GenerateCodeFactory; |
| | | import com.java110.dto.file.FileDto; |
| | | import com.java110.doc.annotation.*; |
| | | import com.java110.dto.user.UserAttrDto; |
| | | import com.java110.dto.user.UserDto; |
| | | import com.java110.intf.common.IFileInnerServiceSMO; |
| | | import com.java110.intf.common.IFileRelInnerServiceSMO; |
| | | import com.java110.intf.store.IOrgStaffRelV1InnerServiceSMO; |
| | | import com.java110.intf.store.IStoreUserV1InnerServiceSMO; |
| | | import com.java110.intf.user.IUserAttrV1InnerServiceSMO; |
| | | import com.java110.intf.user.IUserInnerServiceSMO; |
| | | import com.java110.intf.user.IUserV1InnerServiceSMO; |
| | | import com.java110.po.file.FileRelPo; |
| | | import com.java110.po.org.OrgStaffRelPo; |
| | | import com.java110.po.store.StoreUserPo; |
| | | import com.java110.po.user.UserAttrPo; |
| | | import com.java110.po.user.UserPo; |
| | | import com.java110.utils.cache.MappingCache; |
| | | import com.java110.utils.constant.BusinessTypeConstant; |
| | | import com.java110.utils.constant.MappingConstant; |
| | | import com.java110.utils.constant.StoreUserRelConstant; |
| | | import com.java110.utils.constant.UserLevelConstant; |
| | |
| | | |
| | | import java.util.List; |
| | | |
| | | |
| | | @Java110CmdDoc(title = "添加员工", |
| | | description = "外部系统通过添加员工接口 添加员工,注意需要物业管理员账号登录,因为不需要传storeId 是根据管理员登录信息获取的", |
| | | httpMethod = "post", |
| | | url = "http://{ip}:{port}/app/user.staff.add", |
| | | resource = "userDoc", |
| | | author = "吴学文", |
| | | serviceCode = "user.staff.add", |
| | | seq = 3 |
| | | ) |
| | | |
| | | @Java110ParamsDoc(params = { |
| | | @Java110ParamDoc(name = "orgId", length = 30, remark = "组织ID"), |
| | | @Java110ParamDoc(name = "orgName", length = 64, remark = "组织名称"), |
| | | @Java110ParamDoc(name = "name", length = 64, remark = "名称"), |
| | | @Java110ParamDoc(name = "sex", length = 64, remark = "性别 0女 1男"), |
| | | @Java110ParamDoc(name = "email", length = 64, remark = "邮箱"), |
| | | @Java110ParamDoc(name = "tel", length = 11, remark = "手机号"), |
| | | @Java110ParamDoc(name = "address", length = 64, remark = "地址"), |
| | | @Java110ParamDoc(name = "relCd", length = 64, remark = "岗位,普通员工 1000 部门经理 2000 部门副经理 3000 部门组长 4000 分公司总经理 5000 分公司副总经理 6000 总经理助理 7000 总公司总经理 8000 总公司副总经理 9000"), |
| | | }) |
| | | |
| | | @Java110ResponseDoc( |
| | | params = { |
| | | @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "返回编号,0 成功 其他失败"), |
| | | @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "成功", remark = "描述"), |
| | | } |
| | | ) |
| | | |
| | | @Java110ExampleDoc( |
| | | reqBody = "{\"orgId\":\"102022091988250052\",\"orgName\":\"演示物业 / 件部\",\"username\":\"张三\",\"sex\":\"0\",\"email\":\"231@qq.com\",\"tel\":\"123\",\"address\":\"123\",\"relCd\":\"1000\",\"photo\":\"\",\"name\":\"张三\"}", |
| | | resBody = "{'code':0,'msg':'成功'}" |
| | | ) |
| | | |
| | | @Java110Cmd(serviceCode = "user.staff.add") |
| | | public class UserStaffAddCmd extends Cmd { |
| | | |
| | | |
| | | @Autowired |
| | | private IUserInnerServiceSMO userInnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IUserAttrV1InnerServiceSMO userAttrV1InnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IStoreUserV1InnerServiceSMO storeUserV1InnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IFileInnerServiceSMO fileInnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IOrgStaffRelV1InnerServiceSMO orgStaffRelV1InnerServiceSMOImpl; |
| | |
| | | |
| | | @Override |
| | | public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException { |
| | | String storeId = CmdContextUtils.getStoreId(context); |
| | | Assert.hasLength(storeId, "用户未登录"); |
| | | |
| | | //获取数据上下文对象 |
| | | Assert.jsonObjectHaveKey(reqJson, "storeId", "请求参数中未包含storeId 节点,请确认"); |
| | | Assert.jsonObjectHaveKey(reqJson, "storeTypeCd", "请求参数中未包含storeTypeCd 节点,请确认"); |
| | | //判断员工手机号是否重复(员工可根据手机号登录平台) |
| | | UserDto userDto = new UserDto(); |
| | | userDto.setTel(reqJson.getString("tel")); |
| | | userDto.setUserFlag("1"); |
| | | List<UserDto> users = userInnerServiceSMOImpl.getUsers(userDto); |
| | | userDto.setLevelCd("01"); //员工 |
| | | userDto.setStoreId(storeId); |
| | | List<UserDto> users = userInnerServiceSMOImpl.getStaffs(userDto); |
| | | Assert.listIsNull(users, "员工手机号不能重复,请重新输入"); |
| | | |
| | | } |
| | | |
| | | @Override |
| | | @Java110Transactional |
| | | public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException { |
| | | String userId = ""; |
| | | String oldUserId = ""; |
| | | |
| | | String relCd = reqJson.getString("relCd");//员工 组织 岗位 |
| | | if (!reqJson.containsKey("userId") || "-1".equals(reqJson.getString("userId"))) { |
| | | //将userId 强制写成-1 |
| | | oldUserId = "-1"; |
| | | userId = GenerateCodeFactory.getUserId(); |
| | | reqJson.put("userId", userId); |
| | | //添加用户 |
| | | addUser(reqJson); |
| | | } |
| | | |
| | | userId = GenerateCodeFactory.getUserId(); |
| | | reqJson.put("userId", userId); |
| | | reqJson.put("relCd", "-1".equals(oldUserId) ? StoreUserRelConstant.REL_COMMON : StoreUserRelConstant.REL_ADMIN); |
| | | //添加用户 |
| | | addUser(reqJson); |
| | | reqJson.put("userId", userId); |
| | | if (!reqJson.containsKey("relCd") || StringUtil.isEmpty(reqJson.getString("relCd"))) { |
| | | reqJson.put("relCd", StoreUserRelConstant.REL_COMMON); |
| | | } |
| | | addStaff(reqJson); |
| | | //重写 员工岗位 |
| | | reqJson.put("relCd", relCd); |
| | | addStaffOrg(reqJson); |
| | | int flag = 0; |
| | | if (reqJson.containsKey("photo") && !StringUtils.isEmpty(reqJson.getString("photo"))) { |
| | | FileDto fileDto = new FileDto(); |
| | | fileDto.setFileId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_file_id)); |
| | | fileDto.setFileName(fileDto.getFileId()); |
| | | fileDto.setContext(reqJson.getString("photo")); |
| | | fileDto.setSuffix("jpeg"); |
| | | fileDto.setCommunityId(reqJson.getString("communityId")); |
| | | String fileName = fileInnerServiceSMOImpl.saveFile(fileDto); |
| | | reqJson.put("photoId", fileDto.getFileId()); |
| | | reqJson.put("fileSaveName", fileName); |
| | | JSONObject businessUnit = new JSONObject(); |
| | | businessUnit.put("fileRelId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_fileRelId)); |
| | | businessUnit.put("relTypeCd", "12000"); |
| | | businessUnit.put("saveWay", "table"); |
| | | businessUnit.put("objId", userId); |
| | | businessUnit.put("fileRealName", fileDto.getFileId()); |
| | | businessUnit.put("fileSaveName", fileName); |
| | | businessUnit.put("fileRealName", reqJson.getString("photo")); |
| | | businessUnit.put("fileSaveName", reqJson.getString("photo")); |
| | | FileRelPo fileRelPo = BeanConvertUtil.covertBean(businessUnit, FileRelPo.class); |
| | | flag = fileRelInnerServiceSMOImpl.saveFileRel(fileRelPo); |
| | | if(flag <1){ |
| | | if (flag < 1) { |
| | | throw new CmdException("保存图片异常"); |
| | | } |
| | | } |
| | |
| | | Assert.jsonObjectHaveKey(paramObj, "name", "请求参数中未包含name 节点,请确认"); |
| | | //Assert.jsonObjectHaveKey(paramObj,"email","请求参数中未包含email 节点,请确认"); |
| | | Assert.jsonObjectHaveKey(paramObj, "tel", "请求参数中未包含tel 节点,请确认"); |
| | | Assert.jsonObjectHaveKey(paramObj, "orgId", "请求报文格式错误或未包含部门信息"); |
| | | Assert.jsonObjectHaveKey(paramObj, "address", "请求报文格式错误或未包含地址信息"); |
| | | Assert.jsonObjectHaveKey(paramObj, "sex", "请求报文格式错误或未包含性别信息"); |
| | | Assert.jsonObjectHaveKey(paramObj, "relCd", "请求报文格式错误或未包含员工角色"); |
| | | |
| | | |
| | | if (paramObj.containsKey("email") && !StringUtil.isEmpty(paramObj.getString("email"))) { |
| | |
| | | if (flag < 1) { |
| | | throw new CmdException("保存用户异常"); |
| | | } |
| | | //todo 保存用户身份证号 |
| | | saveUserIdCard(userPo, paramObj); |
| | | } |
| | | |
| | | /** |
| | | * 保存用户身份证号 |
| | | * |
| | | * @param userPo |
| | | * @param paramObj |
| | | */ |
| | | private void saveUserIdCard(UserPo userPo, JSONObject paramObj) { |
| | | if (!paramObj.containsKey("idCard")) { |
| | | return; |
| | | } |
| | | |
| | | String idCard = paramObj.getString("idCard"); |
| | | if (StringUtil.isEmpty(idCard)) { |
| | | return; |
| | | } |
| | | |
| | | UserAttrPo userAttrPo = new UserAttrPo(); |
| | | userAttrPo.setAttrId(GenerateCodeFactory.getAttrId()); |
| | | userAttrPo.setSpecCd(UserAttrDto.SPEC_ID_CARD); |
| | | userAttrPo.setUserId(userPo.getUserId()); |
| | | userAttrPo.setValue(idCard); |
| | | |
| | | userAttrV1InnerServiceSMOImpl.saveUserAttr(userAttrPo); |
| | | } |
| | | |
| | | /** |
| | |
| | | |
| | | public void addStaffOrg(JSONObject paramInJson) { |
| | | |
| | | if (!paramInJson.containsKey("orgId") || StringUtil.isEmpty(paramInJson.getString("orgId"))) { |
| | | return; |
| | | } |
| | | |
| | | JSONObject businessOrgStaffRel = new JSONObject(); |
| | | businessOrgStaffRel.put("relId", "-1"); |
| | | businessOrgStaffRel.put("relId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_relId)); |
| | | businessOrgStaffRel.put("storeId", paramInJson.getString("storeId")); |
| | | businessOrgStaffRel.put("staffId", paramInJson.getString("userId")); |
| | | businessOrgStaffRel.put("orgId", paramInJson.getString("orgId")); |