mirror of
https://github.com/zoriya/Kyoo.git
synced 2025-05-24 02:02:36 -04:00
Add audio streams
This commit is contained in:
parent
677cab6a57
commit
afacf61fbc
@ -2,6 +2,7 @@ package main
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/zoriya/kyoo/transcoder/src"
|
||||
|
||||
@ -96,7 +97,10 @@ func (h *Handler) GetVideoIndex(c echo.Context) error {
|
||||
func (h *Handler) GetAudioIndex(c echo.Context) error {
|
||||
resource := c.Param("resource")
|
||||
slug := c.Param("slug")
|
||||
audio := c.Param("audio")
|
||||
audio, err := strconv.ParseInt(c.Param("audio"), 10, 32)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
client, err := GetClientId(c)
|
||||
if err != nil {
|
||||
@ -108,7 +112,7 @@ func (h *Handler) GetAudioIndex(c echo.Context) error {
|
||||
return err
|
||||
}
|
||||
|
||||
ret, err := h.transcoder.GetAudioIndex(path, audio, client)
|
||||
ret, err := h.transcoder.GetAudioIndex(path, int32(audio), client)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -157,7 +161,10 @@ func (h *Handler) GetVideoSegment(c echo.Context) error {
|
||||
func (h *Handler) GetAudioSegment(c echo.Context) error {
|
||||
resource := c.Param("resource")
|
||||
slug := c.Param("slug")
|
||||
audio := c.Param("audio")
|
||||
audio, err := strconv.ParseInt(c.Param("audio"), 10, 32)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
segment, err := ParseSegment(c.Param("chunk"))
|
||||
if err != nil {
|
||||
return err
|
||||
@ -173,7 +180,7 @@ func (h *Handler) GetAudioSegment(c echo.Context) error {
|
||||
return err
|
||||
}
|
||||
|
||||
ret, err := h.transcoder.GetAudioSegment(path, audio, segment, client)
|
||||
ret, err := h.transcoder.GetAudioSegment(path, int32(audio), segment, client)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
34
transcoder/src/audiostream.go
Normal file
34
transcoder/src/audiostream.go
Normal file
@ -0,0 +1,34 @@
|
||||
package src
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
)
|
||||
|
||||
type AudioStream struct {
|
||||
Stream
|
||||
index int32
|
||||
}
|
||||
|
||||
func NewAudioStream(file *FileStream, idx int32) *AudioStream {
|
||||
log.Printf("Creating a audio stream %d for %s", idx, file.Path)
|
||||
ret := new(AudioStream)
|
||||
ret.index = idx
|
||||
ret.Stream = NewStream(file, ret)
|
||||
return ret
|
||||
}
|
||||
|
||||
func (as *AudioStream) getOutPath() string {
|
||||
return fmt.Sprintf("%s/segment-a%d-%%03d.ts", as.file.Out, as.index)
|
||||
}
|
||||
|
||||
func (as *AudioStream) getTranscodeArgs(segments string) []string {
|
||||
return []string{
|
||||
"-map", fmt.Sprintf("0:a:%d", as.index),
|
||||
"-c:a", "aac",
|
||||
// TODO: Support 5.1 audio streams.
|
||||
"-ac", "2",
|
||||
// TODO: Support multi audio qualities.
|
||||
"-b:a", "128k",
|
||||
}
|
||||
}
|
@ -20,7 +20,8 @@ type FileStream struct {
|
||||
Info *MediaInfo
|
||||
streams map[Quality]*VideoStream
|
||||
vlock sync.RWMutex
|
||||
// audios map[uint32]*AudioStream
|
||||
audios map[int32]*AudioStream
|
||||
alock sync.RWMutex
|
||||
}
|
||||
|
||||
func GetOutPath() string {
|
||||
@ -60,6 +61,7 @@ func NewFileStream(path string) (*FileStream, error) {
|
||||
CanTransmux: can_transmux,
|
||||
Info: info.info,
|
||||
streams: make(map[Quality]*VideoStream),
|
||||
audios: make(map[int32]*AudioStream),
|
||||
}, nil
|
||||
}
|
||||
|
||||
@ -211,3 +213,28 @@ func (fs *FileStream) GetVideoSegment(quality Quality, segment int32, client str
|
||||
stream := fs.getVideoStream(quality)
|
||||
return stream.GetSegment(segment, client)
|
||||
}
|
||||
|
||||
func (fs *FileStream) getAudioStream(audio int32) *AudioStream {
|
||||
fs.alock.RLock()
|
||||
stream, ok := fs.audios[audio]
|
||||
fs.alock.RUnlock()
|
||||
|
||||
if ok {
|
||||
return stream
|
||||
}
|
||||
|
||||
fs.alock.Lock()
|
||||
defer fs.alock.Unlock()
|
||||
fs.audios[audio] = NewAudioStream(fs, audio)
|
||||
return fs.audios[audio]
|
||||
}
|
||||
|
||||
func (fs *FileStream) GetAudioIndex(audio int32, client string) (string, error) {
|
||||
stream := fs.getAudioStream(audio)
|
||||
return stream.GetIndex(client)
|
||||
}
|
||||
|
||||
func (fs *FileStream) GetAudioSegment(audio int32, segment int32, client string) (string, error) {
|
||||
stream := fs.getAudioStream(audio)
|
||||
return stream.GetSegment(segment, client)
|
||||
}
|
||||
|
@ -172,7 +172,6 @@ func (ts *Stream) run(start int32) error {
|
||||
// we need this and not a return in the condition because we want to unlock
|
||||
// the lock (and can't defer since this is a loop)
|
||||
if should_stop {
|
||||
println("close because requested", encoder_id)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
@ -88,8 +88,12 @@ func (t *Transcoder) GetVideoIndex(path string, quality Quality, client string)
|
||||
return stream.GetVideoIndex(quality, client)
|
||||
}
|
||||
|
||||
func (t *Transcoder) GetAudioIndex(path string, audio string, client string) (string, error) {
|
||||
return "", nil
|
||||
func (t *Transcoder) GetAudioIndex(path string, audio int32, client string) (string, error) {
|
||||
stream, err := t.getFileStream(path)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
return stream.GetAudioIndex(audio, client)
|
||||
}
|
||||
|
||||
func (t *Transcoder) GetVideoSegment(
|
||||
@ -107,9 +111,13 @@ func (t *Transcoder) GetVideoSegment(
|
||||
|
||||
func (t *Transcoder) GetAudioSegment(
|
||||
path string,
|
||||
audio string,
|
||||
audio int32,
|
||||
segment int32,
|
||||
client string,
|
||||
) (string, error) {
|
||||
return "", nil
|
||||
stream, err := t.getFileStream(path)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
return stream.GetAudioSegment(audio, segment, client)
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user