新版仿ok交易所-后端
zyy
2025-08-26 9cadad100ba1d3c18966f9df7e1c3213abc0d214
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
package com.yami.trading.admin.controller.user;
 
import cn.hutool.extra.qrcode.QrCodeUtil;
import cn.hutool.extra.qrcode.QrConfig;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.yami.trading.admin.controller.user.model.WithdrawListModel;
import com.yami.trading.admin.controller.user.model.WithdrawRemarksModel;
import com.yami.trading.admin.model.*;
import com.yami.trading.bean.user.dto.WithdrawDto;
import com.yami.trading.common.annotation.SysLog;
import com.yami.trading.common.domain.Result;
import com.yami.trading.common.exception.YamiShopBindException;
import com.yami.trading.security.common.util.SecurityUtils;
import com.yami.trading.security.common.manager.PasswordManager;
import com.yami.trading.service.RealNameAuthRecordService;
import com.yami.trading.service.WithdrawService;
import com.yami.trading.sys.model.SysUser;
import com.yami.trading.sys.service.SysUserService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.crypto.password.PasswordEncoder;
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 javax.validation.Valid;
 
@RestController
@RequestMapping("withdraw")
@Api(tags = "UDST提现订单")
public class WithdrawController {
    @Autowired
    WithdrawService withdrawService;
    @Autowired
    RealNameAuthRecordService realNameAuthRecordService;
    @Autowired
    SysUserService sysUserService;
    @Autowired
    PasswordEncoder passwordEncoder;
    @Autowired
    PasswordManager passwordManager;
 
    @ApiOperation(value = "列表")
    @PostMapping("list")
    public Result<Page<WithdrawDto>> list(@RequestBody @Valid WithdrawListModel request) {
        Page<WithdrawDto> page = new Page(request.getCurrent(), request.getSize());
        withdrawService.listRecord(page, request.getStatus(),
                request.getRolename(), request.getUserName(), request.getOrderNo());
        QrConfig config = new QrConfig(345, 345);
        config.setMargin(3);
        for (WithdrawDto withdrawDto: page.getRecords()){
            String base64 = QrCodeUtil.generateAsBase64(withdrawDto.getAddress(), config, "png");
            withdrawDto.setQdcode(base64);
        }
        return Result.ok(page);
    }
 
    @ApiOperation(value = "通过审核手动打款")
    @PostMapping("examineOk")
    @SysLog("UDST提现订单-通过审核手动打款")
    public Result<?> examineOk(@RequestBody @Valid WithdrawExamineModel model) {
        Long adminUserId = SecurityUtils.getSysUser().getUserId();
        sysUserService.checkSafeWord(model.getSafePasssword());
        withdrawService.examineOk(model.getId(), adminUserId);
        return Result.ok(null);
    }
 
    @ApiOperation(value = "驳回")
    @PostMapping("reject")
    @SysLog("UDST提现订单-驳回")
    public Result<?> reject(@RequestBody @Valid WithdrawRejectModel model) {
        String adminUserName = SecurityUtils.getSysUser().getUsername();
        withdrawService.reject(model.getId(), model.getContent(), adminUserName);
        return Result.ok(null);
    }
 
 
 
    @ApiOperation(value = "备注")
    @PostMapping("remarks")
    @SysLog("UDST提现订单-驳回")
    public Result<?> remarks(@RequestBody @Valid WithdrawRemarksModel model) {
        withdrawService.remarks(model.getId(),model.getRemarks());
        return Result.ok(null);
    }
    @ApiOperation(value = "修改用户提现订单收款地址")
    @PostMapping("changeAddress")
    @SysLog("UDST提现订单-修改用户提现订单收款地址")
    public Result<?> changeAddress(@RequestBody @Valid ChangeAddressModel model) {
        String adminUserName = SecurityUtils.getSysUser().getUsername();
        Long adminUserId = SecurityUtils.getSysUser().getUserId();
        model.setSafeWord(passwordManager.decryptPassword(model.getSafeWord()));
        SysUser user = sysUserService.getSysUserById(SecurityUtils.getSysUser().getUserId());
        if (passwordEncoder.matches(model.getSafeWord(), user.getSafePassword())) {
            throw new YamiShopBindException("资金密码不正确!");
        }
        withdrawService.updateAddress(model.getId(), adminUserName, adminUserId, model.getChangeAfterAddress());
        return Result.ok(null);
 
 
 
 
    }
}