Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
李少辉-开发者
gitlab-foss
提交
795cd7f9
G
gitlab-foss
项目概览
李少辉-开发者
/
gitlab-foss
通知
15
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
gitlab-foss
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
795cd7f9
编写于
4月 23, 2018
作者:
J
James Edwards-Jones
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Replace define_method with alias_method in Omniauth Controllers
上级
d3a8a074
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
12 addition
and
16 deletion
+12
-16
app/controllers/ldap/omniauth_callbacks_controller.rb
app/controllers/ldap/omniauth_callbacks_controller.rb
+6
-8
app/controllers/omniauth_callbacks_controller.rb
app/controllers/omniauth_callbacks_controller.rb
+5
-7
lib/gitlab/auth/ldap/user.rb
lib/gitlab/auth/ldap/user.rb
+1
-1
未找到文件。
app/controllers/ldap/omniauth_callbacks_controller.rb
浏览文件 @
795cd7f9
...
...
@@ -2,23 +2,21 @@ class Ldap::OmniauthCallbacksController < OmniauthCallbacksController
extend
::
Gitlab
::
Utils
::
Override
def
self
.
define_providers!
if
Gitlab
::
Auth
::
LDAP
::
Config
.
enabled?
Gitlab
::
Auth
::
LDAP
::
Config
.
available_servers
.
each
do
|
server
|
define_method
server
[
'provider_name'
]
do
ldap
end
end
return
unless
Gitlab
::
Auth
::
LDAP
::
Config
.
enabled?
Gitlab
::
Auth
::
LDAP
::
Config
.
available_servers
.
each
do
|
server
|
alias_method
server
[
'provider_name'
],
:ldap
end
end
define_providers!
# We only find ourselves here
# if the authentication to LDAP was successful.
def
ldap
sign_in_user_flow
(
Gitlab
::
Auth
::
LDAP
::
User
)
end
define_providers!
override
:set_remember_me
def
set_remember_me
(
user
)
user
.
remember_me
=
params
[
:remember_me
]
if
user
.
persisted?
...
...
app/controllers/omniauth_callbacks_controller.rb
浏览文件 @
795cd7f9
...
...
@@ -4,10 +4,12 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
protect_from_forgery
except:
[
:kerberos
,
:saml
,
:cas3
]
def
handle_omniauth
omniauth_flow
(
Gitlab
::
Auth
::
OAuth
)
end
Gitlab
.
config
.
omniauth
.
providers
.
each
do
|
provider
|
define_method
provider
[
'name'
]
do
handle_omniauth
end
alias_method
provider
[
'name'
],
:handle_omniauth
end
# Extend the standard implementation to also increment
...
...
@@ -70,10 +72,6 @@ class OmniauthCallbacksController < Devise::OmniauthCallbacksController
private
def
handle_omniauth
omniauth_flow
(
Gitlab
::
Auth
::
OAuth
)
end
def
omniauth_flow
(
auth_module
,
identity_linker:
nil
)
if
current_user
log_audit_event
(
current_user
,
with:
oauth
[
'provider'
])
...
...
lib/gitlab/auth/ldap/user.rb
浏览文件 @
795cd7f9
...
...
@@ -49,7 +49,7 @@ module Gitlab
end
def
valid_sign_in?
allowed?
allowed?
&&
super
end
def
ldap_config
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录