mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Re-attempt to delete temporary upload if the file is locked by another process (#12447)
Replace all calls to os.Remove/os.RemoveAll by retrying util.Remove/util.RemoveAll and remove circular dependencies from util. Fix #12339 Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: silverwind <me@silverwind.io>
This commit is contained in:
		| @@ -8,9 +8,6 @@ import ( | ||||
| 	"net/url" | ||||
| 	"path" | ||||
| 	"strings" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| ) | ||||
|  | ||||
| // PathEscapeSegments escapes segments of a path while not escaping forward slash | ||||
| @@ -30,13 +27,11 @@ func URLJoin(base string, elems ...string) string { | ||||
| 	} | ||||
| 	baseURL, err := url.Parse(base) | ||||
| 	if err != nil { | ||||
| 		log.Error("URLJoin: Invalid base URL %s", base) | ||||
| 		return "" | ||||
| 	} | ||||
| 	joinedPath := path.Join(elems...) | ||||
| 	argURL, err := url.Parse(joinedPath) | ||||
| 	if err != nil { | ||||
| 		log.Error("URLJoin: Invalid arg %s", joinedPath) | ||||
| 		return "" | ||||
| 	} | ||||
| 	joinedURL := baseURL.ResolveReference(argURL).String() | ||||
| @@ -45,16 +40,3 @@ func URLJoin(base string, elems ...string) string { | ||||
| 	} | ||||
| 	return joinedURL | ||||
| } | ||||
|  | ||||
| // IsExternalURL checks if rawURL points to an external URL like http://example.com | ||||
| func IsExternalURL(rawURL string) bool { | ||||
| 	parsed, err := url.Parse(rawURL) | ||||
| 	if err != nil { | ||||
| 		return true | ||||
| 	} | ||||
| 	appURL, _ := url.Parse(setting.AppURL) | ||||
| 	if len(parsed.Host) != 0 && strings.Replace(parsed.Host, "www.", "", 1) != strings.Replace(appURL.Host, "www.", "", 1) { | ||||
| 		return true | ||||
| 	} | ||||
| 	return false | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user