-
-
Notifications
You must be signed in to change notification settings - Fork 112
/
create.go
110 lines (94 loc) · 2.84 KB
/
create.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
package user
import (
"net/http"
"encoding/json"
"go.mongodb.org/mongo-driver/mongo"
"time"
"github.com/azukaar/cosmos-server/src/utils"
)
type CreateRequestJSON struct {
Nickname string `validate:"required,min=3,max=32,alphanum"`
Email string `validate:"omitempty,email"`
}
func UserCreate(w http.ResponseWriter, req *http.Request) {
if utils.AdminOnly(w, req) != nil {
return
}
if(req.Method == "POST") {
var request CreateRequestJSON
err1 := json.NewDecoder(req.Body).Decode(&request)
if err1 != nil {
utils.Error("UserCreation: Invalid User Request", err1)
utils.HTTPError(w, "User Creation Error",
http.StatusInternalServerError, "UC001")
return
}
errV := utils.Validate.Struct(request)
if errV != nil {
utils.Error("UserCreation: Invalid User Request", errV)
utils.HTTPError(w, "User Creation Error: " + errV.Error(),
http.StatusInternalServerError, "UC003")
return
}
nickname := utils.Sanitize(request.Nickname)
email := utils.Sanitize(request.Email)
c, errCo := utils.GetCollection(utils.GetRootAppId(), "users")
if errCo != nil {
utils.Error("Database Connect", errCo)
utils.HTTPError(w, "Database", http.StatusInternalServerError, "DB001")
return
}
user := utils.User{}
utils.Debug("UserCreation: Creating user " + nickname)
err2 := c.FindOne(nil, map[string]interface{}{
"Nickname": nickname,
}).Decode(&user)
if err2 == mongo.ErrNoDocuments {
RegisterKey := utils.GenerateRandomString(24)
RegisterKeyExp := time.Now().Add(time.Hour * 24 * 7)
_, err3 := c.InsertOne(nil, map[string]interface{}{
"Nickname": nickname,
"Email": email,
"Password": "",
"RegisterKey": RegisterKey,
"RegisterKeyExp": RegisterKeyExp,
"Role": utils.USER,
"PasswordCycle": 0,
"CreatedAt": time.Now(),
})
if err3 != nil {
utils.Error("UserCreation: Error while creating user", err3)
utils.HTTPError(w, "User Creation Error",
http.StatusInternalServerError, "UC001")
return
}
utils.TriggerEvent(
"cosmos.user.create",
"User created",
"success",
"",
map[string]interface{}{
"nickname": nickname,
})
json.NewEncoder(w).Encode(map[string]interface{}{
"status": "OK",
"data": map[string]interface{}{
"registerKey": RegisterKey,
"registerKeyExp": RegisterKeyExp,
},
})
} else if err2 == nil {
utils.Error("UserCreation: User already exists", nil)
utils.HTTPError(w, "User already exists", http.StatusConflict, "UC002")
return
} else {
utils.Error("UserCreation: Error while finding user", err2)
utils.HTTPError(w, "User Creation Error", http.StatusInternalServerError, "UC001")
return
}
} else {
utils.Error("UserCreation: Method not allowed" + req.Method, nil)
utils.HTTPError(w, "Method not allowed", http.StatusMethodNotAllowed, "HTTP001")
return
}
}