From e23023b93f34286f5a807b0b85e9a0619a297ed7 Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期二, 21 二月 2023 23:25:34 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity
---
service-community/src/main/java/com/java110/community/cmd/room/SaveRoomCmd.java | 197 +++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 197 insertions(+), 0 deletions(-)
diff --git a/service-community/src/main/java/com/java110/community/cmd/room/SaveRoomCmd.java b/service-community/src/main/java/com/java110/community/cmd/room/SaveRoomCmd.java
new file mode 100644
index 0000000..6333c55
--- /dev/null
+++ b/service-community/src/main/java/com/java110/community/cmd/room/SaveRoomCmd.java
@@ -0,0 +1,197 @@
+package com.java110.community.cmd.room;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.annotation.Java110Transactional;
+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.GenerateCodeFactory;
+import com.java110.doc.annotation.*;
+import com.java110.dto.RoomDto;
+import com.java110.dto.UnitDto;
+import com.java110.dto.owner.OwnerRoomRelDto;
+import com.java110.intf.community.IRoomV1InnerServiceSMO;
+import com.java110.intf.community.IUnitInnerServiceSMO;
+import com.java110.intf.user.IOwnerRoomRelV1InnerServiceSMO;
+import com.java110.po.owner.OwnerRoomRelPo;
+import com.java110.po.room.RoomPo;
+import com.java110.utils.cache.MappingCache;
+import com.java110.utils.constant.CommonConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.DateUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+
+import java.util.List;
+
+
+@Java110CmdDoc(title = "娣诲姞鎴垮眿",
+ description = "瀵瑰簲鍚庡彴 娣诲姞鎴垮眿鍔熻兘",
+ httpMethod = "post",
+ url = "http://{ip}:{port}/app/room.saveRoom",
+ resource = "communityDoc",
+ author = "鍚村鏂�",
+ serviceCode = "room.saveRoom"
+)
+
+@Java110ParamsDoc(params = {
+ @Java110ParamDoc(name = "communityId", length = 30, remark = "灏忓尯ID"),
+ @Java110ParamDoc(name = "roomNum", length = 64, remark = "鎴垮彿"),
+ @Java110ParamDoc(name = "layer", length = 12, remark = "灞傛暟"),
+ @Java110ParamDoc(name = "unitId", length = 30, remark = "鍗曞厓ID"),
+ @Java110ParamDoc(name = "section", length = 12, remark = "鎴垮眿涓暟"),
+ @Java110ParamDoc(name = "apartment", length = 12, remark = "鍥哄畾 10102"),
+ @Java110ParamDoc(name = "builtUpArea", length = 12, remark = "寤虹瓚闈㈢Н"),
+ @Java110ParamDoc(name = "feeCoefficient", length = 12, remark = "绠楄垂绯绘暟 鍥哄畾1"),
+ @Java110ParamDoc(name = "state", length = 12, remark = "鐘舵�� 2002\t鏈攢鍞�"),
+ @Java110ParamDoc(name = "roomSubType", length = 12, remark = "鎴垮眿绫诲瀷 110\t浣忓畢\n" +
+ "120\t鍔炲叕瀹n" +
+ "119\t瀹胯垗"),
+ @Java110ParamDoc(name = "roomArea", length = 12, remark = "瀹ゅ唴闈㈢Н"),
+ @Java110ParamDoc(name = "roomRent", length = 12, remark = "鍔炲叕瀹� 鎴栬�呭鑸� 鏃剁閲�"),
+ @Java110ParamDoc(name = "remark", length = 512, remark = "澶囨敞"),
+})
+
+@Java110ResponseDoc(
+ params = {
+ @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "杩斿洖缂栧彿锛�0 鎴愬姛 鍏朵粬澶辫触"),
+ @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "鎴愬姛", remark = "鎻忚堪"),
+ }
+)
+
+@Java110ExampleDoc(
+ reqBody = "{\n" +
+ "\t\"roomNum\": \"88488\",\n" +
+ "\t\"layer\": \"1\",\n" +
+ "\t\"unitId\":\"123123123\",\n" +
+ "\t\"section\": \"0\",\n" +
+ "\t\"apartment\": \"10102\",\n" +
+ "\t\"builtUpArea\": \"110\",\n" +
+ "\t\"feeCoefficient\": \"1.00\",\n" +
+ "\t\"state\": \"2002\",\n" +
+ "\t\"remark\": \"sdf\",\n" +
+ "\t\"roomSubType\": \"110\",\n" +
+ "\t\"roomArea\": \"110\",\n" +
+ "\t\"roomRent\": \"0\",\n" +
+ "\t\"communityId\": \"2022121921870161\",\n" +
+ "}",
+ resBody = "{\"code\":0,\"msg\":\"鎴愬姛\"}"
+)
+
+@Java110Cmd(serviceCode = "room.saveRoom")
+public class SaveRoomCmd extends Cmd {
+
+ @Autowired
+ private IUnitInnerServiceSMO unitInnerServiceSMOImpl;
+
+ @Autowired
+ private IRoomV1InnerServiceSMO roomV1InnerServiceSMOImpl;
+
+ @Autowired
+ private IOwnerRoomRelV1InnerServiceSMO ownerRoomRelV1InnerServiceSMOImpl;
+
+ @Override
+ public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+ Assert.jsonObjectHaveKey(reqJson, "communityId", "璇锋眰鎶ユ枃涓湭鍖呭惈communityId鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "unitId", "璇锋眰鎶ユ枃涓湭鍖呭惈unitId鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "roomNum", "璇锋眰鎶ユ枃涓湭鍖呭惈roomNum鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "layer", "璇锋眰鎶ユ枃涓湭鍖呭惈layer鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "section", "璇锋眰鎶ユ枃涓湭鍖呭惈section鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "apartment", "璇锋眰鎶ユ枃涓湭鍖呭惈apartment鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "state", "璇锋眰鎶ユ枃涓湭鍖呭惈state鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "builtUpArea", "璇锋眰鎶ユ枃涓湭鍖呭惈builtUpArea鑺傜偣");
+ Assert.jsonObjectHaveKey(reqJson, "feeCoefficient", "璇锋眰鎶ユ枃涓湭鍖呭惈feeCoefficient鑺傜偣");
+
+ Assert.isInteger(reqJson.getString("section"), "鎴块棿鏁颁笉鏄湁鏁堟暟瀛�");
+ Assert.isMoney(reqJson.getString("builtUpArea"), "寤虹瓚闈㈢Н鏁版嵁鏍煎紡閿欒");
+ Assert.isMoney(reqJson.getString("feeCoefficient"), "鎴垮眿鍗曚环鏁版嵁鏍煎紡閿欒");
+
+ if (!reqJson.containsKey("roomSubType")) {
+ reqJson.put("roomSubType", RoomDto.ROOM_SUB_TYPE_PERSON);
+ }
+
+ if (!reqJson.containsKey("roomRent")) {
+ reqJson.put("roomRent", "0");
+ }
+
+ if (!reqJson.containsKey("roomArea")) {
+ reqJson.put("roomRent", reqJson.getString("builtUpArea"));
+ }
+
+ if (!RoomDto.STATE_FREE.equals(reqJson.getString("state"))) {
+ Assert.hasKeyAndValue(reqJson, "ownerId", "鏈寘鍚笟涓讳俊鎭�");
+ }
+
+ /*if (!"1010".equals(reqJson.getString("apartment")) && !"2020".equals(reqJson.getString("apartment"))) {
+ throw new IllegalArgumentException("涓嶆槸鏈夋晥鎴垮眿鎴峰瀷 浼犲叆鏁版嵁閿欒");
+ }*/
+
+ if (!"2001".equals(reqJson.getString("state"))
+ && !"2002".equals(reqJson.getString("state"))
+ && !"2003".equals(reqJson.getString("state"))
+ && !"2004".equals(reqJson.getString("state"))
+ && !"2005".equals(reqJson.getString("state"))
+ && !"2009".equals(reqJson.getString("state"))) {
+ throw new IllegalArgumentException("涓嶆槸鏈夋晥鎴垮眿鐘舵�� 浼犲叆鏁版嵁閿欒");
+ }
+
+ UnitDto unitDto = new UnitDto();
+ unitDto.setCommunityId(reqJson.getString("communityId"));
+ unitDto.setUnitId(reqJson.getString("unitId"));
+ //鏍¢獙灏忓尯妤糏D鍜屽皬鍖烘槸鍚︽湁瀵瑰簲鍏崇郴
+ List<UnitDto> units = unitInnerServiceSMOImpl.queryUnitsByCommunityId(unitDto);
+
+ if (units == null || units.size() < 1) {
+ throw new IllegalArgumentException("浼犲叆鍗曞厓ID涓嶆槸璇ュ皬鍖虹殑鍗曞厓");
+ }
+
+ reqJson.put("unitNum", units.get(0).getUnitNum());
+ }
+
+ @Override
+ @Java110Transactional
+ public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+ if ("0".equals(reqJson.getString("unitNum"))) { // 澶勭悊涓哄晢閾�
+ reqJson.put("roomType", RoomDto.ROOM_TYPE_SHOPS);
+ } else {
+ reqJson.put("roomType", RoomDto.ROOM_TYPE_ROOM);
+ }
+
+
+ reqJson.put("roomId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_roomId));
+ reqJson.put("userId", context.getReqHeaders().get(CommonConstant.HTTP_USER_ID));
+ RoomPo roomPo = BeanConvertUtil.covertBean(reqJson, RoomPo.class);
+ roomV1InnerServiceSMOImpl.saveRoom(roomPo);
+
+ if (RoomDto.STATE_FREE.equals(roomPo.getState())) {
+ return;
+ }
+
+
+ if (!reqJson.containsKey("startTime")) {
+ reqJson.put("startTime", DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
+ }
+ if (!reqJson.containsKey("endTime")) {
+ reqJson.put("endTime", "2037-01-01 00:00:00");
+ }
+ OwnerRoomRelPo ownerRoomRelPo = new OwnerRoomRelPo();
+ ownerRoomRelPo.setRelId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_relId));
+ ownerRoomRelPo.setRoomId(roomPo.getRoomId());
+ ownerRoomRelPo.setOwnerId(reqJson.getString("ownerId"));
+ ownerRoomRelPo.setStartTime(reqJson.getString("startTime"));
+ ownerRoomRelPo.setEndTime(reqJson.getString("endTime"));
+ ownerRoomRelPo.setState("2001");
+ ownerRoomRelPo.setRemark("娣诲姞鎴垮眿鐩存帴缁戝畾");
+ ownerRoomRelPo.setOperate("ADD");
+ ownerRoomRelPo.setUserId("-1");
+ int flag = ownerRoomRelV1InnerServiceSMOImpl.saveOwnerRoomRel(ownerRoomRelPo);
+
+ if (flag < 1) {
+ throw new CmdException("娣诲姞涓氫富鎴垮眿鍏崇郴");
+ }
+
+
+ }
+}
--
Gitblit v1.8.0