-
Notifications
You must be signed in to change notification settings - Fork 1
/
auth_keys_dao.go
executable file
·82 lines (70 loc) · 1.93 KB
/
auth_keys_dao.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
/*
* Copyright (c) 2018, https://github.com/airwide-code
* All rights reserved.
*
*
*
*/
package mysql_dao
import (
"fmt"
"github.com/golang/glog"
"github.com/jmoiron/sqlx"
"github.com/airwide-code/airwide.datacenter/access/auth_key/dal/dataobject"
)
type AuthKeysDAO struct {
db *sqlx.DB
}
func NewAuthKeysDAO(db *sqlx.DB) *AuthKeysDAO {
return &AuthKeysDAO{db}
}
// insert into auth_keys(auth_id, body) values (:auth_id, :body)
// TODO(@benqi): sqlmap
func (dao *AuthKeysDAO) Insert(do *dataobject.AuthKeysDO) (int64, error) {
var query = "insert into auth_keys(auth_id, body) values (:auth_id, :body)"
r, err := dao.db.NamedExec(query, do)
if err != nil {
errDesc := fmt.Sprintf("NamedExec in Insert(%v), error: %v", do, err)
glog.Error(errDesc)
return 0, err
}
id, err := r.LastInsertId()
if err != nil {
errDesc := fmt.Sprintf("LastInsertId in Insert(%v)_error: %v", do, err)
glog.Error(errDesc)
return 0, err
// panic(mtproto.NewRpcError(int32(mtproto.TLRpcErrorCodes_DBERR), errDesc))
}
return id, nil
}
// select body from auth_keys where auth_id = :auth_id
// TODO(@benqi): sqlmap
func (dao *AuthKeysDAO) SelectByAuthId(auth_id int64) (*dataobject.AuthKeysDO, error) {
var query = "select body from auth_keys where auth_id = ?"
rows, err := dao.db.Queryx(query, auth_id)
if err != nil {
errDesc := fmt.Sprintf("Queryx in SelectByAuthId(_), error: %v", err)
glog.Error(errDesc)
return nil, err
}
defer rows.Close()
do := &dataobject.AuthKeysDO{}
if rows.Next() {
err = rows.StructScan(do)
if err != nil {
errDesc := fmt.Sprintf("StructScan in SelectByAuthId(_), error: %v", err)
glog.Error(errDesc)
return nil, err
}
} else {
return nil, nil
}
err = rows.Err()
if err != nil {
errDesc := fmt.Sprintf("rows in SelectByAuthId(_), error: %v", err)
glog.Error(errDesc)
return nil, err
// panic(mtproto.NewRpcError(int32(mtproto.TLRpcErrorCodes_DBERR), errDesc))
}
return do, nil
}