Improved settings handling - fulltime service
This commit is contained in:
		
							
								
								
									
										108
									
								
								service.py
									
									
									
									
									
								
							
							
						
						
									
										108
									
								
								service.py
									
									
									
									
									
								
							| @ -17,6 +17,11 @@ connection = None | ||||
| db = None | ||||
| mb = None | ||||
|  | ||||
| serviceEnabled = True | ||||
|  | ||||
| refresh_age = 86400     #multiple of random to age info records - needs some validation | ||||
| check_freq = 300#3600   #How often to run a refresh cycle - needs some validation | ||||
|  | ||||
| db_filename = "subsonic_sqlite.db" | ||||
|  | ||||
| last_db_check = 0 | ||||
| @ -42,14 +47,12 @@ 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)) | ||||
|     xbmc.executebuiltin('Notification(%s, %s, %d, %s)' % (title, text, time, icon)) | ||||
|  | ||||
| def get_connection(): | ||||
|     global connection | ||||
|      | ||||
|     global connection     | ||||
|     if connection==None:    | ||||
|         connected = False   | ||||
|         # Create connection       | ||||
|         connected = False     | ||||
|         try: | ||||
|             connection = libsonic.Connection( | ||||
|                 baseUrl=Addon().get_setting('subsonic_url'), | ||||
| @ -72,13 +75,10 @@ def get_connection(): | ||||
|     return connection | ||||
|  | ||||
| def get_mb(): | ||||
|     global mb | ||||
|     mb = musicbrainz.MBConnection() | ||||
|     return mb | ||||
|  | ||||
| def get_db(): | ||||
|     global db | ||||
|     global db_filename  | ||||
|     db_path = os.path.join(plugin.profile_dir, db_filename)    | ||||
|     plugin.log("Getting DB %s"%db_path)   | ||||
|     try: | ||||
| @ -87,23 +87,8 @@ def get_db(): | ||||
|         plugin.log("Connecting to DB failed: %s"%e)     | ||||
|     return db    | ||||
|  | ||||
| def check_artist_info(): | ||||
|     db = get_db() | ||||
|     connection = get_connection() | ||||
|     response = connection.getArtists() | ||||
|     for index in response["artists"]["index"]: | ||||
|             for artist in index["artist"]: | ||||
|                 artist_id = artist['id'] | ||||
|                 artist_name = db.get_value(artist_id, 'artist_name') | ||||
|                 artist_info = db.get_value(artist_id, 'artist_info') | ||||
|                 artist_wiki = db.get_value(artist_id, 'wikipedia_extract') | ||||
|                 plugin.log("Name %s"%(artist_name)) | ||||
|                 plugin.log("LastFM %s"%(artist_info)) | ||||
|                 plugin.log("Wiki %s"%(artist_wiki)) | ||||
|  | ||||
| def refresh_artist(artist_id): | ||||
|     db = get_db() | ||||
|     mb = get_mb() | ||||
|     connection = get_connection() | ||||
|     artist = connection.getArtist(artist_id)#['subsonic-response'] | ||||
|     artist_name = artist['artist']['name'] | ||||
| @ -115,44 +100,43 @@ def refresh_artist(artist_id): | ||||
|         plugin.log("subbed: %s"%artist_info) | ||||
|     except: | ||||
|         artist_info = "" | ||||
|     mb_artist_id = mb.get_artist_id(artist_name) | ||||
|     artist_image_url = mb.get_artist_image(mb_artist_id) | ||||
|     wikipedia_url = mb.get_artist_wikpedia(mb_artist_id) | ||||
|     artist_wiki_extract = mb.get_wiki_extract(wikipedia_url) | ||||
|     wikipedia_image = mb.get_wiki_image(wikipedia_url) | ||||
|     db.update_value(artist_id, 'artist_name', artist_name) | ||||
|     db.update_value(artist_id, 'artist_info', artist_info) | ||||
|     db.update_value(artist_id, 'mb_artist_id', mb_artist_id) | ||||
|     db.update_value(artist_id, 'image_url', artist_image_url) | ||||
|     db.update_value(artist_id, 'wikipedia_url', wikipedia_url) | ||||
|     db.update_value(artist_id, 'wikipedia_extract', artist_wiki_extract) | ||||
|     db.update_value(artist_id, 'wikipedia_image', wikipedia_image) | ||||
|     if enhancedInfo: | ||||
|         mb = get_mb() | ||||
|         mb_artist_id = mb.get_artist_id(artist_name) | ||||
|         artist_image_url = mb.get_artist_image(mb_artist_id) | ||||
|         wikipedia_url = mb.get_artist_wikpedia(mb_artist_id) | ||||
|         artist_wiki_extract = mb.get_wiki_extract(wikipedia_url) | ||||
|         wikipedia_image = mb.get_wiki_image(wikipedia_url) | ||||
|         db.update_value(artist_id, 'artist_name', artist_name) | ||||
|         db.update_value(artist_id, 'artist_info', artist_info) | ||||
|         db.update_value(artist_id, 'mb_artist_id', mb_artist_id) | ||||
|         db.update_value(artist_id, 'image_url', artist_image_url) | ||||
|         db.update_value(artist_id, 'wikipedia_url', wikipedia_url) | ||||
|         db.update_value(artist_id, 'wikipedia_extract', artist_wiki_extract) | ||||
|         db.update_value(artist_id, 'wikipedia_image', wikipedia_image) | ||||
|  | ||||
| def check_db_status(forced=False): | ||||
|     global last_db_check | ||||
|     refresh_age = 86400 | ||||
|     check_freq = 300#3600 | ||||
|     refresh_single_flag = False    | ||||
|     if(enhancedInfo): | ||||
|         try:              | ||||
|             if(time.time()-check_freq > last_db_check) or forced: | ||||
|                 #popup("DB Check Starting") | ||||
|                 plugin.log("DB check starting %s %s" % (time.time(), last_db_check)) | ||||
|                 db = get_db() | ||||
|                 connection = get_connection() | ||||
|                 response = connection.getArtists() | ||||
|                 for index in response["artists"]["index"]: | ||||
|                         for artist in index["artist"]: | ||||
|                             artist_id = artist['id'] | ||||
|                             record_age = db.get_record_age(artist_id)  | ||||
|                             if(forced or not record_age or (record_age > (random.randint(1,111)*refresh_age))) and not refresh_single_flag: | ||||
|                                 #plugin.log("Record age %s vs %s for %s"%(record_age, (random.randint(1,111)*refresh_age), artist_id))  | ||||
|                                 #popup("Refreshing %s" % artist_id) | ||||
|                                 refresh_artist(artist_id) | ||||
|                                 if(record_age>0):refresh_single_flag = True | ||||
|                 last_db_check = time.time() | ||||
|         except Exception as e: | ||||
|             plugin.log("DB rcheck failed %s"%e) | ||||
|     try:              | ||||
|         if(time.time()-check_freq > last_db_check) or forced: | ||||
|             #popup("DB Check Starting") | ||||
|             plugin.log("DB check starting %s %s" % (time.time(), last_db_check)) | ||||
|             db = get_db() | ||||
|             connection = get_connection() | ||||
|             response = connection.getArtists() | ||||
|             for index in response["artists"]["index"]: | ||||
|                     for artist in index["artist"]: | ||||
|                         artist_id = artist['id'] | ||||
|                         record_age = db.get_record_age(artist_id)  | ||||
|                         if(forced or not record_age or (record_age > (random.randint(1,111)*refresh_age))) and not refresh_single_flag: | ||||
|                             #plugin.log("Record age %s vs %s for %s"%(record_age, (random.randint(1,111)*refresh_age), artist_id))  | ||||
|                             #popup("Refreshing %s" % artist_id) | ||||
|                             refresh_artist(artist_id) | ||||
|                             if(record_age>0):refresh_single_flag = True | ||||
|             last_db_check = time.time() | ||||
|     except Exception as e: | ||||
|         plugin.log("DB check failed %s"%e) | ||||
|  | ||||
|     return | ||||
|  | ||||
| @ -179,12 +163,9 @@ def check_player_status(): | ||||
|         except Exception as e: | ||||
|             xbmc.log("Subsonic scrobble check failed %e"%e, xbmc.LOGINFO) | ||||
|     return                 | ||||
|         #pass | ||||
|         #xbmc.log("Playing stopped", xbmc.LOGINFO) | ||||
|  | ||||
| def scrobble_track(track_id): | ||||
|     connection = get_connection() | ||||
|  | ||||
|     if connection==False: | ||||
|         return False | ||||
|     res = connection.scrobble(track_id) | ||||
| @ -196,8 +177,9 @@ def scrobble_track(track_id): | ||||
|         popup("Scrobble failed") | ||||
|         return False | ||||
|  | ||||
|  | ||||
| if __name__ == '__main__': | ||||
|     if(scrobbleEnabled or enhancedInfo):   | ||||
|     if serviceEnabled:   | ||||
|         monitor = xbmc.Monitor() | ||||
|         xbmc.log("Subsonic service started", xbmc.LOGINFO) | ||||
|         popup("Subsonic service started") | ||||
| @ -207,4 +189,4 @@ if __name__ == '__main__': | ||||
|             check_player_status() | ||||
|             check_db_status() | ||||
|     else: | ||||
|         plugin.log("Subsonic service not started due to settings") | ||||
|         plugin.log("Subsonic service not enabled") | ||||
|  | ||||
		Reference in New Issue
	
	Block a user