Fetch the repository succeeded.
/*
* @Descripttion:
* @version:
* @Author: congsir
* @Date: 2022-01-05 12:13:37
* @LastEditors: Please set LastEditors
* @LastEditTime: 2022-01-18 17:59:37
*/
package dbops
import (
"database/sql"
"log"
"strconv"
"sync"
"gitee.com/shanghaitech-university-codec_0/video_server/api/defs"
)
func InsertSession(sid string, ttl int64, uname string) error {
ttlstr := strconv.FormatInt(ttl, 10)
stmtIns, err := dbConn.Prepare("INSERT INTO sessions (session_id, TTL, login_name) VALUES (?, ?, ?)")
if err != nil {
return err
}
_, err = stmtIns.Exec(sid, ttlstr, uname)
if err != nil {
return err
}
defer stmtIns.Close()
return nil
}
func RetrieveSession(sid string) (*defs.SimpleSession, error) {
ss := &defs.SimpleSession{}
stmtOut, err := dbConn.Prepare("SELECT TTL, login_name FROM sessions WHERE session_id=?")
if err != nil {
return nil, err
}
var ttl string
var uname string
stmtOut.QueryRow(sid).Scan(&ttl, &uname)
if err != nil && err != sql.ErrNoRows {
return nil, err
}
if res, err := strconv.ParseInt(ttl, 10, 64); err == nil {
ss.TTL = res
ss.Username = uname
} else {
return nil, err
}
defer stmtOut.Close()
return ss, nil
}
func RetrieveAllSessions() (*sync.Map, error) {
m := &sync.Map{}
stmtOut, err := dbConn.Prepare("SELECT * FROM sessions")
if err != nil {
log.Printf("%s", err)
return nil, err
}
rows, err := stmtOut.Query()
if err != nil {
log.Printf("%s", err)
return nil, err
}
for rows.Next() {
var id string
var ttlstr string
var login_name string
if er := rows.Scan(&id, &ttlstr, &login_name); er != nil {
log.Printf("retrive sessions error: %s", er)
break
}
if ttl, err1 := strconv.ParseInt(ttlstr, 10, 64); err1 == nil {
ss := &defs.SimpleSession{Username: login_name, TTL: ttl}
m.Store(id, ss)
log.Printf(" session id: %s, ttl: %d", id, ss.TTL)
}
}
return m, nil
}
func DeleteSession(sid string) error {
stmtOut, err := dbConn.Prepare("DELETE FROM sessions WHERE session_id = ?")
if err != nil {
log.Printf("%s", err)
return err
}
if _, err := stmtOut.Query(sid); err != nil {
return err
}
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。