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
dcc12505
Commit
dcc12505
authored
Jun 08, 2017
by
Michael Kozono
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Set `Net::LDAP` `ca_file` option
parent
b67c0078
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
45 additions
and
5 deletions
+45
-5
lib/gitlab/ldap/config.rb
lib/gitlab/ldap/config.rb
+15
-5
spec/lib/gitlab/ldap/config_spec.rb
spec/lib/gitlab/ldap/config_spec.rb
+30
-0
No files found.
lib/gitlab/ldap/config.rb
View file @
dcc12505
...
@@ -179,11 +179,21 @@ module Gitlab
...
@@ -179,11 +179,21 @@ module Gitlab
end
end
def
tls_options
(
method
)
def
tls_options
(
method
)
if
method
&&
options
[
'verify_certificates'
]
return
{
verify_mode:
OpenSSL
::
SSL
::
VERIFY_NONE
}
unless
method
opts
=
if
options
[
'verify_certificates'
]
OpenSSL
::
SSL
::
SSLContext
::
DEFAULT_PARAMS
OpenSSL
::
SSL
::
SSLContext
::
DEFAULT_PARAMS
else
else
# It is important to explicitly set verify_mode for two reasons:
# 1. The behavior of OpenSSL is undefined when verify_mode is not set.
# 2. The net-ldap gem implementation verifies the certificate hostname
# unless verify_mode is set to VERIFY_NONE.
{
verify_mode:
OpenSSL
::
SSL
::
VERIFY_NONE
}
{
verify_mode:
OpenSSL
::
SSL
::
VERIFY_NONE
}
end
end
opts
[
:ca_file
]
=
options
[
'ca_file'
]
if
options
[
'ca_file'
].
present?
opts
end
end
def
auth_options
def
auth_options
...
...
spec/lib/gitlab/ldap/config_spec.rb
View file @
dcc12505
...
@@ -138,6 +138,36 @@ describe Gitlab::LDAP::Config, lib: true do
...
@@ -138,6 +138,36 @@ describe Gitlab::LDAP::Config, lib: true do
})
})
end
end
end
end
context
'when ca_file is specified'
do
it
'passes it through in tls_options'
do
stub_ldap_config
(
options:
{
'host'
=>
'ldap.example.com'
,
'port'
=>
686
,
'encryption'
=>
'simple_tls'
,
'ca_file'
=>
'/etc/ca.pem'
}
)
expect
(
config
.
adapter_options
[
:encryption
][
:tls_options
]).
to
include
({
ca_file:
'/etc/ca.pem'
})
end
end
context
'when ca_file is a blank string'
do
it
'does not add the ca_file key to tls_options'
do
stub_ldap_config
(
options:
{
'host'
=>
'ldap.example.com'
,
'port'
=>
686
,
'encryption'
=>
'simple_tls'
,
'ca_file'
=>
' '
}
)
expect
(
config
.
adapter_options
[
:encryption
][
:tls_options
]).
not_to
have_key
(
:ca_file
)
end
end
end
end
describe
'#omniauth_options'
do
describe
'#omniauth_options'
do
...
...
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