-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdata.go
More file actions
71 lines (50 loc) · 1.14 KB
/
data.go
File metadata and controls
71 lines (50 loc) · 1.14 KB
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
package main
import (
"database/sql"
"fmt"
"os"
_ "github.com/lib/pq"
)
var Db *sql.DB
type User struct {
Name string
Password string
}
func InitDb() error {
var (
dbname = os.Getenv("POSTGRES_DB")
dbuser = os.Getenv("POSTGRES_USER")
dbpassword = os.Getenv("POSTGRES_PASSWORD")
dbhost = os.Getenv("POSTGRES_HOST")
dbport = os.Getenv("POSTGRES_PORT")
uri = fmt.Sprintf("user=%s dbname=%s password=%s host=%s port=%s sslmode=disable", dbuser, dbname, dbpassword, dbhost, dbport)
)
db, err := sql.Open("postgres", uri)
if err != nil {
return err
}
Db = db
return nil
}
func GetUsers() ([]User, error) {
users := []User{}
rows, err := Db.Query(`SELECT user_name, password FROM app_user;`)
if err != nil {
return users, err
}
defer rows.Close()
for rows.Next() {
u := User{}
rows.Scan(&u.Name, &u.Password)
users = append(users, u)
}
return users, nil
}
func AddUser(name string, password string) error {
fmt.Println(name, password)
_, err := Db.Exec("INSERT INTO app_user (user_name, password) VALUES($1, $2);", name, password)
if err != nil {
return err
}
return nil
}