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
Jérome Perrin
gitlab-ce
Commits
b95918dd
Commit
b95918dd
authored
Apr 02, 2018
by
Douwe Maan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make error messages even more descriptive
parent
7143bb88
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
51 additions
and
37 deletions
+51
-37
lib/gitlab/url_blocker.rb
lib/gitlab/url_blocker.rb
+47
-33
spec/models/project_spec.rb
spec/models/project_spec.rb
+2
-2
spec/services/projects/import_service_spec.rb
spec/services/projects/import_service_spec.rb
+2
-2
No files found.
lib/gitlab/url_blocker.rb
View file @
b95918dd
...
@@ -10,28 +10,27 @@ module Gitlab
...
@@ -10,28 +10,27 @@ module Gitlab
begin
begin
uri
=
Addressable
::
URI
.
parse
(
url
)
uri
=
Addressable
::
URI
.
parse
(
url
)
# Allow imports from the GitLab instance itself but only from the configured ports
rescue
Addressable
::
URI
::
InvalidURIError
return
true
if
internal?
(
uri
)
raise
BlockedUrlError
,
"URI is invalid"
end
raise
BlockedUrlError
,
"Port is blocked"
if
blocked_port?
(
uri
.
port
,
valid_ports
)
raise
BlockedUrlError
,
"User is blocked"
if
blocked_user_or_hostname?
(
uri
.
user
)
raise
BlockedUrlError
,
"Hostname is blocked"
if
blocked_user_or_hostname?
(
uri
.
hostname
)
addrs_info
=
Addrinfo
.
getaddrinfo
(
uri
.
hostname
,
80
,
nil
,
:STREAM
)
# Allow imports from the GitLab instance itself but only from the configured ports
return
true
if
internal?
(
uri
)
if
!
allow_localhost
&&
localhost?
(
addrs_info
)
port
=
uri
.
port
||
uri
.
default_port
raise
BlockedUrlError
,
"Requests to localhost are blocked"
validate_port!
(
port
,
valid_ports
)
if
valid_ports
.
any?
end
validate_user!
(
uri
.
user
)
validate_hostname!
(
uri
.
hostname
)
if
!
allow_private_networks
&&
private_network?
(
addrs_info
)
begin
raise
BlockedUrlError
,
"Requests to the private local network are blocked"
addrs_info
=
Addrinfo
.
getaddrinfo
(
uri
.
hostname
,
port
,
nil
,
:STREAM
)
end
rescue
Addressable
::
URI
::
InvalidURIError
raise
BlockedUrlError
,
"URI is invalid"
rescue
SocketError
rescue
SocketError
return
return
true
end
end
validate_localhost!
(
addrs_info
)
unless
allow_localhost
validate_local_network!
(
addrs_info
)
unless
allow_private_networks
true
true
end
end
...
@@ -45,16 +44,42 @@ module Gitlab
...
@@ -45,16 +44,42 @@ module Gitlab
private
private
def
blocked_port?
(
port
,
valid_ports
)
def
validate_port!
(
port
,
valid_ports
)
return
false
if
port
.
blank?
||
valid_ports
.
blank?
return
if
port
.
blank?
# Only ports under 1024 are restricted
return
if
port
>=
1024
return
if
valid_ports
.
include?
(
port
)
raise
BlockedUrlError
,
"Only allowed ports are
#{
valid_ports
.
join
(
', '
)
}
, and any over 1024"
end
def
validate_user!
(
value
)
return
if
value
.
blank?
return
if
value
=~
/\A\p{Alnum}/
port
<
1024
&&
!
valid_ports
.
include?
(
port
)
raise
BlockedUrlError
,
"Username needs to start with an alphanumeric character"
end
end
def
blocked_user_or_hostname?
(
value
)
def
validate_hostname!
(
value
)
return
false
if
value
.
blank?
return
if
value
.
blank?
return
if
value
=~
/\A\p{Alnum}/
value
!~
/\A\p{Alnum}/
raise
BlockedUrlError
,
"Hostname needs to start with an alphanumeric character"
end
def
validate_localhost!
(
addrs_info
)
local_ips
=
[
"127.0.0.1"
,
"::1"
,
"0.0.0.0"
]
local_ips
.
concat
(
Socket
.
ip_address_list
.
map
(
&
:ip_address
))
return
if
(
local_ips
&
addrs_info
.
map
(
&
:ip_address
)).
empty?
raise
BlockedUrlError
,
"Requests to localhost are not allowed"
end
def
validate_local_network!
(
addrs_info
)
return
unless
addrs_info
.
any?
{
|
addr
|
addr
.
ipv4_private?
||
addr
.
ipv6_sitelocal?
}
raise
BlockedUrlError
,
"Requests to the local network are not allowed"
end
end
def
internal?
(
uri
)
def
internal?
(
uri
)
...
@@ -71,17 +96,6 @@ module Gitlab
...
@@ -71,17 +96,6 @@ module Gitlab
(
uri
.
port
.
blank?
||
uri
.
port
==
config
.
gitlab_shell
.
ssh_port
)
(
uri
.
port
.
blank?
||
uri
.
port
==
config
.
gitlab_shell
.
ssh_port
)
end
end
def
localhost?
(
addrs_info
)
blocked_ips
=
[
"127.0.0.1"
,
"::1"
,
"0.0.0.0"
]
blocked_ips
.
concat
(
Socket
.
ip_address_list
.
map
(
&
:ip_address
))
(
blocked_ips
&
addrs_info
.
map
(
&
:ip_address
)).
any?
end
def
private_network?
(
addrs_info
)
addrs_info
.
any?
{
|
addr
|
addr
.
ipv4_private?
||
addr
.
ipv6_sitelocal?
}
end
def
config
def
config
Gitlab
.
config
Gitlab
.
config
end
end
...
...
spec/models/project_spec.rb
View file @
b95918dd
...
@@ -224,14 +224,14 @@ describe Project do
...
@@ -224,14 +224,14 @@ describe Project do
project2
=
build
(
:project
,
import_url:
'http://localhost:9000/t.git'
)
project2
=
build
(
:project
,
import_url:
'http://localhost:9000/t.git'
)
expect
(
project2
).
to
be_invalid
expect
(
project2
).
to
be_invalid
expect
(
project2
.
errors
[
:import_url
]
).
to
include
(
'imports are not allowed from that URL
'
)
expect
(
project2
.
errors
[
:import_url
]
.
first
).
to
include
(
'Requests to localhost are not allowed
'
)
end
end
it
"does not allow blocked import_url port"
do
it
"does not allow blocked import_url port"
do
project2
=
build
(
:project
,
import_url:
'http://github.com:25/t.git'
)
project2
=
build
(
:project
,
import_url:
'http://github.com:25/t.git'
)
expect
(
project2
).
to
be_invalid
expect
(
project2
).
to
be_invalid
expect
(
project2
.
errors
[
:import_url
]
).
to
include
(
'imports are not allowed from that URL
'
)
expect
(
project2
.
errors
[
:import_url
]
.
first
).
to
include
(
'Only allowed ports are 22, 80, 443
'
)
end
end
describe
'project pending deletion'
do
describe
'project pending deletion'
do
...
...
spec/services/projects/import_service_spec.rb
View file @
b95918dd
...
@@ -156,7 +156,7 @@ describe Projects::ImportService do
...
@@ -156,7 +156,7 @@ describe Projects::ImportService do
result
=
described_class
.
new
(
project
,
user
).
execute
result
=
described_class
.
new
(
project
,
user
).
execute
expect
(
result
[
:status
]).
to
eq
:error
expect
(
result
[
:status
]).
to
eq
:error
expect
(
result
[
:message
]).
to
end_with
'Blocked import URL.'
expect
(
result
[
:message
]).
to
include
(
'Requests to localhost are not allowed'
)
end
end
it
'fails with port 25'
do
it
'fails with port 25'
do
...
@@ -165,7 +165,7 @@ describe Projects::ImportService do
...
@@ -165,7 +165,7 @@ describe Projects::ImportService do
result
=
described_class
.
new
(
project
,
user
).
execute
result
=
described_class
.
new
(
project
,
user
).
execute
expect
(
result
[
:status
]).
to
eq
:error
expect
(
result
[
:status
]).
to
eq
:error
expect
(
result
[
:message
]).
to
end_with
'Blocked import URL.'
expect
(
result
[
:message
]).
to
include
(
'Only allowed ports are 22, 80, 443'
)
end
end
end
end
...
...
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