Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
32c4f70a
Commit
32c4f70a
authored
Dec 19, 2018
by
Ahmad Hassan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Followups on review
parent
c1ed498f
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
40 additions
and
45 deletions
+40
-45
changelogs/unreleased/support-gitaly-tls.yml
changelogs/unreleased/support-gitaly-tls.yml
+1
-1
doc/administration/gitaly/index.md
doc/administration/gitaly/index.md
+4
-4
lib/gitlab/gitaly_client.rb
lib/gitlab/gitaly_client.rb
+13
-17
spec/lib/gitlab/gitaly_client_spec.rb
spec/lib/gitlab/gitaly_client_spec.rb
+22
-23
No files found.
changelogs/unreleased/support-gitaly-tls.yml
View file @
32c4f70a
...
@@ -2,4 +2,4 @@
...
@@ -2,4 +2,4 @@
title
:
Support tls communication in gitaly
title
:
Support tls communication in gitaly
merge_request
:
22602
merge_request
:
22602
author
:
author
:
type
:
chang
ed
type
:
add
ed
doc/administration/gitaly/index.md
View file @
32c4f70a
...
@@ -228,8 +228,8 @@ Omnibus installations:
...
@@ -228,8 +228,8 @@ Omnibus installations:
```
ruby
```
ruby
# /etc/gitlab/gitlab.rb
# /etc/gitlab/gitlab.rb
git_data_dirs
({
git_data_dirs
({
'default'
=>
{
'path'
=>
'/mnt/gitlab/default'
,
'gitaly_address'
=>
'tls://gitaly.internal:
8075
'
},
'default'
=>
{
'path'
=>
'/mnt/gitlab/default'
,
'gitaly_address'
=>
'tls://gitaly.internal:
9999
'
},
'storage1'
=>
{
'path'
=>
'/mnt/gitlab/storage1'
,
'gitaly_address'
=>
'tls://gitaly.internal:
8075
'
},
'storage1'
=>
{
'path'
=>
'/mnt/gitlab/storage1'
,
'gitaly_address'
=>
'tls://gitaly.internal:
9999
'
},
})
})
gitlab_rails
[
'gitaly_token'
]
=
'abc123secret'
gitlab_rails
[
'gitaly_token'
]
=
'abc123secret'
...
@@ -244,10 +244,10 @@ gitlab:
...
@@ -244,10 +244,10 @@ gitlab:
storages
:
storages
:
default
:
default
:
path
:
/mnt/gitlab/default/repositories
path
:
/mnt/gitlab/default/repositories
gitaly_address
:
tls://gitaly.internal:
8075
gitaly_address
:
tls://gitaly.internal:
9999
storage1
:
storage1
:
path
:
/mnt/gitlab/storage1/repositories
path
:
/mnt/gitlab/storage1/repositories
gitaly_address
:
tls://gitaly.internal:
8075
gitaly_address
:
tls://gitaly.internal:
9999
gitaly
:
gitaly
:
token
:
'
abc123secret'
token
:
'
abc123secret'
...
...
lib/gitlab/gitaly_client.rb
View file @
32c4f70a
...
@@ -26,7 +26,7 @@ module Gitlab
...
@@ -26,7 +26,7 @@ module Gitlab
end
end
end
end
PEM_RE
XP
=
/[-]+BEGIN CERTIFICATE[-]+.+?[-]+END CERTIFICATE[-]
+/m
PEM_RE
GEX
=
/\-+BEGIN CERTIFICATE\-+.+?\-+END CERTIFICATE\-
+/m
SERVER_VERSION_FILE
=
'GITALY_SERVER_VERSION'
SERVER_VERSION_FILE
=
'GITALY_SERVER_VERSION'
MAXIMUM_GITALY_CALLS
=
35
MAXIMUM_GITALY_CALLS
=
35
CLIENT_NAME
=
(
Sidekiq
.
server?
?
'gitlab-sidekiq'
:
'gitlab-web'
).
freeze
CLIENT_NAME
=
(
Sidekiq
.
server?
?
'gitlab-sidekiq'
:
'gitlab-web'
).
freeze
...
@@ -57,29 +57,27 @@ module Gitlab
...
@@ -57,29 +57,27 @@ module Gitlab
end
end
end
end
def
self
.
certs
def
self
.
stub_
certs
return
@certs
if
@certs
return
@certs
if
@certs
cert_paths
=
Dir
[
"
#{
OpenSSL
::
X509
::
DEFAULT_CERT_DIR
}
/*"
]
cert_paths
=
Dir
[
"
#{
OpenSSL
::
X509
::
DEFAULT_CERT_DIR
}
/*"
]
cert_paths
<<
OpenSSL
::
X509
::
DEFAULT_CERT_FILE
if
File
.
exist?
OpenSSL
::
X509
::
DEFAULT_CERT_FILE
cert_paths
<<
OpenSSL
::
X509
::
DEFAULT_CERT_FILE
if
File
.
exist?
OpenSSL
::
X509
::
DEFAULT_CERT_FILE
@certs
=
[]
@certs
=
cert_paths
.
flat_map
do
|
cert_file
|
cert_paths
.
each
do
|
cert_file
|
File
.
read
(
cert_file
).
scan
(
PEM_REGEX
).
map
do
|
cert
|
begin
begin
File
.
read
(
cert_file
).
scan
(
PEM_REXP
).
each
do
|
cert
|
OpenSSL
::
X509
::
Certificate
.
new
(
cert
).
to_pem
pem
=
OpenSSL
::
X509
::
Certificate
.
new
(
cert
).
to_pem
rescue
OpenSSL
::
OpenSSLError
=>
e
@certs
<<
pem
Rails
.
logger
.
error
"Could not load certificate
#{
cert_file
}
#{
e
}
"
nil
end
end
rescue
StandardError
=>
e
end
.
compact
Rails
.
logger
.
error
"Could not load certificate
#{
e
}
"
end
.
uniq
.
join
(
"
\n
"
)
end
end
@certs
=
@certs
.
uniq
.
join
"
\n
"
end
end
def
self
.
stub_creds
(
storage
)
def
self
.
stub_creds
(
storage
)
if
URI
(
address
(
storage
)).
scheme
==
'tls'
if
URI
(
address
(
storage
)).
scheme
==
'tls'
GRPC
::
Core
::
ChannelCredentials
.
new
certs
GRPC
::
Core
::
ChannelCredentials
.
new
stub_
certs
else
else
:this_channel_is_insecure
:this_channel_is_insecure
end
end
...
@@ -94,9 +92,7 @@ module Gitlab
...
@@ -94,9 +92,7 @@ module Gitlab
end
end
def
self
.
stub_address
(
storage
)
def
self
.
stub_address
(
storage
)
addr
=
address
(
storage
)
address
(
storage
).
sub
(
%r{^tcp://|^tls://}
,
''
)
addr
=
addr
.
sub
(
%r{^tcp://|^tls://}
,
''
)
if
%w(tcp tls)
.
include?
URI
(
addr
).
scheme
addr
end
end
def
self
.
clear_stubs!
def
self
.
clear_stubs!
...
...
spec/lib/gitlab/gitaly_client_spec.rb
View file @
32c4f70a
...
@@ -3,6 +3,12 @@ require 'spec_helper'
...
@@ -3,6 +3,12 @@ require 'spec_helper'
# We stub Gitaly in `spec/support/gitaly.rb` for other tests. We don't want
# We stub Gitaly in `spec/support/gitaly.rb` for other tests. We don't want
# those stubs while testing the GitalyClient itself.
# those stubs while testing the GitalyClient itself.
describe
Gitlab
::
GitalyClient
do
describe
Gitlab
::
GitalyClient
do
def
stub_repos_storages
(
address
)
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
'default'
=>
{
'gitaly_address'
=>
address
}
})
end
describe
'.stub_class'
do
describe
'.stub_class'
do
it
'returns the gRPC health check stub'
do
it
'returns the gRPC health check stub'
do
expect
(
described_class
.
stub_class
(
:health_check
)).
to
eq
(
::
Grpc
::
Health
::
V1
::
Health
::
Stub
)
expect
(
described_class
.
stub_class
(
:health_check
)).
to
eq
(
::
Grpc
::
Health
::
V1
::
Health
::
Stub
)
...
@@ -15,12 +21,8 @@ describe Gitlab::GitalyClient do
...
@@ -15,12 +21,8 @@ describe Gitlab::GitalyClient do
describe
'.stub_address'
do
describe
'.stub_address'
do
it
'returns the same result after being called multiple times'
do
it
'returns the same result after being called multiple times'
do
address
=
'localhost:9876'
address
=
'tcp://localhost:9876'
prefixed_address
=
"tcp://
#{
address
}
"
stub_repos_storages
address
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
'default'
=>
{
'gitaly_address'
=>
prefixed_address
}
})
2
.
times
do
2
.
times
do
expect
(
described_class
.
stub_address
(
'default'
)).
to
eq
(
'localhost:9876'
)
expect
(
described_class
.
stub_address
(
'default'
)).
to
eq
(
'localhost:9876'
)
...
@@ -29,19 +31,24 @@ describe Gitlab::GitalyClient do
...
@@ -29,19 +31,24 @@ describe Gitlab::GitalyClient do
end
end
describe
'.stub_creds'
do
describe
'.stub_creds'
do
it
'returns :this_channel_is_insecure if unix'
do
address
=
'unix:/tmp/gitaly.sock'
stub_repos_storages
address
expect
(
described_class
.
stub_creds
(
'default'
)).
to
eq
(
:this_channel_is_insecure
)
end
it
'returns :this_channel_is_insecure if tcp'
do
it
'returns :this_channel_is_insecure if tcp'
do
address
=
'tcp://localhost:9876'
address
=
'tcp://localhost:9876'
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
stub_repos_storages
address
'default'
=>
{
'gitaly_address'
=>
address
}
})
expect
(
described_class
.
stub_creds
(
'default'
)).
to
eq
(
:this_channel_is_insecure
)
expect
(
described_class
.
stub_creds
(
'default'
)).
to
eq
(
:this_channel_is_insecure
)
end
end
it
'returns Credentials object if tls'
do
it
'returns Credentials object if tls'
do
address
=
'tls://localhost:9876'
address
=
'tls://localhost:9876'
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
stub_repos_storages
address
'default'
=>
{
'gitaly_address'
=>
address
}
})
expect
(
described_class
.
stub_creds
(
'default'
)).
to
be_a
(
GRPC
::
Core
::
ChannelCredentials
)
expect
(
described_class
.
stub_creds
(
'default'
)).
to
be_a
(
GRPC
::
Core
::
ChannelCredentials
)
end
end
end
end
...
@@ -55,9 +62,7 @@ describe Gitlab::GitalyClient do
...
@@ -55,9 +62,7 @@ describe Gitlab::GitalyClient do
context
'when passed a UNIX socket address'
do
context
'when passed a UNIX socket address'
do
it
'passes the address as-is to GRPC'
do
it
'passes the address as-is to GRPC'
do
address
=
'unix:/tmp/gitaly.sock'
address
=
'unix:/tmp/gitaly.sock'
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
stub_repos_storages
address
'default'
=>
{
'gitaly_address'
=>
address
}
})
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
...
@@ -69,10 +74,7 @@ describe Gitlab::GitalyClient do
...
@@ -69,10 +74,7 @@ describe Gitlab::GitalyClient do
it
'strips tls:// prefix before passing it to GRPC::Core::Channel initializer'
do
it
'strips tls:// prefix before passing it to GRPC::Core::Channel initializer'
do
address
=
'localhost:9876'
address
=
'localhost:9876'
prefixed_address
=
"tls://
#{
address
}
"
prefixed_address
=
"tls://
#{
address
}
"
stub_repos_storages
prefixed_address
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
'default'
=>
{
'gitaly_address'
=>
prefixed_address
}
})
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
...
@@ -84,10 +86,7 @@ describe Gitlab::GitalyClient do
...
@@ -84,10 +86,7 @@ describe Gitlab::GitalyClient do
it
'strips tcp:// prefix before passing it to GRPC::Core::Channel initializer'
do
it
'strips tcp:// prefix before passing it to GRPC::Core::Channel initializer'
do
address
=
'localhost:9876'
address
=
'localhost:9876'
prefixed_address
=
"tcp://
#{
address
}
"
prefixed_address
=
"tcp://
#{
address
}
"
stub_repos_storages
prefixed_address
allow
(
Gitlab
.
config
.
repositories
).
to
receive
(
:storages
).
and_return
({
'default'
=>
{
'gitaly_address'
=>
prefixed_address
}
})
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
expect
(
Gitaly
::
CommitService
::
Stub
).
to
receive
(
:new
).
with
(
address
,
any_args
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment