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
|
package repository
import (
"gitlab.com/gitlab-org/gitaly/v14/client"
"gitlab.com/gitlab-org/gitaly/v14/internal/git"
"gitlab.com/gitlab-org/gitaly/v14/internal/git/catfile"
"gitlab.com/gitlab-org/gitaly/v14/internal/git/localrepo"
"gitlab.com/gitlab-org/gitaly/v14/internal/git/repository"
"gitlab.com/gitlab-org/gitaly/v14/internal/gitaly/config"
"gitlab.com/gitlab-org/gitaly/v14/internal/gitaly/rubyserver"
"gitlab.com/gitlab-org/gitaly/v14/internal/gitaly/transaction"
"gitlab.com/gitlab-org/gitaly/v14/internal/storage"
"gitlab.com/gitlab-org/gitaly/v14/proto/go/gitalypb"
)
type server struct {
ruby *rubyserver.Server
conns *client.Pool
locator storage.Locator
txManager transaction.Manager
gitCmdFactory git.CommandFactory
cfg config.Cfg
binDir string
loggingCfg config.Logging
catfileCache catfile.Cache
}
// NewServer creates a new instance of a gRPC repo server
func NewServer(
cfg config.Cfg,
rs *rubyserver.Server,
locator storage.Locator,
txManager transaction.Manager,
gitCmdFactory git.CommandFactory,
catfileCache catfile.Cache,
) gitalypb.RepositoryServiceServer {
return &server{
ruby: rs,
locator: locator,
txManager: txManager,
gitCmdFactory: gitCmdFactory,
conns: client.NewPoolWithOptions(
client.WithDialer(client.HealthCheckDialer(client.DialContext)),
client.WithDialOptions(client.FailOnNonTempDialError()...),
),
cfg: cfg,
binDir: cfg.BinDir,
loggingCfg: cfg.Logging,
catfileCache: catfileCache,
}
}
func (s *server) localrepo(repo repository.GitRepo) *localrepo.Repo {
return localrepo.New(s.gitCmdFactory, s.catfileCache, repo, s.cfg)
}
|