Commit 2df4f350f6570a692915e68df56a7bfa32144acf
1 parent
a6f2e90645
Exists in
master
and in
8 other branches
Merge branch 'master' of E:\mycelipse_workspace\longmei\regional-platform with conflicts.
Showing 7 changed files with 135 additions and 54 deletions
- platform-biz-patient-service/src/main/java/com/lyms/platform/biz/dal/impl/AntenatalExaminationDaoImpl.java
- platform-biz-patient-service/src/main/java/com/lyms/platform/biz/service/AntenatalExaminationService.java
- platform-dal/src/main/java/com/lyms/platform/pojo/HighRiskSmsModel.java
- platform-dal/src/main/java/com/lyms/platform/query/HighRiskSmsQuery.java
- platform-data-api/src/main/java/com/lyms/platform/data/pojo/MessageContent.java
- platform-data-api/src/main/java/com/lyms/platform/data/service/impl/SmsServiceImpl.java
- platform-data-api/src/main/java/com/lyms/platform/data/util/AmsMessageService.java
platform-biz-patient-service/src/main/java/com/lyms/platform/biz/dal/impl/AntenatalExaminationDaoImpl.java
View file @
2df4f35
| ... | ... | @@ -62,7 +62,8 @@ |
| 62 | 62 | |
| 63 | 63 | @Override |
| 64 | 64 | public List<AntenatalExaminationModel> queryYuyueAntenatalExamination(Date yuYueDate,String hospitalId) { |
| 65 | - AggregationOperation match = Aggregation.match(Criteria.where("nextCheckTime").gte(yuYueDate).lte(yuYueDate).and("hospitalId").is(hospitalId)); | |
| 65 | + AggregationOperation match = Aggregation.match(Criteria.where("hospitalId").gte(yuYueDate).lte(yuYueDate).and("hospitalId").is(hospitalId)); | |
| 66 | +// AggregationOperation match = Aggregation.match(Criteria.where("nextCheckTime").gte(yuYueDate).lte(yuYueDate).and("hospitalId").is(hospitalId)); | |
| 66 | 67 | AggregationOperation group = Aggregation.group("parentId").max("created").as("created"); |
| 67 | 68 | Aggregation aggregation = Aggregation.newAggregation(match, group); |
| 68 | 69 | AggregationResults<AntenatalExaminationModel> result = this.mongoTemplate.aggregate(aggregation, "lyms_antex", AntenatalExaminationModel.class); |
platform-biz-patient-service/src/main/java/com/lyms/platform/biz/service/AntenatalExaminationService.java
View file @
2df4f35
| ... | ... | @@ -142,5 +142,10 @@ |
| 142 | 142 | public List<AntenatalExaminationModel> queryYuyueAntenatalExamination(Date startDate,String hospitalId,String pid) { |
| 143 | 143 | return iAntenatalExaminationDao.queryYuyueAntenatalExamination(startDate, hospitalId,pid); |
| 144 | 144 | } |
| 145 | + | |
| 146 | + | |
| 147 | + public List<AntenatalExaminationModel> queryLastAntenatalExamination(MongoQuery query) { | |
| 148 | + return iAntenatalExaminationDao.queryAntenatalExamination(query.addOrder(Sort.Direction.DESC, "created")); | |
| 149 | + } | |
| 145 | 150 | } |
platform-dal/src/main/java/com/lyms/platform/pojo/HighRiskSmsModel.java
View file @
2df4f35
| ... | ... | @@ -33,6 +33,15 @@ |
| 33 | 33 | private Date modified; |
| 34 | 34 | |
| 35 | 35 | private String phone; |
| 36 | + private String messageId; | |
| 37 | + | |
| 38 | + public String getMessageId() { | |
| 39 | + return messageId; | |
| 40 | + } | |
| 41 | + | |
| 42 | + public void setMessageId(String messageId) { | |
| 43 | + this.messageId = messageId; | |
| 44 | + } | |
| 36 | 45 | |
| 37 | 46 | public String getId() { |
| 38 | 47 | return id; |
platform-dal/src/main/java/com/lyms/platform/query/HighRiskSmsQuery.java
View file @
2df4f35
| ... | ... | @@ -31,6 +31,16 @@ |
| 31 | 31 | |
| 32 | 32 | private String phone; |
| 33 | 33 | |
| 34 | + private String messageId; | |
| 35 | + | |
| 36 | + public String getMessageId() { | |
| 37 | + return messageId; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public void setMessageId(String messageId) { | |
| 41 | + this.messageId = messageId; | |
| 42 | + } | |
| 43 | + | |
| 34 | 44 | @Override |
| 35 | 45 | public MongoQuery convertToQuery() { |
| 36 | 46 | MongoCondition condition = MongoCondition.newInstance(); |
| ... | ... | @@ -40,6 +50,8 @@ |
| 40 | 50 | |
| 41 | 51 | if (null != patientId) { |
| 42 | 52 | condition = condition.and("patientId", patientId, MongoOper.IS); |
| 53 | + } if (null != messageId) { | |
| 54 | + condition = condition.and("messageId", messageId, MongoOper.IS); | |
| 43 | 55 | } |
| 44 | 56 | if(null!=highId){ |
| 45 | 57 | condition=condition.and("highId",highId,MongoOper.IS); |
platform-data-api/src/main/java/com/lyms/platform/data/pojo/MessageContent.java
View file @
2df4f35
| ... | ... | @@ -12,6 +12,16 @@ |
| 12 | 12 | private String content; |
| 13 | 13 | private String title; |
| 14 | 14 | private List<Tag> tags; |
| 15 | + private String highRiskId; | |
| 16 | + | |
| 17 | + public String getHighRiskId() { | |
| 18 | + return highRiskId; | |
| 19 | + } | |
| 20 | + | |
| 21 | + public void setHighRiskId(String highRiskId) { | |
| 22 | + this.highRiskId = highRiskId; | |
| 23 | + } | |
| 24 | + | |
| 15 | 25 | public String getId() { |
| 16 | 26 | return id; |
| 17 | 27 | } |
platform-data-api/src/main/java/com/lyms/platform/data/service/impl/SmsServiceImpl.java
View file @
2df4f35
| ... | ... | @@ -95,54 +95,47 @@ |
| 95 | 95 | |
| 96 | 96 | if (CollectionUtils.isNotEmpty(configs)) |
| 97 | 97 | { |
| 98 | - for(SmsConfigModel config : configs) | |
| 99 | - { | |
| 98 | + for(SmsConfigModel config : configs) { | |
| 100 | 99 | String hospitalId = config.getHospitalId(); |
| 101 | - if (StringUtils.isEmpty(hospitalId)) | |
| 102 | - { | |
| 100 | + if (StringUtils.isEmpty(hospitalId)) { | |
| 103 | 101 | continue; |
| 104 | 102 | } |
| 105 | 103 | |
| 106 | 104 | //每周几发送的指导短信 |
| 107 | 105 | String timeStr = config.getGuideTime(); |
| 108 | - if (StringUtils.isEmpty(timeStr)) | |
| 109 | - { | |
| 106 | + if (StringUtils.isEmpty(timeStr)) { | |
| 110 | 107 | continue; |
| 111 | 108 | } |
| 112 | 109 | |
| 113 | 110 | List<String> guideTimes = JsonUtil.toList(timeStr, String.class); |
| 114 | - if (guideTimes == null || guideTimes.size() != 2) | |
| 115 | - { | |
| 111 | + if (guideTimes == null || guideTimes.size() != 2) { | |
| 116 | 112 | continue; |
| 117 | 113 | } |
| 118 | 114 | |
| 119 | 115 | //判断医院是否运行 |
| 120 | - if (!isRunning(hospitalId)) | |
| 121 | - { | |
| 116 | + if (!isRunning(hospitalId)) { | |
| 122 | 117 | continue; |
| 123 | 118 | } |
| 124 | 119 | |
| 125 | 120 | String strService = config.getSmsService(); |
| 126 | 121 | |
| 127 | 122 | //判断消息服务是否启动 |
| 128 | - boolean isStart = isStartService(SmsServiceEnums.YBZD.getId(),strService); | |
| 129 | - if (!isStart) | |
| 130 | - { | |
| 123 | + boolean isStart = isStartService(SmsServiceEnums.YBZD.getId(), strService); | |
| 124 | + if (!isStart) { | |
| 131 | 125 | continue; |
| 132 | 126 | } |
| 133 | 127 | |
| 134 | - //通过医院id先从缓存中取 如果没有取到就调用ams获取该医院短信 并保存到amsSmses中 | |
| 135 | - Map<String, List<MessageContent>> amsSmses = amsSmsCache.get(hospitalId); | |
| 136 | - if (amsSmses == null || amsSmses.size() == 0) | |
| 137 | - { | |
| 138 | - // 查询模板短信 从ams平台配置的短信通过医院ID | |
| 139 | - amsSmses = AmsMessageService | |
| 128 | + //通过医院id先从缓存中取 如果没有取到就调用ams获取该医院短信 并保存到amsSmses中 | |
| 129 | + Map<String, List<MessageContent>> amsSmses = amsSmsCache.get(hospitalId); | |
| 130 | + if (amsSmses == null || amsSmses.size() == 0) | |
| 131 | + { | |
| 132 | + // 查询模板短信 从ams平台配置的短信通过医院ID | |
| 133 | + amsSmses = AmsMessageService | |
| 140 | 134 | .getMessageTemplateMap(hospitalId, |
| 141 | 135 | AmsServiceTypeEnum.YUN_GUIDE); |
| 142 | - amsSmsCache.put(String.valueOf(hospitalId),amsSmses); | |
| 136 | + amsSmsCache.put(hospitalId,amsSmses); | |
| 137 | + } | |
| 143 | 138 | |
| 144 | - } | |
| 145 | - | |
| 146 | 139 | PatientsQuery patientsQuery = new PatientsQuery(); |
| 147 | 140 | patientsQuery.setYn(YnEnums.YES.getId()); |
| 148 | 141 | patientsQuery.setHospitalId(hospitalId); |
| 149 | 142 | |
| 150 | 143 | |
| 151 | 144 | |
| 152 | 145 | |
| 153 | 146 | |
| 154 | 147 | |
| 155 | 148 | |
| 156 | 149 | |
| 157 | 150 | |
| 158 | 151 | |
| 159 | 152 | |
| ... | ... | @@ -247,52 +240,72 @@ |
| 247 | 240 | List risks = findLastRisk(pat.getPid()); |
| 248 | 241 | if (CollectionUtils.isNotEmpty(risks)) |
| 249 | 242 | { |
| 243 | + List<MessageContent> highRiskContents = new ArrayList(); | |
| 244 | + //把多种高危因素的短信合并在一起 | |
| 250 | 245 | for (Object obj : risks) |
| 251 | 246 | { |
| 252 | 247 | Map<String,Object> riskMap = (Map<String,Object>)obj; |
| 253 | - | |
| 254 | - HighRiskSmsQuery hquery = new HighRiskSmsQuery(); | |
| 255 | - hquery.setHighId(String.valueOf(riskMap.get("id"))); | |
| 256 | - hquery.setPhone(pat.getPhone()); | |
| 257 | - hquery.setPatientId(pat.getId()); | |
| 258 | - int count = highRiskService.queryHighRiskCount(hquery); | |
| 259 | - if (count > 0) | |
| 260 | - { | |
| 261 | - continue; | |
| 262 | - } | |
| 263 | - | |
| 264 | 248 | String name = String.valueOf(riskMap.get("name")); |
| 265 | 249 | List<MessageContent> messageContents = amsSmses.get(name); |
| 266 | 250 | if (CollectionUtils.isNotEmpty(messageContents)) |
| 267 | 251 | { |
| 268 | 252 | for (MessageContent message : messageContents) |
| 269 | 253 | { |
| 270 | - String messageContent = "【"+messagePrefix+"】" + message.getContent(); | |
| 254 | + message.setHighRiskId(String.valueOf(riskMap.get("id"))); | |
| 255 | + } | |
| 256 | + } | |
| 257 | + highRiskContents.addAll(messageContents); | |
| 258 | + } | |
| 259 | + if (CollectionUtils.isNotEmpty(highRiskContents)) | |
| 260 | + { | |
| 261 | + //可以发送的高危短信 | |
| 262 | + List<MessageContent> sendMessageContents = new ArrayList<>(); | |
| 271 | 263 | |
| 272 | - MessageRequest request = getMessageRequest( messageContent,pat.getPhone(),ServiceObjEnums.YUNOBJ.getId(), SmsServiceEnums.GWZD.getId(), | |
| 273 | - pat.getHospitalId(),message.getId(),pat.getId()); | |
| 264 | + for (MessageContent message : highRiskContents) | |
| 265 | + { | |
| 274 | 266 | |
| 267 | + HighRiskSmsQuery hquery = new HighRiskSmsQuery(); | |
| 268 | + hquery.setMessageId(message.getId()); | |
| 269 | + hquery.setHighId(message.getHighRiskId()); | |
| 270 | + hquery.setPhone(pat.getPhone()); | |
| 271 | + hquery.setPatientId(pat.getId()); | |
| 272 | + | |
| 273 | + int count = highRiskService.queryHighRiskCount(hquery); | |
| 274 | + if (count > 0) | |
| 275 | + { | |
| 276 | + continue; | |
| 277 | + } | |
| 278 | + //把未发送过的添加到集合中 | |
| 279 | + sendMessageContents.add(message); | |
| 280 | + } | |
| 281 | + | |
| 282 | + if (CollectionUtils.isNotEmpty(sendMessageContents)) { | |
| 283 | + | |
| 284 | + //根据集合的长度随机一个数字 | |
| 285 | + int index = (int)(Math.random()*sendMessageContents.size()); | |
| 286 | + | |
| 287 | + //从集合中随机取一个发送 | |
| 288 | + MessageContent message =sendMessageContents.get(index); | |
| 289 | + String messageContent = "【" + messagePrefix + "】" + message.getContent(); | |
| 290 | + MessageRequest request = getMessageRequest(messageContent, pat.getPhone(), ServiceObjEnums.YUNOBJ.getId(), SmsServiceEnums.GWZD.getId(), | |
| 291 | + pat.getHospitalId(), message.getId(), pat.getId()); | |
| 275 | 292 | messages.add(request); |
| 276 | - isRisk = true; | |
| 277 | 293 | |
| 278 | - HighRiskSmsModel highRiskSmsModel = new HighRiskSmsModel(); | |
| 294 | + HighRiskSmsModel highRiskSmsModel = new HighRiskSmsModel(); | |
| 279 | 295 | highRiskSmsModel.setPatientId(pat.getId()); |
| 280 | - highRiskSmsModel.setHighId(String.valueOf(riskMap.get("id"))); | |
| 296 | + highRiskSmsModel.setHighId(message.getHighRiskId()); | |
| 281 | 297 | highRiskSmsModel.setPhone(pat.getPhone()); |
| 282 | 298 | highRiskSmsModel.setHospitalId(pat.getHospitalId()); |
| 283 | 299 | highRiskSmsModel.setCreated(new Date()); |
| 284 | 300 | highRiskSmsModel.setModified(new Date()); |
| 301 | + highRiskSmsModel.setMessageId(message.getId()); | |
| 285 | 302 | highRiskService.addHighRiskSmsModel(highRiskSmsModel); |
| 286 | 303 | |
| 287 | - break; | |
| 288 | - } | |
| 304 | + isRisk = true; | |
| 289 | 305 | |
| 290 | - if (isRisk) | |
| 291 | - { | |
| 292 | - break; | |
| 293 | 306 | } |
| 294 | 307 | } |
| 295 | - } | |
| 308 | + | |
| 296 | 309 | } |
| 297 | 310 | } |
| 298 | 311 | |
| ... | ... | @@ -309,7 +322,7 @@ |
| 309 | 322 | { |
| 310 | 323 | for(MessageContent message : messageContents) |
| 311 | 324 | { |
| 312 | -// //判断当前短信是否已经发送 通过短信ID和孕妇ID | |
| 325 | + //判断当前短信是否已经发送 通过短信ID和孕妇ID | |
| 313 | 326 | boolean isExist = SaveMessageService.isExistSms(pat.getId(), message.getId()); |
| 314 | 327 | if (isExist) |
| 315 | 328 | { |
| ... | ... | @@ -2217,7 +2230,19 @@ |
| 2217 | 2230 | |
| 2218 | 2231 | for (AntenatalExaminationModel f : fuzs) |
| 2219 | 2232 | { |
| 2220 | - idset.add(f.getId()); //这里的id就是parentid | |
| 2233 | + | |
| 2234 | + AntExQuery antExQuery = new AntExQuery(); | |
| 2235 | + antExQuery.setYn(YnEnums.YES.getId()); | |
| 2236 | + antExQuery.setParentId(f.getId()); | |
| 2237 | + | |
| 2238 | + List<AntenatalExaminationModel> list = antenatalExaminationService.queryLastAntenatalExamination(antExQuery.convertToQuery()); | |
| 2239 | + if (CollectionUtils.isNotEmpty(list)) | |
| 2240 | + { | |
| 2241 | + if (list.get(0).getNextCheckTime() != null) | |
| 2242 | + { | |
| 2243 | + idset.add(f.getId()); //这里的id就是parentid | |
| 2244 | + } | |
| 2245 | + } | |
| 2221 | 2246 | } |
| 2222 | 2247 | return idset; |
| 2223 | 2248 | } |
| ... | ... | @@ -2263,7 +2288,18 @@ |
| 2263 | 2288 | |
| 2264 | 2289 | for (AntenatalExaminationModel f : fuzs) |
| 2265 | 2290 | { |
| 2266 | - idset.add(f.getParentId()); | |
| 2291 | + AntExQuery antExQuery = new AntExQuery(); | |
| 2292 | + antExQuery.setYn(YnEnums.YES.getId()); | |
| 2293 | + antExQuery.setParentId(f.getId()); | |
| 2294 | + | |
| 2295 | + List<AntenatalExaminationModel> list = antenatalExaminationService.queryLastAntenatalExamination(antExQuery.convertToQuery()); | |
| 2296 | + if (CollectionUtils.isNotEmpty(list)) | |
| 2297 | + { | |
| 2298 | + if (list.get(0).getNextCheckTime() != null) | |
| 2299 | + { | |
| 2300 | + idset.add(f.getId()); //这里的id就是parentid | |
| 2301 | + } | |
| 2302 | + } | |
| 2267 | 2303 | } |
| 2268 | 2304 | return idset.size() > 0; |
| 2269 | 2305 | } |
platform-data-api/src/main/java/com/lyms/platform/data/util/AmsMessageService.java
View file @
2df4f35
| ... | ... | @@ -82,13 +82,13 @@ |
| 82 | 82 | params.put("limit", "9999"); |
| 83 | 83 | String str = HttpRequest.sendGet(AMS_URL, |
| 84 | 84 | params, headers); |
| 85 | - System.out.println(str); | |
| 85 | +// System.out.println(str); | |
| 86 | 86 | ObjectMapper om = new ObjectMapper(); |
| 87 | 87 | MessageResponseEntity mre = null; |
| 88 | 88 | Map<String,List<MessageContent>> map = new HashMap<String, List<MessageContent>>(); |
| 89 | 89 | try { |
| 90 | 90 | mre = om.readValue(str, MessageResponseEntity.class); |
| 91 | - System.out.println(mre); | |
| 91 | +// System.out.println(mre); | |
| 92 | 92 | } catch (JsonParseException e) { |
| 93 | 93 | e.printStackTrace(); |
| 94 | 94 | } catch (JsonMappingException e) { |
| ... | ... | @@ -124,8 +124,9 @@ |
| 124 | 124 | } |
| 125 | 125 | } |
| 126 | 126 | }else{//失败 |
| 127 | - logger.error("error info :errorcode="+mre.getErrorcode() | |
| 128 | - +" errormsg="+mre.getErrormsg()); | |
| 127 | + System.out.println("hospitalId="+hospitalId+"---"+mre); | |
| 128 | + logger.error("error info :errorcode=" + mre.getErrorcode() | |
| 129 | + + " errormsg=" + mre.getErrormsg()); | |
| 129 | 130 | } |
| 130 | 131 | }else{ |
| 131 | 132 | logger.error("接口调用失败!!!"); |
| 132 | 133 | |
| ... | ... | @@ -182,8 +183,15 @@ |
| 182 | 183 | |
| 183 | 184 | |
| 184 | 185 | public static void main(String[] args) { |
| 185 | -// getMessageTemplateMap("8be01f59-ad25-4ae6-968d-8450c9421e0b", | |
| 186 | +// Map<String,List<MessageContent>> list = getMessageTemplateMap("242", | |
| 186 | 187 | // AmsServiceTypeEnum.CHILD_GUIDE); |
| 188 | +// | |
| 189 | +// List<MessageContent> msgs = list.get("新生儿感染"); | |
| 190 | + for (int i = 0;i< 100 ;i++) | |
| 191 | + { | |
| 192 | + int index = (int)(Math.random()*8); | |
| 193 | + System.out.println(index); | |
| 194 | + } | |
| 187 | 195 | |
| 188 | 196 | // String result = "头:9.5|胸:10.0|腹:10.0"; |
| 189 | 197 | // String b = ""; |