Skip to content

Commit

Permalink
Implement a workaround to signal Opus support (mumble) (#1764)
Browse files Browse the repository at this point in the history
* Mumble: Implement a workaround to signal Opus support without pulling in the CGO gopus dependency.

* mumble: lowercase error messages

* mumble: Add link to #1750 in bridge/mumble/codec.go
  • Loading branch information
s3lph authored Mar 19, 2022
1 parent c51753c commit 663850a
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 0 deletions.
70 changes: 70 additions & 0 deletions bridge/mumble/codec.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
package bmumble

import (
"fmt"

"layeh.com/gumble/gumble"
)

// This is a dummy implementation of a Gumble audio codec which claims
// to implement Opus, but does not actually do anything. This serves
// as a workaround until https://github.com/layeh/gumble/pull/61 is
// merged.
// See https://github.com/42wim/matterbridge/issues/1750 for details.

const (
audioCodecIDOpus = 4
)

func registerNullCodecAsOpus() {
codec := &NullCodec{
encoder: &NullAudioEncoder{},
decoder: &NullAudioDecoder{},
}
gumble.RegisterAudioCodec(audioCodecIDOpus, codec)
}

type NullCodec struct {
encoder *NullAudioEncoder
decoder *NullAudioDecoder
}

func (c *NullCodec) ID() int {
return audioCodecIDOpus
}

func (c *NullCodec) NewEncoder() gumble.AudioEncoder {
e := &NullAudioEncoder{}
return e
}

func (c *NullCodec) NewDecoder() gumble.AudioDecoder {
d := &NullAudioDecoder{}
return d
}

type NullAudioEncoder struct{}

func (e *NullAudioEncoder) ID() int {
return audioCodecIDOpus
}

func (e *NullAudioEncoder) Encode(pcm []int16, mframeSize, maxDataBytes int) ([]byte, error) {
return nil, fmt.Errorf("not implemented")
}

func (e *NullAudioEncoder) Reset() {
}

type NullAudioDecoder struct{}

func (d *NullAudioDecoder) ID() int {
return audioCodecIDOpus
}

func (d *NullAudioDecoder) Decode(data []byte, frameSize int) ([]int16, error) {
return nil, fmt.Errorf("not implemented")
}

func (d *NullAudioDecoder) Reset() {
}
1 change: 1 addition & 0 deletions bridge/mumble/mumble.go
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,7 @@ func (b *Bmumble) doConnect() error {
gumbleConfig.Password = password
}

registerNullCodecAsOpus()
client, err := gumble.DialWithDialer(new(net.Dialer), b.GetString("Server"), gumbleConfig, &b.tlsConfig)
if err != nil {
return err
Expand Down

0 comments on commit 663850a

Please sign in to comment.