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
39d14f2f
Commit
39d14f2f
authored
Feb 13, 2018
by
Andreas Brandl
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Shortcut when all levels visible.
parent
d13aebab
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
34 additions
and
1 deletion
+34
-1
app/models/project.rb
app/models/project.rb
+6
-0
lib/gitlab/visibility_level.rb
lib/gitlab/visibility_level.rb
+6
-1
spec/lib/gitlab/visibility_level_spec.rb
spec/lib/gitlab/visibility_level_spec.rb
+22
-0
No files found.
app/models/project.rb
View file @
39d14f2f
...
...
@@ -325,6 +325,12 @@ class Project < ActiveRecord::Base
levels
=
Gitlab
::
VisibilityLevel
.
levels_for_user
(
user
)
if
Gitlab
::
VisibilityLevel
.
all_levels?
(
levels
)
# If the user is allowed to see all projects,
# we can shortcut and just return.
return
all
end
authorized_projects
=
where
(
'EXISTS (?)'
,
authorized
).
select
(
:id
)
visible_projects
=
where
(
'visibility_level IN (?)'
,
levels
).
select
(
:id
)
...
...
lib/gitlab/visibility_level.rb
View file @
39d14f2f
...
...
@@ -20,6 +20,7 @@ module Gitlab
PRIVATE
=
0
unless
const_defined?
(
:PRIVATE
)
INTERNAL
=
10
unless
const_defined?
(
:INTERNAL
)
PUBLIC
=
20
unless
const_defined?
(
:PUBLIC
)
ALL_LEVELS
=
[
PRIVATE
,
INTERNAL
,
PUBLIC
].
freeze
unless
const_defined?
(
:ALL_LEVELS
)
class
<<
self
delegate
:values
,
to: :options
...
...
@@ -28,7 +29,7 @@ module Gitlab
return
[
PUBLIC
]
unless
user
if
user
.
full_private_access?
[
PRIVATE
,
INTERNAL
,
PUBLIC
]
ALL_LEVELS
elsif
user
.
external?
[
PUBLIC
]
else
...
...
@@ -36,6 +37,10 @@ module Gitlab
end
end
def
all_levels?
(
levels
=
[])
levels
&
.
sort
==
ALL_LEVELS
end
def
string_values
string_options
.
keys
end
...
...
spec/lib/gitlab/visibility_level_spec.rb
View file @
39d14f2f
...
...
@@ -50,6 +50,28 @@ describe Gitlab::VisibilityLevel do
end
end
describe
'.all_levels?'
do
let
(
:levels
)
do
[
Gitlab
::
VisibilityLevel
::
PUBLIC
,
Gitlab
::
VisibilityLevel
::
INTERNAL
,
Gitlab
::
VisibilityLevel
::
PRIVATE
].
shuffle
end
it
'returns true only when given all levels defined at once'
do
expect
(
described_class
.
all_levels?
(
levels
)).
to
be_truthy
end
it
'returns true for ALL_LEVELS'
do
expect
(
described_class
.
all_levels?
(
Gitlab
::
VisibilityLevel
::
ALL_LEVELS
)).
to
be_truthy
end
it
'returns false if any one level is missing'
do
expect
(
described_class
.
all_levels?
(
levels
[
0
..-
2
])).
to
be_falsey
end
end
describe
'.allowed_levels'
do
it
'only includes the levels that arent restricted'
do
stub_application_setting
(
restricted_visibility_levels:
[
Gitlab
::
VisibilityLevel
::
INTERNAL
])
...
...
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