MQTask.java 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583
  1. package com.iamberry.rst.controllers.mq;
  2. import com.iamberry.rst.controllers.sys.SysController;
  3. import com.iamberry.rst.core.cm.*;
  4. import com.iamberry.rst.core.fm.ComplaintDetectInfo;
  5. import com.iamberry.rst.core.order.ProductType;
  6. import com.iamberry.rst.core.sms.OrderMessage;
  7. import com.iamberry.rst.core.sms.SmsMessage;
  8. import com.iamberry.rst.core.sys.Admin;
  9. import com.iamberry.rst.faces.address.AddressService;
  10. import com.iamberry.rst.faces.cm.*;
  11. import com.iamberry.rst.faces.fm.ComplaintDetectInfoService;
  12. import com.iamberry.rst.faces.order.EfastOrderService;
  13. import com.iamberry.rst.faces.sms.MessageService;
  14. import com.iamberry.rst.faces.sms.SmsService;
  15. import com.iamberry.rst.faces.sys.SysConfigService;
  16. import com.iamberry.rst.faces.sys.SysService;
  17. import com.iamberry.rst.util.SmsConfig;
  18. import com.iamberry.rst.utils.EfastUtil;
  19. import com.iamberry.rst.core.tools.KuaiDi100;
  20. import com.iamberry.wechat.tools.ResponseJson;
  21. import net.sf.json.JSONArray;
  22. import net.sf.json.JSONObject;
  23. import org.slf4j.Logger;
  24. import org.slf4j.LoggerFactory;
  25. import org.springframework.beans.factory.InitializingBean;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.context.annotation.Lazy;
  28. import org.springframework.scheduling.annotation.Scheduled;
  29. import org.springframework.stereotype.Component;
  30. import java.text.MessageFormat;
  31. import java.text.SimpleDateFormat;
  32. import java.util.*;
  33. import static com.iamberry.rst.util.SmsConfig.*;
  34. @Component(value="mqTask")
  35. @Lazy(false)
  36. public class MQTask implements InitializingBean {
  37. private static Logger logger = LoggerFactory.getLogger(SysController.class);
  38. @Autowired
  39. private MessageService messageService;
  40. @Autowired
  41. private SmsService smsService;
  42. @Autowired
  43. private EfastOrderService efastOrderService;
  44. @Autowired
  45. private SalesOrderService salesOrderService;
  46. @Autowired
  47. private SysService sysService;
  48. @Autowired
  49. private AddressService addressService;
  50. @Autowired
  51. private CustomerService customerService;
  52. @Autowired
  53. private SysConfigService sysConfigService;
  54. @Autowired
  55. private KuaiDi100 kuaidi100;
  56. @Autowired
  57. private PostageAuthorityService postageAuthorityService;
  58. @Autowired
  59. private PostageService postageService;
  60. @Autowired
  61. private CompanyInfoService companyInfoService;
  62. @Autowired
  63. private ComplaintDetectInfoService complaintDetectInfoService;
  64. @Autowired
  65. private EfastUtil efastUtil;
  66. private Object lock = new Object();
  67. private Object lock1 = new Object();
  68. public void afterPropertiesSet() throws Exception {
  69. }
  70. //@Scheduled(cron = "*/10 * * * * ?")
  71. //@Scheduled(cron = "0 0 9,11,14,16,18,20 * * ? ")//推送时间分别为每天早上九点、中午十一点、下午三点、下午六点、晚上八点
  72. //@Scheduled(cron = "0 0 */1 * * ?")//每小时执行一次
  73. // @Scheduled(cron = "0 0/3 * * * ?")//每三分钟执行一次
  74. public void auditMessagePush(){
  75. logger.info("------------执行消息提醒,推送待处理订单短信 start-----------");
  76. List<SmsMessage> smsMessageList = messageService.listOrderMessages();
  77. if(smsMessageList != null && smsMessageList.size() > 0){
  78. //循环推送短信
  79. for(SmsMessage smsMessage : smsMessageList){
  80. ResponseJson json = smsService.sms(smsMessage.getTel(),smsMessage.getTypes(),smsMessage.getCounts());
  81. if(json.getReturnCode() == 200){
  82. logger.info("------------推送到+"+smsMessage.getTel()+"一条"+(smsMessage.getTypes() == 1?"待处理":"驳回")+"短信成功");
  83. //设置审核通过记录为无效
  84. if(smsMessage.getTypes() == 3){
  85. OrderMessage orderMessage = new OrderMessage();
  86. orderMessage.setMessageStatus(2);
  87. orderMessage.setMessageType(3);
  88. messageService.updateOrderMessageStatus(orderMessage);
  89. }
  90. }else{
  91. logger.info("------------推送到+"+smsMessage.getTel()+"一条"+(smsMessage.getTypes() == 1?"待处理":"驳回")+"短信失败"+json.getReturnMsg());
  92. }
  93. }
  94. }
  95. }
  96. /**
  97. * 批量同步百胜订单信息 -- 客诉系统 -- 作废
  98. * @throws Exception
  99. */
  100. //@Scheduled(cron = "0 0 */1 * * ?")//每小时执行一次
  101. //@Scheduled(cron = "0 0/3 * * * ?")//每三分钟执行一次
  102. //@Scheduled(cron = "*/10 * * * * ?")
  103. public void syncEfastOrderList() throws Exception {
  104. logger.info("---------------- 批量同步百胜订单开始 ---------------");
  105. int pageNo = 1;
  106. int pageSize = 20;
  107. boolean flag = false; //控制是否还需要获取百胜订单信息
  108. String date = "";
  109. synchronized (lock) {
  110. String configParameter = sysConfigService.getSysConfig(1);
  111. do {
  112. //批量获取百胜订单信息
  113. JSONObject obj = null;
  114. try{
  115. obj = efastOrderService.listOrderInfoFormEfast(pageNo, pageSize, configParameter);
  116. }catch (Exception e){
  117. logger.info("Efast订单获取失败,失败原因:"+e.getMessage());
  118. }
  119. if (obj == null) {
  120. return;
  121. }
  122. int totalResults = obj.getInt("total_results"); //百胜返回总页数
  123. if (pageNo < totalResults) {
  124. flag = true;
  125. pageNo++;
  126. } else {
  127. flag = false;
  128. }
  129. salesOrderService.addSalesOrderList(obj);
  130. } while (flag); //百胜返回条目数如果等于设置的分页条目数,则继续查询下一页
  131. }
  132. logger.info("---------------- 批量同步百胜订单结束 ---------------");
  133. }
  134. /**
  135. * 同步百胜订单状态等信息----客诉系统 -- 作废
  136. * @throws Exception
  137. */
  138. //@Scheduled(cron = "0 0 */1 * * ?")//每小时执行一次
  139. // @Scheduled(cron = "0 0/3 * * * ?")//每三分钟执行一次
  140. //@Scheduled(cron = "*/10 * * * * ?")
  141. public void syncEfastOrderStatus() throws Exception {
  142. int pageNo = 1;
  143. int pageSize = 20;
  144. boolean flag = false; //控制是否还需要获取百胜订单信息
  145. /*int returnPageNo = 1;
  146. int returnPageSize = 20;
  147. boolean returnFlag = false; //控制是否还需要获取百胜退单信息*/
  148. synchronized (lock1) {
  149. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
  150. Date beginDate = new Date();
  151. SalesOrder order = new SalesOrder();
  152. Calendar date = Calendar.getInstance();
  153. //获取同步百胜订单的开始时间
  154. String configParameter = sysConfigService.getSysConfig(2); //获取客诉订单同步百胜订单状态时间间隔
  155. date.setTime(beginDate);
  156. date.set(Calendar.DATE, date.get(Calendar.DATE) - Integer.valueOf(configParameter));
  157. order.setStartDate(format.parse(format.format(date.getTime())));
  158. order.setSalesCreateTime(format.parse(format.format(date.getTime())));
  159. //根据创建时间获取订单信息
  160. List<SalesOrder> orderlist = salesOrderService.listSalesOrder(order);
  161. logger.info("需要同步订单状态的订单有:" + orderlist.size() + "个;");
  162. if (orderlist == null || orderlist.size() == 0) {
  163. return;
  164. }
  165. do {
  166. //批量获取百胜订单信息
  167. JSONObject obj = efastOrderService.listOrderInfoFormEfast(pageNo, pageSize, format.format(order.getSalesCreateTime()));
  168. if (obj == null) {
  169. return;
  170. }
  171. JSONArray orderList = obj.getJSONArray("list");
  172. if (orderList == null || orderList.size() == 0) {
  173. return;
  174. }
  175. salesOrderService.updateOrderList(orderList, orderlist);
  176. int totalResults = obj.getInt("total_results"); //百胜返回总页数
  177. if (pageNo < totalResults) {
  178. flag = true;
  179. pageNo++;
  180. } else {
  181. flag = false;
  182. }
  183. } while (flag); //百胜返回条目数如果等于设置的分页条目数,则继续查询下一页
  184. //无法实现获取退单信息,只能查出已确认未收货的订单
  185. /*do {
  186. //批量获取百胜退单信息
  187. JSONObject obj = efastOrderService.listReturnOrderFormEfast(returnPageNo, returnPageSize, format.format(date.getTime()));
  188. if (obj == null) {
  189. return;
  190. }
  191. JSONArray orderList = obj.getJSONArray("list");
  192. System.out.println("orderList="+orderList);
  193. if (orderList == null || orderList.size() == 0) {
  194. return;
  195. }
  196. salesOrderService.updateReturnOrderList(orderList, orderlist);
  197. int totalResults = obj.getInt("total_results"); //百胜返回总页数
  198. if (returnPageNo < totalResults) {
  199. returnFlag = true;
  200. returnPageNo++;
  201. } else {
  202. returnFlag = false;
  203. }
  204. } while (returnFlag); //百胜返回条目数如果等于设置的分页条目数,则继续查询下一页*/
  205. }
  206. }
  207. /**客诉系统 自动追踪发货信息**/
  208. // @Scheduled(cron = "0 0/30 * * * ?")//每30分钟执行一次
  209. /*@Scheduled(cron = "0 0/3 * * * ?")//每三分钟执行一次*/
  210. // public void synchronousDelivery()throws Exception{
  211. //
  212. //
  213. // /*同步维修订单*/
  214. // Repair repair = new Repair();
  215. // List<Repair> listRepair = repairService.listSynchronizingRepair(repair);
  216. // if(listRepair.size() > 0){
  217. // for(Repair re:listRepair){
  218. // JSONObject respData = efastOrderService.getOrderFormEfastByOrderId(re.getRepairBackEfastOrderId());
  219. // EfastOrder efastOrder = efastUtil.respDataConversion(respData);
  220. // if(efastOrder == null){
  221. // return;
  222. // }
  223. // if (efastOrder.getOrderStatus() == 1){//1代表已发货 发货状态: 0(未发货)1(已发货,即已扫描出库)3(备货中)
  224. // re.setRepairSendName(efastOrder.getOrderAddressName());
  225. // re.setRepairSendTel(efastOrder.getOrderAddressTel());
  226. // //查询省市县id
  227. // /*Map<String,String> pccMap = provincesCitiesCounties(efastOrder);
  228. // re.setProvinceNumber(Integer.valueOf(pccMap.get("provinceId")));
  229. // re.setCityNumber(Integer.valueOf(pccMap.get("cityId")));
  230. // re.setAreaNumber(Integer.valueOf(pccMap.get("districtId")));*/
  231. // /*re.setRepairSendMergeAddress(pccMap.get("province")+"-"+pccMap.get("city")+"-"+pccMap.get("district"));*/
  232. // /*re.setRepairSendAddress(efastOrder.getOrderAddress());*/
  233. // re.setRepairSendLogisticsCompany(efastOrder.getOrderPostFirm());
  234. // re.setRepairSendLogisticsNo(efastOrder.getOrderPostNum());
  235. // /*re.setRepairSendStatus(2);*/
  236. // Integer msg = repairService.updateRepairInfo(re,null,null);
  237. // if(msg > 0){
  238. // //发送维修发货通知短信
  239. // sendSMS("<维修业务>",efastOrder.getOrderPostFirm(),efastOrder.getOrderPostNum(),re.getCustomerId(),re.getRepairBackTel());
  240. // }
  241. // }
  242. //
  243. // }
  244. // }
  245. //
  246. // /*同步换货订单*/
  247. // Renewed renewed = new Renewed();
  248. // List<Renewed> listRenewed = renewedService.listSynchronizingRenewed(renewed);
  249. // if(listRenewed.size() > 0){
  250. // for(Renewed re:listRenewed){
  251. // JSONObject respData = efastOrderService.getOrderFormEfastByOrderId(re.getRenewedBackEfastOrderId());
  252. // EfastOrder efastOrder = efastUtil.respDataConversion(respData);
  253. // if(efastOrder == null){
  254. // return;
  255. // }
  256. // if (efastOrder.getOrderStatus() == 1){//1代表已发货 发货状态: 0(未发货)1(已发货,即已扫描出库)3(备货中)
  257. // re.setRenewedSendName(efastOrder.getOrderAddressName());
  258. // re.setRenewedSendTel(efastOrder.getOrderAddressTel());
  259. // /*//查询省市县id
  260. // Map<String,String> pccMap = provincesCitiesCounties(efastOrder);
  261. // re.setProvinceNumber(Integer.valueOf(pccMap.get("provinceId")));
  262. // re.setCityNumber(Integer.valueOf(pccMap.get("cityId")));
  263. // re.setAreaNumber(Integer.valueOf(pccMap.get("districtId")));
  264. // re.setRenewedSendMergeAddress(pccMap.get("province")+"-"+pccMap.get("city")+"-"+pccMap.get("district"));
  265. // re.setRenewedSendAddress(efastOrder.getOrderAddress());*/
  266. // re.setRenewedSendLogisticsCompany(efastOrder.getOrderPostFirm());
  267. // re.setRenewedSendLogisticsNo(efastOrder.getOrderPostNum());
  268. // /*re.setRenewedSendStatus(2);*/
  269. // Integer msg = renewedService.updateRenewedInfo(re,null,null);
  270. // if(msg > 0){
  271. // //发送换货发货通知短信
  272. // sendSMS("<换货业务>",efastOrder.getOrderPostFirm(),efastOrder.getOrderPostNum(),re.getCustomerId(),re.getRenewedBackTel());
  273. // }
  274. // }
  275. // }
  276. // }
  277. // /*同步补发订单*/
  278. // Reissue reissue = new Reissue();
  279. // List<Reissue> listReissue = reissueService.listSynchronizingReissue(reissue);
  280. // if(listReissue.size() > 0){
  281. // for(Reissue re:listReissue){
  282. // JSONObject respData = efastOrderService.getOrderFormEfastByOrderId(re.getReissueBackEfastOrderId());
  283. // EfastOrder efastOrder = efastUtil.respDataConversion(respData);
  284. // if(efastOrder == null){
  285. // return;
  286. // }
  287. // if (efastOrder.getOrderStatus() == 1){//1代表已发货 发货状态: 0(未发货)1(已发货,即已扫描出库)3(备货中)
  288. // re.setReissueSendName(efastOrder.getOrderAddressName());
  289. // re.setReissueSendTel(efastOrder.getOrderAddressTel());
  290. // /*//查询省市县id
  291. // Map<String,String> pccMap = provincesCitiesCounties(efastOrder);
  292. // re.setProvinceNumber(Integer.valueOf(pccMap.get("provinceId")));
  293. // re.setCityNumber(Integer.valueOf(pccMap.get("cityId")));
  294. // re.setAreaNumber(Integer.valueOf(pccMap.get("districtId")));
  295. // re.setReissueSendMergeAddress(pccMap.get("province")+"-"+pccMap.get("city")+"-"+pccMap.get("district"));
  296. // re.setReissueSendAddress(efastOrder.getOrderAddress());*/
  297. // re.setReissueSendLogisticsCompany(efastOrder.getOrderPostFirm());
  298. // re.setReissueSendLogisticsNo(efastOrder.getOrderPostNum());
  299. // /*re.setReissueSendStatus(2);*/
  300. // Integer msg = reissueService.updateReissueInfo(re);
  301. // if(msg > 0){
  302. // //发送补发发货通知短信
  303. // sendSMS("<补发业务>",efastOrder.getOrderPostFirm(),efastOrder.getOrderPostNum(),re.getCustomerId(),re.getReissueSendTel());
  304. //
  305. // }
  306. // }
  307. // }
  308. // }
  309. // }
  310. /**
  311. * 发送发货通知
  312. * @param relation 维修 换货 补发
  313. * @param postFirm 物流公司代码
  314. * @param postNum 物流单号
  315. * @param customerId 客诉主键id
  316. * @param tel 手机号
  317. */
  318. public void sendSMS(String relation,String postFirm,String postNum,Integer customerId,String tel){
  319. if(postFirm != null && !postFirm.equals("") && postNum != null && !postNum.equals("")
  320. && customerId > 0 && !tel.equals("")){
  321. postFirm = KuaiDi100.replace(postFirm);
  322. if(!postFirm.equals("")){
  323. ProductType productType = customerService.getcompanyAffiliation(customerId);
  324. if(productType != null){
  325. String rejected_text = "";
  326. //1:美国watero; 2:上朵电动牙刷 3:优尼雅净水机
  327. if (productType.getTypeCompany() == 1){
  328. rejected_text = RELATION_SEND_WATERO;
  329. }
  330. if (productType.getTypeCompany() == 2){
  331. rejected_text = RELATION_SEND_SHANGDUO;
  332. }
  333. if (productType.getTypeCompany() == 3){
  334. rejected_text = RELATION_SEND_YULIA;
  335. }
  336. if (productType.getTypeCompany() == 4){
  337. rejected_text = RELATION_SEND_AIBERLE;
  338. }
  339. String text = MessageFormat.format(rejected_text, relation,postFirm+","+postNum);
  340. smsService.sendOtherCMS(tel,text);
  341. }
  342. }
  343. }
  344. }
  345. /**
  346. * 查询省市县id
  347. * @param
  348. */
  349. // public Map<String,String> provincesCitiesCounties(EfastOrder efastOrder){
  350. // Map<String,String> map = new HashMap<String, String>();
  351. // String province = "";
  352. // String city = "";
  353. // String zone = "";
  354. // //省
  355. // if(efastOrder.getOrderProvince().substring(efastOrder.getOrderProvince().length() - 1,efastOrder.getOrderProvince().length()).equals("省")){
  356. // province = efastOrder.getOrderProvince().substring(0,efastOrder.getOrderProvince().length() - 1);
  357. // }else{
  358. // province = efastOrder.getOrderProvince();
  359. // }
  360. // Province provinceinfo = new Province();
  361. // provinceinfo.setProvince(province);
  362. // List<Province> provinceList = addressService.listProvince(provinceinfo);
  363. // if(provinceList.size() < 1){
  364. // provinceinfo.setProvince(null);
  365. // provinceList = addressService.listProvince(provinceinfo);
  366. // }
  367. // map.put("provinceId",String.valueOf(provinceList.get(0).getProvinceId()));
  368. // map.put("province",provinceList.get(0).getProvince());
  369. //
  370. //
  371. // //市
  372. // city = efastOrder.getOrderCity().substring(0,efastOrder.getOrderCity().length() - 1);
  373. // City cityInfo = new City();
  374. // cityInfo.setCity(city);
  375. // List<City> cityList = addressService.listCity(cityInfo);
  376. // if(cityList.size() < 1){
  377. // cityInfo.setCity(null);
  378. // cityInfo.setProvinceId(provinceList.get(0).getProvinceId());
  379. // cityList = addressService.listCity(cityInfo);
  380. // }
  381. // map.put("cityId",String.valueOf(cityList.get(0).getCityId()));
  382. // map.put("city",cityList.get(0).getCity());
  383. //
  384. // //区
  385. // zone = efastOrder.getOrderArea().substring(0,efastOrder.getOrderArea().length() - 1);
  386. // District district = new District();
  387. // district.setDistrict(zone);
  388. // List<District> districtList = addressService.listDistrict(district);
  389. // if(districtList.size() < 1){
  390. // district.setDistrict(null);
  391. // district.setCityId(cityList.get(0).getCityId());
  392. // districtList = addressService.listDistrict(district);
  393. // }
  394. // map.put("districtId",String.valueOf(districtList.get(0).getDistrictId()));
  395. // map.put("district",districtList.get(0).getDistrict());
  396. // return map;
  397. // }
  398. /**客诉系统 自动追踪发货信息**/
  399. // @Scheduled(cron = "0 0/60 * * * ?")//每60分钟执行一次
  400. // @Scheduled(cron = "0 0/1 * * * ?")//每1分钟执行一次
  401. // public void syncSendBackCustomer()throws Exception{
  402. // CmRelation cmRelation = new CmRelation();
  403. // cmRelation.setRelationBackStatus(2);
  404. // List<CmRelation> cmRelationList = cmRelationService.getCmRelationList(cmRelation);
  405. // for(int i=0;i<cmRelationList.size();i++){
  406. // CmRelation cc = cmRelationList.get(i);
  407. // if(!StringUtils.isEmpty(cc.getRelationBackLogisticsCompany()) && !StringUtils.isEmpty(cc.getRelationBackLogisticsNo())){
  408. // JSONObject rst = kuaidi100.getExpressInfo(cc.getRelationBackLogisticsCompany(),cc.getRelationBackLogisticsNo());
  409. // if(rst.has("state") && rst.getInt("state") == 3){ //当快递状态为已签收的时候
  410. // Integer flag = 0;
  411. // try{
  412. // flag = cmRelationService.updateStatus(cc);
  413. // }catch (RuntimeException e){
  414. // logger.info("====== 客诉寄回签收报错 :客诉id:"+cc.getCustomerId()+" ======"+e.getMessage());
  415. // }
  416. // if(flag < 1){
  417. // logger.info("====== 客诉寄回签收失败 :客诉id:"+cc.getCustomerId()+" ======");
  418. // }else{
  419. // logger.info("====== 客诉寄回签收成功 :客诉id:"+cc.getCustomerId()+" ======");
  420. // }
  421. // }
  422. // }
  423. // }
  424. // }
  425. /**客诉系统 自动追踪发货信息**/
  426. // @Scheduled(cron = "0 0/2 * * * ?")//每2分钟执行一次
  427. @Scheduled(cron = "0 0 9 * * ?")//每天上午午9点触发
  428. public void postageRemind()throws Exception{
  429. Map<Integer,Integer> map = new HashMap<Integer,Integer>();
  430. List<CompanyInfo> companyInfoList = companyInfoService.listCompanyInfo(new CompanyInfo());
  431. for (CompanyInfo ci: companyInfoList ) {
  432. /*权限去重*/
  433. Set<Integer> authorityCustomerManagerSet = new HashSet();
  434. Set<Integer> authorityFinancialManagerSet = new HashSet();
  435. Set<Integer> authorityFinancialPaymentSet = new HashSet();
  436. PostageAuthority postageAuthority = new PostageAuthority();
  437. postageAuthority.setAuthorityStatus(1);
  438. postageAuthority.setCompanyId(ci.getCompanyId());
  439. List<PostageAuthority> postageAuthorityList = postageAuthorityService.getPostageAuthorityList(postageAuthority);
  440. for (int j=0;j<postageAuthorityList.size();j++){
  441. PostageAuthority pa = postageAuthorityList.get(j);
  442. if(pa.getAuthorityCustomerManager() != null && pa.getAuthorityCustomerManager() != 0){
  443. authorityCustomerManagerSet.add(pa.getAuthorityCustomerManager());
  444. }
  445. if(pa.getAuthorityFinancialManager() != null && pa.getAuthorityFinancialManager() != 0){
  446. authorityFinancialManagerSet.add(pa.getAuthorityFinancialManager());
  447. }
  448. if(pa.getAuthorityFinancialPayment() != null && pa.getAuthorityFinancialPayment() != 0){
  449. authorityFinancialPaymentSet.add(pa.getAuthorityFinancialPayment());
  450. }
  451. }
  452. Postage pt = new Postage();
  453. pt.setCompanyId(ci.getCompanyId());
  454. pt.setPostageManagerStatus(1); //客服经理审核 1:审核中
  455. for (Integer customerManager: authorityCustomerManagerSet) { //customerManager 为id
  456. Integer postageNumber = postageService.getPostageNumber(pt);
  457. if(map.get(customerManager) == null){
  458. map.put(customerManager,postageNumber);
  459. }else{
  460. Integer number = map.get(customerManager);
  461. map.put(customerManager,number + postageNumber);
  462. }
  463. }
  464. pt = new Postage();
  465. pt.setCompanyId(ci.getCompanyId());
  466. pt.setPostageFinanceStatus(1); //状态(财务审核) 1:审核中
  467. for (Integer financialManager: authorityFinancialManagerSet) { //financialManager 为id
  468. Integer postageNumber = postageService.getPostageNumber(pt);
  469. if(map.get(financialManager) == null){
  470. map.put(financialManager,postageNumber);
  471. }else{
  472. Integer number = map.get(financialManager);
  473. map.put(financialManager,number + postageNumber);
  474. }
  475. }
  476. pt = new Postage();
  477. pt.setCompanyId(ci.getCompanyId());
  478. pt.setPostageTransferStatus(1); //是否转账:1待转 2:已转
  479. for (Integer financialPayment: authorityFinancialPaymentSet) { //financialPayment 为id
  480. Integer postageNumber = postageService.getPostageNumber(pt);
  481. if(map.get(financialPayment) == null){
  482. map.put(financialPayment,postageNumber);
  483. }else{
  484. Integer number = map.get(financialPayment);
  485. map.put(financialPayment,number + postageNumber);
  486. }
  487. }
  488. }
  489. for (Map.Entry<Integer,Integer> m: map.entrySet()) {
  490. Integer number = m.getValue();
  491. Admin admin = new Admin();
  492. admin.setAdminId(m.getKey());
  493. admin = sysService.get(admin);
  494. String tel = admin.getAdminTel();
  495. if(admin == null || tel == null || "".equals(tel)){
  496. logger.info("邮费转账发送待处理短信,手机号码为空,"+ tel+"===id为"+m.getKey());
  497. continue;
  498. }
  499. if(number == null || number == 0){
  500. continue;
  501. }
  502. String text = MessageFormat.format(REMIND_POSTAGE_PENDING,number);
  503. smsService.sendOtherCMS(tel,text);
  504. }
  505. }
  506. /**
  507. * 查询维修超时数据并短信通知
  508. */
  509. @Scheduled(cron = "0 50 8 * * ?")//每天上午午9点触发
  510. /* @Scheduled(cron = "0 0/1 * * * ?")//每2分钟执行一次*/
  511. public void detectTimeoutNotice() throws Exception {
  512. logger.info("---------------- 询维修超时数据并短信通知开始 ---------------");
  513. //待检测即将超时数据
  514. List<ComplaintDetectInfo> listMaintenanceCut = complaintDetectInfoService.listMaintenanceCutNotice();
  515. //待维修即将超时数据
  516. List<ComplaintDetectInfo> listCompleteCut = complaintDetectInfoService.listCompleteCutNotice();
  517. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
  518. if(listMaintenanceCut != null && listMaintenanceCut.size() > 0){
  519. for(ComplaintDetectInfo info : listMaintenanceCut){
  520. if(info.getDetectNumber() != null && info.getMaintenanceCutTime() != null){
  521. //发送短信通知维修检测人员
  522. String text = MessageFormat.format(SmsConfig.DETECTION_TIMEOUT_NOTIFICATION, info.getDetectNumber(),"检测超时",format.format(info.getMaintenanceCutTime()));
  523. String result = smsService.sendOtherCMS(SmsConfig.CUSTOMER_PHONE, text);
  524. logger.info("给 " + SmsConfig.CUSTOMER_PHONE + " 手机用户发送短信:" + text+"发送检测即将超时数据维修人员:"+result);
  525. }
  526. }
  527. }
  528. if(listCompleteCut != null && listCompleteCut.size() > 0){
  529. for(ComplaintDetectInfo info : listCompleteCut){
  530. //发送短信通知维修检测人员
  531. if(info.getDetectNumber() != null && info.getCompleteCutTime() != null){
  532. String text = MessageFormat.format(SmsConfig.DETECTION_TIMEOUT_NOTIFICATION, info.getDetectNumber(),"维修超时",format.format(info.getCompleteCutTime()));
  533. String result = smsService.sendOtherCMS(SmsConfig.CUSTOMER_PHONE, text);
  534. logger.info("给 " + SmsConfig.CUSTOMER_PHONE + " 手机用户发送短信:" + text+"发送维修即将超时数据维修人员:"+result);
  535. }
  536. }
  537. }
  538. logger.info("---------------- 询维修超时数据并短信通知结束 ---------------");
  539. }
  540. }