|
@@ -0,0 +1,143 @@
|
|
|
|
|
+package com.java110.api.listener.room;
|
|
|
|
|
+
|
|
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
|
|
+import com.java110.api.listener.AbstractServiceApiDataFlowListener;
|
|
|
|
|
+import com.java110.common.constant.BusinessTypeConstant;
|
|
|
|
|
+import com.java110.common.constant.CommonConstant;
|
|
|
|
|
+import com.java110.common.constant.ServiceCodeConstant;
|
|
|
|
|
+import com.java110.common.util.Assert;
|
|
|
|
|
+import com.java110.core.annotation.Java110Listener;
|
|
|
|
|
+import com.java110.core.context.DataFlowContext;
|
|
|
|
|
+import com.java110.core.smo.unit.IUnitInnerServiceSMO;
|
|
|
|
|
+import com.java110.dto.UnitDto;
|
|
|
|
|
+import com.java110.entity.center.AppService;
|
|
|
|
|
+import com.java110.event.service.api.ServiceDataFlowEvent;
|
|
|
|
|
+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;
|
|
|
|
|
+
|
|
|
|
|
+/**
|
|
|
|
|
+ * @ClassName SaveUnitListener
|
|
|
|
|
+ * @Description TODO 删除房屋信息
|
|
|
|
|
+ * @Author wuxw
|
|
|
|
|
+ * @Date 2019/5/3 11:54
|
|
|
|
|
+ * @Version 1.0
|
|
|
|
|
+ * add by wuxw 2019/5/3
|
|
|
|
|
+ **/
|
|
|
|
|
+@Java110Listener("deleteRoomListener")
|
|
|
|
|
+public class DeleteRoomListener extends AbstractServiceApiDataFlowListener {
|
|
|
|
|
+ private static Logger logger = LoggerFactory.getLogger(DeleteRoomListener.class);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public String getServiceCode() {
|
|
|
|
|
+ return ServiceCodeConstant.SERVICE_CODE_DELETE_ROOMS;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public HttpMethod getHttpMethod() {
|
|
|
|
|
+ return HttpMethod.POST;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public void soService(ServiceDataFlowEvent event) {
|
|
|
|
|
+
|
|
|
|
|
+ logger.debug("ServiceDataFlowEvent : {}", event);
|
|
|
|
|
+
|
|
|
|
|
+ DataFlowContext dataFlowContext = event.getDataFlowContext();
|
|
|
|
|
+ AppService service = event.getAppService();
|
|
|
|
|
+
|
|
|
|
|
+ String paramIn = dataFlowContext.getReqData();
|
|
|
|
|
+
|
|
|
|
|
+ //校验数据
|
|
|
|
|
+ validate(paramIn);
|
|
|
|
|
+ JSONObject paramObj = JSONObject.parseObject(paramIn);
|
|
|
|
|
+
|
|
|
|
|
+ HttpHeaders header = new HttpHeaders();
|
|
|
|
|
+ dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.HTTP_ORDER_TYPE_CD, "D");
|
|
|
|
|
+ JSONArray businesses = new JSONArray();
|
|
|
|
|
+
|
|
|
|
|
+ //添加单元信息
|
|
|
|
|
+ businesses.add(deleteRoom(paramObj, dataFlowContext));
|
|
|
|
|
+
|
|
|
|
|
+ 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 接口调用放传入入参
|
|
|
|
|
+ * @param dataFlowContext 数据上下文
|
|
|
|
|
+ * @return 订单服务能够接受的报文
|
|
|
|
|
+ */
|
|
|
|
|
+ private JSONObject deleteRoom(JSONObject paramInJson, DataFlowContext dataFlowContext) {
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_DELETE_ROOM_INFO);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ);
|
|
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
|
|
+ JSONObject businessUnit = new JSONObject();
|
|
|
|
|
+ businessUnit.putAll(paramInJson);
|
|
|
|
|
+ businessUnit.put("userId", dataFlowContext.getRequestCurrentHeaders().get(CommonConstant.HTTP_USER_ID));
|
|
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessRoom", businessUnit);
|
|
|
|
|
+
|
|
|
|
|
+ return business;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 数据校验
|
|
|
|
|
+ *
|
|
|
|
|
+ * @param paramIn "communityId": "7020181217000001",
|
|
|
|
|
+ * "memberId": "3456789",
|
|
|
|
|
+ * "memberTypeCd": "390001200001"
|
|
|
|
|
+ */
|
|
|
|
|
+ private void validate(String paramIn) {
|
|
|
|
|
+ Assert.jsonObjectHaveKey(paramIn, "roomId", "请求报文中未包含roomId节点");
|
|
|
|
|
+ Assert.jsonObjectHaveKey(paramIn, "communityId", "请求报文中未包含communityId节点");
|
|
|
|
|
+ Assert.jsonObjectHaveKey(paramIn, "unitId", "请求报文中未包含unitId节点");
|
|
|
|
|
+
|
|
|
|
|
+ JSONObject reqJson = JSONObject.parseObject(paramIn);
|
|
|
|
|
+
|
|
|
|
|
+ UnitDto unitDto = new UnitDto();
|
|
|
|
|
+ unitDto.setCommunityId(reqJson.getString("communityId"));
|
|
|
|
|
+ unitDto.setUnitId(reqJson.getString("unitId"));
|
|
|
|
|
+ //校验小区楼ID和小区是否有对应关系
|
|
|
|
|
+ List<UnitDto> units = unitInnerServiceSMOImpl.queryUnitsByCommunityId(unitDto);
|
|
|
|
|
+
|
|
|
|
|
+ if (units == null || units.size() < 1) {
|
|
|
|
|
+ throw new IllegalArgumentException("传入单元ID不是该小区的单元");
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Override
|
|
|
|
|
+ public int getOrder() {
|
|
|
|
|
+ return DEFAULT_ORDER;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public IUnitInnerServiceSMO getUnitInnerServiceSMOImpl() {
|
|
|
|
|
+ return unitInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public void setUnitInnerServiceSMOImpl(IUnitInnerServiceSMO unitInnerServiceSMOImpl) {
|
|
|
|
|
+ this.unitInnerServiceSMOImpl = unitInnerServiceSMOImpl;
|
|
|
|
|
+ }
|
|
|
|
|
+}
|