OWareAdjustmentOrderServiceImpl.java 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. package com.emato.biz.service.impl;
  2. import java.util.*;
  3. import com.alibaba.fastjson.JSON;
  4. import com.alibaba.fastjson.JSONArray;
  5. import com.alibaba.fastjson.JSONObject;
  6. import com.emato.biz.config.OmsConfig;
  7. import com.emato.biz.domain.warehouse.OWareAdjustmentOrderItem;
  8. import com.emato.biz.domain.warehouse.OWbInveMng;
  9. import com.emato.biz.mapper.warehouse.OWareAdjustmentOrderItemMapper;
  10. import com.emato.common.utils.DateUtils;
  11. import com.emato.common.utils.oms.request.OkHttpUtils;
  12. import com.emato.common.utils.oms.request.OmsSign;
  13. import okhttp3.Request;
  14. import org.slf4j.Logger;
  15. import org.slf4j.LoggerFactory;
  16. import org.springframework.beans.factory.annotation.Autowired;
  17. import org.springframework.stereotype.Service;
  18. import com.emato.biz.mapper.warehouse.OWareAdjustmentOrderMapper;
  19. import com.emato.biz.domain.warehouse.OWareAdjustmentOrder;
  20. import com.emato.biz.service.warehouse.IOWareAdjustmentOrderService;
  21. import org.springframework.transaction.annotation.Transactional;
  22. /**
  23. * 库存内调结转出入库记录Service业务层处理
  24. *
  25. * @author yangbo
  26. * @date 2021-02-01
  27. */
  28. @Service
  29. public class OWareAdjustmentOrderServiceImpl implements IOWareAdjustmentOrderService
  30. {
  31. @Autowired
  32. private OWareAdjustmentOrderMapper oWareAdjustmentOrderMapper;
  33. @Autowired
  34. private OWareAdjustmentOrderItemMapper oWareAdjustmentOrderItemMapper;
  35. private static final Logger LOGGER = LoggerFactory.getLogger(OWareAdjustmentOrderServiceImpl.class);
  36. /**
  37. * 查询库存内调结转出入库记录
  38. *
  39. * @param adjustmentOrderSn 库存内调结转出入库记录ID
  40. * @return 库存内调结转出入库记录
  41. */
  42. @Override
  43. public OWareAdjustmentOrder selectOWareAdjustmentOrderById(String adjustmentOrderSn)
  44. {
  45. return oWareAdjustmentOrderMapper.selectOWareAdjustmentOrderById(adjustmentOrderSn);
  46. }
  47. /**
  48. * 查询库存内调结转出入库记录列表
  49. *
  50. * @param oWareAdjustmentOrder 库存内调结转出入库记录
  51. * @return 库存内调结转出入库记录
  52. */
  53. @Override
  54. public List<OWareAdjustmentOrder> selectOWareAdjustmentOrderList(OWareAdjustmentOrder oWareAdjustmentOrder)
  55. {
  56. return oWareAdjustmentOrderMapper.selectOWareAdjustmentOrderList(oWareAdjustmentOrder);
  57. }
  58. /**
  59. * 新增库存内调结转出入库记录
  60. *
  61. * @param oWareAdjustmentOrder 库存内调结转出入库记录
  62. * @return 结果
  63. */
  64. @Override
  65. public int insertOWareAdjustmentOrder(OWareAdjustmentOrder oWareAdjustmentOrder)
  66. {
  67. oWareAdjustmentOrder.setCreateTime(DateUtils.getNowDate());
  68. return oWareAdjustmentOrderMapper.insertOWareAdjustmentOrder(oWareAdjustmentOrder);
  69. }
  70. /**
  71. * 修改库存内调结转出入库记录
  72. *
  73. * @param oWareAdjustmentOrder 库存内调结转出入库记录
  74. * @return 结果
  75. */
  76. @Override
  77. public int updateOWareAdjustmentOrder(OWareAdjustmentOrder oWareAdjustmentOrder)
  78. {
  79. return oWareAdjustmentOrderMapper.updateOWareAdjustmentOrder(oWareAdjustmentOrder);
  80. }
  81. /**
  82. * 批量删除库存内调结转出入库记录
  83. *
  84. * @param adjustmentOrderSns 需要删除的库存内调结转出入库记录ID
  85. * @return 结果
  86. */
  87. @Override
  88. public int deleteOWareAdjustmentOrderByIds(String[] adjustmentOrderSns)
  89. {
  90. return oWareAdjustmentOrderMapper.deleteOWareAdjustmentOrderByIds(adjustmentOrderSns);
  91. }
  92. /**
  93. * 删除库存内调结转出入库记录信息
  94. *
  95. * @param adjustmentOrderSn 库存内调结转出入库记录ID
  96. * @return 结果
  97. */
  98. @Override
  99. public int deleteOWareAdjustmentOrderById(String adjustmentOrderSn)
  100. {
  101. return oWareAdjustmentOrderMapper.deleteOWareAdjustmentOrderById(adjustmentOrderSn);
  102. }
  103. @Override
  104. @Transactional
  105. public int pullAdjustmentOrder(String merchSn) {
  106. int page = 1;
  107. Integer querySize = OmsConfig.getQuerySize();
  108. int resultCode = pullAdjustmentOrder(merchSn,page, querySize);
  109. while(resultCode != 1){
  110. page = page + 1;
  111. resultCode = pullAdjustmentOrder(merchSn, page, querySize);
  112. }
  113. return resultCode;
  114. }
  115. private int pullAdjustmentOrder(String merchSn, int page, Integer querySize) {
  116. Map<String,String> data = new HashMap();
  117. data.put("merchId",merchSn);
  118. data.put("page",page+"");
  119. data.put("limit",querySize.toString());
  120. Map<String, String> sParaTemp = new TreeMap<String, String>();
  121. sParaTemp.put("data", JSON.toJSONString(data));
  122. sParaTemp.put("merchId",OmsConfig.getMerchSn());
  123. String timestamp = String.valueOf(System.currentTimeMillis()/1000);
  124. sParaTemp.put("timestamp", timestamp);
  125. //生成要请求给oms秘钥
  126. // String sign = OmsSign.sign(sParaTemp,cus.getWaybill().get("secret-key"));
  127. LOGGER.info("md5混淆码参数:" + OmsConfig.getMd5Salt());
  128. String sign = OmsSign.sign(sParaTemp,OmsConfig.getMd5Salt());
  129. sParaTemp.put("sign", sign);
  130. //构建Request
  131. String url = OmsConfig.getQueryAdjustmentUrl();
  132. // url = "http://127.0.0.1:8680/al/shop/order/query";
  133. Request request = OkHttpUtils.buildRequest(url, JSON.toJSONString(sParaTemp));
  134. LOGGER.info("oms的请求报文:" + request);
  135. // 同步访问,返回结果字符串
  136. String responseString = null;
  137. try {
  138. responseString = OkHttpUtils.post(request);
  139. } catch (Exception e) {
  140. e.printStackTrace();
  141. LOGGER.error(e.getMessage());
  142. return 1;
  143. // throw e;
  144. }
  145. try {
  146. LOGGER.info("oms的响应报文"+responseString);
  147. //解析响应数据
  148. JSONObject jsonObject = JSONObject.parseObject(responseString);
  149. JSONArray result = (JSONArray) jsonObject.get("data");
  150. Object msg = jsonObject.get("msg");
  151. Object code = jsonObject.get("code");
  152. if(result == null || result.size() == 0){
  153. return 1;
  154. }
  155. for(int i = 0 ; i < result.size(); i ++){
  156. JSONObject o = (JSONObject) result.get(i);
  157. OWareAdjustmentOrder adjustmentOrder = o.toJavaObject(OWareAdjustmentOrder.class);
  158. // OWbInveMng wb = (OWbInveMng) o;
  159. oWareAdjustmentOrderMapper.saveOrUpdate(adjustmentOrder);
  160. }
  161. } catch (Exception e) {
  162. e.printStackTrace();
  163. LOGGER.error(e.getMessage());
  164. return 1;
  165. }
  166. return 0;
  167. }
  168. @Override
  169. public int pullAdjustmentorderDetail(String[] adjustmentOrderSns) {
  170. List<String> transferList = new ArrayList<>(adjustmentOrderSns.length);
  171. Collections.addAll(transferList,adjustmentOrderSns);
  172. int resultCode = 0;
  173. for (String adjustmentOrderSn : transferList) {
  174. int page = 1;
  175. Integer querySize = OmsConfig.getQuerySize();
  176. resultCode = pullAdjustmentorderDetailFromOms(adjustmentOrderSn,page, querySize);
  177. while(resultCode != 1){
  178. page = page + 1;
  179. resultCode = pullAdjustmentorderDetailFromOms(adjustmentOrderSn, page, querySize);
  180. }
  181. }
  182. return resultCode;
  183. }
  184. private int pullAdjustmentorderDetailFromOms(String adjustmentOrderSn, int page, Integer querySize) {
  185. Map<String,Object> data = new HashMap();
  186. data.put("adjustmentOrderSn",adjustmentOrderSn);
  187. data.put("page",page+"");
  188. data.put("limit",querySize.toString());
  189. Map<String, String> sParaTemp = new TreeMap<String, String>();
  190. sParaTemp.put("data", JSON.toJSONString(data));
  191. sParaTemp.put("merchId",OmsConfig.getMerchSn());
  192. String timestamp = String.valueOf(System.currentTimeMillis()/1000);
  193. sParaTemp.put("timestamp", timestamp);
  194. //生成要请求给oms秘钥
  195. // String sign = OmsSign.sign(sParaTemp,cus.getWaybill().get("secret-key"));
  196. LOGGER.info("md5混淆码参数:" + OmsConfig.getMd5Salt());
  197. String sign = OmsSign.sign(sParaTemp,OmsConfig.getMd5Salt());
  198. sParaTemp.put("sign", sign);
  199. //构建Request
  200. String url = OmsConfig.getQueryAdjustmentDetailUrl();
  201. // url = "http://127.0.0.1:8680/al/shop/order/query";
  202. Request request = OkHttpUtils.buildRequest(url, JSON.toJSONString(sParaTemp));
  203. LOGGER.info("oms的请求报文:" + request);
  204. // 同步访问,返回结果字符串
  205. String responseString = null;
  206. try {
  207. responseString = OkHttpUtils.post(request);
  208. } catch (Exception e) {
  209. e.printStackTrace();
  210. LOGGER.error(e.getMessage());
  211. return 1;
  212. // throw e;
  213. }
  214. try {
  215. LOGGER.info("oms的响应报文"+responseString);
  216. //解析响应数据
  217. JSONObject jsonObject = JSONObject.parseObject(responseString);
  218. JSONArray result = (JSONArray) jsonObject.get("data");
  219. Object msg = jsonObject.get("msg");
  220. Object code = jsonObject.get("code");
  221. if(result == null || result.size() == 0){
  222. return 1;
  223. }
  224. for(int i = 0 ; i < result.size(); i ++){
  225. JSONObject o = (JSONObject) result.get(i);
  226. OWareAdjustmentOrderItem adjustmentOrderItem = o.toJavaObject(OWareAdjustmentOrderItem.class);
  227. // OWbInveMng wb = (OWbInveMng) o;
  228. oWareAdjustmentOrderItemMapper.saveOrUpdate(adjustmentOrderItem);
  229. }
  230. } catch (Exception e) {
  231. e.printStackTrace();
  232. LOGGER.error(e.getMessage());
  233. return 1;
  234. }
  235. return 0;
  236. }
  237. }