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}