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// AccessLevel implements backend.AccessMethod
25func (*Noop) AccessLevel(repo string, pk ssh.PublicKey) backend.AccessLevel {
26 return backend.AdminAccess
27}
28
29// AddAdmin implements backend.Backend
30func (*Noop) AddAdmin(pk ssh.PublicKey) error {
31 return ErrNotImpl
32}
33
34// AddCollaborator implements backend.Backend
35func (*Noop) AddCollaborator(pk ssh.PublicKey, repo string) error {
36 return ErrNotImpl
37}
38
39// AllowKeyless implements backend.Backend
40func (*Noop) AllowKeyless() bool {
41 return true
42}
43
44// AnonAccess implements backend.Backend
45func (*Noop) AnonAccess() backend.AccessLevel {
46 return backend.AdminAccess
47}
48
49// CreateRepository implements backend.Backend
50func (*Noop) CreateRepository(name string, private bool) (backend.Repository, error) {
51 temp, err := os.MkdirTemp("", "soft-serve")
52 if err != nil {
53 return nil, err
54 }
55
56 rp := filepath.Join(temp, name)
57 _, err = git.Init(rp, private)
58 if err != nil {
59 return nil, err
60 }
61
62 return &repo{path: rp}, nil
63}
64
65// DeleteRepository implements backend.Backend
66func (*Noop) DeleteRepository(name string) error {
67 return ErrNotImpl
68}
69
70// Description implements backend.Backend
71func (*Noop) Description(repo string) string {
72 return ""
73}
74
75// IsAdmin implements backend.Backend
76func (*Noop) IsAdmin(pk ssh.PublicKey) bool {
77 return true
78}
79
80// IsCollaborator implements backend.Backend
81func (*Noop) IsCollaborator(pk ssh.PublicKey, repo string) bool {
82 return true
83}
84
85// IsPrivate implements backend.Backend
86func (*Noop) IsPrivate(repo string) bool {
87 return false
88}
89
90// RenameRepository implements backend.Backend
91func (*Noop) RenameRepository(oldName string, newName string) error {
92 return ErrNotImpl
93}
94
95// Repositories implements backend.Backend
96func (*Noop) Repositories() ([]backend.Repository, error) {
97 return nil, ErrNotImpl
98}
99
100// Repository implements backend.Backend
101func (*Noop) Repository(repo string) (backend.Repository, error) {
102 return nil, ErrNotImpl
103}
104
105// ServerHost implements backend.Backend
106func (*Noop) ServerHost() string {
107 return "localhost"
108}
109
110// ServerName implements backend.Backend
111func (*Noop) ServerName() string {
112 return "Soft Serve"
113}
114
115// ServerPort implements backend.Backend
116func (n *Noop) ServerPort() string {
117 return n.Port
118}
119
120// SetAllowKeyless implements backend.Backend
121func (*Noop) SetAllowKeyless(allow bool) error {
122 return ErrNotImpl
123}
124
125// SetAnonAccess implements backend.Backend
126func (*Noop) SetAnonAccess(level backend.AccessLevel) error {
127 return ErrNotImpl
128}
129
130// SetDescription implements backend.Backend
131func (*Noop) SetDescription(repo string, desc string) error {
132 return ErrNotImpl
133}
134
135// SetPrivate implements backend.Backend
136func (*Noop) SetPrivate(repo string, priv bool) error {
137 return ErrNotImpl
138}
139
140// SetServerHost implements backend.Backend
141func (*Noop) SetServerHost(host string) error {
142 return ErrNotImpl
143}
144
145// SetServerName implements backend.Backend
146func (*Noop) SetServerName(name string) error {
147 return ErrNotImpl
148}
149
150// SetServerPort implements backend.Backend
151func (*Noop) SetServerPort(port string) error {
152 return ErrNotImpl
153}