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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
5c7388d4
Commit
5c7388d4
authored
Sep 20, 2018
by
Martin Wortschack
Committed by
Dmitriy Zaporozhets
Sep 20, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
EE Port: Split admin settings into subpages
parent
184c9f35
Changes
24
Show whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
747 additions
and
572 deletions
+747
-572
app/assets/javascripts/pages/admin/application_settings/index.js
...ets/javascripts/pages/admin/application_settings/index.js
+0
-5
app/assets/javascripts/pages/admin/application_settings/metrics_and_profiling/index.js
...admin/application_settings/metrics_and_profiling/index.js
+8
-0
app/controllers/admin/application_settings_controller.rb
app/controllers/admin/application_settings_controller.rb
+31
-1
app/controllers/concerns/internal_redirect.rb
app/controllers/concerns/internal_redirect.rb
+6
-0
app/helpers/application_helper.rb
app/helpers/application_helper.rb
+9
-1
app/helpers/application_settings_helper.rb
app/helpers/application_settings_helper.rb
+4
-0
app/views/admin/application_settings/ci_cd.html.haml
app/views/admin/application_settings/ci_cd.html.haml
+26
-0
app/views/admin/application_settings/integrations.html.haml
app/views/admin/application_settings/integrations.html.haml
+31
-0
app/views/admin/application_settings/metrics_and_profiling.html.haml
...dmin/application_settings/metrics_and_profiling.html.haml
+50
-0
app/views/admin/application_settings/network.html.haml
app/views/admin/application_settings/network.html.haml
+36
-0
app/views/admin/application_settings/preferences.html.haml
app/views/admin/application_settings/preferences.html.haml
+69
-0
app/views/admin/application_settings/reporting.html.haml
app/views/admin/application_settings/reporting.html.haml
+36
-0
app/views/admin/application_settings/repository.html.haml
app/views/admin/application_settings/repository.html.haml
+36
-0
app/views/admin/application_settings/show.html.haml
app/views/admin/application_settings/show.html.haml
+19
-298
app/views/layouts/nav/sidebar/_admin.html.haml
app/views/layouts/nav/sidebar/_admin.html.haml
+45
-1
config/routes/admin.rb
config/routes/admin.rb
+1
-0
ee/app/views/admin/application_settings/geo.html.haml
ee/app/views/admin/application_settings/geo.html.haml
+5
-0
ee/app/views/admin/application_settings/templates.html.haml
ee/app/views/admin/application_settings/templates.html.haml
+7
-0
ee/spec/features/admin/admin_settings_spec.rb
ee/spec/features/admin/admin_settings_spec.rb
+23
-2
ee/spec/features/ci_shared_runner_settings_spec.rb
ee/spec/features/ci_shared_runner_settings_spec.rb
+1
-1
locale/gitlab.pot
locale/gitlab.pot
+10
-4
qa/qa/page/admin/settings/main.rb
qa/qa/page/admin/settings/main.rb
+2
-2
spec/features/admin/admin_settings_spec.rb
spec/features/admin/admin_settings_spec.rb
+291
-256
spec/features/admin/admin_uses_repository_checks_spec.rb
spec/features/admin/admin_uses_repository_checks_spec.rb
+1
-1
No files found.
app/assets/javascripts/pages/admin/application_settings/index.js
View file @
5c7388d4
import
initSettingsPanels
from
'
~/settings_panels
'
;
import
initSettingsPanels
from
'
~/settings_panels
'
;
import
projectSelect
from
'
~/project_select
'
;
import
projectSelect
from
'
~/project_select
'
;
import
UsagePingPayload
from
'
./usage_ping_payload
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
// Initialize expandable settings panels
// Initialize expandable settings panels
initSettingsPanels
();
initSettingsPanels
();
projectSelect
();
projectSelect
();
new
UsagePingPayload
(
document
.
querySelector
(
'
.js-usage-ping-payload-trigger
'
),
document
.
querySelector
(
'
.js-usage-ping-payload
'
),
).
init
();
});
});
app/assets/javascripts/pages/admin/application_settings/metrics_and_profiling/index.js
0 → 100644
View file @
5c7388d4
import
UsagePingPayload
from
'
./../usage_ping_payload
'
;
document
.
addEventListener
(
'
DOMContentLoaded
'
,
()
=>
{
new
UsagePingPayload
(
document
.
querySelector
(
'
.js-usage-ping-payload-trigger
'
),
document
.
querySelector
(
'
.js-usage-ping-payload
'
),
).
init
();
});
app/controllers/admin/application_settings_controller.rb
View file @
5c7388d4
class
Admin::ApplicationSettingsController
<
Admin
::
ApplicationController
class
Admin::ApplicationSettingsController
<
Admin
::
ApplicationController
include
InternalRedirect
prepend
EE
::
Admin
::
ApplicationSettingsController
prepend
EE
::
Admin
::
ApplicationSettingsController
before_action
:set_application_setting
before_action
:set_application_setting
...
@@ -6,6 +7,33 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
...
@@ -6,6 +7,33 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
def
show
def
show
end
end
def
integrations
end
def
repository
end
def
templates
end
def
ci_cd
end
def
reporting
end
def
metrics_and_profiling
end
def
network
end
def
geo
end
def
preferences
end
def
update
def
update
successful
=
ApplicationSettings
::
UpdateService
successful
=
ApplicationSettings
::
UpdateService
.
new
(
@application_setting
,
current_user
,
application_setting_params
)
.
new
(
@application_setting
,
current_user
,
application_setting_params
)
...
@@ -15,10 +43,12 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
...
@@ -15,10 +43,12 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
session
[
:ask_for_usage_stats_consent
]
=
current_user
.
requires_usage_stats_consent?
session
[
:ask_for_usage_stats_consent
]
=
current_user
.
requires_usage_stats_consent?
end
end
redirect_path
=
referer_path
(
request
)
||
admin_application_settings_path
respond_to
do
|
format
|
respond_to
do
|
format
|
if
successful
if
successful
format
.
json
{
head
:ok
}
format
.
json
{
head
:ok
}
format
.
html
{
redirect_to
admin_application_settings
_path
,
notice:
'Application settings saved successfully'
}
format
.
html
{
redirect_to
redirect
_path
,
notice:
'Application settings saved successfully'
}
else
else
format
.
json
{
head
:bad_request
}
format
.
json
{
head
:bad_request
}
format
.
html
{
render
:show
}
format
.
html
{
render
:show
}
...
...
app/controllers/concerns/internal_redirect.rb
View file @
5c7388d4
...
@@ -37,4 +37,10 @@ module InternalRedirect
...
@@ -37,4 +37,10 @@ module InternalRedirect
path_with_query
=
[
uri
.
path
,
uri
.
query
].
compact
.
join
(
'?'
)
path_with_query
=
[
uri
.
path
,
uri
.
query
].
compact
.
join
(
'?'
)
[
path_with_query
,
uri
.
fragment
].
compact
.
join
(
"#"
)
[
path_with_query
,
uri
.
fragment
].
compact
.
join
(
"#"
)
end
end
def
referer_path
(
request
)
return
unless
request
.
referer
.
presence
URI
(
request
.
referer
).
path
end
end
end
app/helpers/application_helper.rb
View file @
5c7388d4
...
@@ -9,7 +9,15 @@ module ApplicationHelper
...
@@ -9,7 +9,15 @@ module ApplicationHelper
# See https://docs.gitlab.com/ee/development/ee_features.html#code-in-app-views
# See https://docs.gitlab.com/ee/development/ee_features.html#code-in-app-views
# rubocop: disable CodeReuse/ActiveRecord
# rubocop: disable CodeReuse/ActiveRecord
def
render_if_exists
(
partial
,
locals
=
{})
def
render_if_exists
(
partial
,
locals
=
{})
render
(
partial
,
locals
)
if
lookup_context
.
exists?
(
partial
,
[],
true
)
render
(
partial
,
locals
)
if
partial_exists?
(
partial
)
end
def
partial_exists?
(
partial
)
lookup_context
.
exists?
(
partial
,
[],
true
)
end
def
template_exists?
(
template
)
lookup_context
.
exists?
(
template
,
[],
false
)
end
end
# rubocop: enable CodeReuse/ActiveRecord
# rubocop: enable CodeReuse/ActiveRecord
...
...
app/helpers/application_settings_helper.rb
View file @
5c7388d4
...
@@ -265,4 +265,8 @@ module ApplicationSettingsHelper
...
@@ -265,4 +265,8 @@ module ApplicationSettingsHelper
:web_ide_clientside_preview_enabled
:web_ide_clientside_preview_enabled
]
]
end
end
def
expanded_by_default?
Rails
.
env
.
test?
end
end
end
app/views/admin/application_settings/ci_cd.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"CI/CD"
)
-
page_title
_
(
"CI/CD"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-ci-cd.no-animate
#js-ci-cd-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Continuous Integration and Deployment'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Auto DevOps, runners and job artifacts'
)
.settings-content
=
render
'ci_cd'
-
if
Gitlab
.
config
.
registry
.
enabled
%section
.settings.as-registry.no-animate
#js-registry-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Container Registry'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various container registry settings.'
)
.settings-content
=
render
'registry'
app/views/admin/application_settings/integrations.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Integrations"
)
-
page_title
_
(
"Integrations"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
=
render_if_exists
'admin/application_settings/elasticsearch_form'
,
expanded:
expanded_by_default?
%section
.settings.as-plantuml.no-animate
#js-plantuml-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'PlantUML'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Allow rendering of PlantUML diagrams in Asciidoc documents.'
)
.settings-content
=
render
'plantuml'
=
render_if_exists
'admin/application_settings/slack'
,
expanded:
expanded_by_default?
%section
.settings.as-third-party-offers.no-animate
#js-third-party-offers-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Third party offers'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Control the display of third party offers.'
)
.settings-content
=
render
'third_party_offers'
,
application_setting:
@application_setting
=
render_if_exists
'admin/application_settings/snowplow'
,
expanded:
expanded_by_default?
app/views/admin/application_settings/metrics_and_profiling.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Metrics and profiling"
)
-
page_title
_
(
"Metrics and profiling"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-influx.no-animate
#js-influx-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Metrics - Influx'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable and configure InfluxDB metrics.'
)
.settings-content
=
render
'influx'
%section
.settings.as-prometheus.no-animate
#js-prometheus-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Metrics - Prometheus'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable and configure Prometheus metrics.'
)
.settings-content
=
render
'prometheus'
%section
.settings.as-performance-bar.no-animate
#js-performance-bar-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Profiling - Performance bar'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable the Performance Bar for a given group.'
)
=
link_to
icon
(
'question-circle'
),
help_page_path
(
'administration/monitoring/performance/performance_bar'
)
.settings-content
=
render
'performance_bar'
%section
.settings.as-usage.no-animate
#js-usage-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
#usage-statistics
%h4
=
_
(
'Usage statistics'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable or disable version check and usage ping.'
)
.settings-content
=
render
'usage'
=
render_if_exists
'admin/application_settings/pseudonymizer_settings'
,
expanded:
expanded_by_default?
app/views/admin/application_settings/network.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Network"
)
-
page_title
_
(
"Network"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-performance.no-animate
#js-performance-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Performance optimization'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various settings that affect GitLab performance.'
)
.settings-content
=
render
'performance'
%section
.settings.as-ip-limits.no-animate
#js-ip-limits-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'User and IP Rate Limits'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure limits for web and API requests.'
)
.settings-content
=
render
'ip_limits'
%section
.settings.as-outbound.no-animate
#js-outbound-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Outbound requests'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Allow requests to the local network from hooks and services.'
)
.settings-content
=
render
'outbound'
app/views/admin/application_settings/preferences.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Preferences"
)
-
page_title
_
(
"Preferences"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-email.no-animate
#js-email-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Email'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various email settings.'
)
.settings-content
=
render
'email'
%section
.settings.as-help-page.no-animate
#js-help-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Help page'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Help page text and support page url.'
)
.settings-content
=
render
'help_page'
%section
.settings.as-pages.no-animate
#js-pages-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Pages'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Size and domain settings for static websites'
)
.settings-content
=
render
'pages'
%section
.settings.as-realtime.no-animate
#js-realtime-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Real-time features'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Change this value to influence how frequently the GitLab UI polls for updates.'
)
.settings-content
=
render
'realtime'
%section
.settings.as-background.no-animate
#js-background-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Background jobs'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure Sidekiq job throttling.'
)
.settings-content
=
render
'background_jobs'
%section
.settings.as-gitaly.no-animate
#js-gitaly-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Gitaly'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure Gitaly timeouts.'
)
.settings-content
=
render
'gitaly'
app/views/admin/application_settings/reporting.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Reporting"
)
-
page_title
_
(
"Reporting"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-spam.no-animate
#js-spam-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Spam and Anti-bot Protection'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable reCAPTCHA or Akismet and set IP limits.'
)
.settings-content
=
render
'spam'
%section
.settings.as-abuse.no-animate
#js-abuse-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Abuse reports'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Set notification email for abuse reports.'
)
.settings-content
=
render
'abuse'
%section
.settings.as-logging.no-animate
#js-logging-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Error Reporting and Logging'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable Sentry for error reporting and logging.'
)
.settings-content
=
render
'logging'
app/views/admin/application_settings/repository.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
_
(
"Repository"
)
-
page_title
_
(
"Repository"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
%section
.settings.as-mirror.no-animate
#js-mirror-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Repository mirror'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
'Collapse'
:
'Expand'
%p
=
_
(
'Configure push mirrors.'
)
.settings-content
=
render
partial:
'repository_mirrors_form'
%section
.settings.as-repository-storage.no-animate
#js-repository-storage-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Repository storage'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure storage path and circuit breaker settings.'
)
.settings-content
=
render
'repository_storage'
%section
.settings.as-repository-check.no-animate
#js-repository-check-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Repository maintenance'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure automatic git checks and housekeeping on repositories.'
)
.settings-content
=
render
'repository_check'
app/views/admin/application_settings/show.html.haml
View file @
5c7388d4
-
breadcrumb_title
"Settings"
-
breadcrumb_title
_
(
"Settings"
)
-
page_title
"Settings"
-
page_title
_
(
"Settings"
)
-
@content_class
=
"limit-container-width"
unless
fluid_layout
-
@content_class
=
"limit-container-width"
unless
fluid_layout
-
expanded
=
Rails
.
env
.
test?
%section
.settings.as-visibility-access.no-animate
#js-visibility-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-visibility-access.no-animate
#js-visibility-settings
{
class:
(
'expanded'
if
expanded
_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Visibility and access controls'
)
=
_
(
'Visibility and access controls'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Set default and restrict visibility levels. Configure import sources and git access protocol.'
)
=
_
(
'Set default and restrict visibility levels. Configure import sources and git access protocol.'
)
.settings-content
.settings-content
=
render
'visibility_and_access'
=
render
'visibility_and_access'
%section
.settings.as-account-limit.no-animate
#js-account-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-account-limit.no-animate
#js-account-settings
{
class:
(
'expanded'
if
expanded
_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Account and limit'
)
=
_
(
'Account and limit'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Session expiration, projects limit and attachment size.'
)
=
_
(
'Session expiration, projects limit and attachment size.'
)
.settings-content
.settings-content
=
render
'account_and_limit'
=
render
'account_and_limit'
%section
.settings.as-signup.no-animate
#js-signup-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-signup.no-animate
#js-signup-settings
{
class:
(
'expanded'
if
expanded
_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Sign-up restrictions'
)
=
_
(
'Sign-up restrictions'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Configure the way a user creates a new account.'
)
=
_
(
'Configure the way a user creates a new account.'
)
.settings-content
.settings-content
=
render
'signup'
=
render
'signup'
%section
.settings.as-signin.no-animate
#js-signin-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-signin.no-animate
#js-signin-settings
{
class:
(
'expanded'
if
expanded
_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Sign-in restrictions'
)
=
_
(
'Sign-in restrictions'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Set requirements for a user to sign-in. Enable mandatory two-factor authentication.'
)
=
_
(
'Set requirements for a user to sign-in. Enable mandatory two-factor authentication.'
)
.settings-content
.settings-content
=
render
'signin'
=
render
'signin'
%section
.
settings.as-terms.no-animate
#js-terms-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.
qa-terms-settings.settings.as-terms.no-animate
#js-terms-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Terms of Service and Privacy Policy'
)
=
_
(
'Terms of Service and Privacy Policy'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Include a Terms of Service agreement and Privacy Policy that all users must accept.'
)
=
_
(
'Include a Terms of Service agreement and Privacy Policy that all users must accept.'
)
.settings-content
.settings-content
=
render
'terms'
=
render
'terms'
%section
.settings.as-help-page.no-animate
#js-help-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Help page'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Help page text and support page url.'
)
.settings-content
=
render
'help_page'
%section
.settings.as-pages.no-animate
#js-pages-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Pages'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Size and domain settings for static websites'
)
.settings-content
=
render
'pages'
%section
.settings.as-ci-cd.no-animate
#js-ci-cd-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Continuous Integration and Deployment'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Auto DevOps, runners and job artifacts'
)
.settings-content
=
render
'ci_cd'
%section
.settings.as-influx.no-animate
#js-influx-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Metrics - Influx'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable and configure InfluxDB metrics.'
)
.settings-content
=
render
'influx'
%section
.settings.as-prometheus.no-animate
#js-prometheus-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Metrics - Prometheus'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable and configure Prometheus metrics.'
)
.settings-content
=
render
'prometheus'
%section
.settings.as-performance-bar.no-animate
#js-performance-bar-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Profiling - Performance bar'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable the Performance Bar for a given group.'
)
=
link_to
icon
(
'question-circle'
),
help_page_path
(
'administration/monitoring/performance/performance_bar'
)
.settings-content
=
render
'performance_bar'
%section
.settings.as-snowplow.no-animate
#js-snowplow-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
Snowplow
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure the %{link} integration.'
).
html_safe
%
{
link:
link_to
(
'Snowplow'
,
'https://snowplowanalytics.com/'
,
target:
'_blank'
)
}
.settings-content
=
render
'snowplow'
,
application_setting:
@application_setting
%section
.settings.as-background.no-animate
#js-background-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Background jobs'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure Sidekiq job throttling.'
)
.settings-content
=
render
'background_jobs'
%section
.settings.as-spam.no-animate
#js-spam-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Spam and Anti-bot Protection'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable reCAPTCHA or Akismet and set IP limits.'
)
.settings-content
=
render
'spam'
%section
.settings.as-abuse.no-animate
#js-abuse-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Abuse reports'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Set notification email for abuse reports.'
)
.settings-content
=
render
'abuse'
%section
.settings.as-logging.no-animate
#js-logging-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Error Reporting and Logging'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable Sentry for error reporting and logging.'
)
.settings-content
=
render
'logging'
%section
.qa-repository-storage-settings.settings.as-repository-storage.no-animate
#js-repository-storage-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Repository storage'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure storage path and circuit breaker settings.'
)
.settings-content
=
render
'repository_storage'
%section
.settings.as-repository-check.no-animate
#js-repository-check-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Repository maintenance'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure automatic git checks and housekeeping on repositories.'
)
.settings-content
=
render
'repository_check'
-
if
Gitlab
.
config
.
registry
.
enabled
%section
.settings.as-registry.no-animate
#js-registry-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Container Registry'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various container registry settings.'
)
.settings-content
=
render
'registry'
-
if
koding_enabled?
-
if
koding_enabled?
%section
.settings.as-koding.no-animate
#js-koding-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-koding.no-animate
#js-koding-settings
{
class:
(
'expanded'
if
expanded
_by_default?
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Koding'
)
=
_
(
'Koding'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Online IDE integration settings.'
)
=
_
(
'Online IDE integration settings.'
)
.settings-content
.settings-content
=
render
'koding'
=
render
'koding'
%section
.settings.as-plantuml.no-animate
#js-plantuml-settings
{
class:
(
'expanded'
if
expanded
)
}
=
render_if_exists
'admin/application_settings/external_authorization_service_form'
,
expanded:
expanded_by_default?
.settings-header
%h4
=
_
(
'PlantUML'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Allow rendering of PlantUML diagrams in Asciidoc documents.'
)
.settings-content
=
render
'plantuml'
%section
.settings.as-usage.no-animate
#js-usage-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
#usage-statistics
%h4
=
_
(
'Usage statistics'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Enable or disable version check and usage ping.'
)
.settings-content
=
render
'usage'
%section
.settings.as-email.no-animate
#js-email-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.as-terminal.no-animate
#js-terminal-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Email'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various email settings.'
)
.settings-content
=
render
'email'
%section
.settings.as-gitaly.no-animate
#js-gitaly-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Gitaly'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure Gitaly timeouts.'
)
.settings-content
=
render
'gitaly'
%section
.settings.as-terminal.no-animate
#js-terminal-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Web terminal'
)
=
_
(
'Web terminal'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Set max session time for web terminal.'
)
=
_
(
'Set max session time for web terminal.'
)
.settings-content
.settings-content
=
render
'terminal'
=
render
'terminal'
%section
.settings.as-realtime.no-animate
#js-realtime-settings
{
class:
(
'expanded'
if
expanded
)
}
%section
.settings.no-animate
#js-web-ide-settings
{
class:
(
'expanded'
if
expanded_by_default?
)
}
.settings-header
%h4
=
_
(
'Real-time features'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Change this value to influence how frequently the GitLab UI polls for updates.'
)
.settings-content
=
render
'realtime'
%section
.settings.as-performance.no-animate
#js-performance-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Performance optimization'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Various settings that affect GitLab performance.'
)
.settings-content
=
render
'performance'
%section
.settings.as-ip-limits.no-animate
#js-ip-limits-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'User and IP Rate Limits'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Configure limits for web and API requests.'
)
.settings-content
=
render
'ip_limits'
%section
.settings.as-outbound.no-animate
#js-outbound-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Outbound requests'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Allow requests to the local network from hooks and services.'
)
.settings-content
=
render
'outbound'
%section
.settings.as-mirror.no-animate
#js-mirror-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Repository mirror'
)
%button
.btn.js-settings-toggle
{
type:
'button'
}
=
expanded
?
'Collapse'
:
'Expand'
%p
=
_
(
'Configure push and pull mirrors.'
)
.settings-content
=
render
partial:
'repository_mirrors_form'
=
render_if_exists
'admin/application_settings/geo'
,
expanded:
expanded
=
render_if_exists
'admin/application_settings/external_authorization_service_form'
,
expanded:
expanded
=
render_if_exists
'admin/application_settings/elasticsearch_form'
,
expanded:
expanded
=
render_if_exists
'admin/application_settings/slack'
,
expanded:
expanded
=
render_if_exists
'admin/application_settings/templates'
,
expanded:
expanded
%section
.settings.as-third-party-offers.no-animate
#js-third-party-offers-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
%h4
=
_
(
'Third party offers'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
=
_
(
'Control the display of third party offers.'
)
.settings-content
=
render
'third_party_offers'
,
application_setting:
@application_setting
=
render_if_exists
'admin/application_settings/custom_templates_form'
,
expanded:
expanded
%section
.settings.no-animate
#js-web-ide-settings
{
class:
(
'expanded'
if
expanded
)
}
.settings-header
.settings-header
%h4
%h4
=
_
(
'Web IDE'
)
=
_
(
'Web IDE'
)
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
%button
.btn.btn-default.js-settings-toggle
{
type:
'button'
}
=
expanded
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
=
expanded
_by_default?
?
_
(
'Collapse'
)
:
_
(
'Expand'
)
%p
%p
=
_
(
'Manage Web IDE features'
)
=
_
(
'Manage Web IDE features'
)
.settings-content
.settings-content
...
@@ -381,5 +104,3 @@
...
@@ -381,5 +104,3 @@
=
s_
(
'IDE|Allow live previews of JavaScript projects in the Web IDE using CodeSandbox client side evaluation.'
)
=
s_
(
'IDE|Allow live previews of JavaScript projects in the Web IDE using CodeSandbox client side evaluation.'
)
=
f
.
submit
_
(
'Save changes'
),
class:
"btn btn-success"
=
f
.
submit
_
(
'Save changes'
),
class:
"btn btn-success"
=
render_if_exists
'admin/application_settings/pseudonymizer_settings'
,
expanded:
expanded
app/views/layouts/nav/sidebar/_admin.html.haml
View file @
5c7388d4
...
@@ -246,10 +246,54 @@
...
@@ -246,10 +246,54 @@
=
sprite_icon
(
'settings'
)
=
sprite_icon
(
'settings'
)
%span
.nav-item-name
%span
.nav-item-name
=
_
(
'Settings'
)
=
_
(
'Settings'
)
%ul
.sidebar-sub-level-items.is-fly-out-only
%ul
.sidebar-sub-level-items
=
nav_link
(
controller: :application_settings
,
html_options:
{
class:
"fly-out-top-item"
}
)
do
=
nav_link
(
controller: :application_settings
,
html_options:
{
class:
"fly-out-top-item"
}
)
do
=
link_to
admin_application_settings_path
do
=
link_to
admin_application_settings_path
do
%strong
.fly-out-top-item-name
%strong
.fly-out-top-item-name
=
_
(
'Settings'
)
=
_
(
'Settings'
)
%li
.divider.fly-out-top-item
=
nav_link
(
path:
'application_settings#show'
)
do
=
link_to
admin_application_settings_path
,
title:
_
(
'General'
)
do
%span
=
_
(
'General'
)
=
nav_link
(
path:
'application_settings#integrations'
)
do
=
link_to
integrations_admin_application_settings_path
,
title:
_
(
'Integrations'
)
do
%span
=
_
(
'Integrations'
)
=
nav_link
(
path:
'application_settings#repository'
)
do
=
link_to
repository_admin_application_settings_path
,
title:
_
(
'Repository'
)
do
%span
=
_
(
'Repository'
)
-
if
template_exists?
(
'admin/application_settings/templates'
)
=
nav_link
(
path:
'application_settings#templates'
)
do
=
link_to
templates_admin_application_settings_path
,
title:
_
(
'Templates'
)
do
%span
=
_
(
'Templates'
)
=
nav_link
(
path:
'application_settings#ci_cd'
)
do
=
link_to
ci_cd_admin_application_settings_path
,
title:
_
(
'CI/CD'
)
do
%span
=
_
(
'CI/CD'
)
=
nav_link
(
path:
'application_settings#reporting'
)
do
=
link_to
reporting_admin_application_settings_path
,
title:
_
(
'Reporting'
)
do
%span
=
_
(
'Reporting'
)
=
nav_link
(
path:
'application_settings#metrics_and_profiling'
)
do
=
link_to
metrics_and_profiling_admin_application_settings_path
,
title:
_
(
'Metrics and profiling'
)
do
%span
=
_
(
'Metrics and profiling'
)
=
nav_link
(
path:
'application_settings#network'
)
do
=
link_to
network_admin_application_settings_path
,
title:
_
(
'Network'
)
do
%span
=
_
(
'Network'
)
-
if
template_exists?
(
'admin/application_settings/geo'
)
=
nav_link
(
path:
'application_settings#geo'
)
do
=
link_to
geo_admin_application_settings_path
,
title:
_
(
'Geo'
)
do
%span
=
_
(
'Geo'
)
=
nav_link
(
path:
'application_settings#preferences'
)
do
=
link_to
preferences_admin_application_settings_path
,
title:
_
(
'Preferences'
)
do
%span
=
_
(
'Preferences'
)
=
render
'shared/sidebar_toggle_button'
=
render
'shared/sidebar_toggle_button'
config/routes/admin.rb
View file @
5c7388d4
...
@@ -124,6 +124,7 @@ namespace :admin do
...
@@ -124,6 +124,7 @@ namespace :admin do
put
:reset_runners_token
put
:reset_runners_token
put
:reset_health_check_token
put
:reset_health_check_token
put
:clear_repository_check_states
put
:clear_repository_check_states
get
:integrations
,
:repository
,
:templates
,
:ci_cd
,
:reporting
,
:metrics_and_profiling
,
:network
,
:geo
,
:preferences
end
end
## EE-specific
## EE-specific
...
...
ee/app/views/admin/application_settings/geo.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
"Geo"
-
page_title
"Geo"
-
@content_class
=
"limit-container-width"
unless
fluid_layout
=
render_if_exists
'admin/application_settings/geo'
,
expanded:
expanded_by_default?
ee/app/views/admin/application_settings/templates.html.haml
0 → 100644
View file @
5c7388d4
-
breadcrumb_title
"Templates"
-
page_title
"Templates"
-
@content_class
=
"limit-container-width"
unless
fluid_layout
=
render_if_exists
'admin/application_settings/templates'
,
expanded:
expanded_by_default?
=
render_if_exists
'admin/application_settings/custom_templates_form'
,
expanded:
expanded_by_default?
ee/spec/features/admin/admin_settings_spec.rb
View file @
5c7388d4
...
@@ -7,10 +7,10 @@ describe 'Admin updates EE-only settings' do
...
@@ -7,10 +7,10 @@ describe 'Admin updates EE-only settings' do
stub_env
(
'IN_MEMORY_APPLICATION_SETTINGS'
,
'false'
)
stub_env
(
'IN_MEMORY_APPLICATION_SETTINGS'
,
'false'
)
sign_in
(
create
(
:admin
))
sign_in
(
create
(
:admin
))
allow
(
License
).
to
receive
(
:feature_available?
).
and_return
(
true
)
allow
(
License
).
to
receive
(
:feature_available?
).
and_return
(
true
)
visit
admin_application_settings_path
end
end
it
'Modify GitLab Geo settings'
do
it
'Modify GitLab Geo settings'
do
visit
geo_admin_application_settings_path
page
.
within
(
'.as-geo'
)
do
page
.
within
(
'.as-geo'
)
do
fill_in
'Connection timeout'
,
with:
15
fill_in
'Connection timeout'
,
with:
15
click_button
'Save changes'
click_button
'Save changes'
...
@@ -21,6 +21,7 @@ describe 'Admin updates EE-only settings' do
...
@@ -21,6 +21,7 @@ describe 'Admin updates EE-only settings' do
end
end
it
'Enable external authentication'
do
it
'Enable external authentication'
do
visit
admin_application_settings_path
page
.
within
(
'.as-external-auth'
)
do
page
.
within
(
'.as-external-auth'
)
do
check
'Enable classification control using an external service'
check
'Enable classification control using an external service'
fill_in
'Default classification label'
,
with:
'default'
fill_in
'Default classification label'
,
with:
'default'
...
@@ -31,6 +32,7 @@ describe 'Admin updates EE-only settings' do
...
@@ -31,6 +32,7 @@ describe 'Admin updates EE-only settings' do
end
end
it
'Enable elastic search indexing'
do
it
'Enable elastic search indexing'
do
visit
integrations_admin_application_settings_path
page
.
within
(
'.as-elasticsearch'
)
do
page
.
within
(
'.as-elasticsearch'
)
do
check
'Elasticsearch indexing'
check
'Elasticsearch indexing'
click_button
'Save changes'
click_button
'Save changes'
...
@@ -41,8 +43,9 @@ describe 'Admin updates EE-only settings' do
...
@@ -41,8 +43,9 @@ describe 'Admin updates EE-only settings' do
end
end
it
'Enable Slack application'
do
it
'Enable Slack application'
do
visit
integrations_admin_application_settings_path
allow
(
Gitlab
).
to
receive
(
:com?
).
and_return
(
true
)
allow
(
Gitlab
).
to
receive
(
:com?
).
and_return
(
true
)
visit
admin_application_settings_path
visit
integrations_
admin_application_settings_path
page
.
within
(
'.as-slack'
)
do
page
.
within
(
'.as-slack'
)
do
check
'Enable Slack application'
check
'Enable Slack application'
...
@@ -51,4 +54,22 @@ describe 'Admin updates EE-only settings' do
...
@@ -51,4 +54,22 @@ describe 'Admin updates EE-only settings' do
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
end
end
context
'Templates page'
do
before
do
visit
templates_admin_application_settings_path
end
it
'Render "Templates" section'
do
page
.
within
(
'.as-visibility-access'
)
do
expect
(
page
).
to
have_content
"Templates"
end
end
it
'Render "Custom project templates" section'
do
page
.
within
(
'.as-custom-project-templates'
)
do
expect
(
page
).
to
have_content
"Custom project templates"
end
end
end
end
end
ee/spec/features/ci_shared_runner_settings_spec.rb
View file @
5c7388d4
...
@@ -47,7 +47,7 @@ describe 'CI shared runner settings' do
...
@@ -47,7 +47,7 @@ describe 'CI shared runner settings' do
end
end
def
set_admin_shared_runners_minutes
(
limit
)
def
set_admin_shared_runners_minutes
(
limit
)
visit
admin_application_settings_path
visit
ci_cd_
admin_application_settings_path
page
.
within
(
'.as-ci-cd'
)
do
page
.
within
(
'.as-ci-cd'
)
do
fill_in
'application_setting_shared_runners_minutes'
,
with:
limit
fill_in
'application_setting_shared_runners_minutes'
,
with:
limit
...
...
locale/gitlab.pot
View file @
5c7388d4
...
@@ -2115,15 +2115,12 @@ msgstr ""
...
@@ -2115,15 +2115,12 @@ msgstr ""
msgid "Configure limits for web and API requests."
msgid "Configure limits for web and API requests."
msgstr ""
msgstr ""
msgid "Configure push
and pull
mirrors."
msgid "Configure push mirrors."
msgstr ""
msgstr ""
msgid "Configure storage path and circuit breaker settings."
msgid "Configure storage path and circuit breaker settings."
msgstr ""
msgstr ""
msgid "Configure the %{link} integration."
msgstr ""
msgid "Configure the way a user creates a new account."
msgid "Configure the way a user creates a new account."
msgstr ""
msgstr ""
...
@@ -3347,6 +3344,9 @@ msgstr ""
...
@@ -3347,6 +3344,9 @@ msgstr ""
msgid "Generate a default set of labels"
msgid "Generate a default set of labels"
msgstr ""
msgstr ""
msgid "Geo"
msgstr ""
msgid "Geo Nodes"
msgid "Geo Nodes"
msgstr ""
msgstr ""
...
@@ -4678,6 +4678,9 @@ msgstr ""
...
@@ -4678,6 +4678,9 @@ msgstr ""
msgid "Metrics - Prometheus"
msgid "Metrics - Prometheus"
msgstr ""
msgstr ""
msgid "Metrics and profiling"
msgstr ""
msgid "Metrics|Business"
msgid "Metrics|Business"
msgstr ""
msgstr ""
...
@@ -6307,6 +6310,9 @@ msgstr ""
...
@@ -6307,6 +6310,9 @@ msgstr ""
msgid "Repo by URL"
msgid "Repo by URL"
msgstr ""
msgstr ""
msgid "Reporting"
msgstr ""
msgid "Reports|%{failedString} and %{resolvedString}"
msgid "Reports|%{failedString} and %{resolvedString}"
msgstr ""
msgstr ""
...
...
qa/qa/page/admin/settings/main.rb
View file @
5c7388d4
...
@@ -6,11 +6,11 @@ module QA
...
@@ -6,11 +6,11 @@ module QA
include
QA
::
Page
::
Settings
::
Common
include
QA
::
Page
::
Settings
::
Common
view
'app/views/admin/application_settings/show.html.haml'
do
view
'app/views/admin/application_settings/show.html.haml'
do
element
:
repository_storage
_settings
element
:
terms
_settings
end
end
def
expand_repository_storage
(
&
block
)
def
expand_repository_storage
(
&
block
)
expand_section
(
:
repository_storage
_settings
)
do
expand_section
(
:
terms
_settings
)
do
RepositoryStorage
.
perform
(
&
block
)
RepositoryStorage
.
perform
(
&
block
)
end
end
end
end
...
...
spec/features/admin/admin_settings_spec.rb
View file @
5c7388d4
...
@@ -9,6 +9,10 @@ describe 'Admin updates settings' do
...
@@ -9,6 +9,10 @@ describe 'Admin updates settings' do
before
do
before
do
stub_env
(
'IN_MEMORY_APPLICATION_SETTINGS'
,
'false'
)
stub_env
(
'IN_MEMORY_APPLICATION_SETTINGS'
,
'false'
)
sign_in
(
admin
)
sign_in
(
admin
)
end
context
'General page'
do
before
do
visit
admin_application_settings_path
visit
admin_application_settings_path
end
end
...
@@ -35,31 +39,6 @@ describe 'Admin updates settings' do
...
@@ -35,31 +39,6 @@ describe 'Admin updates settings' do
expect
(
find
(
'#application_setting_visibility_level_20'
)).
not_to
be_checked
expect
(
find
(
'#application_setting_visibility_level_20'
)).
not_to
be_checked
end
end
describe
'LDAP settings'
do
context
'with LDAP enabled'
do
it
'Change allow group owners to manage ldap'
do
allow
(
Gitlab
::
Auth
::
LDAP
::
Config
).
to
receive
(
:enabled?
).
and_return
(
true
)
visit
admin_application_settings_path
page
.
within
(
'.as-visibility-access'
)
do
find
(
'#application_setting_allow_group_owners_to_manage_ldap'
).
set
(
false
)
click_button
'Save'
end
expect
(
page
).
to
have_content
(
'Application settings saved successfully'
)
expect
(
find
(
'#application_setting_allow_group_owners_to_manage_ldap'
)).
not_to
be_checked
end
end
context
'with LDAP disabled'
do
it
'Does not show option to allow group owners to manage ldap'
do
visit
admin_application_settings_path
expect
(
page
).
not_to
have_css
(
'#application_setting_allow_group_owners_to_manage_ldap'
)
end
end
end
it
'Modify import sources'
do
it
'Modify import sources'
do
expect
(
Gitlab
::
CurrentSettings
.
import_sources
).
not_to
be_empty
expect
(
Gitlab
::
CurrentSettings
.
import_sources
).
not_to
be_empty
...
@@ -93,6 +72,24 @@ describe 'Admin updates settings' do
...
@@ -93,6 +72,24 @@ describe 'Admin updates settings' do
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
end
end
it
'Change Keys settings'
do
page
.
within
(
'.as-visibility-access'
)
do
select
'Are forbidden'
,
from:
'RSA SSH keys'
select
'Are allowed'
,
from:
'DSA SSH keys'
select
'Must be at least 384 bits'
,
from:
'ECDSA SSH keys'
select
'Are forbidden'
,
from:
'ED25519 SSH keys'
click_on
'Save changes'
end
forbidden
=
ApplicationSetting
::
FORBIDDEN_KEY_VALUE
.
to_s
expect
(
page
).
to
have_content
'Application settings saved successfully'
expect
(
find_field
(
'RSA SSH keys'
).
value
).
to
eq
(
forbidden
)
expect
(
find_field
(
'DSA SSH keys'
).
value
).
to
eq
(
'0'
)
expect
(
find_field
(
'ECDSA SSH keys'
).
value
).
to
eq
(
'384'
)
expect
(
find_field
(
'ED25519 SSH keys'
).
value
).
to
eq
(
forbidden
)
end
it
'Change Account and Limit Settings'
do
it
'Change Account and Limit Settings'
do
page
.
within
(
'.as-account-limit'
)
do
page
.
within
(
'.as-account-limit'
)
do
uncheck
'Gravatar enabled'
uncheck
'Gravatar enabled'
...
@@ -176,7 +173,7 @@ describe 'Admin updates settings' do
...
@@ -176,7 +173,7 @@ describe 'Admin updates settings' do
allow
(
Devise
).
to
receive
(
:omniauth_providers
).
and_return
([])
allow
(
Devise
).
to
receive
(
:omniauth_providers
).
and_return
([])
# Save an unrelated setting
# Save an unrelated setting
page
.
within
(
'.as-ci-cd
'
)
do
page
.
within
(
'.as-terms
'
)
do
click_button
'Save changes'
click_button
'Save changes'
end
end
...
@@ -184,33 +181,86 @@ describe 'Admin updates settings' do
...
@@ -184,33 +181,86 @@ describe 'Admin updates settings' do
expect
(
Gitlab
::
CurrentSettings
.
disabled_oauth_sign_in_sources
).
to
include
(
'google_oauth2'
)
expect
(
Gitlab
::
CurrentSettings
.
disabled_oauth_sign_in_sources
).
to
include
(
'google_oauth2'
)
end
end
it
'Change Help page'
do
it
'Configure web terminal'
do
page
.
within
(
'.as-help-page'
)
do
page
.
within
(
'.as-terminal'
)
do
fill_in
'Help page text'
,
with:
'Example text'
fill_in
'Max session time'
,
with:
15
check
'Hide marketing-related entries from help'
fill_in
'Support page URL'
,
with:
'http://example.com/help'
click_button
'Save changes'
click_button
'Save changes'
end
end
expect
(
Gitlab
::
CurrentSettings
.
help_page_text
).
to
eq
"Example text"
expect
(
Gitlab
::
CurrentSettings
.
help_page_hide_commercial_content
).
to
be_truthy
expect
(
Gitlab
::
CurrentSettings
.
help_page_support_url
).
to
eq
"http://example.com/help"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
terminal_max_session_time
).
to
eq
(
15
)
end
end
end
it
'Change Pages settings'
do
describe
'LDAP settings'
do
page
.
within
(
'.as-pages'
)
do
context
'with LDAP enabled'
do
fill_in
'Maximum size of pages (MB)'
,
with:
15
it
'Change allow group owners to manage ldap'
do
check
'Require users to prove ownership of custom domains'
allow
(
Gitlab
::
Auth
::
LDAP
::
Config
).
to
receive
(
:enabled?
).
and_return
(
true
)
visit
admin_application_settings_path
page
.
within
(
'.as-visibility-access'
)
do
find
(
'#application_setting_allow_group_owners_to_manage_ldap'
).
set
(
false
)
click_button
'Save'
end
expect
(
page
).
to
have_content
(
'Application settings saved successfully'
)
expect
(
find
(
'#application_setting_allow_group_owners_to_manage_ldap'
)).
not_to
be_checked
end
end
context
'with LDAP disabled'
do
it
'Does not show option to allow group owners to manage ldap'
do
visit
admin_application_settings_path
expect
(
page
).
not_to
have_css
(
'#application_setting_allow_group_owners_to_manage_ldap'
)
end
end
end
context
'Integrations page'
do
before
do
visit
integrations_admin_application_settings_path
end
it
'Enable hiding third party offers'
do
page
.
within
(
'.as-third-party-offers'
)
do
check
'Do not display offers from third parties within GitLab'
click_button
'Save changes'
click_button
'Save changes'
end
end
expect
(
Gitlab
::
CurrentSettings
.
max_pages_size
).
to
eq
15
expect
(
Gitlab
::
CurrentSettings
.
pages_domain_verification_enabled?
).
to
be_truthy
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
hide_third_party_offers
).
to
be
true
end
end
it
'Change Slack Notifications Service template settings'
do
first
(
:link
,
'Service Templates'
).
click
click_link
'Slack notifications'
fill_in
'Webhook'
,
with:
'http://localhost'
fill_in
'Username'
,
with:
'test_user'
fill_in
'service_push_channel'
,
with:
'#test_channel'
page
.
check
(
'Notify only broken pipelines'
)
page
.
check
(
'Notify only default branch'
)
check_all_events
click_on
'Save'
expect
(
page
).
to
have_content
'Application settings saved successfully'
click_link
'Slack notifications'
page
.
all
(
'input[type=checkbox]'
).
each
do
|
checkbox
|
expect
(
checkbox
).
to
be_checked
end
expect
(
find_field
(
'Webhook'
).
value
).
to
eq
'http://localhost'
expect
(
find_field
(
'Username'
).
value
).
to
eq
'test_user'
expect
(
find
(
'#service_push_channel'
).
value
).
to
eq
'#test_channel'
end
end
context
'CI/CD page'
do
it
'Change CI/CD settings'
do
it
'Change CI/CD settings'
do
visit
ci_cd_admin_application_settings_path
page
.
within
(
'.as-ci-cd'
)
do
page
.
within
(
'.as-ci-cd'
)
do
check
'Default to Auto DevOps pipeline for all projects'
check
'Default to Auto DevOps pipeline for all projects'
fill_in
'Auto devops domain'
,
with:
'domain.com'
fill_in
'Auto devops domain'
,
with:
'domain.com'
...
@@ -221,6 +271,30 @@ describe 'Admin updates settings' do
...
@@ -221,6 +271,30 @@ describe 'Admin updates settings' do
expect
(
Gitlab
::
CurrentSettings
.
auto_devops_domain
).
to
eq
(
'domain.com'
)
expect
(
Gitlab
::
CurrentSettings
.
auto_devops_domain
).
to
eq
(
'domain.com'
)
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
end
end
end
context
'Reporting page'
do
it
'Change Spam settings'
do
visit
reporting_admin_application_settings_path
page
.
within
(
'.as-spam'
)
do
check
'Enable reCAPTCHA'
fill_in
'reCAPTCHA Site Key'
,
with:
'key'
fill_in
'reCAPTCHA Private Key'
,
with:
'key'
fill_in
'IPs per user'
,
with:
15
click_button
'Save changes'
end
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
recaptcha_enabled
).
to
be
true
expect
(
Gitlab
::
CurrentSettings
.
unique_ips_limit_per_user
).
to
eq
(
15
)
end
end
context
'Metrics and profiling page'
do
before
do
visit
metrics_and_profiling_admin_application_settings_path
end
it
'Change Influx settings'
do
it
'Change Influx settings'
do
page
.
within
(
'.as-influx'
)
do
page
.
within
(
'.as-influx'
)
do
...
@@ -265,41 +339,20 @@ describe 'Admin updates settings' do
...
@@ -265,41 +339,20 @@ describe 'Admin updates settings' do
expect
(
find_field
(
'Allowed group'
).
value
).
to
be_nil
expect
(
find_field
(
'Allowed group'
).
value
).
to
be_nil
end
end
it
'Change Background jobs settings'
do
it
'loads usage ping payload on click'
,
:js
do
page
.
within
(
'.as-background'
)
do
expect
(
page
).
to
have_button
'Preview payload'
fill_in
'Throttling Factor'
,
with:
1
click_button
'Save changes'
end
expect
(
Gitlab
::
CurrentSettings
.
sidekiq_throttling_factor
).
to
eq
(
1
)
expect
(
page
).
to
have_content
"Application settings saved successfully"
end
it
'Change Spam settings'
do
page
.
within
(
'.as-spam'
)
do
check
'Enable reCAPTCHA'
fill_in
'reCAPTCHA Site Key'
,
with:
'key'
fill_in
'reCAPTCHA Private Key'
,
with:
'key'
fill_in
'IPs per user'
,
with:
15
click_button
'Save changes'
end
expect
(
page
).
to
have_content
"Application settings saved successfully"
find
(
'.js-usage-ping-payload-trigger'
).
click
expect
(
Gitlab
::
CurrentSettings
.
recaptcha_enabled
).
to
be
true
expect
(
Gitlab
::
CurrentSettings
.
unique_ips_limit_per_user
).
to
eq
(
15
)
end
it
'Configure web terminal'
do
expect
(
page
).
to
have_selector
'.js-usage-ping-payload'
page
.
within
(
'.as-terminal'
)
do
expect
(
page
).
to
have_button
'Hide payload'
fill_in
'Max session time'
,
with:
15
click_button
'Save changes'
end
end
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
terminal_max_session_time
).
to
eq
(
15
)
end
end
context
'Network page'
do
it
'Enable outbound requests'
do
it
'Enable outbound requests'
do
visit
network_admin_application_settings_path
page
.
within
(
'.as-outbound'
)
do
page
.
within
(
'.as-outbound'
)
do
check
'Allow requests to the local network from hooks and services'
check
'Allow requests to the local network from hooks and services'
click_button
'Save changes'
click_button
'Save changes'
...
@@ -308,66 +361,48 @@ describe 'Admin updates settings' do
...
@@ -308,66 +361,48 @@ describe 'Admin updates settings' do
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
allow_local_requests_from_hooks_and_services
).
to
be
true
expect
(
Gitlab
::
CurrentSettings
.
allow_local_requests_from_hooks_and_services
).
to
be
true
end
end
end
it
'Enable hiding third party offers'
do
context
'Preferences page'
do
page
.
within
(
'.as-third-party-offers'
)
do
before
do
check
'Do not display offers from third parties within GitLab'
visit
preferences_admin_application_settings_path
end
it
'Change Help page'
do
page
.
within
(
'.as-help-page'
)
do
fill_in
'Help page text'
,
with:
'Example text'
check
'Hide marketing-related entries from help'
fill_in
'Support page URL'
,
with:
'http://example.com/help'
click_button
'Save changes'
click_button
'Save changes'
end
end
expect
(
Gitlab
::
CurrentSettings
.
help_page_text
).
to
eq
"Example text"
expect
(
Gitlab
::
CurrentSettings
.
help_page_hide_commercial_content
).
to
be_truthy
expect
(
Gitlab
::
CurrentSettings
.
help_page_support_url
).
to
eq
"http://example.com/help"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
page
).
to
have_content
"Application settings saved successfully"
expect
(
Gitlab
::
CurrentSettings
.
hide_third_party_offers
).
to
be
true
end
end
it
'Change Slack Notifications Service template settings'
do
it
'Change Pages settings'
do
first
(
:link
,
'Service Templates'
).
click
page
.
within
(
'.as-pages'
)
do
click_link
'Slack notifications'
fill_in
'Maximum size of pages (MB)'
,
with:
15
fill_in
'Webhook'
,
with:
'http://localhost'
check
'Require users to prove ownership of custom domains'
fill_in
'Username'
,
with:
'test_user'
click_button
'Save changes'
fill_in
'service_push_channel'
,
with:
'#test_channel'
page
.
check
(
'Notify only broken pipelines'
)
page
.
check
(
'Notify only default branch'
)
check_all_events
click_on
'Save'
expect
(
page
).
to
have_content
'Application settings saved successfully'
click_link
'Slack notifications'
page
.
all
(
'input[type=checkbox]'
).
each
do
|
checkbox
|
expect
(
checkbox
).
to
be_checked
end
expect
(
find_field
(
'Webhook'
).
value
).
to
eq
'http://localhost'
expect
(
find_field
(
'Username'
).
value
).
to
eq
'test_user'
expect
(
find
(
'#service_push_channel'
).
value
).
to
eq
'#test_channel'
end
end
it
'Change Keys settings'
do
expect
(
Gitlab
::
CurrentSettings
.
max_pages_size
).
to
eq
15
page
.
within
(
'.as-visibility-access'
)
do
expect
(
Gitlab
::
CurrentSettings
.
pages_domain_verification_enabled?
).
to
be_truthy
select
'Are forbidden'
,
from:
'RSA SSH keys'
expect
(
page
).
to
have_content
"Application settings saved successfully"
select
'Are allowed'
,
from:
'DSA SSH keys'
select
'Must be at least 384 bits'
,
from:
'ECDSA SSH keys'
select
'Are forbidden'
,
from:
'ED25519 SSH keys'
click_on
'Save changes'
end
end
forbidden
=
ApplicationSetting
::
FORBIDDEN_KEY_VALUE
.
to_s
it
'Change Background jobs settings'
do
page
.
within
(
'.as-background'
)
do
expect
(
page
).
to
have_content
'Application settings saved successfully'
fill_in
'Throttling Factor'
,
with:
1
expect
(
find_field
(
'RSA SSH keys'
).
value
).
to
eq
(
forbidden
)
click_button
'Save changes'
expect
(
find_field
(
'DSA SSH keys'
).
value
).
to
eq
(
'0'
)
expect
(
find_field
(
'ECDSA SSH keys'
).
value
).
to
eq
(
'384'
)
expect
(
find_field
(
'ED25519 SSH keys'
).
value
).
to
eq
(
forbidden
)
end
end
it
'loads usage ping payload on click'
,
:js
do
expect
(
Gitlab
::
CurrentSettings
.
sidekiq_throttling_factor
).
to
eq
(
1
)
expect
(
page
).
to
have_button
'Preview payload'
expect
(
page
).
to
have_content
"Application settings saved successfully"
end
find
(
'.js-usage-ping-payload-trigger'
).
click
expect
(
page
).
to
have_selector
'.js-usage-ping-payload'
expect
(
page
).
to
have_button
'Hide payload'
end
end
def
check_all_events
def
check_all_events
...
...
spec/features/admin/admin_uses_repository_checks_spec.rb
View file @
5c7388d4
...
@@ -33,7 +33,7 @@ describe 'Admin uses repository checks' do
...
@@ -33,7 +33,7 @@ describe 'Admin uses repository checks' do
end
end
it
'to clear all repository checks'
,
:js
do
it
'to clear all repository checks'
,
:js
do
visit
admin_application_settings_path
visit
repository_
admin_application_settings_path
expect
(
RepositoryCheck
::
ClearWorker
).
to
receive
(
:perform_async
)
expect
(
RepositoryCheck
::
ClearWorker
).
to
receive
(
:perform_async
)
...
...
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