From e375ea232ac33bf7a5d45f1bca22d5a718a4a930 Mon Sep 17 00:00:00 2001 From: Tom Funken Date: Fri, 22 Sep 2023 02:58:02 +0200 Subject: [PATCH] Renamed rewriteRemotePlaylist (#3313) * Add support for remote serving endpoint on local storage * Renamed rewriteRemotePlaylist --- core/storageproviders/local.go | 17 ++++++++++++++--- core/storageproviders/rewriteLocalPlaylist.go | 4 ++-- core/storageproviders/s3Storage.go | 2 +- 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/core/storageproviders/local.go b/core/storageproviders/local.go index f71306ca6..966893b24 100644 --- a/core/storageproviders/local.go +++ b/core/storageproviders/local.go @@ -13,7 +13,9 @@ import ( ) // LocalStorage represents an instance of the local storage provider for HLS video. -type LocalStorage struct{} +type LocalStorage struct { + host string +} // NewLocalStorage returns a new LocalStorage instance. func NewLocalStorage() *LocalStorage { @@ -22,6 +24,7 @@ func NewLocalStorage() *LocalStorage { // Setup configures this storage provider. func (s *LocalStorage) Setup() error { + s.host = data.GetVideoServingEndpoint() return nil } @@ -42,8 +45,16 @@ func (s *LocalStorage) VariantPlaylistWritten(localFilePath string) { // MasterPlaylistWritten is called when the master hls playlist is written. func (s *LocalStorage) MasterPlaylistWritten(localFilePath string) { - if _, err := s.Save(localFilePath, 0); err != nil { - log.Warnln(err) + + // If we're using a remote serving endpoint, we need to rewrite the master playlist + if s.host != "" { + if err := rewritePlaylistLocations(localFilePath, s.host, ""); err != nil { + log.Warnln(err) + } + } else { + if _, err := s.Save(localFilePath, 0); err != nil { + log.Warnln(err) + } } } diff --git a/core/storageproviders/rewriteLocalPlaylist.go b/core/storageproviders/rewriteLocalPlaylist.go index 5ba433ee2..51070d84a 100644 --- a/core/storageproviders/rewriteLocalPlaylist.go +++ b/core/storageproviders/rewriteLocalPlaylist.go @@ -12,8 +12,8 @@ import ( log "github.com/sirupsen/logrus" ) -// rewriteRemotePlaylist will take a local playlist and rewrite it to have absolute URLs to remote locations. -func rewriteRemotePlaylist(localFilePath, remoteServingEndpoint, pathPrefix string) error { +// rewritePlaylistLocations will take a local playlist and rewrite it to have absolute URLs to a specified location. +func rewritePlaylistLocations(localFilePath, remoteServingEndpoint, pathPrefix string) error { f, err := os.Open(localFilePath) // nolint if err != nil { log.Fatalln(err) diff --git a/core/storageproviders/s3Storage.go b/core/storageproviders/s3Storage.go index e73233305..dbe0ce576 100644 --- a/core/storageproviders/s3Storage.go +++ b/core/storageproviders/s3Storage.go @@ -136,7 +136,7 @@ func (s *S3Storage) VariantPlaylistWritten(localFilePath string) { // MasterPlaylistWritten is called when the master hls playlist is written. func (s *S3Storage) MasterPlaylistWritten(localFilePath string) { // Rewrite the playlist to use absolute remote S3 URLs - if err := rewriteRemotePlaylist(localFilePath, s.host, s.s3PathPrefix); err != nil { + if err := rewritePlaylistLocations(localFilePath, s.host, s.s3PathPrefix); err != nil { log.Warnln(err) } }