106 lines
3.7 KiB
Python
106 lines
3.7 KiB
Python
import re
|
|
import xbmc
|
|
import xbmcvfs
|
|
import os
|
|
import xbmcaddon
|
|
# Add the /lib folder to sys
|
|
sys.path.append(xbmcvfs.translatePath(os.path.join(xbmcaddon.Addon("plugin.audio.subsonic").getAddonInfo("path"), "lib")))
|
|
|
|
import libsonic
|
|
|
|
from simpleplugin import Plugin
|
|
from simpleplugin import Addon
|
|
|
|
# Create plugin instance
|
|
plugin = Plugin()
|
|
connection = None
|
|
|
|
try:
|
|
scrobbleEnabled = Addon().get_setting('scrobble')
|
|
except:
|
|
scrobbleEnabled = False
|
|
|
|
scrobbled = False
|
|
|
|
def popup(text, time=5000, image=None):
|
|
title = plugin.addon.getAddonInfo('name')
|
|
icon = plugin.addon.getAddonInfo('icon')
|
|
xbmc.executebuiltin('Notification(%s, %s, %d, %s)' % (title, text,
|
|
time, icon))
|
|
def get_connection():
|
|
global connection
|
|
|
|
if connection==None:
|
|
connected = False
|
|
# Create connection
|
|
try:
|
|
connection = libsonic.Connection(
|
|
baseUrl=Addon().get_setting('subsonic_url'),
|
|
username=Addon().get_setting('username', convert=False),
|
|
password=Addon().get_setting('password', convert=False),
|
|
port=Addon().get_setting('port'),
|
|
apiVersion=Addon().get_setting('apiversion'),
|
|
insecure=Addon().get_setting('insecure'),
|
|
legacyAuth=Addon().get_setting('legacyauth'),
|
|
useGET=Addon().get_setting('useget'),
|
|
)
|
|
connected = connection.ping()
|
|
except:
|
|
pass
|
|
|
|
if connected==False:
|
|
popup('Connection error')
|
|
return False
|
|
|
|
return connection
|
|
|
|
def scrobble_track(track_id):
|
|
connection = get_connection()
|
|
|
|
if connection==False:
|
|
return False
|
|
res = connection.scrobble(track_id)
|
|
#xbmc.log("response %s"%(res), xbmc.LOGINFO)
|
|
if res['status'] == 'ok':
|
|
popup("Scrobbled track")
|
|
return True
|
|
else:
|
|
popup("Scrobble failed")
|
|
return False
|
|
|
|
if __name__ == '__main__':
|
|
if(scrobbleEnabled):
|
|
monitor = xbmc.Monitor()
|
|
xbmc.log("Subsonic service started", xbmc.LOGINFO)
|
|
popup("Subsonic service started")
|
|
while not monitor.abortRequested():
|
|
if monitor.waitForAbort(10):
|
|
break
|
|
if (xbmc.getCondVisibility("Player.HasMedia")):
|
|
try:
|
|
|
|
currentFileName = xbmc.getInfoLabel("Player.Filenameandpath")
|
|
currentFileProgress = xbmc.getInfoLabel("Player.Progress")
|
|
pattern = re.compile(r'plugin:\/\/plugin\.audio\.subsonic\/\?action=play_track&id=(.*?)&')
|
|
currentTrackId = re.findall(pattern, currentFileName)[0]
|
|
#xbmc.log("Name %s Id %s Progress %s"%(currentFileName,currentTrackId,currentFileProgress), xbmc.LOGDEBUG)
|
|
if (int(currentFileProgress)<50):
|
|
scrobbled = False
|
|
elif (int(currentFileProgress)>=50 and scrobbled == False):
|
|
xbmc.log("Scrobbling Track Id %s"%(currentTrackId), xbmc.LOGDEBUG)
|
|
success = scrobble_track(currentTrackId)
|
|
if success:
|
|
scrobbled = True
|
|
else:
|
|
pass
|
|
except IndexError:
|
|
print ("Not a Subsonic track")
|
|
scrobbled = True
|
|
except Exception as e:
|
|
xbmc.log("Subsonic service failed %e"%e, xbmc.LOGINFO)
|
|
else:
|
|
pass
|
|
#xbmc.log("Playing stopped", xbmc.LOGINFO)
|
|
else:
|
|
xbmc.log("Subsonic service not started due to settings", xbmc.LOGINFO)
|