|
|
@@ -0,0 +1,165 @@
|
|
|
+package com.java110.api.listener.room;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.java110.api.listener.AbstractServiceApiListener;
|
|
|
+import com.java110.common.constant.ServiceCodeAddRoomBindingConstant;
|
|
|
+import com.java110.common.util.Assert;
|
|
|
+import com.java110.common.util.StringUtil;
|
|
|
+import com.java110.core.context.DataFlowContext;
|
|
|
+import com.java110.core.factory.GenerateCodeFactory;
|
|
|
+import com.java110.entity.center.AppService;
|
|
|
+import com.java110.event.service.api.ServiceDataFlowEvent;
|
|
|
+import org.springframework.http.HttpHeaders;
|
|
|
+import org.springframework.http.HttpMethod;
|
|
|
+import org.springframework.http.ResponseEntity;
|
|
|
+import com.java110.common.constant.CommonConstant;
|
|
|
+import com.java110.common.constant.BusinessTypeConstant;
|
|
|
+
|
|
|
+import com.java110.core.annotation.Java110Listener;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 保存小区侦听
|
|
|
+ * add by wuxw 2019-06-30
|
|
|
+ */
|
|
|
+@Java110Listener("bindingAddRoomBindingListener")
|
|
|
+public class BindingAddRoomBindingListener extends AbstractServiceApiListener {
|
|
|
+ @Override
|
|
|
+ protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
|
|
|
+ //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
|
|
|
+ JSONArray infos = reqJson.getJSONArray("data");
|
|
|
+
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "roomNum", "必填,请填写房屋编号");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "layer", "必填,请填写房屋楼层");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "section", "必填,请填写房屋楼层");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "apartment", "必填,请选择房屋户型");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "builtUpArea", "必填,请填写房屋建筑面积");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "unitPrice", "必填,请填写房屋每平米单价");
|
|
|
+ Assert.hasKeyByFlowData(infos, "addRoomView", "state", "必填,请选择房屋状态");
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
|
|
|
+
|
|
|
+ HttpHeaders header = new HttpHeaders();
|
|
|
+ context.getRequestCurrentHeaders().put(CommonConstant.HTTP_ORDER_TYPE_CD, "D");
|
|
|
+ JSONArray businesses = new JSONArray();
|
|
|
+
|
|
|
+ AppService service = event.getAppService();
|
|
|
+
|
|
|
+
|
|
|
+ JSONArray infos = reqJson.getJSONArray("data");
|
|
|
+
|
|
|
+
|
|
|
+ JSONObject viewFloorInfo = getObj(infos, "viewFloorInfo");
|
|
|
+ JSONObject viewUnitInfo = getObj(infos, "viewUnitInfo");
|
|
|
+ JSONObject addRoomView = getObj(infos, "addRoomView");
|
|
|
+ if (!hasKey(viewFloorInfo, "floorId")) {
|
|
|
+ viewFloorInfo.put("floorId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_floorId));
|
|
|
+ businesses.add(addBusinessFloor(viewFloorInfo, context));
|
|
|
+ }
|
|
|
+ if (!hasKey(viewUnitInfo, "unitId")) {
|
|
|
+ viewUnitInfo.put("unitId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_unitId));
|
|
|
+ businesses.add(addBusinessUnit(viewUnitInfo, context));
|
|
|
+ }
|
|
|
+ if (!hasKey(addRoomView, "roomId")) {
|
|
|
+ addRoomView.put("roomId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_roomId));
|
|
|
+ businesses.add(addBusinessRoom(addRoomView, context));
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ JSONObject paramInObj = super.restToCenterProtocol(businesses, context.getRequestCurrentHeaders());
|
|
|
+
|
|
|
+ //将 rest header 信息传递到下层服务中去
|
|
|
+ super.freshHttpHeader(header, context.getRequestCurrentHeaders());
|
|
|
+
|
|
|
+ ResponseEntity<String> responseEntity = this.callService(context, service.getServiceCode(), paramInObj);
|
|
|
+
|
|
|
+ context.setResponseEntity(responseEntity);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public String getServiceCode() {
|
|
|
+ return ServiceCodeAddRoomBindingConstant.BINDING_ADDROOMBINDING;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public HttpMethod getHttpMethod() {
|
|
|
+ return HttpMethod.POST;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public int getOrder() {
|
|
|
+ return DEFAULT_ORDER;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private JSONObject addBusinessFloor(JSONObject paramInJson, DataFlowContext dataFlowContext) {
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_SAVE_FLOOR_INFO);
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ);
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
+ JSONObject businessObj = new JSONObject();
|
|
|
+ businessObj.putAll(paramInJson);
|
|
|
+ //计算 应收金额
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessFloor", businessObj);
|
|
|
+ return business;
|
|
|
+ }
|
|
|
+
|
|
|
+ private JSONObject addBusinessUnit(JSONObject paramInJson, DataFlowContext dataFlowContext) {
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_SAVE_UNIT_INFO);
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ);
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
+ JSONObject businessObj = new JSONObject();
|
|
|
+ businessObj.putAll(paramInJson);
|
|
|
+ //计算 应收金额
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessUnit", businessObj);
|
|
|
+ return business;
|
|
|
+ }
|
|
|
+
|
|
|
+ private JSONObject addBusinessRoom(JSONObject paramInJson, DataFlowContext dataFlowContext) {
|
|
|
+ JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
|
|
|
+ business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_SAVE_ROOM_INFO);
|
|
|
+ business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ);
|
|
|
+ business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
|
|
|
+ JSONObject businessObj = new JSONObject();
|
|
|
+ businessObj.putAll(paramInJson);
|
|
|
+ //计算 应收金额
|
|
|
+ business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put("businessRoom", businessObj);
|
|
|
+ return business;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private boolean hasKey(JSONObject info, String key) {
|
|
|
+ if (!info.containsKey(key)
|
|
|
+ || StringUtil.isEmpty(info.getString(key))
|
|
|
+ || info.getString(key).startsWith("-")) {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private JSONObject getObj(JSONArray infos , String flowComponent){
|
|
|
+
|
|
|
+ JSONObject serviceInfo = null;
|
|
|
+
|
|
|
+ for(int infoIndex = 0 ; infoIndex < infos.size(); infoIndex ++){
|
|
|
+
|
|
|
+ Assert.hasKeyAndValue(infos.getJSONObject(infoIndex), "flowComponent", "未包含服务流程组件名称");
|
|
|
+
|
|
|
+ if(flowComponent.equals(infos.getJSONObject(infoIndex).getString("flowComponent"))){
|
|
|
+ serviceInfo = infos.getJSONObject(infoIndex);
|
|
|
+ Assert.notNull(serviceInfo, "未包含服务信息");
|
|
|
+ return serviceInfo;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ throw new IllegalArgumentException("未找到组件编码为【" + flowComponent + "】数据");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+}
|