go-ssb-room/roomdb/sqlite/denied.go

152 lines
3.6 KiB
Go

// SPDX-FileCopyrightText: 2021 The NGI Pointer Secure-Scuttlebutt Team of 2020/2021
//
// SPDX-License-Identifier: MIT
package sqlite
import (
"context"
"database/sql"
"fmt"
"github.com/friendsofgo/errors"
"github.com/mattn/go-sqlite3"
"github.com/volatiletech/sqlboiler/v4/boil"
"github.com/volatiletech/sqlboiler/v4/queries/qm"
refs "github.com/ssbc/go-ssb-refs"
"github.com/ssbc/go-ssb-room/v2/roomdb"
"github.com/ssbc/go-ssb-room/v2/roomdb/sqlite/models"
)
// compiler assertion to ensure the struct fullfills the interface
var _ roomdb.DeniedKeysService = (*DeniedKeys)(nil)
// The DeniedKeys is backed by the members table
type DeniedKeys struct {
db *sql.DB
}
// Add adds the feed to the list.
func (dk DeniedKeys) Add(ctx context.Context, a refs.FeedRef, comment string) error {
// TODO: better valid
if _, err := refs.ParseFeedRef(a.String()); err != nil {
return err
}
var entry models.DeniedKey
entry.PubKey.FeedRef = a
entry.Comment = comment
err := entry.Insert(ctx, dk.db, boil.Whitelist("pub_key", "comment"))
if err != nil {
var sqlErr sqlite3.Error
if errors.As(err, &sqlErr) && sqlErr.ExtendedCode == sqlite3.ErrConstraintUnique {
return roomdb.ErrAlreadyAdded{Ref: a}
}
return fmt.Errorf("Denied-list: failed to insert new entry %s: %w - type:%T", entry.PubKey, err, err)
}
return nil
}
// HasFeed returns true if a feed is on the list.
func (dk DeniedKeys) HasFeed(ctx context.Context, h refs.FeedRef) bool {
_, err := models.DeniedKeys(qm.Where("pub_key = ?", h.String())).One(ctx, dk.db)
if err != nil {
return false
}
return true
}
// HasID returns true if a feed is on the list.
func (dk DeniedKeys) HasID(ctx context.Context, id int64) bool {
_, err := models.FindDeniedKey(ctx, dk.db, id)
if err != nil {
return false
}
return true
}
// GetByID returns the entry if a feed with that ID is on the list.
func (dk DeniedKeys) GetByID(ctx context.Context, id int64) (roomdb.ListEntry, error) {
var entry roomdb.ListEntry
found, err := models.FindDeniedKey(ctx, dk.db, id)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return entry, roomdb.ErrNotFound
}
return entry, err
}
entry.ID = found.ID
entry.PubKey = found.PubKey.FeedRef
entry.Comment = found.Comment
entry.CreatedAt = found.CreatedAt
return entry, nil
}
// List returns a list of all the feeds.
func (dk DeniedKeys) List(ctx context.Context) ([]roomdb.ListEntry, error) {
all, err := models.DeniedKeys().All(ctx, dk.db)
if err != nil {
return nil, err
}
n := len(all)
var lst = make([]roomdb.ListEntry, n)
for i, entry := range all {
lst[i].ID = entry.ID
lst[i].PubKey = entry.PubKey.FeedRef
lst[i].Comment = entry.Comment
lst[i].CreatedAt = entry.CreatedAt
}
return lst, nil
}
func (dk DeniedKeys) Count(ctx context.Context) (uint, error) {
count, err := models.DeniedKeys().Count(ctx, dk.db)
if err != nil {
return 0, err
}
return uint(count), nil
}
// RemoveFeed removes the feed from the list.
func (dk DeniedKeys) RemoveFeed(ctx context.Context, r refs.FeedRef) error {
entry, err := models.DeniedKeys(qm.Where("pub_key = ?", r.String())).One(ctx, dk.db)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return roomdb.ErrNotFound
}
return err
}
_, err = entry.Delete(ctx, dk.db)
if err != nil {
return err
}
return nil
}
// RemoveID removes the feed from the list.
func (dk DeniedKeys) RemoveID(ctx context.Context, id int64) error {
entry, err := models.FindDeniedKey(ctx, dk.db, id)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return roomdb.ErrNotFound
}
return err
}
_, err = entry.Delete(ctx, dk.db)
if err != nil {
return err
}
return nil
}