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
2c2bb5dd
Commit
2c2bb5dd
authored
Jul 04, 2016
by
Stan Hu
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '723-lazy-load-krb5_auth-gem' into 'master'
Lazy-load the krb5_auth gem Closes #723. See merge request !520
parents
e3de18ab
b84baef6
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
20 additions
and
12 deletions
+20
-12
lib/gitlab/kerberos/authentication.rb
lib/gitlab/kerberos/authentication.rb
+10
-5
spec/lib/gitlab/kerberos/authentication_spec.rb
spec/lib/gitlab/kerberos/authentication_spec.rb
+10
-7
No files found.
lib/gitlab/kerberos/authentication.rb
View file @
2c2bb5dd
require
"krb5_auth"
# This calls helps to authenticate to Kerberos by providing username and password
# This calls helps to authenticate to Kerberos by providing username and password
module
Gitlab
module
Gitlab
module
Kerberos
module
Kerberos
class
Authentication
class
Authentication
def
self
.
kerberos_default_realm
def
self
.
kerberos_default_realm
krb5
=
::
Krb5Auth
::
Krb5
.
new
krb5
=
krb5_class
.
new
default_realm
=
krb5
.
get_default_realm
default_realm
=
krb5
.
get_default_realm
krb5
.
close
# release memory allocated by the krb5 library
krb5
.
close
# release memory allocated by the krb5 library
default_realm
default_realm
...
@@ -19,15 +17,22 @@ module Gitlab
...
@@ -19,15 +17,22 @@ module Gitlab
auth
.
login
auth
.
login
end
end
def
self
.
krb5_class
@krb5_class
||=
begin
require
"krb5_auth"
Krb5Auth
::
Krb5
end
end
def
initialize
(
login
,
password
)
def
initialize
(
login
,
password
)
@login
=
login
@login
=
login
@password
=
password
@password
=
password
@krb5
=
::
Krb5Auth
::
Krb5
.
new
@krb5
=
self
.
class
.
krb5_class
.
new
end
end
def
valid?
def
valid?
@krb5
.
get_init_creds_password
(
@login
,
@password
)
@krb5
.
get_init_creds_password
(
@login
,
@password
)
rescue
::
Krb5Auth
::
Krb5
::
Exception
rescue
self
.
class
.
krb5_class
::
Exception
false
false
end
end
...
...
spec/lib/gitlab/kerberos/authentication_spec.rb
View file @
2c2bb5dd
require
'spec_helper'
require
'spec_helper'
describe
Gitlab
::
Kerberos
::
Authentication
do
describe
Gitlab
::
Kerberos
::
Authentication
do
let
(
:klass
)
{
Gitlab
::
Kerberos
::
Authentication
}
let
(
:user
)
{
create
(
:omniauth_user
,
provider: :kerberos
,
extern_uid:
'gitlab@FOO.COM'
)
}
let
(
:user
)
{
create
(
:omniauth_user
,
provider: :kerberos
,
extern_uid:
'gitlab@FOO.COM'
)
}
let
(
:login
)
{
'john'
}
let
(
:login
)
{
'john'
}
let
(
:password
)
{
'password'
}
let
(
:password
)
{
'password'
}
describe
:kerberos_default_realm
do
before
do
described_class
.
krb5_class
# eager load the krb5_auth gem
end
describe
'.kerberos_default_realm'
do
it
"returns the default realm exposed by the Kerberos library"
do
it
"returns the default realm exposed by the Kerberos library"
do
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_default_realm:
"FOO.COM"
)
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_default_realm:
"FOO.COM"
)
expect
(
k
lass
.
kerberos_default_realm
).
to
eq
(
"FOO.COM"
)
expect
(
described_c
lass
.
kerberos_default_realm
).
to
eq
(
"FOO.COM"
)
end
end
end
end
describe
:login
do
describe
'.login'
do
before
do
before
do
allow
(
Devise
).
to
receive_messages
(
omniauth_providers:
[
:kerberos
])
allow
(
Devise
).
to
receive_messages
(
omniauth_providers:
[
:kerberos
])
user
# make sure user is instanciated
user
# make sure user is instanciated
...
@@ -23,20 +26,20 @@ describe Gitlab::Kerberos::Authentication do
...
@@ -23,20 +26,20 @@ describe Gitlab::Kerberos::Authentication do
it
"finds the user if authentication is successful (login without kerberos realm)"
do
it
"finds the user if authentication is successful (login without kerberos realm)"
do
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'gitlab@FOO.COM'
)
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'gitlab@FOO.COM'
)
expect
(
k
lass
.
login
(
'gitlab'
,
password
)).
to
be_truthy
expect
(
described_c
lass
.
login
(
'gitlab'
,
password
)).
to
be_truthy
end
end
it
"finds the user if authentication is successful (login with a kerberos realm)"
do
it
"finds the user if authentication is successful (login with a kerberos realm)"
do
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'gitlab@FOO.COM'
)
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'gitlab@FOO.COM'
)
expect
(
k
lass
.
login
(
'gitlab@FOO.COM'
,
password
)).
to
be_truthy
expect
(
described_c
lass
.
login
(
'gitlab@FOO.COM'
,
password
)).
to
be_truthy
end
end
it
"returns false if there is no such user in kerberos"
do
it
"returns false if there is no such user in kerberos"
do
kerberos_login
=
"some-login"
kerberos_login
=
"some-login"
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'some-login@FOO.COM'
)
allow_any_instance_of
(
::
Krb5Auth
::
Krb5
).
to
receive_messages
(
get_init_creds_password:
true
,
get_default_principal:
'some-login@FOO.COM'
)
expect
(
k
lass
.
login
(
kerberos_login
,
password
)).
to
be_falsy
expect
(
described_c
lass
.
login
(
kerberos_login
,
password
)).
to
be_falsy
end
end
end
end
end
end
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