37a67ed46c8c0e9f1c9664dc91652ef1766d2007.svn-base 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370
  1. package com.chinacreator.process.service;
  2. import java.sql.SQLException;
  3. import java.util.ArrayList;
  4. import java.util.Date;
  5. import java.util.List;
  6. import org.apache.commons.lang.StringUtils;
  7. import org.apache.commons.lang.math.NumberUtils;
  8. import org.apache.commons.lang.time.DateFormatUtils;
  9. import org.apache.log4j.Logger;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.stereotype.Component;
  12. import com.chinacreator.common.exception.BusinessException;
  13. import com.chinacreator.process.bean.ActivityConfigBean;
  14. import com.chinacreator.process.bean.NetOrderBean;
  15. import com.chinacreator.process.bean.OrderBean;
  16. import com.chinacreator.process.dao.ActivityConfigDao;
  17. import com.chinacreator.process.dao.DictionaryDao;
  18. import com.chinacreator.process.dao.YoutuActiveDao;
  19. /**
  20. * 优酷产品处理类
  21. * @author xu.zhou
  22. * @date 20190409
  23. */
  24. @Component
  25. public class YoutuOrderService {
  26. private Logger log = Logger.getLogger("recivemq");
  27. @Autowired
  28. private YoutuActiveDao youtuActiveDao;
  29. @Autowired
  30. private DictionaryDao dictionaryDao;
  31. @Autowired
  32. private ActivityConfigDao activityConfigDao;
  33. public void handle(OrderBean orderBean) throws Exception {
  34. OrderBean activityOrderBean = youtuActiveDao.existUser(orderBean.getUserid(), orderBean.getCpid(),
  35. orderBean.getSpid(),orderBean.getActiveType()+"");
  36. if(activityOrderBean == null){//活动表无数据,订购或退订
  37. orderBean = getOrderInfo(orderBean);
  38. orderBean = setFlowstatus(orderBean,activityOrderBean);
  39. String id = youtuActiveDao.getId();
  40. orderBean.setId(id);
  41. // log.info("添加活动数据");
  42. youtuActiveDao.insertBeans(orderBean);
  43. }else{//活动表有数据,订购或退订
  44. orderBean = getOrderInfo(orderBean);
  45. OrderBean vipOrderBean = getVipInfo(activityOrderBean);
  46. orderBean.setVipstatus(vipOrderBean.getVipstatus());
  47. orderBean.setViptime(vipOrderBean.getViptime());
  48. orderBean.setId(activityOrderBean.getId());
  49. orderBean = setFlowstatus(orderBean,activityOrderBean);
  50. //log.info("更新活动数据");
  51. youtuActiveDao.update(orderBean);
  52. }
  53. //赠送流量流程
  54. if(hasActivityDate(orderBean)){//当前时间在活动期内
  55. OrderBean flowBean = youtuActiveDao.existFlowRec(orderBean);
  56. /**
  57. * 用户订购时如果此表没有数据就新增数据,
  58. 用户退订时如果已有数据且是订购状态更新此表数据为退订,只会更新一次退订操作
  59. */
  60. if(flowBean == null && "0".equals(orderBean.getOrderstatus())){//记录表为空,此次是订购
  61. youtuActiveDao.insertFlowRec(orderBean);
  62. }else if(flowBean == null && "1".equals(orderBean.getFlowstatus())){//记录表为空,此次是要送流量(一分钟内订购又退订的)
  63. youtuActiveDao.insertFlowRec(orderBean);
  64. }else if(flowBean != null && "0".equals(flowBean.getOrderstatus()) && "1".equals(orderBean.getOrderstatus())){ //记录是的订购状态,此次是退订
  65. orderBean.setId(flowBean.getId());
  66. youtuActiveDao.updateFlowRec(orderBean);
  67. }
  68. }else{
  69. updateExpireFlowRec(orderBean);
  70. }
  71. }
  72. /**
  73. * 活动过期后,用户退订时更新记录数据
  74. * @param orderBean
  75. * @return
  76. */
  77. private boolean updateExpireFlowRec(OrderBean orderBean){
  78. boolean result = false;
  79. try {
  80. //在最后的续送日期内
  81. if("1".equals(orderBean.getOrderstatus())){//退订
  82. final Date date = new Date();
  83. String flowOverTime = getConfTime(orderBean.getSpid(),"3"); //dictionaryDao.getValue(orderBean.getCpid()+orderBean.getSpid()+"FlowOverTime"); //流量续送最后一天(活动结束日期加两月)
  84. if(flowOverTime != null && !"".equals(flowOverTime.trim()) && NumberUtils.toLong(DateFormatUtils.format(date, "yyyyMMddHHmmss")) - NumberUtils.toLong(flowOverTime.trim()) <= 0){
  85. //在最后的续送日期内
  86. //查询记录是订购状态且当前时间月份减去订购时间月分份小于或等于2的数据
  87. OrderBean flowBean = youtuActiveDao.existExpireFlowRec(orderBean);
  88. if(flowBean != null){//
  89. orderBean.setId(flowBean.getId());
  90. //更新记录表为退订
  91. youtuActiveDao.updateFlowRec(orderBean);
  92. }
  93. }
  94. }
  95. } catch (Exception e) {
  96. e.printStackTrace();
  97. log.info(orderBean.getUserid()+": errorinfo=>活动过期后,用户退订时更新记录数据出现异常,"+e.getMessage());
  98. }
  99. return result;
  100. }
  101. /**
  102. * 是否在赠送流量活动期内
  103. * @return
  104. */
  105. private boolean hasActivityDate(OrderBean orderBean){
  106. boolean result = false;
  107. try {
  108. final Date date = new Date();
  109. String flowStartTime = getConfTime(orderBean.getSpid(),"1"); //dictionaryDao.getValue(orderBean.getCpid()+orderBean.getSpid()+"FlowStartTime"); //赠送流量开始时间
  110. String flowEndTime = getConfTime(orderBean.getSpid(),"2"); //dictionaryDao.getValue(orderBean.getCpid()+orderBean.getSpid()+"FlowEndTime"); //赠送流量结束时间
  111. if(flowStartTime != null && !"".equals(flowStartTime.trim()) && flowEndTime != null && !"".equals(flowEndTime.trim())){
  112. flowEndTime = flowEndTime.trim();
  113. flowStartTime = flowStartTime.trim();
  114. /*
  115. //1.活动时间:4月1日00:00:00至6月30日23:59:59
  116. if (NumberUtils.toLong(DateFormatUtils.format(date, "yyyyMMddHHmmss")) >= Long.parseLong(flowStartTime)
  117. && NumberUtils.toLong(DateFormatUtils.format(date, "yyyyMMddHHmmss")) <= Long.parseLong(flowEndTime)) {
  118. result = true;
  119. }
  120. //反向通知的数据可能延迟,当天已超过最后赠送时间,但订购时间在活动期内
  121. if(result == false && "0".equals(orderBean.getOrderstatus())){
  122. if (NumberUtils.toLong(orderBean.getOrdertime()) >= Long.parseLong(flowStartTime)
  123. && NumberUtils.toLong(orderBean.getOrdertime()) <= Long.parseLong(flowEndTime)) {
  124. result = true;
  125. }
  126. }
  127. //反向通知的数据可能延迟,订购时间小于活开始时间
  128. if(result == true && "0".equals(orderBean.getOrderstatus())){
  129. if (NumberUtils.toLong(orderBean.getOrdertime()) < Long.parseLong(flowStartTime)) {
  130. result = false;
  131. }
  132. }
  133. */
  134. //订购时间在指定范围内
  135. if (NumberUtils.toLong(orderBean.getOrdertime()) >= Long.parseLong(flowStartTime)
  136. && NumberUtils.toLong(orderBean.getOrdertime()) <= Long.parseLong(flowEndTime)) {
  137. result = true;
  138. }
  139. }
  140. } catch (Exception e) {
  141. e.printStackTrace();
  142. log.info(orderBean.getUserid()+": errorinfo=>判断是否在赠送流量活动期内出现异常,"+e.getMessage());
  143. }
  144. return result;
  145. }
  146. /**
  147. * 获取配置时间
  148. * @param spid
  149. * @param type 1开始时间,2结束时间,3续送最后时间
  150. * @return
  151. * @throws SQLException
  152. */
  153. private String getConfTime(String spid, String type) throws SQLException{
  154. String res = "";
  155. String data = "";
  156. if("1".equals(type)){
  157. data = dictionaryDao.getValue("flowSendStartTime");
  158. }else if("2".equals(type)){
  159. data = dictionaryDao.getValue("flowSendEndTime");
  160. }else if("3".equals(type)){
  161. data = dictionaryDao.getValue("flowSendOverTime");
  162. }
  163. if(data != null && !"".equals(data)){
  164. String [] array = data.split("\\|");
  165. for(String conf : array){
  166. if(spid.equals(conf.split(",")[0])){
  167. res = conf.split(",")[1];
  168. break;
  169. }
  170. }
  171. }
  172. return res;
  173. }
  174. /**
  175. * 设置赠送流量信息
  176. * @param orderBean
  177. */
  178. private OrderBean setFlowstatus(OrderBean orderBean,OrderBean activityOrderBean) throws BusinessException{
  179. try {
  180. //初始化数据
  181. orderBean.setFlowstatus("8"); //不赠送
  182. if(activityOrderBean != null){
  183. orderBean.setFlowstatus(activityOrderBean.getFlowstatus());
  184. }
  185. //判断是否在活动期
  186. if (hasActivityDate(orderBean)) {
  187. String flowStartTime = getConfTime(orderBean.getSpid(),"1"); //dictionaryDao.getValue(orderBean.getCpid()+orderBean.getSpid()+"FlowStartTime"); //赠送流量开始时间
  188. String flowEndTime = getConfTime(orderBean.getSpid(),"2"); //dictionaryDao.getValue(orderBean.getCpid()+orderBean.getSpid()+"FlowEndTime"); //赠送流量结束时间
  189. if(flowStartTime != null ) flowStartTime = flowStartTime.trim();
  190. if(flowEndTime != null ) flowEndTime = flowEndTime.trim();
  191. //优酷20元赠送流量活动日期
  192. if(activityOrderBean == null && "0".equals(orderBean.getOrderstatus())){//新用户订购
  193. orderBean.setFlowstatus("1"); //未赠送
  194. }else if(activityOrderBean == null && "1".equals(orderBean.getOrderstatus())
  195. && flowStartTime != null && flowStartTime.length() > 6
  196. && flowEndTime != null && flowEndTime.length() > 6
  197. && orderBean.getOrdertime() != null && orderBean.getOrdertime().length() > 6
  198. && Integer.parseInt(orderBean.getOrdertime().substring(0, 6)) >= Integer.parseInt(flowStartTime.substring(0, 6))
  199. && Integer.parseInt(orderBean.getOrdertime().substring(0, 6)) <= Integer.parseInt(flowEndTime.substring(0, 6))){
  200. //活动表没记录,且是退订操作,订购时间在在活动期内(一分钟内订购又退订的)
  201. orderBean.setFlowstatus("1"); //未赠送
  202. }else if(activityOrderBean != null && "8".equals(activityOrderBean.getFlowstatus()) && "1".equals(orderBean.getOrderstatus())
  203. && flowStartTime != null && flowStartTime.length() > 6
  204. && flowEndTime != null && flowEndTime.length() > 6
  205. && activityOrderBean.getOrdertime() != null && activityOrderBean.getOrdertime().length() > 6
  206. && Integer.parseInt(activityOrderBean.getOrdertime().substring(0, 6)) < Integer.parseInt(flowStartTime.substring(0, 6))
  207. && orderBean.getOrdertime() != null && orderBean.getOrdertime().length() > 6
  208. && Integer.parseInt(orderBean.getOrdertime().substring(0, 6)) >= Integer.parseInt(flowStartTime.substring(0, 6))
  209. && Integer.parseInt(orderBean.getOrdertime().substring(0, 6)) <= Integer.parseInt(flowEndTime.substring(0, 6))){
  210. //活动表有记录,且是退订操作,活动表的订购时间在活动开始之前订购的,且此次订购时间在活动期内(在活动期内一分钟内订购又退订的)
  211. orderBean.setFlowstatus("1"); //未赠送
  212. }else if(activityOrderBean != null && "8".equals(activityOrderBean.getFlowstatus()) && "0".equals(orderBean.getOrderstatus())){ //老用户活动期间第一次退订后再订购
  213. orderBean.setFlowstatus("1"); //未赠送
  214. }
  215. }
  216. } catch (Exception e) {
  217. e.printStackTrace();
  218. //throw new BusinessException("8011", "设置赠送流量信息出现异常,"+e.getMessage());
  219. log.info(orderBean.getUserid()+": errorinfo=>设置赠送流量信息出现异常,"+e.getMessage());
  220. }
  221. return orderBean;
  222. }
  223. /**
  224. * 获取会员赠送信息
  225. * @param activityOrderBean
  226. * @return
  227. * @throws BusinessException
  228. */
  229. private OrderBean getVipInfo(OrderBean activityOrderBean) throws BusinessException{
  230. //VIPSTATUS IS '腾讯会员赠送状态 0 成功 1失败 2未赠送 3 会员赠送中 4 暂停赠送 5不送';
  231. OrderBean orderBean = new OrderBean();
  232. String vipstatus=activityOrderBean.getVipstatus();
  233. String viptime = activityOrderBean.getViptime();
  234. if(StringUtils.isEmpty(viptime)){
  235. vipstatus = activityOrderBean.getVipstatus();
  236. viptime = activityOrderBean.getViptime();
  237. }else{
  238. //领取会员月份是当月
  239. if(NumberUtils.toLong(viptime.substring(0, 6)) ==NumberUtils.toLong(DateFormatUtils.format(new Date(), "yyyyMM"))){
  240. //续送会员日期是当月
  241. if(activityOrderBean.getVipcontime() != null && NumberUtils.toLong(activityOrderBean.getVipcontime().substring(0, 6)) == NumberUtils.toLong(DateFormatUtils.format(new Date(), "yyyyMM"))){
  242. vipstatus ="0"; //设置赠送会员成功
  243. viptime = activityOrderBean.getVipcontime(); //设置赠送会员时间为续送时间
  244. }else{
  245. vipstatus = activityOrderBean.getVipstatus();//设置领取会员状态为原数据
  246. viptime = activityOrderBean.getViptime(); //设置领取会员时间为原数据
  247. }
  248. //领取会员日期是往月
  249. }else if(NumberUtils.toLong(viptime.substring(0, 6)) < NumberUtils.toLong(DateFormatUtils.format(new Date(), "yyyyMM"))){
  250. //续送会员日期是当月
  251. if(activityOrderBean.getVipcontime() != null && NumberUtils.toLong(activityOrderBean.getVipcontime().substring(0, 6)) == NumberUtils.toLong(DateFormatUtils.format(new Date(), "yyyyMM"))){
  252. vipstatus = activityOrderBean.getVipstatus(); //设置领取会员状态为原数据
  253. viptime = activityOrderBean.getViptime(); //设置领取会员时间为原数据
  254. }else{
  255. vipstatus ="2"; //设置领取会员状态为未赠送
  256. viptime =""; //设置领取会员时间为空
  257. }
  258. }else{
  259. throw new BusinessException("8010", "viptime数据异常");
  260. }
  261. }
  262. orderBean.setVipstatus(vipstatus);
  263. orderBean.setViptime(viptime);
  264. return orderBean;
  265. }
  266. public OrderBean getOrderInfo(OrderBean orderBean) throws Exception{
  267. //获取订购关系表中所有数据
  268. List<NetOrderBean> list = youtuActiveDao.findOrder(orderBean.getCpid(), orderBean.getUserid(),orderBean.getSpid());
  269. List<NetOrderBean> orderlist = new ArrayList<NetOrderBean>();
  270. List<NetOrderBean> cancellist = new ArrayList<NetOrderBean>();
  271. //获取活动配置表的数据
  272. ActivityConfigBean activityConfigBean = activityConfigDao.findByCallerheadtype(orderBean.getCpid(), orderBean.getSpid(), orderBean.getProvince(),orderBean.getActiveType()+"");
  273. if(list != null && list.size()>0){
  274. for (NetOrderBean netOrderBean : list) {
  275. //订购日期大于活动的开始日期且小于活动的结束日期
  276. if(NumberUtils.toLong(netOrderBean.getOrdertimestr()) >= NumberUtils.toLong(activityConfigBean.getBegintime()) && NumberUtils.toLong(netOrderBean.getOrdertimestr()) <= NumberUtils.toLong(activityConfigBean.getEndtime())){
  277. if(netOrderBean.getStatus().equals("0")){//订购状态
  278. orderlist.add(netOrderBean);
  279. }else if(netOrderBean.getStatus().equals("1")){//退订状态
  280. cancellist.add(netOrderBean);
  281. }
  282. }
  283. }
  284. }
  285. String ordertime = ""; //订购时间
  286. String endtime = ""; //结束时间
  287. String canceltime = ""; //退订时间
  288. String orderstatus = ""; //订购状态 :0 订购, 1退订, 2失效, 3 老用户退订, 4老用户当月订了又退
  289. String orderchannel = ""; //订购渠道
  290. String cancelchannel = ""; //退订渠道
  291. String effectivetime = ""; //生效时间
  292. if(orderlist.size()>0 && cancellist.size()==0){//全是订购,取最早订购时间
  293. orderstatus = "0"; //订购
  294. for (NetOrderBean netOrderBean : orderlist) {
  295. if(StringUtils.isEmpty(ordertime)){
  296. ordertime = netOrderBean.getOrdertimestr();
  297. }
  298. if(NumberUtils.toLong(netOrderBean.getOrdertimestr()) <= NumberUtils.toLong(ordertime)){
  299. ordertime = netOrderBean.getOrdertimestr(); //取最是订购时间
  300. orderchannel = netOrderBean.getOrderchannel(); //取最是订购渠道
  301. effectivetime = netOrderBean.getEffecttimestr();//取生效时间
  302. }
  303. }
  304. }else if(cancellist.size() >0 && orderlist.size()==0){//全是退订
  305. orderstatus = "1"; //退订
  306. for (NetOrderBean netOrderBean : cancellist) {
  307. if(StringUtils.isEmpty(ordertime)){
  308. ordertime = netOrderBean.getOrdertimestr();
  309. canceltime = netOrderBean.getCanceltimestr();
  310. cancelchannel = netOrderBean.getCancelchannel();
  311. orderchannel = netOrderBean.getOrderchannel();
  312. endtime = netOrderBean.getEndtimestr();
  313. effectivetime = netOrderBean.getEffecttimestr();//取生效时间
  314. }
  315. if(NumberUtils.toLong(netOrderBean.getOrdertimestr()) <= NumberUtils.toLong(ordertime)){
  316. ordertime = netOrderBean.getOrdertimestr(); //取最早订购时间
  317. orderchannel = netOrderBean.getOrderchannel(); //取最早订购渠道
  318. effectivetime = netOrderBean.getEffecttimestr();//取生效时间
  319. }
  320. if(NumberUtils.toLong(netOrderBean.getCanceltimestr()) >= NumberUtils.toLong(canceltime)){
  321. canceltime = netOrderBean.getCanceltimestr(); //取最晚退订时间
  322. endtime = netOrderBean.getEndtimestr(); //取最晚结束时间
  323. cancelchannel = netOrderBean.getCancelchannel(); //取最晚退订渠道
  324. }
  325. }
  326. }else if(cancellist.size() >0 && orderlist.size()>0){ //有退订又有订购
  327. orderstatus ="0";
  328. orderBean.setCancelchannel(cancelchannel);
  329. for (NetOrderBean netOrderBean : list) {
  330. if(netOrderBean.getStatus().equals("0") || netOrderBean.getStatus().equals("1")){
  331. if(StringUtils.isEmpty(ordertime)){
  332. ordertime = netOrderBean.getOrdertimestr();
  333. effectivetime = netOrderBean.getEffecttimestr();//取生效时间
  334. }
  335. if(NumberUtils.toLong(netOrderBean.getOrdertimestr()) <= NumberUtils.toLong(ordertime)){
  336. ordertime = netOrderBean.getOrdertimestr(); //取最早订购时间
  337. orderchannel=netOrderBean.getOrderchannel(); //取最早订购渠道
  338. effectivetime = netOrderBean.getEffecttimestr();//取生效时间
  339. }
  340. }
  341. }
  342. }else{
  343. throw new BusinessException("8010", "order数据异常");
  344. }
  345. orderBean.setEndtime(endtime);
  346. orderBean.setCanceltime(canceltime);
  347. orderBean.setOrderstatus(orderstatus);
  348. orderBean.setOrdertime(ordertime);
  349. orderBean.setOrderchannel(orderchannel);
  350. orderBean.setCancelchannel(cancelchannel);
  351. orderBean.setEffectivetime(effectivetime);
  352. return orderBean;
  353. }
  354. }