|
@@ -0,0 +1,213 @@
|
|
|
|
|
+package com.java110.api.listener.owner;
|
|
|
|
|
+
|
|
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
|
|
+import com.java110.api.listener.AbstractServiceApiDataFlowListener;
|
|
|
|
|
+import com.java110.api.listener.AbstractServiceApiListener;
|
|
|
|
|
+import com.java110.core.annotation.Java110Listener;
|
|
|
|
|
+import com.java110.core.context.DataFlowContext;
|
|
|
|
|
+import com.java110.core.factory.GenerateCodeFactory;
|
|
|
|
|
+import com.java110.core.smo.file.IFileInnerServiceSMO;
|
|
|
|
|
+import com.java110.core.smo.file.IFileRelInnerServiceSMO;
|
|
|
|
|
+import com.java110.core.smo.owner.IOwnerInnerServiceSMO;
|
|
|
|
|
+import com.java110.dto.file.FileDto;
|
|
|
|
|
+import com.java110.dto.file.FileRelDto;
|
|
|
|
|
+import com.java110.dto.owner.OwnerDto;
|
|
|
|
|
+import com.java110.entity.center.AppService;
|
|
|
|
|
+import com.java110.event.service.api.ServiceDataFlowEvent;
|
|
|
|
|
+import com.java110.utils.constant.BusinessTypeConstant;
|
|
|
|
|
+import com.java110.utils.constant.CommonConstant;
|
|
|
|
|
+import com.java110.utils.constant.ResponseConstant;
|
|
|
|
|
+import com.java110.utils.constant.ServiceCodeConstant;
|
|
|
|
|
+import com.java110.utils.exception.ListenerExecuteException;
|
|
|
|
|
+import com.java110.utils.util.Assert;
|
|
|
|
|
+import com.java110.utils.util.BeanConvertUtil;
|
|
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
|
|
+import org.slf4j.Logger;
|
|
|
|
|
+import org.slf4j.LoggerFactory;
|
|
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
+import org.springframework.http.HttpHeaders;
|
|
|
|
|
+import org.springframework.http.HttpMethod;
|
|
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
|
|
+
|
|
|
|
|
+import java.util.List;
|
|
|
|
|
+import java.util.Map;
|
|
|
|
|
+
|
|
|
|
|
+/**
|
|
|
|
|
+ * @ClassName EditOwnerListener
|
|
|
|
|
+ * @Description TODO 上传业主照片
|
|
|
|
|
+ * @Author wuxw
|
|
|
|
|
+ * @Date 2019/4/28 15:19
|
|
|
|
|
+ * @Version 1.0
|
|
|
|
|
+ * add by wuxw 2019/4/28
|
|
|
|
|
+ **/
|
|
|
|
|
+@Java110Listener("uploadOwnerPhotoListener")
|
|
|
|
|
+public class UploadOwnerPhotoListener extends AbstractServiceApiListener {
|
|
|
|
|
+
|
|
|
|
|
+ private static Logger logger = LoggerFactory.getLogger(UploadOwnerPhotoListener.class);
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IFileInnerServiceSMO fileInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IOwnerInnerServiceSMO ownerInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public String getServiceCode() {
|
|
|
|
|
+ return ServiceCodeConstant.SERVICE_CODE_UPLOAD_OWNER_PHOTO;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public HttpMethod getHttpMethod() {
|
|
|
|
|
+ return HttpMethod.POST;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
|
|
|
|
|
+ Assert.jsonObjectHaveKey(reqJson, "memberId", "请求报文中未包含ownerId");
|
|
|
|
|
+ Assert.jsonObjectHaveKey(reqJson, "photo", "请求报文中未包含photo");
|
|
|
|
|
+ Assert.jsonObjectHaveKey(reqJson, "communityId", "请求报文中未包含communityId");
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
|
|
|
|
|
+ logger.debug("ServiceDataFlowEvent : {}", event);
|
|
|
|
|
+
|
|
|
|
|
+ DataFlowContext dataFlowContext = event.getDataFlowContext();
|
|
|
|
|
+ AppService service = event.getAppService();
|
|
|
|
|
+
|
|
|
|
|
+ HttpHeaders header = new HttpHeaders();
|
|
|
|
|
+ //dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.HTTP_USER_ID, "-1");
|
|
|
|
|
+ dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.HTTP_ORDER_TYPE_CD, "D");
|
|
|
|
|
+ JSONArray businesses = new JSONArray();
|
|
|
|
|
+
|
|
|
|
|
+ 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"));
|
|
|
|
|
+ if (fileInnerServiceSMOImpl.saveFile(fileDto) < 1) {
|
|
|
|
|
+ throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "保存文件出错");
|
|
|
|
|
+ }
|
|
|
|
|
+ reqJson.put("ownerPhotoId", fileDto.getFileId());
|
|
|
|
|
+
|
|
|
|
|
+ businesses.add(editOwnerPhoto(reqJson, dataFlowContext));
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+ //添加小区楼
|
|
|
|
|
+ businesses.add(editOwner(reqJson));
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ JSONObject paramInObj = super.restToCenterProtocol(businesses, dataFlowContext.getRequestCurrentHeaders());
|
|
|
|
|
+
|
|
|
|
|
+ //将 rest header 信息传递到下层服务中去
|
|
|
|
|
+ super.freshHttpHeader(header, dataFlowContext.getRequestCurrentHeaders());
|
|
|
|
|
+
|
|
|
|
|
+ ResponseEntity<String> responseEntity = this.callService(dataFlowContext, service.getServiceCode(), paramInObj);
|
|
|
|
|
+
|
|
|
|
|
+ dataFlowContext.setResponseEntity(responseEntity);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 添加小区楼信息
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param paramInJson 接口调用放传入入参
|
|
|
|
|
+ * @return 订单服务能够接受的报文
|
|
|
|
|
+ */
|
|
|
|
|
+ private JSONObject editOwner(JSONObject paramInJson) {
|
|
|
|
|
+
|
|
|
|
|
+ OwnerDto ownerDto = new OwnerDto();
|
|
|
|
|
+ ownerDto.setMemberId(paramInJson.getString("memberId"));
|
|
|
|
|
+ List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwnerMembers(ownerDto);
|
|
|
|
|
+
|
|
|
|
|
+ Assert.listOnlyOne(ownerDtos, "未查询到业主信息或查询到多条");
|
|
|
|
|
+
|
|
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_UPDATE_OWNER_INFO);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
|
|
+ JSONObject businessOwner = new JSONObject();
|
|
|
|
|
+ Map ownerDtoMap = BeanConvertUtil.beanCovertMap(ownerDtos.get(0));
|
|
|
|
|
+ businessOwner.putAll(ownerDtoMap);
|
|
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessOwner", businessOwner);
|
|
|
|
|
+
|
|
|
|
|
+ return business;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 添加物业费用
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param paramInJson 接口调用放传入入参
|
|
|
|
|
+ * @param dataFlowContext 数据上下文
|
|
|
|
|
+ * @return 订单服务能够接受的报文
|
|
|
|
|
+ */
|
|
|
|
|
+ private JSONObject editOwnerPhoto(JSONObject paramInJson, DataFlowContext dataFlowContext) {
|
|
|
|
|
+
|
|
|
|
|
+ FileRelDto fileRelDto = new FileRelDto();
|
|
|
|
|
+ fileRelDto.setRelTypeCd("10000");
|
|
|
|
|
+ fileRelDto.setObjId(paramInJson.getString("memberId"));
|
|
|
|
|
+ List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
|
|
|
|
|
+ if (fileRelDtos == null || fileRelDtos.size() == 0) {
|
|
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_SAVE_FILE_REL);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ + 2);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
|
|
+ JSONObject businessUnit = new JSONObject();
|
|
|
|
|
+ businessUnit.put("fileRelId", "-1");
|
|
|
|
|
+ businessUnit.put("relTypeCd", "10000");
|
|
|
|
|
+ businessUnit.put("saveWay", "table");
|
|
|
|
|
+ businessUnit.put("objId", paramInJson.getString("memberId"));
|
|
|
|
|
+ businessUnit.put("fileRealName", paramInJson.getString("ownerPhotoId"));
|
|
|
|
|
+ businessUnit.put("fileSaveName", paramInJson.getString("ownerPhotoId"));
|
|
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessFileRel", businessUnit);
|
|
|
|
|
+ return business;
|
|
|
|
|
+ }
|
|
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_UPDATE_FILE_REL);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ + 2);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
|
|
+ JSONObject businessUnit = new JSONObject();
|
|
|
|
|
+ businessUnit.putAll(BeanConvertUtil.beanCovertMap(fileRelDtos.get(0)));
|
|
|
|
|
+ businessUnit.put("fileRealName", paramInJson.getString("ownerPhotoId"));
|
|
|
|
|
+ businessUnit.put("fileSaveName", paramInJson.getString("ownerPhotoId"));
|
|
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessFileRel", businessUnit);
|
|
|
|
|
+ return business;
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public int getOrder() {
|
|
|
|
|
+ return DEFAULT_ORDER;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public IFileInnerServiceSMO getFileInnerServiceSMOImpl() {
|
|
|
|
|
+ return fileInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public void setFileInnerServiceSMOImpl(IFileInnerServiceSMO fileInnerServiceSMOImpl) {
|
|
|
|
|
+ this.fileInnerServiceSMOImpl = fileInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public IFileRelInnerServiceSMO getFileRelInnerServiceSMOImpl() {
|
|
|
|
|
+ return fileRelInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public void setFileRelInnerServiceSMOImpl(IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl) {
|
|
|
|
|
+ this.fileRelInnerServiceSMOImpl = fileRelInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public IOwnerInnerServiceSMO getOwnerInnerServiceSMOImpl() {
|
|
|
|
|
+ return ownerInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public void setOwnerInnerServiceSMOImpl(IOwnerInnerServiceSMO ownerInnerServiceSMOImpl) {
|
|
|
|
|
+ this.ownerInnerServiceSMOImpl = ownerInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+}
|