|
@@ -3,21 +3,30 @@ package com.zhongzheng.modules.order.service.impl;
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import cn.hutool.core.lang.Validator;
|
|
|
import cn.hutool.core.util.StrUtil;
|
|
|
+import com.alibaba.fastjson.JSON;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
|
|
import com.zhongzheng.common.exception.CustomException;
|
|
|
+import com.zhongzheng.common.type.EncryptHandler;
|
|
|
import com.zhongzheng.common.utils.DateUtils;
|
|
|
+import com.zhongzheng.common.utils.ServletUtils;
|
|
|
+import com.zhongzheng.common.utils.ToolsUtils;
|
|
|
+import com.zhongzheng.common.utils.http.HttpUtils;
|
|
|
import com.zhongzheng.modules.course.bo.CourseChapterBusinessAddBo;
|
|
|
import com.zhongzheng.modules.course.mapper.CourseChapterMapper;
|
|
|
-import com.zhongzheng.modules.order.bo.OrderInvoiceAddBo;
|
|
|
-import com.zhongzheng.modules.order.bo.OrderInvoiceEditBo;
|
|
|
-import com.zhongzheng.modules.order.bo.OrderInvoiceOrderAddBo;
|
|
|
-import com.zhongzheng.modules.order.bo.OrderInvoiceQueryBo;
|
|
|
+import com.zhongzheng.modules.order.bo.*;
|
|
|
import com.zhongzheng.modules.order.domain.OrderInvoice;
|
|
|
import com.zhongzheng.modules.order.mapper.OrderInvoiceMapper;
|
|
|
import com.zhongzheng.modules.order.service.IOrderInvoiceOrderService;
|
|
|
import com.zhongzheng.modules.order.service.IOrderInvoiceService;
|
|
|
import com.zhongzheng.modules.order.vo.OrderGoodsVo;
|
|
|
import com.zhongzheng.modules.order.vo.OrderInvoiceVo;
|
|
|
+import com.zhongzheng.modules.system.service.ISysUserService;
|
|
|
+import com.zhongzheng.modules.user.domain.User;
|
|
|
+import com.zhongzheng.modules.user.service.IUserService;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.beans.factory.annotation.Value;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
@@ -25,9 +34,8 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import com.github.pagehelper.Page;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
-import java.util.Collection;
|
|
|
-import java.util.Collections;
|
|
|
-import java.util.List;
|
|
|
+import java.io.IOException;
|
|
|
+import java.util.*;
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
@@ -42,6 +50,12 @@ public class OrderInvoiceServiceImpl extends ServiceImpl<OrderInvoiceMapper, Ord
|
|
|
@Autowired
|
|
|
private IOrderInvoiceOrderService iOrderInvoiceOrderService;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IUserService userService;
|
|
|
+
|
|
|
+ @Value("${invoice.host}")
|
|
|
+ private String INVOICE_PATH;
|
|
|
+
|
|
|
@Override
|
|
|
public OrderInvoiceVo queryById(Long invoiceId){
|
|
|
OrderInvoice db = this.baseMapper.selectById(invoiceId);
|
|
@@ -128,6 +142,63 @@ public class OrderInvoiceServiceImpl extends ServiceImpl<OrderInvoiceMapper, Ord
|
|
|
iOrderInvoiceOrderService.insertByAddBo(item);
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+ //开发票
|
|
|
+ OrderInvoiceBo invoiceBo = new OrderInvoiceBo();
|
|
|
+ Long nowTime = DateUtils.getNowTime();
|
|
|
+ String sign = ToolsUtils.EncoderByMd5( nowTime.toString() + "pubilc2022");
|
|
|
+ //流水号
|
|
|
+ String invoiceOrderSn = DateUtils.getInvoiceOrderSn();
|
|
|
+ invoiceBo.setOrderNo(invoiceOrderSn);
|
|
|
+ invoiceBo.setInvoiceDate(DateUtils.timestampToDateFormat(DateUtils.getNowTime(),"yyyy-MM-dd HH:mm:ss"));
|
|
|
+ if (bo.getSubject() == 1){
|
|
|
+ //个人
|
|
|
+ invoiceBo.setBuyerName(bo.getInvoiceTitle());
|
|
|
+ invoiceBo.setNaturalPersonFlag("1");
|
|
|
+ if (ObjectUtils.isNotNull(bo.getUserId())){
|
|
|
+ User user = userService.getById(bo.getUserId());
|
|
|
+ invoiceBo.setBuyerTaxNum(EncryptHandler.decrypt(user.getIdCard()));
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ //企业
|
|
|
+ invoiceBo.setBuyerName(bo.getInvoiceTitle());
|
|
|
+ invoiceBo.setNaturalPersonFlag("0");
|
|
|
+ invoiceBo.setBuyerTaxNum(bo.getTaxRegistryNumber());
|
|
|
+ }
|
|
|
+ invoiceBo.setEmail(bo.getEmail());
|
|
|
+ if (bo.getType() == 1){
|
|
|
+ //1普通发票
|
|
|
+ invoiceBo.setInvoiceLine("pc");
|
|
|
+ }else {
|
|
|
+ //增值税专用发票
|
|
|
+ invoiceBo.setInvoiceLine("bs");
|
|
|
+ }
|
|
|
+ OrderInvoiceDetailBo detailBo = new OrderInvoiceDetailBo();
|
|
|
+ detailBo.setPrice(bo.getAmount());
|
|
|
+ invoiceBo.setInvoiceDetail(detailBo);
|
|
|
+ OrderInvoiceHostBo hostBo = new OrderInvoiceHostBo();
|
|
|
+ hostBo.setOrder(invoiceBo);
|
|
|
+ Map<String, String> params = new HashMap<>();
|
|
|
+ params.put("stamp", nowTime.toString());
|
|
|
+ params.put("sign", sign);
|
|
|
+ params.put("content", JSONObject.toJSONString(hostBo));
|
|
|
+ params.put("orderNo", invoiceOrderSn);
|
|
|
+ params.put("tenantId", ServletUtils.getRequest().getHeader("TenantId"));
|
|
|
+ String respone = "";
|
|
|
+ try {
|
|
|
+ respone = HttpUtils.sendPost(INVOICE_PATH, JSONObject.parseObject(JSONObject.toJSONString(params)));
|
|
|
+ if (!respone.contains("\"code\":200")) {
|
|
|
+ throw new CustomException("开发票接口请求错误");
|
|
|
+ }
|
|
|
+ OrderInvoice invoice = getById(add.getInvoiceId());
|
|
|
+ invoice.setPeriodStatus(3);
|
|
|
+ invoice.setInvoiceStatus(3);//开票中
|
|
|
+ invoice.setSerialNumber(invoiceOrderSn);
|
|
|
+ updateById(invoice);
|
|
|
+ } catch (Exception e) {
|
|
|
+ log.error("开发票接口请求错误" + respone);
|
|
|
+ throw new CustomException("开发票接口请求错误");
|
|
|
+ }
|
|
|
return rs;
|
|
|
}
|
|
|
|