2020-10-15 00:07:38 +03:00
|
|
|
package storageproviders
|
|
|
|
|
|
|
|
import (
|
2020-10-16 03:50:17 +03:00
|
|
|
"time"
|
2020-10-15 00:07:38 +03:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
|
|
|
"github.com/owncast/owncast/config"
|
2023-05-31 00:05:24 +03:00
|
|
|
"github.com/owncast/owncast/core/data"
|
2021-02-19 10:05:52 +03:00
|
|
|
"github.com/owncast/owncast/core/transcoder"
|
2020-10-15 00:07:38 +03:00
|
|
|
)
|
|
|
|
|
2021-09-12 10:18:15 +03:00
|
|
|
// LocalStorage represents an instance of the local storage provider for HLS video.
|
2020-10-15 00:07:38 +03:00
|
|
|
type LocalStorage struct {
|
2021-10-12 02:29:36 +03:00
|
|
|
// Cleanup old public HLS content every N min from the webroot.
|
2023-05-31 00:05:24 +03:00
|
|
|
onlineCleanupTicker *time.Ticker
|
|
|
|
customVideoServingEndpoint string
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|
|
|
|
|
2021-10-12 02:29:36 +03:00
|
|
|
// NewLocalStorage returns a new LocalStorage instance.
|
|
|
|
func NewLocalStorage() *LocalStorage {
|
|
|
|
return &LocalStorage{}
|
|
|
|
}
|
2020-10-16 03:50:17 +03:00
|
|
|
|
2020-11-13 02:14:59 +03:00
|
|
|
// Setup configures this storage provider.
|
2020-10-15 00:07:38 +03:00
|
|
|
func (s *LocalStorage) Setup() error {
|
2023-05-31 00:05:24 +03:00
|
|
|
if data.GetVideoServingEndpoint() != "" {
|
|
|
|
s.customVideoServingEndpoint = data.GetVideoServingEndpoint()
|
|
|
|
}
|
|
|
|
|
2020-10-16 03:50:17 +03:00
|
|
|
// NOTE: This cleanup timer will have to be disabled to support recordings in the future
|
|
|
|
// as all HLS segments have to be publicly available on disk to keep a recording of them.
|
2021-10-12 02:29:36 +03:00
|
|
|
s.onlineCleanupTicker = time.NewTicker(1 * time.Minute)
|
2020-10-16 03:50:17 +03:00
|
|
|
go func() {
|
2021-10-12 02:29:36 +03:00
|
|
|
for range s.onlineCleanupTicker.C {
|
2021-09-12 21:32:42 +03:00
|
|
|
transcoder.CleanupOldContent(config.HLSStoragePath)
|
2020-10-16 03:50:17 +03:00
|
|
|
}
|
|
|
|
}()
|
2020-10-15 00:07:38 +03:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-11-13 02:14:59 +03:00
|
|
|
// SegmentWritten is called when a single segment of video is written.
|
2020-10-15 00:07:38 +03:00
|
|
|
func (s *LocalStorage) SegmentWritten(localFilePath string) {
|
2021-07-09 21:16:44 +03:00
|
|
|
if _, err := s.Save(localFilePath, 0); err != nil {
|
2020-11-15 05:39:53 +03:00
|
|
|
log.Warnln(err)
|
|
|
|
}
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|
|
|
|
|
2020-11-13 02:14:59 +03:00
|
|
|
// VariantPlaylistWritten is called when a variant hls playlist is written.
|
2020-10-15 00:07:38 +03:00
|
|
|
func (s *LocalStorage) VariantPlaylistWritten(localFilePath string) {
|
2021-07-09 21:16:44 +03:00
|
|
|
if _, err := s.Save(localFilePath, 0); err != nil {
|
2020-10-17 01:04:31 +03:00
|
|
|
log.Errorln(err)
|
2020-10-15 00:07:38 +03:00
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-13 02:14:59 +03:00
|
|
|
// MasterPlaylistWritten is called when the master hls playlist is written.
|
2020-10-15 00:07:38 +03:00
|
|
|
func (s *LocalStorage) MasterPlaylistWritten(localFilePath string) {
|
2023-05-31 00:05:24 +03:00
|
|
|
if s.customVideoServingEndpoint != "" {
|
|
|
|
// Rewrite the playlist to use custom absolute remote URLs
|
|
|
|
if err := rewriteRemotePlaylist(localFilePath, s.customVideoServingEndpoint); err != nil {
|
|
|
|
log.Warnln(err)
|
|
|
|
}
|
|
|
|
} else if _, err := s.Save(localFilePath, 0); err != nil {
|
2020-11-15 05:39:53 +03:00
|
|
|
log.Warnln(err)
|
|
|
|
}
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|
|
|
|
|
2020-11-13 02:14:59 +03:00
|
|
|
// Save will save a local filepath using the storage provider.
|
2020-10-15 00:07:38 +03:00
|
|
|
func (s *LocalStorage) Save(filePath string, retryCount int) (string, error) {
|
2021-09-12 21:32:42 +03:00
|
|
|
return filePath, nil
|
2020-10-15 00:07:38 +03:00
|
|
|
}
|