From fb1c919e5953d50d5dae4d31d6ac7b053e75606f Mon Sep 17 00:00:00 2001 From: Gabe Kangas Date: Tue, 5 Oct 2021 16:45:39 -0700 Subject: [PATCH] Fix the destination path. Closes #1455 (#1456) --- core/storageproviders/s3Storage.go | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/core/storageproviders/s3Storage.go b/core/storageproviders/s3Storage.go index 7bb014a08..27b62c7b7 100644 --- a/core/storageproviders/s3Storage.go +++ b/core/storageproviders/s3Storage.go @@ -5,6 +5,7 @@ import ( "fmt" "os" "path/filepath" + "strings" "github.com/owncast/owncast/core/data" "github.com/owncast/owncast/core/playlist" @@ -130,11 +131,16 @@ func (s *S3Storage) Save(filePath string, retryCount int) (string, error) { } defer file.Close() + // Convert the local path to the variant/file path by stripping the local storage location. + normalizedPath := strings.TrimPrefix(filePath, config.HLSStoragePath) + // Build the remote path by adding the "hls" path prefix. + remotePath := strings.Join([]string{"hls", normalizedPath}, "") + maxAgeSeconds := utils.GetCacheDurationSecondsForPath(filePath) cacheControlHeader := fmt.Sprintf("max-age=%d", maxAgeSeconds) uploadInput := &s3manager.UploadInput{ Bucket: aws.String(s.s3Bucket), // Bucket to be used - Key: aws.String(filePath), // Name of the file to be saved + Key: aws.String(remotePath), // Name of the file to be saved Body: file, // File CacheControl: &cacheControlHeader, }