mirror of
https://github.com/zoriya/Kyoo.git
synced 2025-05-31 12:14:46 -04:00
Add audio streams
This commit is contained in:
parent
677cab6a57
commit
afacf61fbc
@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
"github.com/zoriya/kyoo/transcoder/src"
|
"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 {
|
func (h *Handler) GetAudioIndex(c echo.Context) error {
|
||||||
resource := c.Param("resource")
|
resource := c.Param("resource")
|
||||||
slug := c.Param("slug")
|
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)
|
client, err := GetClientId(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -108,7 +112,7 @@ func (h *Handler) GetAudioIndex(c echo.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ret, err := h.transcoder.GetAudioIndex(path, audio, client)
|
ret, err := h.transcoder.GetAudioIndex(path, int32(audio), client)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -157,7 +161,10 @@ func (h *Handler) GetVideoSegment(c echo.Context) error {
|
|||||||
func (h *Handler) GetAudioSegment(c echo.Context) error {
|
func (h *Handler) GetAudioSegment(c echo.Context) error {
|
||||||
resource := c.Param("resource")
|
resource := c.Param("resource")
|
||||||
slug := c.Param("slug")
|
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"))
|
segment, err := ParseSegment(c.Param("chunk"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -173,7 +180,7 @@ func (h *Handler) GetAudioSegment(c echo.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ret, err := h.transcoder.GetAudioSegment(path, audio, segment, client)
|
ret, err := h.transcoder.GetAudioSegment(path, int32(audio), segment, client)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
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
|
Info *MediaInfo
|
||||||
streams map[Quality]*VideoStream
|
streams map[Quality]*VideoStream
|
||||||
vlock sync.RWMutex
|
vlock sync.RWMutex
|
||||||
// audios map[uint32]*AudioStream
|
audios map[int32]*AudioStream
|
||||||
|
alock sync.RWMutex
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetOutPath() string {
|
func GetOutPath() string {
|
||||||
@ -60,6 +61,7 @@ func NewFileStream(path string) (*FileStream, error) {
|
|||||||
CanTransmux: can_transmux,
|
CanTransmux: can_transmux,
|
||||||
Info: info.info,
|
Info: info.info,
|
||||||
streams: make(map[Quality]*VideoStream),
|
streams: make(map[Quality]*VideoStream),
|
||||||
|
audios: make(map[int32]*AudioStream),
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,3 +213,28 @@ func (fs *FileStream) GetVideoSegment(quality Quality, segment int32, client str
|
|||||||
stream := fs.getVideoStream(quality)
|
stream := fs.getVideoStream(quality)
|
||||||
return stream.GetSegment(segment, client)
|
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
|
// 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)
|
// the lock (and can't defer since this is a loop)
|
||||||
if should_stop {
|
if should_stop {
|
||||||
println("close because requested", encoder_id)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -88,8 +88,12 @@ func (t *Transcoder) GetVideoIndex(path string, quality Quality, client string)
|
|||||||
return stream.GetVideoIndex(quality, client)
|
return stream.GetVideoIndex(quality, client)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Transcoder) GetAudioIndex(path string, audio string, client string) (string, error) {
|
func (t *Transcoder) GetAudioIndex(path string, audio int32, client string) (string, error) {
|
||||||
return "", nil
|
stream, err := t.getFileStream(path)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return stream.GetAudioIndex(audio, client)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Transcoder) GetVideoSegment(
|
func (t *Transcoder) GetVideoSegment(
|
||||||
@ -107,9 +111,13 @@ func (t *Transcoder) GetVideoSegment(
|
|||||||
|
|
||||||
func (t *Transcoder) GetAudioSegment(
|
func (t *Transcoder) GetAudioSegment(
|
||||||
path string,
|
path string,
|
||||||
audio string,
|
audio int32,
|
||||||
segment int32,
|
segment int32,
|
||||||
client string,
|
client string,
|
||||||
) (string, error) {
|
) (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