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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
| package models
import "time"
type User struct {
Id int
Uuid string
Name string
Email string
Password string
CreatedAt time.Time
}
// Create a new session for an existing user
func (user *User) CreateSession() (session Session, err error) {
statement := "insert into sessions (uuid, email, user_id, created_at) values (?, ?, ?, ?)"
stmtin, err := Db.Prepare(statement)
if err != nil {
return
}
defer stmtin.Close()
uuid := createUUID()
stmtin.Exec(uuid, user.Email, user.Id, time.Now())
stmtout, err := Db.Prepare("select id, uuid, email, user_id, created_at from sessions where uuid = ?")
if err != nil {
return
}
defer stmtout.Close()
// use QueryRow to return a row and scan the returned id into the Session struct
err = stmtout.QueryRow(uuid).Scan(&session.Id, &session.Uuid, &session.Email, &session.UserId, &session.CreatedAt)
return
}
// Get the session for an existing user
func (user *User) Session() (session Session, err error) {
session = Session{}
err = Db.QueryRow("SELECT id, uuid, email, user_id, created_at FROM sessions WHERE user_id = ?", user.Id).
Scan(&session.Id, &session.Uuid, &session.Email, &session.UserId, &session.CreatedAt)
return
}
// Create a new user, save user info into the database
func (user *User) Create() (err error) {
// Postgres does not automatically return the last insert id, because it would be wrong to assume
// you're always using a sequence.You need to use the RETURNING keyword in your insert to get this
// information from postgres.
statement := "insert into users (uuid, name, email, password, created_at) values (?, ?, ?, ?, ?)"
stmtin, err := Db.Prepare(statement)
if err != nil {
return
}
defer stmtin.Close()
uuid := createUUID()
stmtin.Exec(uuid, user.Name, user.Email, Encrypt(user.Password), time.Now())
stmtout, err := Db.Prepare("select id, uuid, created_at from users where uuid = ?")
if err != nil {
return
}
defer stmtout.Close()
// use QueryRow to return a row and scan the returned id into the User struct
err = stmtout.QueryRow(uuid).Scan(&user.Id, &user.Uuid, &user.CreatedAt)
return
}
// Delete user from database
func (user *User) Delete() (err error) {
statement := "delete from users where id = ?"
stmt, err := Db.Prepare(statement)
if err != nil {
return
}
defer stmt.Close()
_, err = stmt.Exec(user.Id)
return
}
// Update user information in the database
func (user *User) Update() (err error) {
statement := "update users set name = ?, email = ? where id = ?"
stmt, err := Db.Prepare(statement)
if err != nil {
return
}
defer stmt.Close()
_, err = stmt.Exec(user.Name, user.Email, user.Id)
return
}
// Delete all users from database
func UserDeleteAll() (err error) {
statement := "delete from users"
_, err = Db.Exec(statement)
return
}
// Get all users in the database and returns it
func Users() (users []User, err error) {
rows, err := Db.Query("SELECT id, uuid, name, email, password, created_at FROM users")
if err != nil {
return
}
for rows.Next() {
user := User{}
if err = rows.Scan(&user.Id, &user.Uuid, &user.Name, &user.Email, &user.Password, &user.CreatedAt); err != nil {
return
}
users = append(users, user)
}
rows.Close()
return
}
// Get a single user given the email
func UserByEmail(email string) (user User, err error) {
user = User{}
err = Db.QueryRow("SELECT id, uuid, name, email, password, created_at FROM users WHERE email = ?", email).
Scan(&user.Id, &user.Uuid, &user.Name, &user.Email, &user.Password, &user.CreatedAt)
return
}
// Get a single user given the UUID
func UserByUUID(uuid string) (user User, err error) {
user = User{}
err = Db.QueryRow("SELECT id, uuid, name, email, password, created_at FROM users WHERE uuid = ?", uuid).
Scan(&user.Id, &user.Uuid, &user.Name, &user.Email, &user.Password, &user.CreatedAt)
return
}
|