-
Notifications
You must be signed in to change notification settings - Fork 376
/
replication.go
85 lines (71 loc) · 2.1 KB
/
replication.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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package main
import (
"context"
"flag"
"github.com/peterbourgon/ff/v3/ffcli"
"berty.tech/berty/v2/go/pkg/bertyprotocol"
)
func replicationServerCommand() *ffcli.Command {
fsBuilder := func() (*flag.FlagSet, error) {
fs := flag.NewFlagSet("berty share-invite", flag.ExitOnError)
manager.SetupLocalProtocolServerFlags(fs)
manager.SetupDefaultGRPCListenersFlags(fs)
// fs.StringVar(&pkStr, "pk", pkStr, "auth token sig pk")
// fs.StringVar(&secretStr, "secret", secretStr, "auth tokens secret")
return fs, nil
}
return &ffcli.Command{
Name: "repl-server",
ShortHelp: "replication server",
ShortUsage: "berty [global flags] repl-server [flags]",
FlagSetBuilder: fsBuilder,
Exec: func(ctx context.Context, args []string) error {
if len(args) > 0 {
return flag.ErrHelp
}
var err error
// if secret, err = base64.RawStdEncoding.DecodeString(secretStr); err != nil {
// return err
// }
//
// if pk, err = base64.RawStdEncoding.DecodeString(pkStr); err != nil {
// return err
// }
//
// if len(pk) != ed25519.PublicKeySize {
// return fmt.Errorf("invalid pk size")
// }
// man, err := bertyprotocol.NewAuthTokenVerifier(secret, pk)
// if err != nil {
// return err
// }
// TODO: add auth interceptor
// // grpc.UnaryInterceptor(grpc_auth.UnaryServerInterceptor(man.GRPCAuthInterceptor(bertyprotocol.ServiceReplicationID))),
server, mux, err := manager.GetGRPCServer()
if err != nil {
return err
}
logger, err := manager.GetLogger()
if err != nil {
return err
}
rootDS, err := manager.GetRootDatastore()
if err != nil {
return err
}
odb, err := manager.GetOrbitDB()
if err != nil {
return err
}
replicationService, err := bertyprotocol.NewReplicationService(ctx, rootDS, odb, logger)
if err != nil {
return err
}
bertyprotocol.RegisterReplicationServiceServer(server, replicationService)
if err := bertyprotocol.RegisterReplicationServiceHandlerServer(ctx, mux, replicationService); err != nil {
return err
}
return manager.RunWorkers()
},
}
}