1package noop
  2
  3import (
  4	"fmt"
  5	"os"
  6	"path/filepath"
  7
  8	"github.com/charmbracelet/soft-serve/git"
  9	"github.com/charmbracelet/soft-serve/server/backend"
 10	"golang.org/x/crypto/ssh"
 11)
 12
 13var ErrNotImpl = fmt.Errorf("not implemented")
 14
 15var _ backend.Backend = (*Noop)(nil)
 16
 17var _ backend.AccessMethod = (*Noop)(nil)
 18
 19// Noop is a backend that does nothing. It's used for testing.
 20type Noop struct {
 21	Port string
 22}
 23
 24// RepositoryStorePath implements backend.Backend
 25func (*Noop) RepositoryStorePath() string {
 26	return ""
 27}
 28
 29// Admins implements backend.Backend
 30func (*Noop) Admins() ([]string, error) {
 31	return nil, nil
 32}
 33
 34// Collaborators implements backend.Backend
 35func (*Noop) Collaborators(repo string) ([]string, error) {
 36	return nil, nil
 37}
 38
 39// RemoveAdmin implements backend.Backend
 40func (*Noop) RemoveAdmin(pk ssh.PublicKey) error {
 41	return nil
 42}
 43
 44// RemoveCollaborator implements backend.Backend
 45func (*Noop) RemoveCollaborator(pk ssh.PublicKey, repo string) error {
 46	return nil
 47}
 48
 49// AccessLevel implements backend.AccessMethod
 50func (*Noop) AccessLevel(repo string, pk ssh.PublicKey) backend.AccessLevel {
 51	return backend.AdminAccess
 52}
 53
 54// AddAdmin implements backend.Backend
 55func (*Noop) AddAdmin(pk ssh.PublicKey, memo string) error {
 56	return ErrNotImpl
 57}
 58
 59// AddCollaborator implements backend.Backend
 60func (*Noop) AddCollaborator(pk ssh.PublicKey, memo string, repo string) error {
 61	return ErrNotImpl
 62}
 63
 64// AllowKeyless implements backend.Backend
 65func (*Noop) AllowKeyless() bool {
 66	return true
 67}
 68
 69// AnonAccess implements backend.Backend
 70func (*Noop) AnonAccess() backend.AccessLevel {
 71	return backend.AdminAccess
 72}
 73
 74// CreateRepository implements backend.Backend
 75func (*Noop) CreateRepository(name string, private bool) (backend.Repository, error) {
 76	temp, err := os.MkdirTemp("", "soft-serve")
 77	if err != nil {
 78		return nil, err
 79	}
 80
 81	rp := filepath.Join(temp, name)
 82	_, err = git.Init(rp, private)
 83	if err != nil {
 84		return nil, err
 85	}
 86
 87	return &repo{path: rp}, nil
 88}
 89
 90// DeleteRepository implements backend.Backend
 91func (*Noop) DeleteRepository(name string) error {
 92	return ErrNotImpl
 93}
 94
 95// Description implements backend.Backend
 96func (*Noop) Description(repo string) string {
 97	return ""
 98}
 99
100// IsAdmin implements backend.Backend
101func (*Noop) IsAdmin(pk ssh.PublicKey) bool {
102	return true
103}
104
105// IsCollaborator implements backend.Backend
106func (*Noop) IsCollaborator(pk ssh.PublicKey, repo string) bool {
107	return true
108}
109
110// IsPrivate implements backend.Backend
111func (*Noop) IsPrivate(repo string) bool {
112	return false
113}
114
115// RenameRepository implements backend.Backend
116func (*Noop) RenameRepository(oldName string, newName string) error {
117	return ErrNotImpl
118}
119
120// Repositories implements backend.Backend
121func (*Noop) Repositories() ([]backend.Repository, error) {
122	return nil, ErrNotImpl
123}
124
125// Repository implements backend.Backend
126func (*Noop) Repository(repo string) (backend.Repository, error) {
127	return nil, ErrNotImpl
128}
129
130// SetAllowKeyless implements backend.Backend
131func (*Noop) SetAllowKeyless(allow bool) error {
132	return ErrNotImpl
133}
134
135// SetAnonAccess implements backend.Backend
136func (*Noop) SetAnonAccess(level backend.AccessLevel) error {
137	return ErrNotImpl
138}
139
140// SetDescription implements backend.Backend
141func (*Noop) SetDescription(repo string, desc string) error {
142	return ErrNotImpl
143}
144
145// SetPrivate implements backend.Backend
146func (*Noop) SetPrivate(repo string, priv bool) error {
147	return ErrNotImpl
148}