mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-24 13:53:42 +09:00 
			
		
		
		
	Redirect to a presigned URL of HEAD for HEAD requests (#35088)
Resolves https://github.com/go-gitea/gitea/issues/35086. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -20,7 +20,7 @@ func IsArtifactV4(art *actions_model.ActionArtifact) bool { | ||||
|  | ||||
| func DownloadArtifactV4ServeDirectOnly(ctx *context.Base, art *actions_model.ActionArtifact) (bool, error) { | ||||
| 	if setting.Actions.ArtifactStorage.ServeDirect() { | ||||
| 		u, err := storage.ActionsArtifacts.URL(art.StoragePath, art.ArtifactPath, nil) | ||||
| 		u, err := storage.ActionsArtifacts.URL(art.StoragePath, art.ArtifactPath, ctx.Req.Method, nil) | ||||
| 		if u != nil && err == nil { | ||||
| 			ctx.Redirect(u.String(), http.StatusFound) | ||||
| 			return true, nil | ||||
|   | ||||
| @@ -36,8 +36,8 @@ func (s *ContentStore) ShouldServeDirect() bool { | ||||
| 	return setting.Packages.Storage.ServeDirect() | ||||
| } | ||||
|  | ||||
| func (s *ContentStore) GetServeDirectURL(key BlobHash256Key, filename string, reqParams url.Values) (*url.URL, error) { | ||||
| 	return s.store.URL(KeyToRelativePath(key), filename, reqParams) | ||||
| func (s *ContentStore) GetServeDirectURL(key BlobHash256Key, filename, method string, reqParams url.Values) (*url.URL, error) { | ||||
| 	return s.store.URL(KeyToRelativePath(key), filename, method, reqParams) | ||||
| } | ||||
|  | ||||
| // FIXME: Workaround to be removed in v1.20 | ||||
|   | ||||
| @@ -247,7 +247,7 @@ func (a *AzureBlobStorage) Delete(path string) error { | ||||
| } | ||||
|  | ||||
| // URL gets the redirect URL to a file. The presigned link is valid for 5 minutes. | ||||
| func (a *AzureBlobStorage) URL(path, name string, reqParams url.Values) (*url.URL, error) { | ||||
| func (a *AzureBlobStorage) URL(path, name, _ string, reqParams url.Values) (*url.URL, error) { | ||||
| 	blobClient := a.getBlobClient(path) | ||||
|  | ||||
| 	startTime := time.Now() | ||||
|   | ||||
| @@ -30,7 +30,7 @@ func (s discardStorage) Delete(_ string) error { | ||||
| 	return fmt.Errorf("%s", s) | ||||
| } | ||||
|  | ||||
| func (s discardStorage) URL(_, _ string, _ url.Values) (*url.URL, error) { | ||||
| func (s discardStorage) URL(_, _, _ string, _ url.Values) (*url.URL, error) { | ||||
| 	return nil, fmt.Errorf("%s", s) | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -37,7 +37,7 @@ func Test_discardStorage(t *testing.T) { | ||||
| 				assert.Error(t, err, string(tt)) | ||||
| 			} | ||||
| 			{ | ||||
| 				got, err := tt.URL("path", "name", nil) | ||||
| 				got, err := tt.URL("path", "name", "GET", nil) | ||||
| 				assert.Nil(t, got) | ||||
| 				assert.Errorf(t, err, string(tt)) | ||||
| 			} | ||||
|   | ||||
| @@ -114,7 +114,7 @@ func (l *LocalStorage) Delete(path string) error { | ||||
| } | ||||
|  | ||||
| // URL gets the redirect URL to a file | ||||
| func (l *LocalStorage) URL(path, name string, reqParams url.Values) (*url.URL, error) { | ||||
| func (l *LocalStorage) URL(path, name, _ string, reqParams url.Values) (*url.URL, error) { | ||||
| 	return nil, ErrURLNotSupported | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -279,7 +279,7 @@ func (m *MinioStorage) Delete(path string) error { | ||||
| } | ||||
|  | ||||
| // URL gets the redirect URL to a file. The presigned link is valid for 5 minutes. | ||||
| func (m *MinioStorage) URL(path, name string, serveDirectReqParams url.Values) (*url.URL, error) { | ||||
| func (m *MinioStorage) URL(path, name, method string, serveDirectReqParams url.Values) (*url.URL, error) { | ||||
| 	// copy serveDirectReqParams | ||||
| 	reqParams, err := url.ParseQuery(serveDirectReqParams.Encode()) | ||||
| 	if err != nil { | ||||
| @@ -287,7 +287,12 @@ func (m *MinioStorage) URL(path, name string, serveDirectReqParams url.Values) ( | ||||
| 	} | ||||
| 	// TODO it may be good to embed images with 'inline' like ServeData does, but we don't want to have to read the file, do we? | ||||
| 	reqParams.Set("response-content-disposition", "attachment; filename=\""+quoteEscaper.Replace(name)+"\"") | ||||
| 	u, err := m.client.PresignedGetObject(m.ctx, m.bucket, m.buildMinioPath(path), 5*time.Minute, reqParams) | ||||
| 	expires := 5 * time.Minute | ||||
| 	if method == http.MethodHead { | ||||
| 		u, err := m.client.PresignedHeadObject(m.ctx, m.bucket, m.buildMinioPath(path), expires, reqParams) | ||||
| 		return u, convertMinioErr(err) | ||||
| 	} | ||||
| 	u, err := m.client.PresignedGetObject(m.ctx, m.bucket, m.buildMinioPath(path), expires, reqParams) | ||||
| 	return u, convertMinioErr(err) | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -63,7 +63,7 @@ type ObjectStorage interface { | ||||
| 	Save(path string, r io.Reader, size int64) (int64, error) | ||||
| 	Stat(path string) (os.FileInfo, error) | ||||
| 	Delete(path string) error | ||||
| 	URL(path, name string, reqParams url.Values) (*url.URL, error) | ||||
| 	URL(path, name, method string, reqParams url.Values) (*url.URL, error) | ||||
| 	IterateObjects(path string, iterator func(path string, obj Object) error) error | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user