Read the statement by Michael Teeuw here.
MMM-Spotify
-
Regrettably, DNS requests are still too many. I see 1000 in 10 minutes (purple is a fresh install of MagicMirror with just the clock and the Spotify module):
-
I think the best solution is Don’t use it
(like my other modules) -
Sorry for bothering you guys with my kinky ex-module.
The problem is; There is no server-pushed way to get current playback in RPI with spotify api.
So to get current playing data, frequent api callings are needed.Possible solution under current condition is; removing some features - like progress bar, displaying playtime… So then too many requests are not needed.
In other platforms like desktop PC, Google Chrome has widevine/DRM so we can use “web playback api”, it can make direct playing spotify on browser level, and get playback data directly. But not possible in rpi natively.
Some hacks for widevine exist for RPI chromium, but our MM’s electron still miss that feature.
But! I’ve heard newest Electron(9.0) has a new Chromium(80? 83?) and it might have widevine supported (I haven’t tested yet, or never…)
I’m not sure it would be supported in rpi or not but if who has interest, worthy to try. If supported, you can build a new module which can play spotify directly without raspotify instead this poor module. -
@Sean Thank you for chiming in and for providing a more elaborate response. I thought that the constant polling might be the reason. If I may comment, for other users it may be helpful to put it in the documentation that using the module leads to increased network traffic.
I for one would be happy with a display of the static per-title information and the controls, I will observe what happens when I crank the refresh rate up to 30000 milliseconds.
-
@Sean I hacked together a simple bash script (dnssaver.sh) that fetches IPs and stores them in the hosts file. If I call it with ‘api.spotify.com’ as argument and put it in my crontab it should take a load of the dns server. I’ll keep an eye on it.
-
@Bugsounet either I am doing something wrong or there’s a bug.
I added
onStart: null,
in the module config, but the big Spotify logo keeps displaying all the time. -
if Soptify logo not hidden after start, it’s means :
token missing or token erroryou should have in console something like that :
[SPOTIFY:ERROR] USERNAME: [your username] [SPOTIFY:ERROR] Token Error ! ./[token name].json
if you have set a token … verify the exact name
and report it to your account username specified inspotify.config.json
-> “TOKEN” field -
when ok It display :
-
default style
🔒 Log in to view -
mini style
🔒 Log in to view -
when bottom_bar position is set
🔒 Log in to view
-
-
@mmmmh :
now
idleInterval
is set to 30000 (scan is Spotify is playing every 30 sec)
if playing :updateInterval
is set by default to 1000 (1sec)Attention it’s means that with idleInterval : when Spotify is playing to take 30 sec to display it in mirror !by default !
-
@Bugsounet Thanks. Do I understand this correctly. As long as the module is idle it will only check for updates every 30 seconds and when it is active (music is being played) it updates every second?