Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
LinuxSuRen
jenkins
提交
86ec2a30
J
jenkins
项目概览
LinuxSuRen
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
86ec2a30
编写于
11月 28, 2011
作者:
K
Kohsuke Kawaguchi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[JENKINS-6651] inserting artificial lock in the hope that this will eliminate libpam crash.
上级
9140a2bf
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
21 deletion
+12
-21
core/src/main/java/hudson/security/PAMSecurityRealm.java
core/src/main/java/hudson/security/PAMSecurityRealm.java
+12
-21
未找到文件。
core/src/main/java/hudson/security/PAMSecurityRealm.java
浏览文件 @
86ec2a30
...
...
@@ -23,42 +23,33 @@
*/
package
hudson.security
;
import
groovy.lang.Binding
;
import
hudson.Extension
;
import
hudson.Functions
;
import
hudson.model.Descriptor
;
import
jenkins.model.Jenkins
;
import
hudson.Util
;
import
hudson.
Extension
;
import
hudson.
model.Descriptor
;
import
hudson.os.PosixAPI
;
import
hudson.util.FormValidation
;
import
hudson.util.spring.BeanBuilder
;
import
org.acegisecurity.Authentication
;
import
org.acegisecurity.AuthenticationException
;
import
org.acegisecurity.AuthenticationManager
;
import
org.acegisecurity.BadCredentialsException
;
import
org.acegisecurity.GrantedAuthority
;
import
org.acegisecurity.GrantedAuthorityImpl
;
import
org.acegisecurity.providers.AuthenticationProvider
;
import
org.acegisecurity.providers.UsernamePasswordAuthenticationToken
;
import
org.acegisecurity.userdetails.UsernameNotFoundException
;
import
org.acegisecurity.userdetails.UserDetailsService
;
import
org.acegisecurity.userdetails.UserDetails
;
import
org.acegisecurity.userdetails.User
;
import
org.acegisecurity.userdetails.UserDetails
;
import
org.acegisecurity.userdetails.UsernameNotFoundException
;
import
org.jruby.ext.posix.FileStat
;
import
org.jruby.ext.posix.Group
;
import
org.jruby.ext.posix.POSIX
;
import
org.jruby.ext.posix.Passwd
;
import
org.jvnet.libpam.PAM
;
import
org.jvnet.libpam.PAMException
;
import
org.jvnet.libpam.UnixUser
;
import
org.jvnet.libpam.impl.CLibrary
;
import
org.springframework.dao.DataAccessException
;
import
org.springframework.web.context.WebApplicationContext
;
import
org.kohsuke.stapler.DataBoundConstructor
;
import
org.jruby.ext.posix.POSIX
;
import
org.jruby.ext.posix.FileStat
;
import
org.jruby.ext.posix.Passwd
;
import
org.jruby.ext.posix.Group
;
import
org.springframework.dao.DataAccessException
;
import
java.io.File
;
import
java.util.Set
;
import
java.util.logging.Logger
;
import
java.io.File
;
/**
* {@link SecurityRealm} that uses Unix PAM authentication.
...
...
@@ -77,7 +68,7 @@ public class PAMSecurityRealm extends AbstractPasswordBasedSecurityRealm {
}
@Override
protected
UserDetails
authenticate
(
String
username
,
String
password
)
throws
AuthenticationException
{
protected
synchronized
UserDetails
authenticate
(
String
username
,
String
password
)
throws
AuthenticationException
{
try
{
UnixUser
uu
=
new
PAM
(
serviceName
).
authenticate
(
username
,
password
);
...
...
@@ -149,7 +140,7 @@ public class PAMSecurityRealm extends AbstractPasswordBasedSecurityRealm {
else
group
=
String
.
valueOf
(
st
.
gid
());
if
((
st
.
mode
()&
FileStat
.
S_IRGRP
)!=
0
)
{
// the file is readable to group.
Hudson
should be in the right group, then
// the file is readable to group.
Jenkins
should be in the right group, then
return
FormValidation
.
error
(
Messages
.
PAMSecurityRealm_BelongToGroup
(
user
,
group
));
}
else
{
Passwd
opwd
=
api
.
getpwuid
(
st
.
uid
());
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录