mercury/internal/database/sql/token.go
2023-09-04 03:33:13 +02:00

52 lines
1.6 KiB
Go

package sql
import (
"context"
"time"
"emperror.dev/errors"
"git.sleepycat.moe/sam/mercury/internal/database"
"github.com/keegancsmith/sqlf"
"github.com/oklog/ulid/v2"
)
// TokenStore is the interface to tokens in the database.
type TokenStore struct {
q Querier
}
// NewTokenStore creates a new TokenStore instance.
func NewTokenStore(q Querier) *TokenStore {
return &TokenStore{q: q}
}
func (s *TokenStore) Get(ctx context.Context, id ulid.ULID) (database.Token, error) {
q := sqlf.Sprintf("SELECT * FROM tokens WHERE id = %s", id)
t, err := Get[database.Token](ctx, s.q, q)
return t, errors.Wrap(err, "executing query")
}
func (s *TokenStore) GetApplication(ctx context.Context, id ulid.ULID) (database.Application, error) {
q := sqlf.Sprintf("SELECT * FROM applications WHERE id = %s", id)
app, err := Get[database.Application](ctx, s.q, q)
return app, errors.Wrap(err, "executing query")
}
func (s *TokenStore) Create(ctx context.Context, userID, appID ulid.ULID, scopes []string, expires time.Time) (database.Token, error) {
q := sqlf.Sprintf(`INSERT INTO tokens
(id, user_id, app_id, scopes, expires)
values (%s, %s, %s, %v, %v)
RETURNING *`, makeULID(), userID, appID, scopes, expires)
t, err := Get[database.Token](ctx, s.q, q)
return t, errors.Wrap(err, "executing query")
}
func (s *TokenStore) CreateApplication(ctx context.Context, name string) (database.Application, error) {
q := sqlf.Sprintf("INSERT INTO applications (id, name) VALUES (%s, %s) RETURNING *", makeULID(), name)
app, err := Get[database.Application](ctx, s.q, q)
return app, errors.Wrap(err, "executing query")
}