/
pg_user_url.go
112 lines (87 loc) · 2.09 KB
/
pg_user_url.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
package postgres
import (
"context"
"github.com/chnejohnson/shortener/domain"
"github.com/google/uuid"
"github.com/jackc/pgx/v4"
"github.com/sirupsen/logrus"
)
type pgUserURLRepository struct {
conn *pgx.Conn
}
// NewRepository ...
func NewRepository(conn *pgx.Conn) domain.UserURLRepository {
return &pgUserURLRepository{conn}
}
func (p *pgUserURLRepository) Find(code string) (string, error) {
sql := "SELECT url FROM user_urls WHERE code=$1;"
url := ""
err := p.conn.QueryRow(context.Background(), sql, code).Scan(&url)
if err != nil {
return "", err
}
return url, nil
}
func (p *pgUserURLRepository) FetchAll(userID uuid.UUID) ([]*domain.UserURL, error) {
sql := `
SELECT id, url, code, created_at, total_click
FROM user_urls
WHERE user_id = $1;`
urls := []*domain.UserURL{}
rows, err := p.conn.Query(context.Background(), sql, userID.String())
if err != nil {
return urls, err
}
defer rows.Close()
for rows.Next() {
url := UserURL{}
err := rows.Scan(&url.ID, &url.URL, &url.Code, &url.CreatedAt, &url.TotalClick)
if err != nil {
return urls, err
}
durl := &domain.UserURL{
ID: url.ID,
URL: url.URL,
Code: url.Code,
CreatedAt: url.CreatedAt.Time,
TotalClick: url.TotalClick,
}
if err != nil {
return urls, err
}
urls = append(urls, durl)
}
if rows.Err() != nil {
return urls, rows.Err()
}
return urls, nil
}
// AddTotalClick ...
func (p *pgUserURLRepository) AddTotalClick(code string) error {
sql := `
UPDATE user_urls
SET total_click = total_click + 1
WHERE code = $1;
`
_, err := p.conn.Exec(context.Background(), sql, code)
if err != nil {
return err
}
return nil
}
// AddURL ...
func (p *pgUserURLRepository) AddURL(uu *domain.UserURL) error {
sql := `
INSERT INTO user_urls (url, code, user_id)
VALUES($1, $2, $3);`
_, err := p.conn.Exec(context.Background(), sql, uu.URL, uu.Code, uu.UserID)
if err != nil {
logrus.WithFields(logrus.Fields{
"url": uu.URL,
"code": uu.Code,
"userID": uu.UserID,
}).Error("Fail to insert data into postgres")
return err
}
return nil
}