2017-10-29 22:06:41 +00:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/juju/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Session struct {
|
|
|
|
ID string `db:"id"`
|
|
|
|
UserID string `db:"user_id"`
|
|
|
|
CreatedAt time.Time `db:"created_at"`
|
|
|
|
ExpiresAt time.Time `db:"expires_at"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewSession(userID string) Session {
|
|
|
|
const ttl = 6 * 30 * 24 * time.Hour // 6 months
|
|
|
|
now := time.Now().UTC()
|
|
|
|
exp := now.Add(ttl)
|
|
|
|
|
|
|
|
return Session{
|
|
|
|
ID: newID(),
|
|
|
|
UserID: userID,
|
|
|
|
CreatedAt: now,
|
|
|
|
ExpiresAt: exp,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func FindSession(id string) (*Session, error) {
|
|
|
|
var s Session
|
|
|
|
err := db.Get(&s, "SELECT * FROM sessions WHERE id = ?", id)
|
|
|
|
if err != nil {
|
|
|
|
if err != sql.ErrNoRows {
|
|
|
|
return nil, errors.Annotate(err, "Failed to load session details")
|
|
|
|
}
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return &s, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s Session) Create() error {
|
|
|
|
_, err := db.NamedExec(`
|
2017-11-06 23:12:06 +00:00
|
|
|
INSERT INTO sessions (id, user_id, created_at, expires_at)
|
|
|
|
VALUES (:id, :user_id, :created_at, :expires_at)
|
|
|
|
`, s)
|
2017-10-29 22:06:41 +00:00
|
|
|
if err != nil {
|
|
|
|
return errors.Annotate(err, "Failed to create a session")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s Session) User() (*User, error) {
|
|
|
|
return FindUser(s.UserID)
|
|
|
|
}
|