|  |  |  | 
|---|
|  |  |  | package com.xinquan.user.controller.client; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.util.UUIDUtils; | 
|---|
|  |  |  | import cn.afterturn.easypoi.excel.ExcelExportUtil; | 
|---|
|  |  |  | import cn.afterturn.easypoi.excel.entity.ExportParams; | 
|---|
|  |  |  | import com.alibaba.nacos.common.utils.UuidUtils; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
|---|
|  |  |  | import com.xinquan.common.core.constant.CacheConstants; | 
|---|
|  |  |  | import com.xinquan.common.core.domain.R; | 
|---|
|  |  |  | import com.xinquan.common.datascope.annotation.DataScope; | 
|---|
|  |  |  | import com.xinquan.common.security.utils.SecurityUtils; | 
|---|
|  |  |  | import com.xinquan.common.core.utils.WebUtils; | 
|---|
|  |  |  | import com.xinquan.common.core.utils.page.CollUtils; | 
|---|
|  |  |  | import com.xinquan.common.core.utils.page.PageDTO; | 
|---|
|  |  |  | import com.xinquan.common.log.enums.BusinessType; | 
|---|
|  |  |  | import com.xinquan.common.redis.service.RedisService; | 
|---|
|  |  |  | import com.xinquan.common.security.service.TokenService; | 
|---|
|  |  |  | import com.xinquan.course.api.domain.Course; | 
|---|
|  |  |  | import com.xinquan.order.api.domain.Order; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.AppUserWalletRecord; | 
|---|
|  |  |  | import com.xinquan.user.api.domain.dto.OrderListDTO; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.AppUser; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.AppUserBank; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.AppUserWithdraw; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.vo.UpdateAppUserDTO; | 
|---|
|  |  |  | import com.xinquan.system.api.domain.vo.WalletVO; | 
|---|
|  |  |  | import com.xinquan.system.api.model.LoginUser; | 
|---|
|  |  |  | import com.xinquan.user.domain.export.WithdrawExport; | 
|---|
|  |  |  | import com.xinquan.user.service.AppUserBankService; | 
|---|
|  |  |  | import com.xinquan.user.service.AppUserService; | 
|---|
|  |  |  | import com.xinquan.user.service.AppUserWalletRecordService; | 
|---|
|  |  |  | import com.xinquan.user.service.AppUserWithdrawService; | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParam; | 
|---|
|  |  |  | import io.swagger.annotations.ApiImplicitParams; | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.PostMapping; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestBody; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestMapping; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RestController; | 
|---|
|  |  |  | import org.apache.poi.ss.usermodel.Workbook; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.util.StringUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.servlet.ServletOutputStream; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.net.URLEncoder; | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.Arrays; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * <p> | 
|---|
|  |  |  | 
|---|
|  |  |  | private AppUserWithdrawService withdrawService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private AppUserBankService appUserBankService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TokenService tokenService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private AppUserWalletRecordService appUserWalletRecordService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RedisService redisService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/withdrawList") | 
|---|
|  |  |  | @ApiOperation(value = "提现列表-分页", tags = {"管理后台-提现管理"}) | 
|---|
|  |  |  | public R<PageDTO<AppUserWithdraw>> withdrawList(@RequestBody OrderListDTO courseDTO) { | 
|---|
|  |  |  | LambdaQueryWrapper<AppUserWithdraw> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getBuyContent())){ | 
|---|
|  |  |  | wrapper.like(AppUserWithdraw::getCode,courseDTO.getBuyContent()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getUserNameOrPhone())){ | 
|---|
|  |  |  | List<Long> collect = appUserService.lambdaQuery().like(AppUser::getCellPhone, courseDTO.getUserNameOrPhone()) | 
|---|
|  |  |  | .list().stream().map(AppUser::getId) | 
|---|
|  |  |  | .collect(Collectors.toList()); | 
|---|
|  |  |  | List<Long> collect1 = appUserService.lambdaQuery().like(AppUser::getNickname, courseDTO.getUserNameOrPhone()) | 
|---|
|  |  |  | .list().stream().map(AppUser::getId) | 
|---|
|  |  |  | .collect(Collectors.toList()); | 
|---|
|  |  |  | collect.addAll(collect1); | 
|---|
|  |  |  | if (collect.isEmpty())collect.add(-1L); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getAppUserId,collect); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (courseDTO.getPaymentStatus()!=null && courseDTO.getPaymentStatus()==1){ | 
|---|
|  |  |  | wrapper.eq(AppUserWithdraw::getId,0); | 
|---|
|  |  |  | }else if (courseDTO.getPaymentStatus()!=null &&(courseDTO.getPaymentStatus()==2 || courseDTO.getPaymentStatus()==3)){ | 
|---|
|  |  |  | List<Integer> integers = new ArrayList<>(); | 
|---|
|  |  |  | integers.add(1); | 
|---|
|  |  |  | integers.add(2); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getWithdrawStatus,integers); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getTime())){ | 
|---|
|  |  |  | String startTime =null; | 
|---|
|  |  |  | String endTime =null; | 
|---|
|  |  |  | String[] split = courseDTO.getTime().split(" - "); | 
|---|
|  |  |  | startTime = split[0]+" 00:00:00"; | 
|---|
|  |  |  | endTime = split[1]+" 23:59:59"; | 
|---|
|  |  |  | wrapper.between(AppUserWithdraw::getWithdrawTime,startTime,endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Page<AppUserWithdraw> list = withdrawService.page(new Page<>(courseDTO.getPageCurr(), courseDTO.getPageSize()), wrapper); | 
|---|
|  |  |  | if (CollUtils.isEmpty(list.getRecords())) { | 
|---|
|  |  |  | return R.ok(PageDTO.empty(list)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (AppUserWithdraw record : list.getRecords()) { | 
|---|
|  |  |  | record.setUid(record.getId()+""); | 
|---|
|  |  |  | AppUser byId = appUserService.getById(record.getAppUserId()); | 
|---|
|  |  |  | if(byId!=null){ | 
|---|
|  |  |  | record.setUserName(byId.getNickname()); | 
|---|
|  |  |  | record.setCellPhone(byId.getCellPhone()); | 
|---|
|  |  |  | record.setAvatar(byId.getAvatar()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(PageDTO.of(list, AppUserWithdraw.class)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @ApiOperation(value = "提现管理导出", tags = {"管理后台-提现管理"}) | 
|---|
|  |  |  | @PutMapping("/export") | 
|---|
|  |  |  | public void export(@RequestBody OrderListDTO courseDTO) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | LambdaQueryWrapper<AppUserWithdraw> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getIds())){ | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getId, Arrays.asList(courseDTO.getIds().split(","))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getBuyContent())){ | 
|---|
|  |  |  | wrapper.like(AppUserWithdraw::getCode,courseDTO.getBuyContent()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getUserNameOrPhone())){ | 
|---|
|  |  |  | List<Long> collect = appUserService.lambdaQuery().like(AppUser::getCellPhone, courseDTO.getUserNameOrPhone()) | 
|---|
|  |  |  | .list().stream().map(AppUser::getId) | 
|---|
|  |  |  | .collect(Collectors.toList()); | 
|---|
|  |  |  | if (collect.isEmpty())collect.add(-1L); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getAppUserId,collect); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (courseDTO.getPaymentStatus()!=null && courseDTO.getPaymentStatus()==1){ | 
|---|
|  |  |  | wrapper.eq(AppUserWithdraw::getId,0); | 
|---|
|  |  |  | }else if (courseDTO.getPaymentStatus()!=null &&(courseDTO.getPaymentStatus()==2 || courseDTO.getPaymentStatus()==3)){ | 
|---|
|  |  |  | List<Integer> integers = new ArrayList<>(); | 
|---|
|  |  |  | integers.add(1); | 
|---|
|  |  |  | integers.add(2); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getWithdrawStatus,integers); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getTime())){ | 
|---|
|  |  |  | String startTime =null; | 
|---|
|  |  |  | String endTime =null; | 
|---|
|  |  |  | String[] split = courseDTO.getTime().split(" - "); | 
|---|
|  |  |  | startTime = split[0]+"00:00:00"; | 
|---|
|  |  |  | endTime = split[1]+"23:59:59"; | 
|---|
|  |  |  | wrapper.between(AppUserWithdraw::getWithdrawTime,startTime,endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AppUserWithdraw> list = withdrawService.list(wrapper); | 
|---|
|  |  |  | List<WithdrawExport> withdrawExports = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (AppUserWithdraw record : list) { | 
|---|
|  |  |  | WithdrawExport withdrawExport = new WithdrawExport(); | 
|---|
|  |  |  | record.setUid(record.getId()+""); | 
|---|
|  |  |  | AppUser byId = appUserService.getById(record.getAppUserId()); | 
|---|
|  |  |  | if(byId!=null){ | 
|---|
|  |  |  | withdrawExport.setUserName(byId.getNickname()); | 
|---|
|  |  |  | withdrawExport.setCellphone(byId.getCellPhone()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | withdrawExport.setCode(record.getCode()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | withdrawExport.setAmount("¥"+record.getAmount()+""); | 
|---|
|  |  |  | withdrawExport.setWithdrawType("1"); | 
|---|
|  |  |  | withdrawExport.setWithdrawStatus(record.getWithdrawStatus()+""); | 
|---|
|  |  |  | DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); | 
|---|
|  |  |  | String format = df.format(record.getCreateTime()); | 
|---|
|  |  |  | withdrawExport.setCreateTime(format); | 
|---|
|  |  |  | withdrawExports.add(withdrawExport); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), WithdrawExport.class, withdrawExports); | 
|---|
|  |  |  | HttpServletResponse response = WebUtils.response(); | 
|---|
|  |  |  | response.setContentType("application/vnd.ms-excel"); | 
|---|
|  |  |  | response.setCharacterEncoding("utf-8"); | 
|---|
|  |  |  | ServletOutputStream outputStream = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | String fileName = URLEncoder.encode("提现管理导出.xls", "utf-8"); | 
|---|
|  |  |  | response.setHeader("Content-Disposition", "attachment;filename=" + fileName); | 
|---|
|  |  |  | response.setContentType("application/vnd.ms-excel;charset=UTF-8"); | 
|---|
|  |  |  | response.setHeader("Pragma", "no-cache"); | 
|---|
|  |  |  | response.setHeader("Cache-Control", "no-cache"); | 
|---|
|  |  |  | outputStream = response.getOutputStream(); | 
|---|
|  |  |  | workbook.write(outputStream); | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | outputStream.close(); | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/withdrawInfo") | 
|---|
|  |  |  | @ApiOperation(value = "提现列表-查看详情", tags = {"管理后台-提现管理"}) | 
|---|
|  |  |  | public R<AppUserWithdraw> withdrawList(String uid){ | 
|---|
|  |  |  | AppUserWithdraw byId = withdrawService.getById(uid); | 
|---|
|  |  |  | return R.ok(byId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 远程调用获取提现记录 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping("/getWithdrawList") | 
|---|
|  |  |  | public R<List<AppUserWithdraw>> getWithdraw(@RequestBody OrderListDTO courseDTO) { | 
|---|
|  |  |  | LambdaQueryWrapper<AppUserWithdraw> wrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getBuyContent())){ | 
|---|
|  |  |  | if (!courseDTO.getBuyContent().contains("提现")){ | 
|---|
|  |  |  | wrapper.like(AppUserWithdraw::getCode,courseDTO.getBuyContent()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getUserNameOrPhone())){ | 
|---|
|  |  |  | List<Long> collect = appUserService.lambdaQuery().like(AppUser::getCellPhone, courseDTO.getUserNameOrPhone()) | 
|---|
|  |  |  | .list().stream().map(AppUser::getId) | 
|---|
|  |  |  | .collect(Collectors.toList()); | 
|---|
|  |  |  | if (collect.isEmpty())collect.add(-1L); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getAppUserId,collect); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (courseDTO.getOrderFrom()!=null && courseDTO.getOrderFrom()!=5){ | 
|---|
|  |  |  | wrapper.eq(AppUserWithdraw::getId,0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (courseDTO.getPayType()!=null && courseDTO.getPayType()!=4){ | 
|---|
|  |  |  | wrapper.eq(AppUserWithdraw::getId,0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (courseDTO.getPaymentStatus()!=null && courseDTO.getPaymentStatus()==1){ | 
|---|
|  |  |  | wrapper.eq(AppUserWithdraw::getId,0); | 
|---|
|  |  |  | }else if (courseDTO.getPaymentStatus()!=null &&(courseDTO.getPaymentStatus()==2 || courseDTO.getPaymentStatus()==3)){ | 
|---|
|  |  |  | List<Integer> integers = new ArrayList<>(); | 
|---|
|  |  |  | integers.add(1); | 
|---|
|  |  |  | integers.add(2); | 
|---|
|  |  |  | wrapper.in(AppUserWithdraw::getWithdrawStatus,integers); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.hasLength(courseDTO.getTime())){ | 
|---|
|  |  |  | String startTime =null; | 
|---|
|  |  |  | String endTime =null; | 
|---|
|  |  |  | String[] split = courseDTO.getTime().split(" - "); | 
|---|
|  |  |  | startTime = split[0]+"00:00:00"; | 
|---|
|  |  |  | endTime = split[1]+"23:59:59"; | 
|---|
|  |  |  | wrapper.between(AppUserWithdraw::getWithdrawTime,startTime,endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<AppUserWithdraw> list = withdrawService.list(wrapper); | 
|---|
|  |  |  | return R.ok(list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/withdraw") | 
|---|
|  |  |  | @ApiOperation(value = "提现", tags = {"钱包"}) | 
|---|
|  |  |  | @ApiImplicitParams({ | 
|---|
|  |  |  | 
|---|
|  |  |  | @ApiImplicitParam(name = "money", value = "提现金额", dataType = "String", required = true) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | public R withdraw(Long bankId,String money) { | 
|---|
|  |  |  | Long userId = SecurityUtils.getUserId(); | 
|---|
|  |  |  | if (userId==0)return R.tokenError("登录失效"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LoginUser loginUser = tokenService.getLoginUser(); | 
|---|
|  |  |  | if (loginUser==null){ | 
|---|
|  |  |  | return R.tokenError("登录失效"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long userId = loginUser.getUserid(); | 
|---|
|  |  |  | AppUser byId = appUserService.getById(userId); | 
|---|
|  |  |  | if (byId.getBalance().compareTo(new BigDecimal(money))<0){ | 
|---|
|  |  |  | return R.fail("提现金额不能超过钱包余额"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | byId.setBalance(byId.getBalance().subtract(new BigDecimal(money))); | 
|---|
|  |  |  | appUserService.updateById(byId); | 
|---|
|  |  |  | BigDecimal bigDecimal = new BigDecimal(money); | 
|---|
|  |  |  | AppUserWithdraw appUserWithdraw = new AppUserWithdraw(); | 
|---|
|  |  |  | appUserWithdraw.setAppUserId(userId); | 
|---|
|  |  |  | 
|---|
|  |  |  | appUserWithdraw.setWithdrawStatus(0); | 
|---|
|  |  |  | // todo 提现流水号 | 
|---|
|  |  |  | appUserWithdraw.setSerialNo(UuidUtils.generateUuid()); | 
|---|
|  |  |  | appUserWithdraw.setCode(UuidUtils.generateUuid()); | 
|---|
|  |  |  | appUserWithdraw.setWithdrawTime(LocalDateTime.now()); | 
|---|
|  |  |  | appUserWithdraw.setCreateTime(LocalDateTime.now()); | 
|---|
|  |  |  | withdrawService.save(appUserWithdraw); | 
|---|
|  |  |  | // 先扣去余额 | 
|---|
|  |  |  | AppUserWalletRecord appUserWalletRecord = new AppUserWalletRecord(); | 
|---|
|  |  |  | appUserWalletRecord.setAppUserId(userId); | 
|---|
|  |  |  | appUserWalletRecord.setChangeType(2); | 
|---|
|  |  |  | appUserWalletRecord.setReason("提现"); | 
|---|
|  |  |  | appUserWalletRecord.setOrderId(appUserWithdraw.getId()); | 
|---|
|  |  |  | appUserWalletRecord.setAmount(new BigDecimal(money)); | 
|---|
|  |  |  | appUserWalletRecordService.save(appUserWalletRecord); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/addBank") | 
|---|
|  |  |  | @ApiOperation(value = "提现-添加银行卡", tags = {"钱包"}) | 
|---|
|  |  |  | public R wallet(@RequestBody AppUserBank appUserWithdraw) { | 
|---|
|  |  |  | Long userId = SecurityUtils.getUserId(); | 
|---|
|  |  |  | if (userId==0)return R.tokenError("登录失效"); | 
|---|
|  |  |  | LoginUser loginUser = tokenService.getLoginUser(); | 
|---|
|  |  |  | if (loginUser==null){ | 
|---|
|  |  |  | return R.tokenError("登录失效"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long userId = loginUser.getUserid(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | appUserWithdraw.setAppUserId(userId); | 
|---|
|  |  |  | Boolean flag = redisService.hasKey(CacheConstants.ADD_CARD_PHONE_CODE_PREFIX + appUserWithdraw.getCellPhone()); | 
|---|
|  |  |  | if(!flag){ | 
|---|
|  |  |  | return R.fail("验证码已失效,请重新获取"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String code = redisService.getCacheObject(CacheConstants.ADD_CARD_PHONE_CODE_PREFIX + appUserWithdraw.getCellPhone()); | 
|---|
|  |  |  | if (!appUserWithdraw.getCode().equals(code)) { | 
|---|
|  |  |  | return R.fail("验证码不正确"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | appUserBankService.save(appUserWithdraw); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/deleteBank") | 
|---|
|  |  |  | @ApiOperation(value = "提现-删除银行卡", tags = {"钱包"}) | 
|---|
|  |  |  | public R deleteBank(Long id) { | 
|---|
|  |  |  | Long userId = SecurityUtils.getUserId(); | 
|---|
|  |  |  | if (userId==0)return R.tokenError("登录失效"); | 
|---|
|  |  |  | LoginUser loginUser = tokenService.getLoginUser(); | 
|---|
|  |  |  | if (loginUser==null){ | 
|---|
|  |  |  | return R.tokenError("登录失效"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long userId = loginUser.getUserid(); | 
|---|
|  |  |  | if(userId ==null || userId == 0)return R.tokenError("登录失效"); | 
|---|
|  |  |  | appUserBankService.removeById(id); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @PostMapping("/bankList") | 
|---|
|  |  |  | @ApiOperation(value = "提现-获取银行卡列表", tags = {"钱包"}) | 
|---|
|  |  |  | public R<List<AppUserBank>> bankList() { | 
|---|
|  |  |  | Long userId = SecurityUtils.getUserId(); | 
|---|
|  |  |  | if (userId==0)return R.tokenError("登录失效"); | 
|---|
|  |  |  | LoginUser loginUser = tokenService.getLoginUser(); | 
|---|
|  |  |  | if (loginUser==null){ | 
|---|
|  |  |  | return R.tokenError("登录失效"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long userId = loginUser.getUserid(); | 
|---|
|  |  |  | if(userId ==null || userId == 0)return R.tokenError("登录失效"); | 
|---|
|  |  |  | List<AppUserBank> list = appUserBankService.lambdaQuery() | 
|---|
|  |  |  | .eq(AppUserBank::getAppUserId, userId).list(); | 
|---|
|  |  |  | return R.ok(list); | 
|---|