This commit is contained in:
dute7liang
2023-12-24 15:48:49 +08:00
parent 8c897acfda
commit 7b51bda039
28 changed files with 751 additions and 26 deletions

View File

@@ -0,0 +1,95 @@
package com.ruoyi.cai.controller;
import cn.dev33.satoken.annotation.SaCheckPermission;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.cai.domain.CaiGoods;
import com.ruoyi.cai.service.CaiGoodsService;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.annotation.RepeatSubmit;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.PageQuery;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.validate.AddGroup;
import com.ruoyi.common.core.validate.EditGroup;
import com.ruoyi.common.enums.BusinessType;
import lombok.RequiredArgsConstructor;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.util.Arrays;
/**
* 充值配置
*
* @author 77
* @date 2023-12-24
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/cai/goods")
public class CaiGoodsController extends BaseController {
private final CaiGoodsService caiGoodsService;
/**
* 查询充值配置列表
*/
@SaCheckPermission("cai:goods:list")
@GetMapping("/list")
public TableDataInfo<CaiGoods> list(CaiGoods bo, PageQuery pageQuery) {
Page<CaiGoods> page = caiGoodsService.page(pageQuery.build(), Wrappers.lambdaQuery(bo));
return TableDataInfo.build(page);
}
/**
* 获取充值配置详细信息
*
* @param id 主键
*/
@SaCheckPermission("cai:goods:query")
@GetMapping("/{id}")
public R<CaiGoods> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) {
return R.ok(caiGoodsService.getById(id));
}
/**
* 新增充值配置
*/
@SaCheckPermission("cai:goods:add")
@Log(title = "充值配置", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody CaiGoods bo) {
return toAjax(caiGoodsService.save(bo));
}
/**
* 修改充值配置
*/
@SaCheckPermission("cai:goods:edit")
@Log(title = "充值配置", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody CaiGoods bo) {
return toAjax(caiGoodsService.updateById(bo));
}
/**
* 删除充值配置
*
* @param ids 主键串
*/
@SaCheckPermission("cai:goods:remove")
@Log(title = "充值配置", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] ids) {
return toAjax(caiGoodsService.removeBatchByIds(Arrays.asList(ids), true));
}
}

View File

@@ -0,0 +1,95 @@
package com.ruoyi.cai.controller;
import cn.dev33.satoken.annotation.SaCheckPermission;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.cai.domain.CaiWithdrawExchange;
import com.ruoyi.cai.service.CaiWithdrawExchangeService;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.annotation.RepeatSubmit;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.PageQuery;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.validate.AddGroup;
import com.ruoyi.common.core.validate.EditGroup;
import com.ruoyi.common.enums.BusinessType;
import lombok.RequiredArgsConstructor;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.util.Arrays;
/**
* 提现 - 兑换配置
*
* @author 77
* @date 2023-12-24
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/cai/withdrawExchange")
public class CaiWithdrawExchangeController extends BaseController {
private final CaiWithdrawExchangeService caiWithdrawExchangeService;
/**
* 查询提现 - 兑换配置列表
*/
@SaCheckPermission("cai:withdrawExchange:list")
@GetMapping("/list")
public TableDataInfo<CaiWithdrawExchange> list(CaiWithdrawExchange bo, PageQuery pageQuery) {
Page<CaiWithdrawExchange> page = caiWithdrawExchangeService.page(pageQuery.build(), Wrappers.lambdaQuery(bo));
return TableDataInfo.build(page);
}
/**
* 获取提现 - 兑换配置详细信息
*
* @param id 主键
*/
@SaCheckPermission("cai:withdrawExchange:query")
@GetMapping("/{id}")
public R<CaiWithdrawExchange> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long id) {
return R.ok(caiWithdrawExchangeService.getById(id));
}
/**
* 新增提现 - 兑换配置
*/
@SaCheckPermission("cai:withdrawExchange:add")
@Log(title = "提现 - 兑换配置", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody CaiWithdrawExchange bo) {
return toAjax(caiWithdrawExchangeService.save(bo));
}
/**
* 修改提现 - 兑换配置
*/
@SaCheckPermission("cai:withdrawExchange:edit")
@Log(title = "提现 - 兑换配置", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody CaiWithdrawExchange bo) {
return toAjax(caiWithdrawExchangeService.updateById(bo));
}
/**
* 删除提现 - 兑换配置
*
* @param ids 主键串
*/
@SaCheckPermission("cai:withdrawExchange:remove")
@Log(title = "提现 - 兑换配置", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] ids) {
return toAjax(caiWithdrawExchangeService.removeBatchByIds(Arrays.asList(ids), true));
}
}

View File

@@ -1,10 +1,20 @@
package com.ruoyi.cai.controller.app;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.cai.domain.CaiAccountBankcard;
import com.ruoyi.cai.domain.CaiAccountCash;
import com.ruoyi.cai.domain.CaiAccountRecharge;
import com.ruoyi.cai.dto.app.query.*;
import com.ruoyi.cai.dto.app.vo.*;
import com.ruoyi.cai.manager.CurrentUserManager;
import com.ruoyi.cai.service.CaiAccountBankcardService;
import com.ruoyi.cai.service.CaiAccountCashService;
import com.ruoyi.cai.service.CaiAccountRechargeService;
import com.ruoyi.cai.service.CaiUserAlbumService;
import com.ruoyi.common.core.domain.PageQuery;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.helper.LoginHelper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
@@ -20,7 +30,31 @@ public class CaiCurrentUserAppController {
@Autowired
private CurrentUserManager currentUserManager;
@Autowired
private CaiAccountRechargeService caiAccountRechargeService;
@Autowired
private CaiAccountCashService accountCashService;
@Autowired
private CaiUserAlbumService userAlbumService;
@GetMapping("/user/aliInfo")
public R<CaiAccountBankcard> aliInfo(){
CaiAccountBankcard accountBankcard = currentUserManager.aliInfo();
return R.ok(accountBankcard);
}
@PostMapping("/user/save-or-update/ali")
public R<Boolean> updateAli(AccountAliBankCardRes res){
currentUserManager.saveOrUpdateAliInfo(res);
return R.ok(true);
}
@PostMapping("/user/withdraw/ali")
public R<Boolean> withdraw(WithdrawRes res){
res.setUserId(LoginHelper.getUserId());
accountCashService.withdraw(res);
return R.ok(true);
}
@GetMapping("/user/info")
public R<CurrentUserInfoVo> currentInfo(){
return R.ok(currentUserManager.currentInfo());
@@ -61,4 +95,22 @@ public class CaiCurrentUserAppController {
public R<Boolean> userAlbumAdd(List<AlbumResetRes> res){
return R.ok(userAlbumService.resetAlbum(res,LoginHelper.getUserId()));
}
@GetMapping("/user/recharge/log")
public TableDataInfo<AccountRechargeVo> rechargeLog(PageQuery query){
Long userId = LoginHelper.getUserId();
Page<CaiAccountRecharge> page = caiAccountRechargeService.page(query.build(), Wrappers.lambdaQuery(CaiAccountRecharge.class)
.eq(CaiAccountRecharge::getUserId, userId)
.orderByDesc(CaiAccountRecharge::getCreateTime));
return TableDataInfo.build(page,AccountRechargeVo::new);
}
@GetMapping("/user/cash/log")
public TableDataInfo<AccountCashVo> cashLog(PageQuery query){
Long userId = LoginHelper.getUserId();
Page<CaiAccountCash> page = accountCashService.page(query.build(), Wrappers.lambdaQuery(CaiAccountCash.class)
.eq(CaiAccountCash::getUserId, userId)
.orderByDesc(CaiAccountCash::getCreateTime));
return TableDataInfo.build(page,AccountCashVo::new);
}
}

View File

@@ -0,0 +1,39 @@
package com.ruoyi.cai.controller.app;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.ruoyi.cai.domain.CaiGoods;
import com.ruoyi.cai.domain.CaiWithdrawExchange;
import com.ruoyi.cai.service.CaiGoodsService;
import com.ruoyi.cai.service.CaiWithdrawExchangeService;
import com.ruoyi.common.core.domain.R;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/api/setting")
public class CaiSettingAppController {
@Autowired
private CaiGoodsService goodsService;
@Autowired
private CaiWithdrawExchangeService withdrawExchangeService;
@GetMapping("/goods")
public R<List<CaiGoods>> goods(){
List<CaiGoods> list = goodsService.list(Wrappers.lambdaQuery(CaiGoods.class)
.eq(CaiGoods::getStatus,0)
.orderByAsc(CaiGoods::getPrice));
return R.ok(list);
}
@GetMapping("/withdraw")
public R<List<CaiWithdrawExchange>> withdraw(){
List<CaiWithdrawExchange> list = withdrawExchangeService.list(Wrappers.lambdaQuery(CaiWithdrawExchange.class)
.orderByAsc(CaiWithdrawExchange::getMoney));
return R.ok(list);
}
}