Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
李少辉-开发者
gitlab-foss
提交
7ca017b5
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,发现更多精彩内容 >>
未验证
提交
7ca017b5
编写于
6月 26, 2015
作者:
D
Dmitriy Zaporozhets
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Refactor issue, mr, note abilities to include project abilities too
Signed-off-by:
N
Dmitriy Zaporozhets
<
dmitriy.zaporozhets@gmail.com
>
上级
083d4604
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
13 deletion
+30
-13
app/models/ability.rb
app/models/ability.rb
+30
-13
未找到文件。
app/models/ability.rb
浏览文件 @
7ca017b5
...
...
@@ -68,6 +68,7 @@ class Ability
def
project_abilities
(
user
,
project
)
rules
=
[]
key
=
"/user/
#{
user
.
id
}
/project/
#{
project
.
id
}
"
RequestStore
.
store
[
key
]
||=
begin
team
=
project
.
team
...
...
@@ -182,7 +183,6 @@ class Ability
def
project_master_rules
project_dev_rules
+
[
:push_code_to_protected_branches
,
:update_issue
,
:update_project_snippet
,
:update_merge_request
,
:admin_milestone
,
...
...
@@ -244,26 +244,40 @@ class Ability
rules
.
flatten
end
[
:issue
,
:note
,
:project_snippet
,
:personal_snippet
,
:merge_request
].
each
do
|
name
|
[
:issue
,
:merge_request
].
each
do
|
name
|
define_method
"
#{
name
}
_abilities"
do
|
user
,
subject
|
if
user
.
is_admin?
[
rules
=
[]
if
subject
.
author
==
user
||
(
subject
.
respond_to?
(
:assignee
)
&&
subject
.
assignee
==
user
)
rules
+=
[
:"read_
#{
name
}
"
,
:"update_
#{
name
}
"
,
:"admin_
#{
name
}
"
]
elsif
subject
.
author
==
user
||
(
subject
.
respond_to?
(
:assignee
)
&&
subject
.
assignee
==
user
)
[
end
rules
+=
project_abilities
(
user
,
subject
.
project
)
rules
end
end
[
:note
,
:project_snippet
,
:personal_snippet
].
each
do
|
name
|
define_method
"
#{
name
}
_abilities"
do
|
user
,
subject
|
rules
=
[]
if
subject
.
author
==
user
rules
+=
[
:"read_
#{
name
}
"
,
:"update_
#{
name
}
"
,
:"admin_
#{
name
}
"
]
else
if
subject
.
respond_to?
(
:project
)
&&
subject
.
project
project_abilities
(
user
,
subject
.
project
)
else
[]
end
end
if
subject
.
respond_to?
(
:project
)
&&
subject
.
project
rules
+=
project_abilities
(
user
,
subject
.
project
)
end
rules
end
end
...
...
@@ -272,13 +286,16 @@ class Ability
target_user
=
subject
.
user
group
=
subject
.
group
can_manage
=
group_abilities
(
user
,
group
).
include?
(
:admin_group
)
if
can_manage
&&
(
user
!=
target_user
)
rules
<<
:update_group_member
rules
<<
:destroy_group_member
end
if
!
group
.
last_owner?
(
user
)
&&
(
can_manage
||
(
user
==
target_user
))
rules
<<
:destroy_group_member
end
rules
end
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录