Add support mic mode for wyoming module
This commit is contained in:
@@ -18,6 +18,7 @@ func Init() {
|
|||||||
Mod map[string]struct {
|
Mod map[string]struct {
|
||||||
Listen string `yaml:"listen"`
|
Listen string `yaml:"listen"`
|
||||||
Name string `yaml:"name"`
|
Name string `yaml:"name"`
|
||||||
|
Mode string `yaml:"mode"`
|
||||||
WakeURI string `yaml:"wake_uri"`
|
WakeURI string `yaml:"wake_uri"`
|
||||||
VADThreshold float32 `yaml:"vad_threshold"`
|
VADThreshold float32 `yaml:"vad_threshold"`
|
||||||
} `yaml:"wyoming"`
|
} `yaml:"wyoming"`
|
||||||
@@ -60,13 +61,13 @@ func Init() {
|
|||||||
log.Trace().Msgf("[wyoming] "+format, v...)
|
log.Trace().Msgf("[wyoming] "+format, v...)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
go serve(srv, cfg.Listen)
|
go serve(srv, cfg.Mode, cfg.Listen)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var log zerolog.Logger
|
var log zerolog.Logger
|
||||||
|
|
||||||
func serve(srv *wyoming.Server, address string) {
|
func serve(srv *wyoming.Server, mode, address string) {
|
||||||
ln, err := net.Listen("tcp", address)
|
ln, err := net.Listen("tcp", address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Warn().Msgf("[wyoming] listen error: %s", err)
|
log.Warn().Msgf("[wyoming] listen error: %s", err)
|
||||||
@@ -78,16 +79,25 @@ func serve(srv *wyoming.Server, address string) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
go handle(srv, conn)
|
go handle(srv, mode, conn)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func handle(srv *wyoming.Server, conn net.Conn) {
|
func handle(srv *wyoming.Server, mode string, conn net.Conn) {
|
||||||
addr := conn.RemoteAddr()
|
addr := conn.RemoteAddr()
|
||||||
|
|
||||||
log.Trace().Msgf("[wyoming] %s connected", addr)
|
log.Trace().Msgf("[wyoming] %s connected", addr)
|
||||||
|
|
||||||
if err := srv.Handle(conn); err != nil {
|
var err error
|
||||||
|
|
||||||
|
switch mode {
|
||||||
|
case "mic":
|
||||||
|
err = srv.HandleMic(conn)
|
||||||
|
default:
|
||||||
|
err = srv.Handle(conn)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
log.Error().Msgf("[wyoming] %s error: %s", addr, err)
|
log.Error().Msgf("[wyoming] %s error: %s", addr, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,35 @@
|
|||||||
|
package wyoming
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net"
|
||||||
|
|
||||||
|
"github.com/AlexxIT/go2rtc/pkg/core"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (s *Server) HandleMic(conn net.Conn) error {
|
||||||
|
defer conn.Close()
|
||||||
|
|
||||||
|
var closed core.Waiter
|
||||||
|
var timestamp int
|
||||||
|
|
||||||
|
api := NewAPI(conn)
|
||||||
|
mic := newMicConsumer(func(chunk []byte) {
|
||||||
|
data := fmt.Sprintf(`{"rate":16000,"width":2,"channels":1,"timestamp":%d}`, timestamp)
|
||||||
|
evt := &Event{Type: "audio-chunk", Data: []byte(data), Payload: chunk}
|
||||||
|
if err := api.WriteEvent(evt); err != nil {
|
||||||
|
closed.Done(nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
timestamp += len(chunk) / 2
|
||||||
|
})
|
||||||
|
mic.RemoteAddr = api.conn.RemoteAddr().String()
|
||||||
|
|
||||||
|
if err := s.MicHandler(mic); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer mic.Stop()
|
||||||
|
|
||||||
|
return closed.Wait()
|
||||||
|
}
|
||||||
@@ -142,9 +142,6 @@ func (s *satellite) pause() {
|
|||||||
|
|
||||||
s.state = stateUnavailable
|
s.state = stateUnavailable
|
||||||
if s.mic != nil {
|
if s.mic != nil {
|
||||||
if s.mic.onClose != nil {
|
|
||||||
s.mic.onClose()
|
|
||||||
}
|
|
||||||
_ = s.mic.Stop()
|
_ = s.mic.Stop()
|
||||||
s.mic = nil
|
s.mic = nil
|
||||||
}
|
}
|
||||||
@@ -296,6 +293,13 @@ func (c *micConsumer) AddTrack(media *core.Media, codec *core.Codec, track *core
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *micConsumer) Stop() error {
|
||||||
|
if c.onClose != nil {
|
||||||
|
c.onClose()
|
||||||
|
}
|
||||||
|
return c.Connection.Stop()
|
||||||
|
}
|
||||||
|
|
||||||
type sndProducer struct {
|
type sndProducer struct {
|
||||||
core.Connection
|
core.Connection
|
||||||
data []byte
|
data []byte
|
||||||
|
|||||||
Reference in New Issue
Block a user