about summary refs log tree commit diff
path: root/tools/mpd-stats/cmd/mpd-scrobbler/main.go
diff options
context:
space:
mode:
authorFranck Cuny <franck@fcuny.net>2021-10-09 17:20:22 -0700
committerFranck Cuny <franck@fcuny.net>2022-06-11 14:32:06 -0700
commit4f176ac4a02d8424d21b597b516e69cbec341a2c (patch)
tree49a1333648342ecf981502f8051464d3a3ef01de /tools/mpd-stats/cmd/mpd-scrobbler/main.go
parentREADME: add some information about logging (diff)
downloadworld-4f176ac4a02d8424d21b597b516e69cbec341a2c.tar.gz
scrobbler: watch for events and print song details
We create a module "mpd" to interact with our MPD instance. For now we
only have a single function to create a new client, which creates an
actual client for mpd (and we ping the instance every 30 seconds), and
a watcher to receive new events.

The tool "scrobbler" then wait for new events and display songs
information.
Diffstat (limited to 'tools/mpd-stats/cmd/mpd-scrobbler/main.go')
-rw-r--r--tools/mpd-stats/cmd/mpd-scrobbler/main.go35
1 files changed, 35 insertions, 0 deletions
diff --git a/tools/mpd-stats/cmd/mpd-scrobbler/main.go b/tools/mpd-stats/cmd/mpd-scrobbler/main.go
new file mode 100644
index 0000000..9929225
--- /dev/null
+++ b/tools/mpd-stats/cmd/mpd-scrobbler/main.go
@@ -0,0 +1,35 @@
+package main
+
+import (
+	"log"
+
+	"golang.fcuny.net/mpd-stats/internal/mpd"
+)
+
+func main() {
+	net := "tcp"
+	addr := "localhost:6600"
+
+	c, err := mpd.NewMPD(net, addr)
+	if err != nil {
+		log.Fatalf("failed to create a client: %v", err)
+	}
+
+	defer c.Watcher.Close()
+	defer c.Client.Close()
+
+	for {
+		e := <-c.Watcher.Event
+		if e != "" {
+			attrs, err := c.Client.CurrentSong()
+			if err != nil {
+				log.Fatalf("could not get current song: %v", err)
+			}
+			currentAlbum := attrs["Album"]
+			artist := attrs["Artist"]
+			song := attrs["Title"]
+			duration := attrs["duration"]
+			log.Printf("we're playing %s/%s/%s [%s]\n", artist, currentAlbum, song, duration)
+		}
+	}
+}