BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
gitlab-ce
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
gitlab-ce
Commits
7ea641b6
Commit
7ea641b6
authored
Feb 21, 2017
by
Douwe Maan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Enable Style/ColonMethodCall
parent
b2da4623
Hide whitespace changes
Inline
Side-by-side
Showing
27 changed files
with
36 additions
and
38 deletions
+36
-38
.rubocop.yml
.rubocop.yml
+3
-0
.rubocop_todo.yml
.rubocop_todo.yml
+0
-5
two_factor_auths_controller.rb
app/controllers/profiles/two_factor_auths_controller.rb
+1
-1
commit.rb
app/models/commit.rb
+1
-1
drone_ci_service.rb
app/models/project_services/drone_ci_service.rb
+2
-2
repository.rb
app/models/repository.rb
+1
-1
download_service.rb
app/services/projects/download_service.rb
+1
-1
irker_worker.rb
app/workers/irker_worker.rb
+3
-3
notes.rb
lib/api/notes.rb
+1
-1
repo.rb
lib/bitbucket/representation/repo.rb
+1
-1
gon_helper.rb
lib/gitlab/gon_helper.rb
+1
-1
shell.rb
lib/gitlab/shell.rb
+1
-1
dashboard_issues_spec.rb
spec/features/atom/dashboard_issues_spec.rb
+1
-1
issues_spec.rb
spec/features/atom/issues_spec.rb
+2
-2
dashboard_issues_spec.rb
spec/features/dashboard_issues_spec.rb
+2
-2
export_file_spec.rb
spec/features/projects/import_export/export_file_spec.rb
+1
-1
import_file_spec.rb
spec/features/projects/import_export/import_file_spec.rb
+1
-1
namespace_export_file_spec.rb
...ures/projects/import_export/namespace_export_file_spec.rb
+1
-1
blob_spec.rb
spec/lib/gitlab/git/blob_spec.rb
+1
-1
git_spec.rb
spec/lib/gitlab/git_spec.rb
+3
-3
avatar_saver_spec.rb
spec/lib/gitlab/import_export/avatar_saver_spec.rb
+1
-1
file_importer_spec.rb
spec/lib/gitlab/import_export/file_importer_spec.rb
+1
-1
project_tree_saver_spec.rb
spec/lib/gitlab/import_export/project_tree_saver_spec.rb
+1
-1
repo_bundler_spec.rb
spec/lib/gitlab/import_export/repo_bundler_spec.rb
+1
-1
wiki_repo_bundler_spec.rb
spec/lib/gitlab/import_export/wiki_repo_bundler_spec.rb
+1
-1
kubernetes_spec.rb
spec/lib/gitlab/kubernetes_spec.rb
+1
-1
git_garbage_collect_worker_spec.rb
spec/workers/git_garbage_collect_worker_spec.rb
+2
-2
No files found.
.rubocop.yml
View file @
7ea641b6
...
...
@@ -959,6 +959,9 @@ Style/BracesAroundHashParameters:
Style/CaseEquality
:
Enabled
:
false
Style/ColonMethodCall
:
Enabled
:
true
Style/CommentAnnotation
:
Enabled
:
false
...
...
.rubocop_todo.yml
View file @
7ea641b6
...
...
@@ -38,11 +38,6 @@ RSpec/SingleArgumentMessageChain:
Exclude
:
-
'
spec/requests/api/internal_spec.rb'
# Offense count: 33
# Cop supports --auto-correct.
Style/ColonMethodCall
:
Enabled
:
false
# Offense count: 32
# Cop supports --auto-correct.
# Configuration parameters: EnforcedStyle, SupportedStyles, SingleLineConditionsOnly.
...
...
app/controllers/profiles/two_factor_auths_controller.rb
View file @
7ea641b6
...
...
@@ -80,7 +80,7 @@ class Profiles::TwoFactorAuthsController < Profiles::ApplicationController
def
build_qr_code
uri
=
current_user
.
otp_provisioning_uri
(
account_string
,
issuer:
issuer_host
)
RQRCode
::
render_qrcode
(
uri
,
:svg
,
level: :m
,
unit:
3
)
RQRCode
.
render_qrcode
(
uri
,
:svg
,
level: :m
,
unit:
3
)
end
def
account_string
...
...
app/models/commit.rb
View file @
7ea641b6
...
...
@@ -105,7 +105,7 @@ class Commit
end
def
diff_line_count
@diff_line_count
||=
Commit
::
diff_line_count
(
raw_diffs
)
@diff_line_count
||=
Commit
.
diff_line_count
(
raw_diffs
)
@diff_line_count
end
...
...
app/models/project_services/drone_ci_service.rb
View file @
7ea641b6
...
...
@@ -39,7 +39,7 @@ class DroneCiService < CiService
def
commit_status_path
(
sha
,
ref
)
url
=
[
drone_url
,
"gitlab/
#{
project
.
full_path
}
/commits/
#{
sha
}
"
,
"?branch=
#{
URI
::
encode
(
ref
.
to_s
)
}
&access_token=
#{
token
}
"
]
"?branch=
#{
URI
.
encode
(
ref
.
to_s
)
}
&access_token=
#{
token
}
"
]
URI
.
join
(
*
url
).
to_s
end
...
...
@@ -74,7 +74,7 @@ class DroneCiService < CiService
def
build_page
(
sha
,
ref
)
url
=
[
drone_url
,
"gitlab/
#{
project
.
full_path
}
/redirect/commits/
#{
sha
}
"
,
"?branch=
#{
URI
::
encode
(
ref
.
to_s
)
}
"
]
"?branch=
#{
URI
.
encode
(
ref
.
to_s
)
}
"
]
URI
.
join
(
*
url
).
to_s
end
...
...
app/models/repository.rb
View file @
7ea641b6
...
...
@@ -892,7 +892,7 @@ class Repository
def
get_committer_and_author
(
user
,
email:
nil
,
name:
nil
)
committer
=
user_to_committer
(
user
)
author
=
Gitlab
::
Git
::
committer_hash
(
email:
email
,
name:
name
)
||
committer
author
=
Gitlab
::
Git
.
committer_hash
(
email:
email
,
name:
name
)
||
committer
{
author:
author
,
...
...
app/services/projects/download_service.rb
View file @
7ea641b6
...
...
@@ -25,7 +25,7 @@ module Projects
end
def
http?
(
url
)
url
=~
/\A
#{
URI
::
regexp
([
'http'
,
'https'
])
}
\z/
url
=~
/\A
#{
URI
.
regexp
([
'http'
,
'https'
])
}
\z/
end
def
valid_domain?
(
url
)
...
...
app/workers/irker_worker.rb
View file @
7ea641b6
...
...
@@ -120,8 +120,8 @@ class IrkerWorker
end
def
compare_url
(
data
,
repo_path
)
sha1
=
Commit
::
truncate_sha
(
data
[
'before'
])
sha2
=
Commit
::
truncate_sha
(
data
[
'after'
])
sha1
=
Commit
.
truncate_sha
(
data
[
'before'
])
sha2
=
Commit
.
truncate_sha
(
data
[
'after'
])
compare_url
=
"
#{
Gitlab
.
config
.
gitlab
.
url
}
/
#{
repo_path
}
/compare"
compare_url
+=
"/
#{
sha1
}
...
#{
sha2
}
"
colorize_url
compare_url
...
...
@@ -129,7 +129,7 @@ class IrkerWorker
def
send_one_commit
(
project
,
hook_attrs
,
repo_name
,
branch
)
commit
=
commit_from_id
project
,
hook_attrs
[
'id'
]
sha
=
colorize_sha
Commit
::
truncate_sha
(
hook_attrs
[
'id'
])
sha
=
colorize_sha
Commit
.
truncate_sha
(
hook_attrs
[
'id'
])
author
=
hook_attrs
[
'author'
][
'name'
]
files
=
colorize_nb_files
(
files_count
commit
)
title
=
commit
.
title
...
...
lib/api/notes.rb
View file @
7ea641b6
...
...
@@ -85,7 +85,7 @@ module API
note
=
::
Notes
::
CreateService
.
new
(
user_project
,
current_user
,
opts
).
execute
if
note
.
valid?
present
note
,
with:
Entities
::
const_get
(
note
.
class
.
name
)
present
note
,
with:
Entities
.
const_get
(
note
.
class
.
name
)
else
not_found!
(
"Note
#{
note
.
errors
.
messages
}
"
)
end
...
...
lib/bitbucket/representation/repo.rb
View file @
7ea641b6
...
...
@@ -23,7 +23,7 @@ module Bitbucket
url
=
raw
[
'links'
][
'clone'
].
find
{
|
link
|
link
[
'name'
]
==
'https'
}.
fetch
(
'href'
)
if
token
.
present?
clone_url
=
URI
::
parse
(
url
)
clone_url
=
URI
.
parse
(
url
)
clone_url
.
user
=
"x-token-auth:
#{
token
}
"
clone_url
.
to_s
else
...
...
lib/gitlab/gon_helper.rb
View file @
7ea641b6
...
...
@@ -2,7 +2,7 @@ module Gitlab
module
GonHelper
def
add_gon_variables
gon
.
api_version
=
API
::
API
.
version
gon
.
default_avatar_url
=
URI
::
join
(
Gitlab
.
config
.
gitlab
.
url
,
ActionController
::
Base
.
helpers
.
image_path
(
'no_avatar.png'
)).
to_s
gon
.
default_avatar_url
=
URI
.
join
(
Gitlab
.
config
.
gitlab
.
url
,
ActionController
::
Base
.
helpers
.
image_path
(
'no_avatar.png'
)).
to_s
gon
.
max_file_size
=
current_application_settings
.
max_attachment_size
gon
.
relative_url_root
=
Gitlab
.
config
.
gitlab
.
relative_url_root
gon
.
shortcuts_path
=
help_page_path
(
'shortcuts'
)
...
...
lib/gitlab/shell.rb
View file @
7ea641b6
...
...
@@ -82,7 +82,7 @@ module Gitlab
def
import_repository
(
storage
,
name
,
url
)
# Timeout should be less than 900 ideally, to prevent the memory killer
# to silently kill the process without knowing we are timing out here.
output
,
status
=
Popen
::
popen
([
gitlab_shell_projects_path
,
'import-project'
,
output
,
status
=
Popen
.
popen
([
gitlab_shell_projects_path
,
'import-project'
,
storage
,
"
#{
name
}
.git"
,
url
,
'800'
])
raise
Error
,
output
unless
status
.
zero?
true
...
...
spec/features/atom/dashboard_issues_spec.rb
View file @
7ea641b6
...
...
@@ -23,7 +23,7 @@ describe "Dashboard Issues Feed", feature: true do
visit
issues_dashboard_path
(
:atom
,
private_token:
user
.
private_token
,
state:
'opened'
,
assignee_id:
user
.
id
)
link
=
find
(
'link[type="application/atom+xml"]'
)
params
=
CGI
::
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
params
=
CGI
.
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
expect
(
params
).
to
include
(
'private_token'
=>
[
user
.
private_token
])
expect
(
params
).
to
include
(
'state'
=>
[
'opened'
])
...
...
spec/features/atom/issues_spec.rb
View file @
7ea641b6
...
...
@@ -43,7 +43,7 @@ describe 'Issues Feed', feature: true do
:atom
,
private_token:
user
.
private_token
,
state:
'opened'
,
assignee_id:
user
.
id
)
link
=
find
(
'link[type="application/atom+xml"]'
)
params
=
CGI
::
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
params
=
CGI
.
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
expect
(
params
).
to
include
(
'private_token'
=>
[
user
.
private_token
])
expect
(
params
).
to
include
(
'state'
=>
[
'opened'
])
...
...
@@ -54,7 +54,7 @@ describe 'Issues Feed', feature: true do
visit
issues_group_path
(
group
,
:atom
,
private_token:
user
.
private_token
,
state:
'opened'
,
assignee_id:
user
.
id
)
link
=
find
(
'link[type="application/atom+xml"]'
)
params
=
CGI
::
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
params
=
CGI
.
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
expect
(
params
).
to
include
(
'private_token'
=>
[
user
.
private_token
])
expect
(
params
).
to
include
(
'state'
=>
[
'opened'
])
...
...
spec/features/dashboard_issues_spec.rb
View file @
7ea641b6
...
...
@@ -49,9 +49,9 @@ describe "Dashboard Issues filtering", feature: true, js: true do
visit_issues
(
milestone_title:
''
,
assignee_id:
user
.
id
)
link
=
find
(
'.nav-controls a'
,
text:
'Subscribe'
)
params
=
CGI
::
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
params
=
CGI
.
parse
(
URI
.
parse
(
link
[
:href
]).
query
)
auto_discovery_link
=
find
(
'link[type="application/atom+xml"]'
,
visible:
false
)
auto_discovery_params
=
CGI
::
parse
(
URI
.
parse
(
auto_discovery_link
[
:href
]).
query
)
auto_discovery_params
=
CGI
.
parse
(
URI
.
parse
(
auto_discovery_link
[
:href
]).
query
)
expect
(
params
).
to
include
(
'private_token'
=>
[
user
.
private_token
])
expect
(
params
).
to
include
(
'milestone_title'
=>
[
''
])
...
...
spec/features/projects/import_export/export_file_spec.rb
View file @
7ea641b6
...
...
@@ -9,7 +9,7 @@ feature 'Import/Export - project export integration test', feature: true, js: tr
include
ExportFileHelper
let
(
:user
)
{
create
(
:admin
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/import_file_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/import_file_spec"
}
let
(
:config_hash
)
{
YAML
.
load_file
(
Gitlab
::
ImportExport
.
config_file
).
deep_stringify_keys
}
let
(
:sensitive_words
)
{
%w[pass secret token key]
}
...
...
spec/features/projects/import_export/import_file_spec.rb
View file @
7ea641b6
...
...
@@ -4,7 +4,7 @@ feature 'Import/Export - project import integration test', feature: true, js: tr
include
Select2Helper
let
(
:file
)
{
File
.
join
(
Rails
.
root
,
'spec'
,
'features'
,
'projects'
,
'import_export'
,
'test_project_export.tar.gz'
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/import_file_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/import_file_spec"
}
background
do
allow_any_instance_of
(
Gitlab
::
ImportExport
).
to
receive
(
:storage_path
).
and_return
(
export_path
)
...
...
spec/features/projects/import_export/namespace_export_file_spec.rb
View file @
7ea641b6
require
'spec_helper'
feature
'Import/Export - Namespace export file cleanup'
,
feature:
true
,
js:
true
do
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/import_file_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/import_file_spec"
}
let
(
:config_hash
)
{
YAML
.
load_file
(
Gitlab
::
ImportExport
.
config_file
).
deep_stringify_keys
}
let
(
:project
)
{
create
(
:empty_project
)
}
...
...
spec/lib/gitlab/git/blob_spec.rb
View file @
7ea641b6
...
...
@@ -292,7 +292,7 @@ describe Gitlab::Git::Blob, seed_helper: true do
it
'should preserve file modes with commit'
do
commit_options
[
:file
][
:path
]
=
'files/executables/ls'
entry
=
Gitlab
::
Git
::
Blob
::
find_entry_by_path
(
repository
,
commit
.
tree
.
oid
,
commit_options
[
:file
][
:path
])
entry
=
Gitlab
::
Git
::
Blob
.
find_entry_by_path
(
repository
,
commit
.
tree
.
oid
,
commit_options
[
:file
][
:path
])
expect
(
entry
[
:filemode
]).
to
eq
(
0100755
)
end
end
...
...
spec/lib/gitlab/git_spec.rb
View file @
7ea641b6
...
...
@@ -19,7 +19,7 @@ describe Gitlab::Git, lib: true do
describe
'committer_hash'
do
it
"returns a hash containing the given email and name"
do
committer_hash
=
Gitlab
::
Git
::
committer_hash
(
email:
committer_email
,
name:
committer_name
)
committer_hash
=
Gitlab
::
Git
.
committer_hash
(
email:
committer_email
,
name:
committer_name
)
expect
(
committer_hash
[
:email
]).
to
eq
(
committer_email
)
expect
(
committer_hash
[
:name
]).
to
eq
(
committer_name
)
...
...
@@ -28,7 +28,7 @@ describe Gitlab::Git, lib: true do
context
'when email is nil'
do
it
"returns nil"
do
committer_hash
=
Gitlab
::
Git
::
committer_hash
(
email:
nil
,
name:
committer_name
)
committer_hash
=
Gitlab
::
Git
.
committer_hash
(
email:
nil
,
name:
committer_name
)
expect
(
committer_hash
).
to
be_nil
end
...
...
@@ -36,7 +36,7 @@ describe Gitlab::Git, lib: true do
context
'when name is nil'
do
it
"returns nil"
do
committer_hash
=
Gitlab
::
Git
::
committer_hash
(
email:
committer_email
,
name:
nil
)
committer_hash
=
Gitlab
::
Git
.
committer_hash
(
email:
committer_email
,
name:
nil
)
expect
(
committer_hash
).
to
be_nil
end
...
...
spec/lib/gitlab/import_export/avatar_saver_spec.rb
View file @
7ea641b6
...
...
@@ -2,7 +2,7 @@ require 'spec_helper'
describe
Gitlab
::
ImportExport
::
AvatarSaver
,
lib:
true
do
let
(
:shared
)
{
Gitlab
::
ImportExport
::
Shared
.
new
(
relative_path:
'test'
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/project_tree_saver_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/project_tree_saver_spec"
}
let
(
:project_with_avatar
)
{
create
(
:empty_project
,
avatar:
fixture_file_upload
(
Rails
.
root
+
"spec/fixtures/dk.png"
,
"image/png"
))
}
let
(
:project
)
{
create
(
:empty_project
)
}
...
...
spec/lib/gitlab/import_export/file_importer_spec.rb
View file @
7ea641b6
...
...
@@ -2,7 +2,7 @@ require 'spec_helper'
describe
Gitlab
::
ImportExport
::
FileImporter
,
lib:
true
do
let
(
:shared
)
{
Gitlab
::
ImportExport
::
Shared
.
new
(
relative_path:
'test'
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/file_importer_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/file_importer_spec"
}
let
(
:valid_file
)
{
"
#{
shared
.
export_path
}
/valid.json"
}
let
(
:symlink_file
)
{
"
#{
shared
.
export_path
}
/invalid.json"
}
let
(
:subfolder_symlink_file
)
{
"
#{
shared
.
export_path
}
/subfolder/invalid.json"
}
...
...
spec/lib/gitlab/import_export/project_tree_saver_spec.rb
View file @
7ea641b6
...
...
@@ -4,7 +4,7 @@ describe Gitlab::ImportExport::ProjectTreeSaver, services: true do
describe
'saves the project tree into a json object'
do
let
(
:shared
)
{
Gitlab
::
ImportExport
::
Shared
.
new
(
relative_path:
project
.
path_with_namespace
)
}
let
(
:project_tree_saver
)
{
described_class
.
new
(
project:
project
,
current_user:
user
,
shared:
shared
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/project_tree_saver_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/project_tree_saver_spec"
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
setup_project
}
...
...
spec/lib/gitlab/import_export/repo_bundler_spec.rb
View file @
7ea641b6
...
...
@@ -4,7 +4,7 @@ describe Gitlab::ImportExport::RepoSaver, services: true do
describe
'bundle a project Git repo'
do
let
(
:user
)
{
create
(
:user
)
}
let!
(
:project
)
{
create
(
:empty_project
,
:public
,
name:
'searchable_project'
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/project_tree_saver_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/project_tree_saver_spec"
}
let
(
:shared
)
{
Gitlab
::
ImportExport
::
Shared
.
new
(
relative_path:
project
.
path_with_namespace
)
}
let
(
:bundler
)
{
described_class
.
new
(
project:
project
,
shared:
shared
)
}
...
...
spec/lib/gitlab/import_export/wiki_repo_bundler_spec.rb
View file @
7ea641b6
...
...
@@ -4,7 +4,7 @@ describe Gitlab::ImportExport::WikiRepoSaver, services: true do
describe
'bundle a wiki Git repo'
do
let
(
:user
)
{
create
(
:user
)
}
let!
(
:project
)
{
create
(
:empty_project
,
:public
,
name:
'searchable_project'
)
}
let
(
:export_path
)
{
"
#{
Dir
::
tmpdir
}
/project_tree_saver_spec"
}
let
(
:export_path
)
{
"
#{
Dir
.
tmpdir
}
/project_tree_saver_spec"
}
let
(
:shared
)
{
Gitlab
::
ImportExport
::
Shared
.
new
(
relative_path:
project
.
path_with_namespace
)
}
let
(
:wiki_bundler
)
{
described_class
.
new
(
project:
project
,
shared:
shared
)
}
let!
(
:project_wiki
)
{
ProjectWiki
.
new
(
project
,
user
)
}
...
...
spec/lib/gitlab/kubernetes_spec.rb
View file @
7ea641b6
...
...
@@ -9,7 +9,7 @@ describe Gitlab::Kubernetes do
let
(
:pod_name
)
{
'pod1'
}
let
(
:container_name
)
{
'container1'
}
subject
(
:result
)
{
URI
::
parse
(
container_exec_url
(
api_url
,
namespace
,
pod_name
,
container_name
))
}
subject
(
:result
)
{
URI
.
parse
(
container_exec_url
(
api_url
,
namespace
,
pod_name
,
container_name
))
}
it
{
expect
(
result
.
scheme
).
to
eq
(
'wss'
)
}
it
{
expect
(
result
.
host
).
to
eq
(
'example.com'
)
}
...
...
spec/workers/git_garbage_collect_worker_spec.rb
View file @
7ea641b6
...
...
@@ -102,8 +102,8 @@ describe GitGarbageCollectWorker do
new_commit_sha
=
Rugged
::
Commit
.
create
(
rugged
,
message:
"hello world
#{
SecureRandom
.
hex
(
6
)
}
"
,
author:
Gitlab
::
Git
::
committer_hash
(
email:
'foo@bar'
,
name:
'baz'
),
committer:
Gitlab
::
Git
::
committer_hash
(
email:
'foo@bar'
,
name:
'baz'
),
author:
Gitlab
::
Git
.
committer_hash
(
email:
'foo@bar'
,
name:
'baz'
),
committer:
Gitlab
::
Git
.
committer_hash
(
email:
'foo@bar'
,
name:
'baz'
),
tree:
old_commit
.
tree
,
parents:
[
old_commit
],
)
...
...
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