fix: restrict SCP-like URLs to git user only and reject path traversal
- Changed SCP regex to only accept 'git' as the username - Added path traversal check: reject URLs containing '..' - Added test cases for non-git users and path traversal
This commit is contained in:
parent
b4b2a33089
commit
214b5f83ba
@ -17,7 +17,8 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// scpLikeRepoRe matches SCP-like git URLs: git@host:path (e.g. git@github.com:user/repo.git).
|
// scpLikeRepoRe matches SCP-like git URLs: git@host:path (e.g. git@github.com:user/repo.git).
|
||||||
var scpLikeRepoRe = regexp.MustCompile(`^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]+:.+$`)
|
// Only the "git" user is allowed, as that is the standard for SSH deploy keys.
|
||||||
|
var scpLikeRepoRe = regexp.MustCompile(`^git@[a-zA-Z0-9._-]+:.+$`)
|
||||||
|
|
||||||
// validateRepoURL checks that the given repository URL is valid and uses an allowed scheme.
|
// validateRepoURL checks that the given repository URL is valid and uses an allowed scheme.
|
||||||
func validateRepoURL(repoURL string) error {
|
func validateRepoURL(repoURL string) error {
|
||||||
@ -25,6 +26,11 @@ func validateRepoURL(repoURL string) error {
|
|||||||
return errRepoURLEmpty
|
return errRepoURLEmpty
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reject path traversal in any URL format
|
||||||
|
if strings.Contains(repoURL, "..") {
|
||||||
|
return errRepoURLInvalid
|
||||||
|
}
|
||||||
|
|
||||||
// Check for SCP-like git URLs first (git@host:path)
|
// Check for SCP-like git URLs first (git@host:path)
|
||||||
if scpLikeRepoRe.MatchString(repoURL) {
|
if scpLikeRepoRe.MatchString(repoURL) {
|
||||||
return nil
|
return nil
|
||||||
|
|||||||
@ -32,6 +32,11 @@ func TestValidateRepoURL(t *testing.T) {
|
|||||||
{name: "no host https", url: "https:///path", wantErr: true},
|
{name: "no host https", url: "https:///path", wantErr: true},
|
||||||
{name: "no path https", url: "https://github.com", wantErr: true},
|
{name: "no path https", url: "https://github.com", wantErr: true},
|
||||||
{name: "no path https trailing slash", url: "https://github.com/", wantErr: true},
|
{name: "no path https trailing slash", url: "https://github.com/", wantErr: true},
|
||||||
|
{name: "SCP-like non-git user", url: "root@github.com:user/repo.git", wantErr: true},
|
||||||
|
{name: "SCP-like arbitrary user", url: "admin@github.com:user/repo.git", wantErr: true},
|
||||||
|
{name: "path traversal SCP", url: "git@github.com:../../etc/passwd", wantErr: true},
|
||||||
|
{name: "path traversal https", url: "https://github.com/user/../../../etc/passwd", wantErr: true},
|
||||||
|
{name: "path traversal in middle", url: "https://github.com/user/repo/../secret", wantErr: true},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range tests {
|
for _, tc := range tests {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user