-
Notifications
You must be signed in to change notification settings - Fork 86
/
Copy pathserver.go
52 lines (42 loc) · 1.03 KB
/
server.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package server
import (
"context"
"sync"
"github.com/gofrs/uuid"
usersv1 "github.com/johanbrandhorst/grpc-gateway-boilerplate/proto/users/v1"
)
// Backend implements the protobuf interface
type Backend struct {
mu *sync.RWMutex
users []*usersv1.User
}
// New initializes a new Backend struct.
func New() *Backend {
return &Backend{
mu: &sync.RWMutex{},
}
}
// AddUser adds a user to the in-memory store.
func (b *Backend) AddUser(ctx context.Context, _ *usersv1.AddUserRequest) (*usersv1.AddUserResponse, error) {
b.mu.Lock()
defer b.mu.Unlock()
user := &usersv1.User{
Id: uuid.Must(uuid.NewV4()).String(),
}
b.users = append(b.users, user)
return &usersv1.AddUserResponse{
User: user,
}, nil
}
// ListUsers lists all users in the store.
func (b *Backend) ListUsers(_ *usersv1.ListUsersRequest, srv usersv1.UserService_ListUsersServer) error {
b.mu.RLock()
defer b.mu.RUnlock()
for _, user := range b.users {
err := srv.Send(&usersv1.ListUsersResponse{User: user})
if err != nil {
return err
}
}
return nil
}