-
Notifications
You must be signed in to change notification settings - Fork 0
/
callouts.go
111 lines (94 loc) · 1.9 KB
/
callouts.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
package db
import (
"context"
)
var (
calloutsTable string = "callouts"
)
type Callout struct {
Callout string `db:"callout"`
Text string `db:"text"`
GID string `db:"gid"`
}
func (c *Callout) Clone() *Callout {
return &Callout{
Callout: c.Callout,
Text: c.Text,
GID: c.GID,
}
}
func InsertCallout(ctx context.Context, c *Callout) error {
q, err := prepareStmt(
`INSERT OR REPLACE INTO ` + calloutsTable + `
(gid,callout,text) VALUES (?,?,?)`,
)
if err != nil {
return err
}
res, err := q.ExecContext(ctx, c.GID, c.Callout, c.Text)
if err != nil {
return err
}
n, err := res.RowsAffected()
if err != nil {
return err
}
if n == 0 {
return ErrInsert
}
return nil
}
func SelectOneCallout(ctx context.Context, c *Callout) error {
q, err := prepareStmt(
`SELECT gid,callout,text FROM ` + calloutsTable + `
WHERE callout LIKE ? AND gid=? LIMIT 1`,
)
if err != nil {
return err
}
row := q.QueryRowContext(ctx, c.Callout, c.GID)
return row.Scan(&c.GID, &c.Callout, &c.Text)
}
func SelectAllCallouts(ctx context.Context, gid string) ([]string, error) {
var callouts []string
q, err := prepareStmt(
`SELECT callout FROM ` + calloutsTable + ` WHERE gid=?`,
)
if err != nil {
return callouts, err
}
rows, err := q.QueryContext(ctx, gid)
if err != nil {
return callouts, err
}
defer rows.Close()
for rows.Next() {
var callout string
err := rows.Scan(&callout)
if err != nil {
return callouts, err
}
callouts = append(callouts, callout)
}
return callouts, nil
}
func DeleleOneCallout(ctx context.Context, c *Callout) error {
q, err := prepareStmt(
`DELETE FROM ` + calloutsTable + ` WHERE gid=? AND callout=? LIMIT 1`,
)
if err != nil {
return err
}
res, err := q.ExecContext(ctx, c.GID, c.Callout)
if err != nil {
return err
}
n, err := res.RowsAffected()
if err != nil {
return err
}
if n != 1 {
return ErrDelete
}
return nil
}