mirror of
https://github.com/aclindsa/moneygo.git
synced 2024-12-28 00:02:29 -05:00
43 lines
933 B
Go
43 lines
933 B
Go
package db
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/aclindsa/moneygo/internal/models"
|
|
"time"
|
|
)
|
|
|
|
func (tx *Tx) InsertSession(session *models.Session) error {
|
|
return tx.Insert(session)
|
|
}
|
|
|
|
func (tx *Tx) GetSession(secret string) (*models.Session, error) {
|
|
var s models.Session
|
|
|
|
err := tx.SelectOne(&s, "SELECT * from sessions where SessionSecret=?", secret)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if s.Expires.Before(time.Now()) {
|
|
tx.Delete(&s)
|
|
return nil, fmt.Errorf("Session has expired")
|
|
}
|
|
return &s, nil
|
|
}
|
|
|
|
func (tx *Tx) SessionExists(secret string) (bool, error) {
|
|
existing, err := tx.SelectInt("SELECT count(*) from sessions where SessionSecret=?", secret)
|
|
return existing != 0, err
|
|
}
|
|
|
|
func (tx *Tx) DeleteSession(session *models.Session) error {
|
|
count, err := tx.Delete(session)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if count != 1 {
|
|
return fmt.Errorf("Expected to delete 1 user, was going to delete %d", count)
|
|
}
|
|
return nil
|
|
}
|