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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
c8fe4215
Commit
c8fe4215
authored
Oct 29, 2015
by
Douglas Barbosa Alexandre
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve personal snippet access workflow. Fixes #3258
parent
ead3ffd7
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
188 additions
and
17 deletions
+188
-17
CHANGELOG
CHANGELOG
+1
-0
app/controllers/snippets_controller.rb
app/controllers/snippets_controller.rb
+8
-1
app/models/ability.rb
app/models/ability.rb
+49
-16
spec/controllers/snippets_controller_spec.rb
spec/controllers/snippets_controller_spec.rb
+118
-0
spec/factories.rb
spec/factories.rb
+12
-0
No files found.
CHANGELOG
View file @
c8fe4215
...
...
@@ -14,6 +14,7 @@ v 8.2.0 (unreleased)
- Fix: 500 error returned if destroy request without HTTP referer (Kazuki Shimizu)
- Remove deprecated CI events from project settings page
- Use issue editor as cross reference comment author when issue is edited with a new mention.
- Improve personal snippet access workflow
v 8.1.1
- Fix cloning Wiki repositories via HTTP (Stan Hu)
...
...
app/controllers/snippets_controller.rb
View file @
c8fe4215
class
SnippetsController
<
ApplicationController
before_action
:snippet
,
only:
[
:show
,
:edit
,
:destroy
,
:update
,
:raw
]
# Allow read snippet
before_action
:authorize_show_snippet!
,
only:
[
:show
]
# Allow modify snippet
before_action
:authorize_update_snippet!
,
only:
[
:edit
,
:update
]
...
...
@@ -79,10 +82,14 @@ class SnippetsController < ApplicationController
[
Snippet
::
PUBLIC
,
Snippet
::
INTERNAL
]).
find
(
params
[
:id
])
else
PersonalSnippet
.
are_public
.
find
(
params
[
:id
])
PersonalSnippet
.
find
(
params
[
:id
])
end
end
def
authorize_show_snippet!
authenticate_user!
unless
can?
(
current_user
,
:read_personal_snippet
,
@snippet
)
end
def
authorize_update_snippet!
return
render_404
unless
can?
(
current_user
,
:update_personal_snippet
,
@snippet
)
end
...
...
app/models/ability.rb
View file @
c8fe4215
...
...
@@ -22,12 +22,17 @@ class Ability
# List of possible abilities
# for non-authenticated user
def
not_auth_abilities
(
user
,
subject
)
return
not_auth_personal_snippet_abilities
(
subject
)
if
subject
.
kind_of?
(
PersonalSnippet
)
return
not_auth_project_abilities
(
subject
)
if
subject
.
kind_of?
(
Project
)
||
subject
.
respond_to?
(
:project
)
return
not_auth_group_abilities
(
subject
)
if
subject
.
kind_of?
(
Group
)
||
subject
.
respond_to?
(
:group
)
[]
end
def
not_auth_project_abilities
(
subject
)
project
=
if
subject
.
kind_of?
(
Project
)
subject
elsif
subject
.
respond_to?
(
:project
)
subject
.
project
else
nil
subject
.
project
end
if
project
&&
project
.
public?
...
...
@@ -47,19 +52,29 @@ class Ability
rules
-
project_disabled_features_rules
(
project
)
else
group
=
if
subject
.
kind_of?
(
Group
)
subject
elsif
subject
.
respond_to?
(
:group
)
subject
.
group
else
nil
end
[]
end
end
if
group
&&
group
.
public_profile?
[
:read_group
]
else
[]
end
def
not_auth_group_abilities
(
subject
)
group
=
if
subject
.
kind_of?
(
Group
)
subject
else
subject
.
group
end
if
group
&&
group
.
public_profile?
[
:read_group
]
else
[]
end
end
def
not_auth_personal_snippet_abilities
(
snippet
)
if
snippet
.
public?
[
:read_personal_snippet
]
else
[]
end
end
...
...
@@ -278,7 +293,7 @@ class Ability
end
end
[
:note
,
:project_snippet
,
:personal_snippet
].
each
do
|
name
|
[
:note
,
:project_snippet
].
each
do
|
name
|
define_method
"
#{
name
}
_abilities"
do
|
user
,
subject
|
rules
=
[]
...
...
@@ -298,6 +313,24 @@ class Ability
end
end
def
personal_snippet_abilities
(
user
,
snippet
)
rules
=
[]
if
snippet
.
author
==
user
rules
+=
[
:read_personal_snippet
,
:update_personal_snippet
,
:admin_personal_snippet
]
end
if
snippet
.
public?
||
snippet
.
internal?
rules
.
push
(
:read_snippet
)
end
rules
end
def
group_member_abilities
(
user
,
subject
)
rules
=
[]
target_user
=
subject
.
user
...
...
spec/controllers/snippets_controller_spec.rb
0 → 100644
View file @
c8fe4215
require
'spec_helper'
describe
SnippetsController
do
describe
'GET #show'
do
let
(
:user
)
{
create
(
:user
)
}
context
'when the personal snippet is private'
do
let
(
:personal_snippet
)
{
create
(
:personal_snippet
,
:private
,
author:
user
)
}
context
'when signed in'
do
before
do
sign_in
(
user
)
end
context
'when signed in user is not the author'
do
let
(
:other_author
)
{
create
(
:author
)
}
let
(
:other_personal_snippet
)
{
create
(
:personal_snippet
,
:private
,
author:
other_author
)
}
it
'responds with status 404'
do
get
:show
,
id:
other_personal_snippet
.
to_param
expect
(
response
.
status
).
to
eq
(
404
)
end
end
context
'when signed in user is the author'
do
it
'renders the snippet'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
assigns
(
:snippet
)).
to
eq
(
personal_snippet
)
expect
(
response
.
status
).
to
eq
(
200
)
end
end
end
context
'when not signed in'
do
it
'redirects to the sign in page'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
response
).
to
redirect_to
(
new_user_session_path
)
end
end
end
context
'when the personal snippet is internal'
do
let
(
:personal_snippet
)
{
create
(
:personal_snippet
,
:internal
,
author:
user
)
}
context
'when signed in'
do
before
do
sign_in
(
user
)
end
it
'renders the snippet'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
assigns
(
:snippet
)).
to
eq
(
personal_snippet
)
expect
(
response
.
status
).
to
eq
(
200
)
end
end
context
'when not signed in'
do
it
'redirects to the sign in page'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
response
).
to
redirect_to
(
new_user_session_path
)
end
end
end
context
'when the personal snippet is public'
do
let
(
:personal_snippet
)
{
create
(
:personal_snippet
,
:public
,
author:
user
)
}
context
'when signed in'
do
before
do
sign_in
(
user
)
end
it
'renders the snippet'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
assigns
(
:snippet
)).
to
eq
(
personal_snippet
)
expect
(
response
.
status
).
to
eq
(
200
)
end
end
context
'when not signed in'
do
it
'renders the snippet'
do
get
:show
,
id:
personal_snippet
.
to_param
expect
(
assigns
(
:snippet
)).
to
eq
(
personal_snippet
)
expect
(
response
.
status
).
to
eq
(
200
)
end
end
end
context
'when the personal snippet does not exist'
do
context
'when signed in'
do
before
do
sign_in
(
user
)
end
it
'responds with status 404'
do
get
:show
,
id:
'doesntexist'
expect
(
response
.
status
).
to
eq
(
404
)
end
end
context
'when not signed in'
do
it
'responds with status 404'
do
get
:show
,
id:
'doesntexist'
expect
(
response
.
status
).
to
eq
(
404
)
end
end
end
end
end
spec/factories.rb
View file @
c8fe4215
...
...
@@ -165,6 +165,18 @@ FactoryGirl.define do
title
content
file_name
trait
:public
do
visibility_level
Gitlab
::
VisibilityLevel
::
PUBLIC
end
trait
:internal
do
visibility_level
Gitlab
::
VisibilityLevel
::
INTERNAL
end
trait
:private
do
visibility_level
Gitlab
::
VisibilityLevel
::
PRIVATE
end
end
factory
:snippet
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