-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathuser.go
142 lines (132 loc) · 2.59 KB
/
user.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
package main
type User struct {
ID int
Email string
}
func InsertUser(user *User) error {
var id int
err := db.QueryRow(`
INSERT INTO users(email)
VALUES ($1)
RETURNING id
`, user.Email).Scan(&id)
if err != nil {
return err
}
user.ID = id
return nil
}
func GetUserByID(id int) (*User, error) {
var email string
err := db.QueryRow("SELECT email FROM users WHERE id=$1", id).Scan(&email)
if err != nil {
return nil, err
}
return &User{
ID: id,
Email: email,
}, nil
}
func RemoveUserByID(id int) error {
_, err := db.Exec("DELETE FROM users WHERE id=$1", id)
return err
}
func Follow(followerID, followeeID int) error {
_, err := db.Exec(`
INSERT INTO followers(follower_id, followee_id)
VALUES ($1, $2)
`, followerID, followeeID)
return err
}
func Unfollow(followerID, followeeID int) error {
_, err := db.Exec(`
DELETE FROM followers
WHERE follower_id=$1
AND followee_id=$2
`, followerID, followeeID)
return err
}
func GetFollowerByIDAndUser(id int, userID int) (*User, error) {
var email string
err := db.QueryRow(`
SELECT u.email
FROM users AS u, followers AS f
WHERE u.id = f.follower_id
AND f.follower_id=$1
AND f.followee_id=$2
LIMIT 1
`, id, userID).Scan(&email)
if err != nil {
return nil, err
}
return &User{
ID: id,
Email: email,
}, nil
}
func GetFollowersForUser(id int) ([]*User, error) {
rows, err := db.Query(`
SELECT u.id, u.email
FROM users AS u, followers AS f
WHERE u.id=f.follower_id
AND f.followee_id=$1
`, id)
if err != nil {
return nil, err
}
defer rows.Close()
var (
users = []*User{}
uid int
email string
)
for rows.Next() {
if err = rows.Scan(&uid, &email); err != nil {
return nil, err
}
users = append(users, &User{ID: id, Email: email})
}
return users, nil
}
func GetFolloweeByIDAndUser(id int, userID int) (*User, error) {
var email string
err := db.QueryRow(`
SELECT u.email
FROM users AS u, followers AS f
WHERE u.id = f.followee_id
AND f.followee_id=$1
AND f.follower_id=$2
LIMIT 1
`, id, userID).Scan(&email)
if err != nil {
return nil, err
}
return &User{
ID: id,
Email: email,
}, nil
}
func GetFolloweesForUser(id int) ([]*User, error) {
rows, err := db.Query(`
SELECT u.id, u.email
FROM users AS u, followers AS f
WHERE u.id=f.follower_id
AND f.follower_id=$1
`, id)
if err != nil {
return nil, err
}
defer rows.Close()
var (
users = []*User{}
uid int
email string
)
for rows.Next() {
if err = rows.Scan(&uid, &email); err != nil {
return nil, err
}
users = append(users, &User{ID: id, Email: email})
}
return users, nil
}