mirror of
https://gitee.com/huangge1199_admin/vue-pro.git
synced 2025-01-31 17:40:05 +08:00
Merge remote-tracking branch 'yudao/feature/mall_product' into feature/mall_product
This commit is contained in:
commit
e26814be31
BIN
.image/common/mall-feature.png
Normal file
BIN
.image/common/mall-feature.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 32 KiB |
BIN
.image/common/mall-preview.png
Normal file
BIN
.image/common/mall-preview.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 255 KiB |
BIN
.image/common/ruoyi-vue-pro-architecture.png
Normal file
BIN
.image/common/ruoyi-vue-pro-architecture.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 192 KiB |
BIN
.image/common/ruoyi-vue-pro-biz.png
Normal file
BIN
.image/common/ruoyi-vue-pro-biz.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 80 KiB |
BIN
.image/common/yudao-cloud-architecture.png
Normal file
BIN
.image/common/yudao-cloud-architecture.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 493 KiB |
20
README.md
20
README.md
@ -23,7 +23,7 @@
|
|||||||
>
|
>
|
||||||
> 😜 给项目点点 Star 吧,这对我们真的很重要!
|
> 😜 给项目点点 Star 吧,这对我们真的很重要!
|
||||||
|
|
||||||
![架构图](https://static.iocoder.cn/ruoyi-vue-pro-architecture.png?imageView2/2/format/webp)
|
![架构图](/.image/common/ruoyi-vue-pro-architecture.png)
|
||||||
|
|
||||||
* 管理后台的电脑端:Vue3 提供 [element-plus](https://gitee.com/yudaocode/yudao-ui-admin-vue3)、[vben(ant-design-vue)](https://gitee.com/yudaocode/yudao-ui-admin-vben) 两个版本,Vue2 提供 [element-ui](https://gitee.com/zhijiantianya/ruoyi-vue-pro/tree/master/yudao-ui-admin) 版本
|
* 管理后台的电脑端:Vue3 提供 [element-plus](https://gitee.com/yudaocode/yudao-ui-admin-vue3)、[vben(ant-design-vue)](https://gitee.com/yudaocode/yudao-ui-admin-vben) 两个版本,Vue2 提供 [element-ui](https://gitee.com/zhijiantianya/ruoyi-vue-pro/tree/master/yudao-ui-admin) 版本
|
||||||
* 管理后台的移动端:采用 [uni-app](https://github.com/dcloudio/uni-app) 方案,一份代码多终端适配,同时支持 APP、小程序、H5!
|
* 管理后台的移动端:采用 [uni-app](https://github.com/dcloudio/uni-app) 方案,一份代码多终端适配,同时支持 APP、小程序、H5!
|
||||||
@ -102,7 +102,7 @@
|
|||||||
|
|
||||||
系统内置多种多种业务功能,可以用于快速你的业务系统:
|
系统内置多种多种业务功能,可以用于快速你的业务系统:
|
||||||
|
|
||||||
![功能分层](https://static.iocoder.cn/ruoyi-vue-pro-biz.png?imageView2/2/format/webp)
|
![功能分层](/.image/common/ruoyi-vue-pro-biz.png)
|
||||||
|
|
||||||
* 系统功能
|
* 系统功能
|
||||||
* 基础设施
|
* 基础设施
|
||||||
@ -214,17 +214,19 @@
|
|||||||
|
|
||||||
### 商城系统
|
### 商城系统
|
||||||
|
|
||||||
建设中...
|
![功能图](/.image/common/mall-feature.png)
|
||||||
|
|
||||||
![功能图](http://static.iocoder.cn/mall%20%E5%8A%9F%E8%83%BD%E5%9B%BE-min.png)
|
![功能图](/.image/common/mall-preview.png)
|
||||||
|
|
||||||
![GIF 图-耐心等待](https://raw.githubusercontent.com/YunaiV/Blog/master/Mall/onemall-admin-min.gif)
|
|
||||||
|
|
||||||
![GIF 图-耐心等待](https://raw.githubusercontent.com/YunaiV/Blog/master/Mall/onemall-h5-min.gif)
|
|
||||||
|
|
||||||
### 会员中心
|
### 会员中心
|
||||||
|
|
||||||
和「商城系统」一起开发
|
| | 功能 | 描述 |
|
||||||
|
|-----|------|----------------------------------|
|
||||||
|
| 🚀 | 会员管理 | 会员是 C 端的消费者,该功能用于会员的搜索与管理 |
|
||||||
|
| 🚀 | 会员标签 | 对会员的标签进行创建、查询、修改、删除等操作 |
|
||||||
|
| 🚀 | 会员等级 | 对会员的等级、成长值进行管理,可用于订单折扣等会员权益 |
|
||||||
|
| 🚀 | 会员分组 | 对会员进行分组,用于用户画像、内容推送等运营手段 |
|
||||||
|
| 🚀 | 积分签到 | 回馈给签到、消费等行为的积分,会员可订单抵现、积分兑换等途径消耗 |
|
||||||
|
|
||||||
## 🐨 技术栈
|
## 🐨 技术栈
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
package cn.iocoder.yudao.framework.pay.core.client;
|
package cn.iocoder.yudao.framework.pay.core.client;
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.AbstractPayClient;
|
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 支付客户端的工厂接口
|
* 支付客户端的工厂接口
|
||||||
@ -21,8 +21,18 @@ public interface PayClientFactory {
|
|||||||
* 创建支付客户端
|
* 创建支付客户端
|
||||||
*
|
*
|
||||||
* @param channelId 渠道编号
|
* @param channelId 渠道编号
|
||||||
* @param client 支付客户端
|
* @param channelCode 渠道编码
|
||||||
* @param <Config> 支付配置
|
* @param config 支付配置
|
||||||
*/
|
*/
|
||||||
<Config extends PayClientConfig> void addOrUpdatePayClient(Long channelId, AbstractPayClient<Config> client);
|
<Config extends PayClientConfig> void createOrUpdatePayClient(Long channelId, String channelCode,
|
||||||
|
Config config);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 注册支付客户端 Class,用于模块中实现的 PayClient
|
||||||
|
*
|
||||||
|
* @param channel 支付渠道的编码的枚举
|
||||||
|
* @param payClientClass 支付客户端 class
|
||||||
|
*/
|
||||||
|
void registerPayClientClass(PayChannelEnum channel, Class<?> payClientClass);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,6 @@ import cn.iocoder.yudao.framework.pay.core.client.dto.order.PayOrderUnifiedReqDT
|
|||||||
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundRespDTO;
|
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundRespDTO;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundUnifiedReqDTO;
|
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundUnifiedReqDTO;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.exception.PayException;
|
import cn.iocoder.yudao.framework.pay.core.client.exception.PayException;
|
||||||
import lombok.Getter;
|
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -36,7 +35,6 @@ public abstract class AbstractPayClient<Config extends PayClientConfig> implemen
|
|||||||
/**
|
/**
|
||||||
* 支付配置
|
* 支付配置
|
||||||
*/
|
*/
|
||||||
@Getter
|
|
||||||
protected Config config;
|
protected Config config;
|
||||||
|
|
||||||
public AbstractPayClient(Long channelId, String channelCode, Config config) {
|
public AbstractPayClient(Long channelId, String channelCode, Config config) {
|
||||||
|
@ -1,13 +1,22 @@
|
|||||||
package cn.iocoder.yudao.framework.pay.core.client.impl;
|
package cn.iocoder.yudao.framework.pay.core.client.impl;
|
||||||
|
|
||||||
|
import cn.hutool.core.lang.Assert;
|
||||||
|
import cn.hutool.core.util.ReflectUtil;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.PayClient;
|
import cn.iocoder.yudao.framework.pay.core.client.PayClient;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.PayClientConfig;
|
import cn.iocoder.yudao.framework.pay.core.client.PayClientConfig;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.PayClientFactory;
|
import cn.iocoder.yudao.framework.pay.core.client.PayClientFactory;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.client.impl.alipay.*;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.client.impl.mock.MockPayClient;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.*;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
|
||||||
|
import static cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 支付客户端的工厂实现类
|
* 支付客户端的工厂实现类
|
||||||
*
|
*
|
||||||
@ -18,10 +27,38 @@ public class PayClientFactoryImpl implements PayClientFactory {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 支付客户端 Map
|
* 支付客户端 Map
|
||||||
|
*
|
||||||
* key:渠道编号
|
* key:渠道编号
|
||||||
*/
|
*/
|
||||||
private final ConcurrentMap<Long, AbstractPayClient<?>> clients = new ConcurrentHashMap<>();
|
private final ConcurrentMap<Long, AbstractPayClient<?>> clients = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 支付客户端 Class Map
|
||||||
|
*/
|
||||||
|
private final Map<PayChannelEnum, Class<?>> clientClass = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
public PayClientFactoryImpl() {
|
||||||
|
// 微信支付客户端
|
||||||
|
clientClass.put(WX_PUB, WxPubPayClient.class);
|
||||||
|
clientClass.put(WX_LITE, WxLitePayClient.class);
|
||||||
|
clientClass.put(WX_APP, WxAppPayClient.class);
|
||||||
|
clientClass.put(WX_BAR, WxBarPayClient.class);
|
||||||
|
clientClass.put(WX_NATIVE, WxNativePayClient.class);
|
||||||
|
// 支付包支付客户端
|
||||||
|
clientClass.put(ALIPAY_WAP, AlipayWapPayClient.class);
|
||||||
|
clientClass.put(ALIPAY_QR, AlipayQrPayClient.class);
|
||||||
|
clientClass.put(ALIPAY_APP, AlipayAppPayClient.class);
|
||||||
|
clientClass.put(ALIPAY_PC, AlipayPcPayClient.class);
|
||||||
|
clientClass.put(ALIPAY_BAR, AlipayBarPayClient.class);
|
||||||
|
// Mock 支付客户端
|
||||||
|
clientClass.put(MOCK, MockPayClient.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void registerPayClientClass(PayChannelEnum channel, Class<?> payClientClass) {
|
||||||
|
clientClass.put(channel, payClientClass);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PayClient getPayClient(Long channelId) {
|
public PayClient getPayClient(Long channelId) {
|
||||||
AbstractPayClient<?> client = clients.get(channelId);
|
AbstractPayClient<?> client = clients.get(channelId);
|
||||||
@ -33,12 +70,26 @@ public class PayClientFactoryImpl implements PayClientFactory {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public <Config extends PayClientConfig> void addOrUpdatePayClient(Long channelId, AbstractPayClient<Config> client) {
|
public <Config extends PayClientConfig> void createOrUpdatePayClient(Long channelId, String channelCode,
|
||||||
AbstractPayClient<Config> prePayClient = (AbstractPayClient<Config>) clients.putIfAbsent(channelId, client);
|
Config config) {
|
||||||
if (prePayClient == null) {
|
AbstractPayClient<Config> client = (AbstractPayClient<Config>) clients.get(channelId);
|
||||||
|
if (client == null) {
|
||||||
|
client = this.createPayClient(channelId, channelCode, config);
|
||||||
client.init();
|
client.init();
|
||||||
|
clients.put(client.getId(), client);
|
||||||
} else {
|
} else {
|
||||||
prePayClient.refresh(client.getConfig());
|
client.refresh(config);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private <Config extends PayClientConfig> AbstractPayClient<Config> createPayClient(Long channelId, String channelCode,
|
||||||
|
Config config) {
|
||||||
|
PayChannelEnum channelEnum = PayChannelEnum.getByCode(channelCode);
|
||||||
|
Assert.notNull(channelEnum, String.format("支付渠道(%s) 为空", channelCode));
|
||||||
|
Class<?> payClientClass = clientClass.get(channelEnum);
|
||||||
|
Assert.notNull(payClientClass, String.format("支付渠道(%s) Class 为空", channelCode));
|
||||||
|
return (AbstractPayClient<Config>) ReflectUtil.newInstance(payClientClass, channelId, config);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ import cn.iocoder.yudao.framework.pay.core.client.impl.alipay.AlipayQrPayClient;
|
|||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.alipay.AlipayWapPayClient;
|
import cn.iocoder.yudao.framework.pay.core.client.impl.alipay.AlipayWapPayClient;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.WxPayClientConfig;
|
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.WxPayClientConfig;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.WxPubPayClient;
|
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.WxPubPayClient;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
||||||
import org.junit.jupiter.api.Disabled;
|
import org.junit.jupiter.api.Disabled;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
@ -40,8 +41,7 @@ public class PayClientFactoryImplIntegrationTest {
|
|||||||
config.setMchKey("0alL64UDQdlCwiKZ73ib7ypaIjMns06p");
|
config.setMchKey("0alL64UDQdlCwiKZ73ib7ypaIjMns06p");
|
||||||
// 创建客户端
|
// 创建客户端
|
||||||
Long channelId = RandomUtil.randomLong();
|
Long channelId = RandomUtil.randomLong();
|
||||||
|
payClientFactory.createOrUpdatePayClient(channelId, PayChannelEnum.WX_PUB.getCode(), config);
|
||||||
payClientFactory.addOrUpdatePayClient(channelId, new WxPubPayClient(channelId, config));
|
|
||||||
PayClient client = payClientFactory.getPayClient(channelId);
|
PayClient client = payClientFactory.getPayClient(channelId);
|
||||||
// 发起支付
|
// 发起支付
|
||||||
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
||||||
@ -64,7 +64,7 @@ public class PayClientFactoryImplIntegrationTest {
|
|||||||
config.setApiV3Key("joerVi8y5DJ3o4ttA0o1uH47Xz1u2Ase");
|
config.setApiV3Key("joerVi8y5DJ3o4ttA0o1uH47Xz1u2Ase");
|
||||||
// 创建客户端
|
// 创建客户端
|
||||||
Long channelId = RandomUtil.randomLong();
|
Long channelId = RandomUtil.randomLong();
|
||||||
payClientFactory.addOrUpdatePayClient(channelId, new WxPubPayClient(channelId, config));
|
payClientFactory.createOrUpdatePayClient(channelId, PayChannelEnum.WX_PUB.getCode(), config);
|
||||||
PayClient client = payClientFactory.getPayClient(channelId);
|
PayClient client = payClientFactory.getPayClient(channelId);
|
||||||
// 发起支付
|
// 发起支付
|
||||||
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
||||||
@ -87,7 +87,7 @@ public class PayClientFactoryImplIntegrationTest {
|
|||||||
config.setAlipayPublicKey("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnq90KnF4dTnlzzmxpujbI05OYqi5WxAS6cL0gnZFv2gK51HExF8v/BaP7P979PhFMgWTqmOOI+Dtno5s+yD09XTY1WkshbLk6i4g2Xlr8fyW9ODnkU88RI2w9UdPhQU4cPPwBNlrsYhKkVK2OxwM3kFqjoBBY0CZoZCsSQ3LDH5WeZqPArlsS6xa2zqJBuuoKjMrdpELl3eXSjP8K54eDJCbeetCZNKWLL3DPahTPB7LZikfYmslb0QUvCgGapD0xkS7eVq70NaL1G57MWABs4tbfWgxike4Daj3EfUrzIVspQxj7w8HEj9WozJPgL88kSJSits0pqD3n5r8HSuseQIDAQAB");
|
config.setAlipayPublicKey("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnq90KnF4dTnlzzmxpujbI05OYqi5WxAS6cL0gnZFv2gK51HExF8v/BaP7P979PhFMgWTqmOOI+Dtno5s+yD09XTY1WkshbLk6i4g2Xlr8fyW9ODnkU88RI2w9UdPhQU4cPPwBNlrsYhKkVK2OxwM3kFqjoBBY0CZoZCsSQ3LDH5WeZqPArlsS6xa2zqJBuuoKjMrdpELl3eXSjP8K54eDJCbeetCZNKWLL3DPahTPB7LZikfYmslb0QUvCgGapD0xkS7eVq70NaL1G57MWABs4tbfWgxike4Daj3EfUrzIVspQxj7w8HEj9WozJPgL88kSJSits0pqD3n5r8HSuseQIDAQAB");
|
||||||
// 创建客户端
|
// 创建客户端
|
||||||
Long channelId = RandomUtil.randomLong();
|
Long channelId = RandomUtil.randomLong();
|
||||||
payClientFactory.addOrUpdatePayClient(channelId, new AlipayQrPayClient(channelId, config));
|
payClientFactory.createOrUpdatePayClient(channelId, PayChannelEnum.ALIPAY_QR.getCode(), config);
|
||||||
PayClient client = payClientFactory.getPayClient(channelId);
|
PayClient client = payClientFactory.getPayClient(channelId);
|
||||||
// 发起支付
|
// 发起支付
|
||||||
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
||||||
@ -111,7 +111,7 @@ public class PayClientFactoryImplIntegrationTest {
|
|||||||
config.setAlipayPublicKey("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnq90KnF4dTnlzzmxpujbI05OYqi5WxAS6cL0gnZFv2gK51HExF8v/BaP7P979PhFMgWTqmOOI+Dtno5s+yD09XTY1WkshbLk6i4g2Xlr8fyW9ODnkU88RI2w9UdPhQU4cPPwBNlrsYhKkVK2OxwM3kFqjoBBY0CZoZCsSQ3LDH5WeZqPArlsS6xa2zqJBuuoKjMrdpELl3eXSjP8K54eDJCbeetCZNKWLL3DPahTPB7LZikfYmslb0QUvCgGapD0xkS7eVq70NaL1G57MWABs4tbfWgxike4Daj3EfUrzIVspQxj7w8HEj9WozJPgL88kSJSits0pqD3n5r8HSuseQIDAQAB");
|
config.setAlipayPublicKey("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnq90KnF4dTnlzzmxpujbI05OYqi5WxAS6cL0gnZFv2gK51HExF8v/BaP7P979PhFMgWTqmOOI+Dtno5s+yD09XTY1WkshbLk6i4g2Xlr8fyW9ODnkU88RI2w9UdPhQU4cPPwBNlrsYhKkVK2OxwM3kFqjoBBY0CZoZCsSQ3LDH5WeZqPArlsS6xa2zqJBuuoKjMrdpELl3eXSjP8K54eDJCbeetCZNKWLL3DPahTPB7LZikfYmslb0QUvCgGapD0xkS7eVq70NaL1G57MWABs4tbfWgxike4Daj3EfUrzIVspQxj7w8HEj9WozJPgL88kSJSits0pqD3n5r8HSuseQIDAQAB");
|
||||||
// 创建客户端
|
// 创建客户端
|
||||||
Long channelId = RandomUtil.randomLong();
|
Long channelId = RandomUtil.randomLong();
|
||||||
payClientFactory.addOrUpdatePayClient(channelId, new AlipayWapPayClient(channelId, config));
|
payClientFactory.createOrUpdatePayClient(channelId, PayChannelEnum.ALIPAY_WAP.getCode(), config);
|
||||||
PayClient client = payClientFactory.getPayClient(channelId);
|
PayClient client = payClientFactory.getPayClient(channelId);
|
||||||
// 发起支付
|
// 发起支付
|
||||||
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
PayOrderUnifiedReqDTO reqDTO = buildPayOrderUnifiedReqDTO();
|
||||||
|
@ -110,8 +110,9 @@ public class ProductSpuServiceImpl implements ProductSpuService {
|
|||||||
spu.setMarketPrice(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getMarketPrice));
|
spu.setMarketPrice(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getMarketPrice));
|
||||||
// sku 单价最低的商品的成本价格
|
// sku 单价最低的商品的成本价格
|
||||||
spu.setCostPrice(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getCostPrice));
|
spu.setCostPrice(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getCostPrice));
|
||||||
// sku 单价最低的商品的条形码
|
// sku 单价最低的商品的条形码 TODO 芋艿:条形码字段,是不是可以删除
|
||||||
spu.setBarCode(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getBarCode));
|
spu.setBarCode("");
|
||||||
|
// spu.setBarCode(getMinValue(skus, ProductSkuCreateOrUpdateReqVO::getBarCode));
|
||||||
// skus 库存总数
|
// skus 库存总数
|
||||||
spu.setStock(getSumValue(skus, ProductSkuCreateOrUpdateReqVO::getStock, Integer::sum));
|
spu.setStock(getSumValue(skus, ProductSkuCreateOrUpdateReqVO::getStock, Integer::sum));
|
||||||
// 若是 spu 已有状态则不处理
|
// 若是 spu 已有状态则不处理
|
||||||
|
@ -81,12 +81,13 @@ public class SeckillConfigController {
|
|||||||
@GetMapping("/list-all-simple")
|
@GetMapping("/list-all-simple")
|
||||||
@Operation(summary = "获得所有开启状态的秒杀时段精简列表", description = "主要用于前端的下拉选项")
|
@Operation(summary = "获得所有开启状态的秒杀时段精简列表", description = "主要用于前端的下拉选项")
|
||||||
public CommonResult<List<SeckillConfigSimpleRespVO>> getListAllSimple() {
|
public CommonResult<List<SeckillConfigSimpleRespVO>> getListAllSimple() {
|
||||||
List<SeckillConfigDO> list = seckillConfigService.getSeckillConfigListByStatus(CommonStatusEnum.ENABLE.getStatus());
|
List<SeckillConfigDO> list = seckillConfigService.getSeckillConfigListByStatus(
|
||||||
|
CommonStatusEnum.ENABLE.getStatus());
|
||||||
return success(SeckillConfigConvert.INSTANCE.convertList1(list));
|
return success(SeckillConfigConvert.INSTANCE.convertList1(list));
|
||||||
}
|
}
|
||||||
|
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
@Operation(summary = "获得秒杀活动分页")
|
@Operation(summary = "获得秒杀时间段分页")
|
||||||
@PreAuthorize("@ss.hasPermission('promotion:seckill-config:query')")
|
@PreAuthorize("@ss.hasPermission('promotion:seckill-config:query')")
|
||||||
public CommonResult<PageResult<SeckillConfigRespVO>> getSeckillActivityPage(@Valid SeckillConfigPageReqVO pageVO) {
|
public CommonResult<PageResult<SeckillConfigRespVO>> getSeckillActivityPage(@Valid SeckillConfigPageReqVO pageVO) {
|
||||||
PageResult<SeckillConfigDO> pageResult = seckillConfigService.getSeckillConfigPage(pageVO);
|
PageResult<SeckillConfigDO> pageResult = seckillConfigService.getSeckillConfigPage(pageVO);
|
||||||
|
@ -35,7 +35,7 @@ public class AppBargainActivityController {
|
|||||||
activity1.setId(1L);
|
activity1.setId(1L);
|
||||||
activity1.setName("618 大砍价");
|
activity1.setName("618 大砍价");
|
||||||
activity1.setSpuId(2048L);
|
activity1.setSpuId(2048L);
|
||||||
activity1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity1.setMarketPrice(50);
|
activity1.setMarketPrice(50);
|
||||||
activity1.setBargainPrice(100);
|
activity1.setBargainPrice(100);
|
||||||
activity1.setStartTime(LocalDateTimeUtils.addTime(Duration.ofDays(-2)));
|
activity1.setStartTime(LocalDateTimeUtils.addTime(Duration.ofDays(-2)));
|
||||||
@ -47,7 +47,7 @@ public class AppBargainActivityController {
|
|||||||
activity2.setId(2L);
|
activity2.setId(2L);
|
||||||
activity2.setName("双十一砍价");
|
activity2.setName("双十一砍价");
|
||||||
activity2.setSpuId(4096L);
|
activity2.setSpuId(4096L);
|
||||||
activity2.setPicUrl("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
activity2.setPicUrl("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
activity2.setMarketPrice(100);
|
activity2.setMarketPrice(100);
|
||||||
activity2.setBargainPrice(200);
|
activity2.setBargainPrice(200);
|
||||||
activity2.setStartTime(LocalDateTimeUtils.addTime(Duration.ofDays(-2)));
|
activity2.setStartTime(LocalDateTimeUtils.addTime(Duration.ofDays(-2)));
|
||||||
@ -69,7 +69,7 @@ public class AppBargainActivityController {
|
|||||||
activity1.setId(1L);
|
activity1.setId(1L);
|
||||||
activity1.setName("618 大砍价");
|
activity1.setName("618 大砍价");
|
||||||
activity1.setSpuId(2048L);
|
activity1.setSpuId(2048L);
|
||||||
activity1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity1.setMarketPrice(50);
|
activity1.setMarketPrice(50);
|
||||||
activity1.setBargainPrice(100);
|
activity1.setBargainPrice(100);
|
||||||
activityList.add(activity1);
|
activityList.add(activity1);
|
||||||
@ -78,7 +78,7 @@ public class AppBargainActivityController {
|
|||||||
activity2.setId(2L);
|
activity2.setId(2L);
|
||||||
activity2.setName("双十一砍价");
|
activity2.setName("双十一砍价");
|
||||||
activity2.setSpuId(4096L);
|
activity2.setSpuId(4096L);
|
||||||
activity2.setPicUrl("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
activity2.setPicUrl("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
activity2.setMarketPrice(100);
|
activity2.setMarketPrice(100);
|
||||||
activity2.setBargainPrice(200);
|
activity2.setBargainPrice(200);
|
||||||
activityList.add(activity2);
|
activityList.add(activity2);
|
||||||
@ -94,7 +94,7 @@ public class AppBargainActivityController {
|
|||||||
activity.setId(2L);
|
activity.setId(2L);
|
||||||
activity.setName("618 大砍价");
|
activity.setName("618 大砍价");
|
||||||
activity.setSpuId(2048L);
|
activity.setSpuId(2048L);
|
||||||
activity.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity.setMarketPrice(50);
|
activity.setMarketPrice(50);
|
||||||
activity.setBargainPrice(100);
|
activity.setBargainPrice(100);
|
||||||
activity.setStock(10);
|
activity.setStock(10);
|
||||||
|
@ -81,7 +81,7 @@ public class AppBargainRecordController {
|
|||||||
record1.setPrice(200);
|
record1.setPrice(200);
|
||||||
record1.setPayPrice(180);
|
record1.setPayPrice(180);
|
||||||
record1.setStatus(1);
|
record1.setStatus(1);
|
||||||
record1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
record1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
record1.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
record1.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
||||||
page.getList().add(record1);
|
page.getList().add(record1);
|
||||||
|
|
||||||
@ -96,7 +96,7 @@ public class AppBargainRecordController {
|
|||||||
record2.setPrice(200);
|
record2.setPrice(200);
|
||||||
record2.setPayPrice(280);
|
record2.setPayPrice(280);
|
||||||
record2.setStatus(2);
|
record2.setStatus(2);
|
||||||
record2.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
record2.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
record2.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
record2.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
||||||
page.getList().add(record2);
|
page.getList().add(record2);
|
||||||
|
|
||||||
@ -111,7 +111,7 @@ public class AppBargainRecordController {
|
|||||||
record3.setPrice(200);
|
record3.setPrice(200);
|
||||||
record3.setPayPrice(380);
|
record3.setPayPrice(380);
|
||||||
record3.setStatus(2);
|
record3.setStatus(2);
|
||||||
record3.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
record3.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
record3.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
record3.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
||||||
record3.setOrderId(100L);
|
record3.setOrderId(100L);
|
||||||
page.getList().add(record3);
|
page.getList().add(record3);
|
||||||
@ -127,7 +127,7 @@ public class AppBargainRecordController {
|
|||||||
record4.setPrice(200);
|
record4.setPrice(200);
|
||||||
record4.setPayPrice(380);
|
record4.setPayPrice(380);
|
||||||
record4.setStatus(3);
|
record4.setStatus(3);
|
||||||
record4.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
record4.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
record4.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
record4.setExpireTime(LocalDateTimeUtils.addTime(Duration.ofDays(2)));
|
||||||
record4.setOrderId(100L);
|
record4.setOrderId(100L);
|
||||||
page.getList().add(record4);
|
page.getList().add(record4);
|
||||||
|
@ -38,7 +38,7 @@ public class AppCombinationActivityController {
|
|||||||
activity1.setName("618 大拼团");
|
activity1.setName("618 大拼团");
|
||||||
activity1.setUserSize(3);
|
activity1.setUserSize(3);
|
||||||
activity1.setSpuId(2048L);
|
activity1.setSpuId(2048L);
|
||||||
activity1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity1.setMarketPrice(50);
|
activity1.setMarketPrice(50);
|
||||||
activity1.setCombinationPrice(100);
|
activity1.setCombinationPrice(100);
|
||||||
activityList.add(activity1);
|
activityList.add(activity1);
|
||||||
@ -48,7 +48,7 @@ public class AppCombinationActivityController {
|
|||||||
activity2.setName("双十一拼团");
|
activity2.setName("双十一拼团");
|
||||||
activity2.setUserSize(5);
|
activity2.setUserSize(5);
|
||||||
activity2.setSpuId(4096L);
|
activity2.setSpuId(4096L);
|
||||||
activity2.setPicUrl("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
activity2.setPicUrl("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
activity2.setMarketPrice(100);
|
activity2.setMarketPrice(100);
|
||||||
activity2.setCombinationPrice(200);
|
activity2.setCombinationPrice(200);
|
||||||
activityList.add(activity2);
|
activityList.add(activity2);
|
||||||
|
@ -41,7 +41,7 @@ public class AppCombinationRecordController {
|
|||||||
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/ouwtwJycbic2JrCoZjETict0klxd1uRuicRneKk00ewMcCClxVcVHQT91Sh9MJGtwibf1fOicD1WpwSP4icJM6eQq1AA/132");
|
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/ouwtwJycbic2JrCoZjETict0klxd1uRuicRneKk00ewMcCClxVcVHQT91Sh9MJGtwibf1fOicD1WpwSP4icJM6eQq1AA/132");
|
||||||
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/RpUrhwens58qc99OcGs993xL4M5QPOe05ekqF9Eia440kRicAlicicIdQWicHBmy2bzLgHzHguWEzHHxnIgeictL7bLA/132");
|
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/RpUrhwens58qc99OcGs993xL4M5QPOe05ekqF9Eia440kRicAlicicIdQWicHBmy2bzLgHzHguWEzHHxnIgeictL7bLA/132");
|
||||||
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/S4tfqmxc8GZGsKc1K4mnhpvtG16gtMrLnTQfDibhr7jJich9LRI5RQKZDoqEjZM3azMib5nic7F4ZXKMEgYyLO08KA/132");
|
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/S4tfqmxc8GZGsKc1K4mnhpvtG16gtMrLnTQfDibhr7jJich9LRI5RQKZDoqEjZM3azMib5nic7F4ZXKMEgYyLO08KA/132");
|
||||||
summary.getAvatars().add("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
summary.getAvatars().add("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
return success(summary);
|
return success(summary);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,7 +61,7 @@ public class AppCombinationRecordController {
|
|||||||
record.setExpireTime(new Date());
|
record.setExpireTime(new Date());
|
||||||
record.setUserSize(10);
|
record.setUserSize(10);
|
||||||
record.setUserCount(i);
|
record.setUserCount(i);
|
||||||
record.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
record.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
record.setActivityId(1L);
|
record.setActivityId(1L);
|
||||||
record.setSpuName("活动:" + i);
|
record.setSpuName("活动:" + i);
|
||||||
list.add(record);
|
list.add(record);
|
||||||
@ -84,7 +84,7 @@ public class AppCombinationRecordController {
|
|||||||
headRecord.setUserCount(3);
|
headRecord.setUserCount(3);
|
||||||
headRecord.setStatus(1);
|
headRecord.setStatus(1);
|
||||||
headRecord.setActivityId(10L);
|
headRecord.setActivityId(10L);
|
||||||
headRecord.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
headRecord.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
headRecord.setCombinationPrice(100);
|
headRecord.setCombinationPrice(100);
|
||||||
detail.setHeadRecord(headRecord);
|
detail.setHeadRecord(headRecord);
|
||||||
// 团员
|
// 团员
|
||||||
|
@ -39,7 +39,7 @@ public class AppSeckillActivityController {
|
|||||||
activity1.setId(1L);
|
activity1.setId(1L);
|
||||||
activity1.setName("618 大秒杀");
|
activity1.setName("618 大秒杀");
|
||||||
activity1.setSpuId(2048L);
|
activity1.setSpuId(2048L);
|
||||||
activity1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity1.setMarketPrice(50);
|
activity1.setMarketPrice(50);
|
||||||
activity1.setSeckillPrice(100);
|
activity1.setSeckillPrice(100);
|
||||||
activityList.add(activity1);
|
activityList.add(activity1);
|
||||||
@ -48,7 +48,7 @@ public class AppSeckillActivityController {
|
|||||||
activity2.setId(2L);
|
activity2.setId(2L);
|
||||||
activity2.setName("双十一大秒杀");
|
activity2.setName("双十一大秒杀");
|
||||||
activity2.setSpuId(4096L);
|
activity2.setSpuId(4096L);
|
||||||
activity2.setPicUrl("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
activity2.setPicUrl("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
activity2.setMarketPrice(100);
|
activity2.setMarketPrice(100);
|
||||||
activity2.setSeckillPrice(200);
|
activity2.setSeckillPrice(200);
|
||||||
activityList.add(activity2);
|
activityList.add(activity2);
|
||||||
@ -65,7 +65,7 @@ public class AppSeckillActivityController {
|
|||||||
activity1.setId(1L);
|
activity1.setId(1L);
|
||||||
activity1.setName("618 大秒杀");
|
activity1.setName("618 大秒杀");
|
||||||
activity1.setSpuId(2048L);
|
activity1.setSpuId(2048L);
|
||||||
activity1.setPicUrl("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
activity1.setPicUrl("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg");
|
||||||
activity1.setMarketPrice(50);
|
activity1.setMarketPrice(50);
|
||||||
activity1.setSeckillPrice(100);
|
activity1.setSeckillPrice(100);
|
||||||
activity1.setUnitName("个");
|
activity1.setUnitName("个");
|
||||||
@ -77,7 +77,7 @@ public class AppSeckillActivityController {
|
|||||||
activity2.setId(2L);
|
activity2.setId(2L);
|
||||||
activity2.setName("双十一大秒杀");
|
activity2.setName("双十一大秒杀");
|
||||||
activity2.setSpuId(4096L);
|
activity2.setSpuId(4096L);
|
||||||
activity2.setPicUrl("https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132");
|
activity2.setPicUrl("https://static.iocoder.cn/mall/132.jpeg");
|
||||||
activity2.setMarketPrice(100);
|
activity2.setMarketPrice(100);
|
||||||
activity2.setSeckillPrice(200);
|
activity2.setSeckillPrice(200);
|
||||||
activity2.setUnitName("套");
|
activity2.setUnitName("套");
|
||||||
|
@ -25,8 +25,8 @@ public class AppSeckillConfigController {
|
|||||||
public CommonResult<List<AppSeckillConfigRespVO>> getSeckillConfigList() {
|
public CommonResult<List<AppSeckillConfigRespVO>> getSeckillConfigList() {
|
||||||
return success(Arrays.asList(
|
return success(Arrays.asList(
|
||||||
new AppSeckillConfigRespVO().setId(1L).setStartTime("00:00").setEndTime("09:59")
|
new AppSeckillConfigRespVO().setId(1L).setStartTime("00:00").setEndTime("09:59")
|
||||||
.setSliderPicUrls(Arrays.asList("https://demo26.crmeb.net/uploads/attach/2021/11/15/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg",
|
.setSliderPicUrls(Arrays.asList("https://static.iocoder.cn/mall/a79f5d2ea6bf0c3c11b2127332dfe2df.jpg",
|
||||||
"https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTKXMYJOomfp7cebz3cIeb8sHk3GGSIJtWEgREe3j7J1WoAbTvIOicpcNdFkWAziatBSMod8b5RyS4CQ/132")),
|
"https://static.iocoder.cn/mall/132.jpeg")),
|
||||||
new AppSeckillConfigRespVO().setId(2L).setStartTime("10:00").setEndTime("12:59"),
|
new AppSeckillConfigRespVO().setId(2L).setStartTime("10:00").setEndTime("12:59"),
|
||||||
new AppSeckillConfigRespVO().setId(2L).setStartTime("13:00").setEndTime("22:59"),
|
new AppSeckillConfigRespVO().setId(2L).setStartTime("13:00").setEndTime("22:59"),
|
||||||
new AppSeckillConfigRespVO().setId(2L).setStartTime("23:00").setEndTime("23:59")
|
new AppSeckillConfigRespVO().setId(2L).setStartTime("23:00").setEndTime("23:59")
|
||||||
|
@ -16,7 +16,7 @@ public interface SeckillConfigMapper extends BaseMapperX<SeckillConfigDO> {
|
|||||||
return selectPage(reqVO, new LambdaQueryWrapperX<SeckillConfigDO>()
|
return selectPage(reqVO, new LambdaQueryWrapperX<SeckillConfigDO>()
|
||||||
.likeIfPresent(SeckillConfigDO::getName, reqVO.getName())
|
.likeIfPresent(SeckillConfigDO::getName, reqVO.getName())
|
||||||
.eqIfPresent(SeckillConfigDO::getStatus, reqVO.getStatus())
|
.eqIfPresent(SeckillConfigDO::getStatus, reqVO.getStatus())
|
||||||
.orderByDesc(SeckillConfigDO::getId));
|
.orderByAsc(SeckillConfigDO::getStartTime));
|
||||||
}
|
}
|
||||||
|
|
||||||
default List<SeckillConfigDO> selectListByStatus(Integer status) {
|
default List<SeckillConfigDO> selectListByStatus(Integer status) {
|
||||||
|
@ -11,7 +11,6 @@ import cn.iocoder.yudao.framework.common.util.servlet.ServletUtils;
|
|||||||
import cn.iocoder.yudao.module.member.controller.app.auth.vo.*;
|
import cn.iocoder.yudao.module.member.controller.app.auth.vo.*;
|
||||||
import cn.iocoder.yudao.module.member.convert.auth.AuthConvert;
|
import cn.iocoder.yudao.module.member.convert.auth.AuthConvert;
|
||||||
import cn.iocoder.yudao.module.member.dal.dataobject.user.MemberUserDO;
|
import cn.iocoder.yudao.module.member.dal.dataobject.user.MemberUserDO;
|
||||||
import cn.iocoder.yudao.module.member.dal.mysql.user.MemberUserMapper;
|
|
||||||
import cn.iocoder.yudao.module.member.service.user.MemberUserService;
|
import cn.iocoder.yudao.module.member.service.user.MemberUserService;
|
||||||
import cn.iocoder.yudao.module.system.api.logger.LoginLogApi;
|
import cn.iocoder.yudao.module.system.api.logger.LoginLogApi;
|
||||||
import cn.iocoder.yudao.module.system.api.logger.dto.LoginLogCreateReqDTO;
|
import cn.iocoder.yudao.module.system.api.logger.dto.LoginLogCreateReqDTO;
|
||||||
@ -60,9 +59,6 @@ public class MemberAuthServiceImpl implements MemberAuthService {
|
|||||||
@Resource
|
@Resource
|
||||||
private WxMaService wxMaService;
|
private WxMaService wxMaService;
|
||||||
|
|
||||||
@Resource
|
|
||||||
private MemberUserMapper userMapper;
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AppAuthLoginRespVO login(AppAuthLoginReqVO reqVO) {
|
public AppAuthLoginRespVO login(AppAuthLoginReqVO reqVO) {
|
||||||
// 使用手机 + 密码,进行登录。
|
// 使用手机 + 密码,进行登录。
|
||||||
|
@ -168,9 +168,6 @@ public class MemberUserServiceImpl implements MemberUserService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isPasswordMatch(String rawPassword, String encodedPassword) {
|
public boolean isPasswordMatch(String rawPassword, String encodedPassword) {
|
||||||
if(true) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return passwordEncoder.matches(rawPassword, encodedPassword);
|
return passwordEncoder.matches(rawPassword, encodedPassword);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package cn.iocoder.yudao.module.pay.framework.pay.wallet;
|
package cn.iocoder.yudao.module.pay.framework.pay.wallet;
|
||||||
|
|
||||||
|
import cn.hutool.extra.spring.SpringUtil;
|
||||||
import cn.iocoder.yudao.framework.common.exception.ServiceException;
|
import cn.iocoder.yudao.framework.common.exception.ServiceException;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.dto.order.PayOrderRespDTO;
|
import cn.iocoder.yudao.framework.pay.core.client.dto.order.PayOrderRespDTO;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.dto.order.PayOrderUnifiedReqDTO;
|
import cn.iocoder.yudao.framework.pay.core.client.dto.order.PayOrderUnifiedReqDTO;
|
||||||
@ -7,6 +8,7 @@ import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundRespDTO;
|
|||||||
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundUnifiedReqDTO;
|
import cn.iocoder.yudao.framework.pay.core.client.dto.refund.PayRefundUnifiedReqDTO;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.AbstractPayClient;
|
import cn.iocoder.yudao.framework.pay.core.client.impl.AbstractPayClient;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.NonePayClientConfig;
|
import cn.iocoder.yudao.framework.pay.core.client.impl.NonePayClientConfig;
|
||||||
|
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
||||||
import cn.iocoder.yudao.module.pay.dal.dataobject.wallet.PayWalletTransactionDO;
|
import cn.iocoder.yudao.module.pay.dal.dataobject.wallet.PayWalletTransactionDO;
|
||||||
import cn.iocoder.yudao.module.pay.service.wallet.PayWalletService;
|
import cn.iocoder.yudao.module.pay.service.wallet.PayWalletService;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
@ -23,30 +25,26 @@ import static cn.iocoder.yudao.framework.common.exception.enums.GlobalErrorCodeC
|
|||||||
@Slf4j
|
@Slf4j
|
||||||
public class WalletPayClient extends AbstractPayClient<NonePayClientConfig> {
|
public class WalletPayClient extends AbstractPayClient<NonePayClientConfig> {
|
||||||
|
|
||||||
private PayWalletService payWalletService;
|
private PayWalletService wallService;
|
||||||
|
|
||||||
public WalletPayClient(Long channelId, String channelCode, NonePayClientConfig config) {
|
public WalletPayClient(Long channelId, NonePayClientConfig config) {
|
||||||
super(channelId, channelCode, config);
|
super(channelId, PayChannelEnum.WALLET.getCode(), config);
|
||||||
}
|
|
||||||
|
|
||||||
public WalletPayClient(Long channelId, String channelCode, NonePayClientConfig config,
|
|
||||||
PayWalletService payWalletService) {
|
|
||||||
this(channelId, channelCode, config);
|
|
||||||
this.payWalletService = payWalletService;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doInit() {
|
protected void doInit() {
|
||||||
// 钱包支付,无需初始化
|
if (wallService == null) {
|
||||||
|
wallService = SpringUtil.getBean(PayWalletService.class);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected PayOrderRespDTO doUnifiedOrder(PayOrderUnifiedReqDTO reqDTO) {
|
protected PayOrderRespDTO doUnifiedOrder(PayOrderUnifiedReqDTO reqDTO) {
|
||||||
try {
|
try {
|
||||||
PayWalletTransactionDO transaction = payWalletService.pay(reqDTO.getOutTradeNo(), reqDTO.getPrice());
|
PayWalletTransactionDO transaction = wallService.pay(reqDTO.getOutTradeNo(), reqDTO.getPrice());
|
||||||
return PayOrderRespDTO.successOf(transaction.getNo(), transaction.getCreator(),
|
return PayOrderRespDTO.successOf(transaction.getNo(), transaction.getCreator(),
|
||||||
transaction.getTransactionTime(),
|
transaction.getTransactionTime(),
|
||||||
reqDTO.getOutTradeNo(), "WALLET_PAY_SUCCESS"); // TODO @jason:transaction 作为 traData 好了;
|
reqDTO.getOutTradeNo(), transaction);
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
log.error("[doUnifiedOrder] 失败", ex);
|
log.error("[doUnifiedOrder] 失败", ex);
|
||||||
Integer errorCode = INTERNAL_SERVER_ERROR.getCode();
|
Integer errorCode = INTERNAL_SERVER_ERROR.getCode();
|
||||||
@ -74,10 +72,10 @@ public class WalletPayClient extends AbstractPayClient<NonePayClientConfig> {
|
|||||||
@Override
|
@Override
|
||||||
protected PayRefundRespDTO doUnifiedRefund(PayRefundUnifiedReqDTO reqDTO) {
|
protected PayRefundRespDTO doUnifiedRefund(PayRefundUnifiedReqDTO reqDTO) {
|
||||||
try {
|
try {
|
||||||
PayWalletTransactionDO payWalletTransaction = payWalletService.refund(reqDTO.getOutRefundNo(),
|
PayWalletTransactionDO payWalletTransaction = wallService.refund(reqDTO.getOutRefundNo(),
|
||||||
reqDTO.getRefundPrice(), reqDTO.getReason());
|
reqDTO.getRefundPrice(), reqDTO.getReason());
|
||||||
return PayRefundRespDTO.successOf(payWalletTransaction.getNo(), payWalletTransaction.getTransactionTime(),
|
return PayRefundRespDTO.successOf(payWalletTransaction.getNo(), payWalletTransaction.getTransactionTime(),
|
||||||
reqDTO.getOutRefundNo(), "WALLET_REFUND_SUCCESS");
|
reqDTO.getOutRefundNo(), payWalletTransaction);
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
log.error("[doUnifiedRefund] 失败", ex);
|
log.error("[doUnifiedRefund] 失败", ex);
|
||||||
Integer errorCode = INTERNAL_SERVER_ERROR.getCode();
|
Integer errorCode = INTERNAL_SERVER_ERROR.getCode();
|
||||||
|
@ -8,12 +8,6 @@ import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
|
|||||||
import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
|
import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.PayClientConfig;
|
import cn.iocoder.yudao.framework.pay.core.client.PayClientConfig;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.PayClientFactory;
|
import cn.iocoder.yudao.framework.pay.core.client.PayClientFactory;
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.AbstractPayClient;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.NonePayClientConfig;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.alipay.*;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.mock.MockPayClient;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.mock.MockPayClientConfig;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.client.impl.weixin.*;
|
|
||||||
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
||||||
import cn.iocoder.yudao.framework.tenant.core.util.TenantUtils;
|
import cn.iocoder.yudao.framework.tenant.core.util.TenantUtils;
|
||||||
import cn.iocoder.yudao.module.pay.controller.admin.channel.vo.PayChannelCreateReqVO;
|
import cn.iocoder.yudao.module.pay.controller.admin.channel.vo.PayChannelCreateReqVO;
|
||||||
@ -22,7 +16,6 @@ import cn.iocoder.yudao.module.pay.convert.channel.PayChannelConvert;
|
|||||||
import cn.iocoder.yudao.module.pay.dal.dataobject.channel.PayChannelDO;
|
import cn.iocoder.yudao.module.pay.dal.dataobject.channel.PayChannelDO;
|
||||||
import cn.iocoder.yudao.module.pay.dal.mysql.channel.PayChannelMapper;
|
import cn.iocoder.yudao.module.pay.dal.mysql.channel.PayChannelMapper;
|
||||||
import cn.iocoder.yudao.module.pay.framework.pay.wallet.WalletPayClient;
|
import cn.iocoder.yudao.module.pay.framework.pay.wallet.WalletPayClient;
|
||||||
import cn.iocoder.yudao.module.pay.service.wallet.PayWalletService;
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
@ -64,14 +57,15 @@ public class PayChannelServiceImpl implements PayChannelService {
|
|||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private Validator validator;
|
private Validator validator;
|
||||||
@Resource
|
|
||||||
private PayWalletService payWalletService;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始化 {@link #payClientFactory} 缓存
|
* 初始化 {@link #payClientFactory} 缓存
|
||||||
*/
|
*/
|
||||||
@PostConstruct
|
@PostConstruct
|
||||||
public void initLocalCache() {
|
public void initLocalCache() {
|
||||||
|
// 注册钱包支付 Class
|
||||||
|
payClientFactory.registerPayClientClass(PayChannelEnum.WALLET, WalletPayClient.class);
|
||||||
|
|
||||||
// 注意:忽略自动多租户,因为要全局初始化缓存
|
// 注意:忽略自动多租户,因为要全局初始化缓存
|
||||||
TenantUtils.executeIgnore(() -> {
|
TenantUtils.executeIgnore(() -> {
|
||||||
// 第一步:查询数据
|
// 第一步:查询数据
|
||||||
@ -85,55 +79,13 @@ public class PayChannelServiceImpl implements PayChannelService {
|
|||||||
log.error("[支付模块 yudao-module-pay - 表结构未导入][参考 https://doc.iocoder.cn/pay/build/ 开启]");
|
log.error("[支付模块 yudao-module-pay - 表结构未导入][参考 https://doc.iocoder.cn/pay/build/ 开启]");
|
||||||
}
|
}
|
||||||
log.info("[initLocalCache][缓存支付渠道,数量为:{}]", channels.size());
|
log.info("[initLocalCache][缓存支付渠道,数量为:{}]", channels.size());
|
||||||
// 第二步:构建缓存:创建或更新支付 Client
|
|
||||||
channels.forEach(payChannel ->{
|
|
||||||
AbstractPayClient<PayClientConfig> payClient = createPayClient(payChannel.getId(), payChannel.getCode(), payChannel.getConfig());
|
|
||||||
payClientFactory.addOrUpdatePayClient(payChannel.getId(), payClient);
|
|
||||||
|
|
||||||
});
|
// 第二步:构建缓存:创建或更新支付 Client
|
||||||
|
channels.forEach(payChannel -> payClientFactory.createOrUpdatePayClient(payChannel.getId(),
|
||||||
|
payChannel.getCode(), payChannel.getConfig()));
|
||||||
this.channelCache = channels;
|
this.channelCache = channels;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
private <Config extends PayClientConfig> AbstractPayClient<Config> createPayClient(
|
|
||||||
Long channelId, String channelCode, Config config) {
|
|
||||||
PayChannelEnum channelEnum = PayChannelEnum.getByCode(channelCode);
|
|
||||||
Assert.notNull(channelEnum, String.format("支付渠道(%s) 为空", channelEnum));
|
|
||||||
// 创建客户端
|
|
||||||
switch (channelEnum) {
|
|
||||||
// 微信支付
|
|
||||||
case WX_PUB:
|
|
||||||
return (AbstractPayClient<Config>) new WxPubPayClient(channelId, (WxPayClientConfig) config);
|
|
||||||
case WX_LITE:
|
|
||||||
return (AbstractPayClient<Config>) new WxLitePayClient(channelId, (WxPayClientConfig) config);
|
|
||||||
case WX_APP:
|
|
||||||
return (AbstractPayClient<Config>) new WxAppPayClient(channelId, (WxPayClientConfig) config);
|
|
||||||
case WX_BAR:
|
|
||||||
return (AbstractPayClient<Config>) new WxBarPayClient(channelId, (WxPayClientConfig) config);
|
|
||||||
case WX_NATIVE:
|
|
||||||
return (AbstractPayClient<Config>) new WxNativePayClient(channelId, (WxPayClientConfig) config);
|
|
||||||
// 支付宝支付
|
|
||||||
case ALIPAY_WAP:
|
|
||||||
return (AbstractPayClient<Config>) new AlipayWapPayClient(channelId, (AlipayPayClientConfig) config);
|
|
||||||
case ALIPAY_QR:
|
|
||||||
return (AbstractPayClient<Config>) new AlipayQrPayClient(channelId, (AlipayPayClientConfig) config);
|
|
||||||
case ALIPAY_APP:
|
|
||||||
return (AbstractPayClient<Config>) new AlipayAppPayClient(channelId, (AlipayPayClientConfig) config);
|
|
||||||
case ALIPAY_PC:
|
|
||||||
return (AbstractPayClient<Config>) new AlipayPcPayClient(channelId, (AlipayPayClientConfig) config);
|
|
||||||
case ALIPAY_BAR:
|
|
||||||
return (AbstractPayClient<Config>) new AlipayBarPayClient(channelId, (AlipayPayClientConfig) config);
|
|
||||||
// 其它支付
|
|
||||||
case MOCK:
|
|
||||||
return (AbstractPayClient<Config>) new MockPayClient(channelId, (MockPayClientConfig) config);
|
|
||||||
case WALLET:
|
|
||||||
return (AbstractPayClient<Config>) new WalletPayClient(
|
|
||||||
channelId, channelCode, (NonePayClientConfig) config, payWalletService);
|
|
||||||
}
|
|
||||||
// 创建失败,错误日志 + 抛出异常
|
|
||||||
log.error("[createPayClient][配置({}) 找不到合适的客户端实现]", config);
|
|
||||||
throw new IllegalArgumentException(String.format("配置(%s) 找不到合适的客户端实现", config));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过定时任务轮询,刷新缓存
|
* 通过定时任务轮询,刷新缓存
|
||||||
|
Loading…
Reference in New Issue
Block a user