/
account.go
117 lines (95 loc) · 2.46 KB
/
account.go
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
107
108
109
110
111
112
113
114
115
116
117
package api
import (
"github.com/copernet/whccommon/log"
"github.com/copernet/whcwallet/api/errs"
"github.com/copernet/whcwallet/logic"
"github.com/copernet/whcwallet/model/view"
"github.com/gin-gonic/gin"
)
var accountService logic.AccountService
func Challenge(c *gin.Context) {
uuid := c.Query("uuid")
if uuid == "" {
c.JSON(200, apiError(ErrEmptyQueryParam))
return
}
challenge, err := accountService.ChallengeLogic(uuid)
if err != nil {
log.WithCtx(c).Warnf("challenge error:%s", err.Error())
c.JSON(200, apiError(ErrChallenge))
return
}
c.JSON(200, apiSuccess(challenge))
}
func Create(c *gin.Context) {
var param view.WalletCreateParam
if err := c.ShouldBind(¶m); err != nil {
log.WithCtx(c).Errorf("Form valid error:%s", err.Error())
c.JSON(200, apiError(ErrFormItems))
return
}
err := accountService.CreateWallet(c, ¶m)
if err != nil {
c.JSON(200, apiErrorWithMsg(ErrCreateWallet, err.Error()))
return
}
c.JSON(200, apiSuccess(nil))
}
func Update(c *gin.Context) {
var param view.WalletUpdateParam
if err := c.ShouldBind(¶m); err != nil {
log.WithCtx(c).Errorf("Form valid error:%s", err.Error())
c.JSON(200, apiError(ErrFormItems))
return
}
err := accountService.UpdateWallet(c, param)
if err != nil {
c.JSON(200, apiErrorWithMsg(ErrUpdateWallet, err.Error()))
return
}
c.JSON(200, apiSuccess(nil))
}
func Login(c *gin.Context) {
var param view.WalletLoginParam
if err := c.ShouldBind(¶m); err != nil {
log.WithCtx(c).Errorf("Form valid error:%s", err.Error())
c.JSON(200, apiError(ErrFormItems))
return
}
wallet, err := accountService.LoginWallet(c, param)
if err != nil {
code := ErrLogin
if err.Error() == errs.MfaTokenNil {
code = ErrMfaToken
}
c.JSON(200, apiErrorWithMsg(code, err.Error()))
return
}
c.JSON(200, apiSuccess(wallet))
}
/**
The api is used for web ajax verify email unique or phone unique
*/
func Verify(c *gin.Context) {
var param view.WalletVerifyParam
if err := c.ShouldBind(¶m); err != nil {
log.WithCtx(c).Errorf("Form valid error:%s", err.Error())
c.JSON(200, apiError(ErrFormItems))
return
}
err := accountService.VerifyWallet(param)
if err != nil {
c.JSON(200, apiErrorWithMsg(ErrVerify, err.Error()))
return
}
c.JSON(200, apiSuccess(nil))
}
func NewMfa(c *gin.Context) {
uuid, _ := c.GetPostForm("uuid")
if uuid == "" {
c.JSON(200, apiError(ErrEmptyQueryParam))
return
}
vo := accountService.NewMfa(uuid)
c.JSON(200, apiSuccess(vo))
}