diff options
author | Unknwon <u@gogs.io> | 2018-09-28 23:19:08 -0400 |
---|---|---|
committer | Unknwon <u@gogs.io> | 2018-09-28 23:19:29 -0400 |
commit | bd7d1e2f169d6cdfecd952a1d3ed55d0f49f4104 (patch) | |
tree | c6c0b5db2afb16081f3aecc8f441f7618f824a91 /pkg/tool | |
parent | aff0bbcc325d9564fcd2b08c2fd52281f0dfc486 (diff) |
routes: fix open redirect vulnerability (#5355)
Reported by @cezar97.
Diffstat (limited to 'pkg/tool')
-rw-r--r-- | pkg/tool/path.go | 12 | ||||
-rw-r--r-- | pkg/tool/path_test.go | 32 |
2 files changed, 44 insertions, 0 deletions
diff --git a/pkg/tool/path.go b/pkg/tool/path.go new file mode 100644 index 00000000..e478abc5 --- /dev/null +++ b/pkg/tool/path.go @@ -0,0 +1,12 @@ +// Copyright 2018 The Gogs Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package tool + +// IsSameSiteURLPath returns true if the URL path belongs to the same site, false otherwise. +// False: //url, http://url, /\url +// True: /url +func IsSameSiteURLPath(url string) bool { + return len(url) >= 2 && url[0] == '/' && url[1] != '/' && url[1] != '\\' +} diff --git a/pkg/tool/path_test.go b/pkg/tool/path_test.go new file mode 100644 index 00000000..530238ce --- /dev/null +++ b/pkg/tool/path_test.go @@ -0,0 +1,32 @@ +// Copyright 2018 The Gogs Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package tool + +import ( + "testing" + + . "github.com/smartystreets/goconvey/convey" +) + +func Test_IsSameSiteURLPath(t *testing.T) { + Convey("Check if a path belongs to the same site", t, func() { + testCases := []struct { + url string + expect bool + }{ + {"//github.com", false}, + {"http://github.com", false}, + {"https://github.com", false}, + {"/\\github.com", false}, + + {"/admin", true}, + {"/user/repo", true}, + } + + for _, tc := range testCases { + So(IsSameSiteURLPath(tc.url), ShouldEqual, tc.expect) + } + }) +} |