diff options
author | xegineering <me@xegineering.eu> | 2024-10-03 19:16:56 +0200 |
---|---|---|
committer | xegineering <me@xegineering.eu> | 2024-10-03 20:00:04 +0200 |
commit | b8fed490c275487f14bff4f5b49a6072d27e5b5f (patch) | |
tree | 0dc59aa2a31c7168fefa47e9839b984f8a6eb502 /stream.go | |
parent | 9b995e02371e45e8cb5806ee7c7eb8139bf24fd8 (diff) | |
download | soundbox-go-b8fed490c275487f14bff4f5b49a6072d27e5b5f.tar soundbox-go-b8fed490c275487f14bff4f5b49a6072d27e5b5f.tar.zst soundbox-go-b8fed490c275487f14bff4f5b49a6072d27e5b5f.zip |
Add soundbox.StreamURLContext()v0.1.0
This should be the primary public API of the library to stream web radio
to soundbox devices.
Diffstat (limited to 'stream.go')
-rw-r--r-- | stream.go | 40 |
1 files changed, 40 insertions, 0 deletions
@@ -1,5 +1,45 @@ package soundbox +import ( + "context" + "fmt" + "os/exec" + "net" +) + // streamingPort is the default network port a soundbox is listening to for // incoming audio stream data. const streamingPort = 5316 + +func StreamURLContext(ctx context.Context, url string, targets []net.HardwareAddr) error { + iface, err := getInterface() + if err != nil { + return err + } + + cmd := []string{ + "-re", + "-i", + url, + } + + for _, target := range targets { + ip, err := toLinkLocal(target) + if err != nil { + return err + } + + cmd = append(cmd, "-acodec") + cmd = append(cmd, "flac") + cmd = append(cmd, "-f") + cmd = append(cmd, "ogg") + cmd = append(cmd, fmt.Sprintf( + "tcp://[%s%%%s]:%d", + ip, + iface.Name, + streamingPort, + )) + } + + return exec.CommandContext(ctx, "ffmpeg", cmd...).Run() +} |