First working scrobble service
This commit is contained in:
		
							
								
								
									
										17
									
								
								addon.xml
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								addon.xml
									
									
									
									
									
								
							| @ -1,13 +1,14 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="yes"?> | ||||
| <addon id="plugin.audio.subsonic" name="Subsonic" version="3.0.1" provider-name="BasilFX,grosbouff,silascutler,Heruwar,warwickh"> | ||||
| <requires> | ||||
|     <import addon="xbmc.python" version="3.0.0"/> | ||||
|     <import addon="script.module.dateutil" version="2.4.2"/> | ||||
|     <import addon="script.module.future" version="0.18.2"/> | ||||
| </requires> | ||||
| <extension point="xbmc.python.pluginsource" library="main.py"> | ||||
|   <provides>audio</provides> | ||||
| </extension> | ||||
|     <requires> | ||||
|         <import addon="xbmc.python" version="3.0.0"/> | ||||
|         <import addon="script.module.dateutil" version="2.4.2"/> | ||||
|         <import addon="script.module.future" version="0.18.2"/> | ||||
|     </requires> | ||||
|     <extension point="xbmc.python.pluginsource" library="main.py"> | ||||
|         <provides>audio</provides> | ||||
|     </extension> | ||||
|     <extension point="xbmc.service" library="service.py" /> | ||||
|     <extension point="xbmc.addon.metadata"> | ||||
|         <summary lang="en">Subsonic music addon for Kodi.</summary> | ||||
|         <summary lang="fr">Extension Subsonic pour Kodi.</summary> | ||||
|  | ||||
| @ -230,9 +230,11 @@ class Connection(object): | ||||
|         viewName = '%s.view' % methodName | ||||
|  | ||||
|         req = self._getRequest(viewName) | ||||
|         xbmc.log("Pinging %s"%str(req.full_url),xbmc.LOGDEBUG)        | ||||
|         try: | ||||
|             res = self._doInfoReq(req) | ||||
|         except: | ||||
|         except Exception as e: | ||||
|             print("Ping failed %s"%e) | ||||
|             return False | ||||
|         if res['status'] == 'ok': | ||||
|             return True | ||||
|  | ||||
| @ -173,3 +173,6 @@ msgctxt "#30043" | ||||
| msgid "Merge album folders" | ||||
| msgstr "" | ||||
|  | ||||
| msgctxt "#30044" | ||||
| msgid "Scrobble to Last.FM" | ||||
| msgstr "" | ||||
|  | ||||
| @ -172,3 +172,7 @@ msgstr "" | ||||
| msgctxt "#30043" | ||||
| msgid "Merge album folders" | ||||
| msgstr "" | ||||
|  | ||||
| msgctxt "#30044" | ||||
| msgid "Scrobble to Last.FM" | ||||
| msgstr "" | ||||
|  | ||||
| @ -171,3 +171,7 @@ msgstr "" | ||||
| msgctxt "#30043" | ||||
| msgid "Merge album folders" | ||||
| msgstr "" | ||||
|  | ||||
| msgctxt "#30044" | ||||
| msgid "Scrobble to Last.FM" | ||||
| msgstr "" | ||||
|  | ||||
| @ -27,6 +27,7 @@ | ||||
|         <setting label="30017" type="lsep" /> | ||||
|         <setting label="30018" id="cachetime" type="labelenum"  default="3600" values="1|5|15|30|60|120|180|720|1440|3600"/> | ||||
|         <setting label="30043" id="merge" type="bool" default="false" /> | ||||
|         <setting label="30044" id="scrobble" type="bool" default="false" /> | ||||
| 		 | ||||
| 	</category> | ||||
| </settings> | ||||
|  | ||||
							
								
								
									
										86
									
								
								service.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								service.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,86 @@ | ||||
| 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 | ||||
|  | ||||
| scrobbled = False | ||||
|  | ||||
| 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 | ||||
|     res = connection.scrobble(track_id) | ||||
|     xbmc.log("response %s"%(scrobble), xbmc.LOGINFO) | ||||
|     if res['status'] == 'ok': | ||||
|         return True | ||||
|     else: | ||||
|         return False | ||||
|  | ||||
| if __name__ == '__main__': | ||||
|     monitor = xbmc.Monitor() | ||||
|      | ||||
|     while not monitor.abortRequested(): | ||||
|         if monitor.waitForAbort(10): | ||||
|             break | ||||
|         if (xbmc.getCondVisibility("Player.HasMedia")): | ||||
|             try:             | ||||
|                 if(Addon().get_setting('scrobble')):            | ||||
|                     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) | ||||
|                         scrobble_track(currentTrackId) | ||||
|                         scrobbled = True | ||||
|                     else: | ||||
|                         pass | ||||
|             except Exception as e: | ||||
|                 xbmc.log("Script failed %e"%e, xbmc.LOGINFO) | ||||
|         else: | ||||
|             pass | ||||
|             #xbmc.log("Playing stopped", xbmc.LOGINFO) | ||||
|  | ||||
		Reference in New Issue
	
	Block a user