mirror of
				https://github.com/krateng/maloja.git
				synced 2023-08-10 21:12:55 +03:00 
			
		
		
		
	Merge branch 'feature-asyncimages' into next_minor_version
This commit is contained in:
		| @@ -16,12 +16,14 @@ from threading import Lock | ||||
| from concurrent.futures import ThreadPoolExecutor | ||||
| import re | ||||
| import datetime | ||||
| import time | ||||
|  | ||||
| import sqlalchemy as sql | ||||
|  | ||||
|  | ||||
|  | ||||
| MAX_RESOLVE_THREADS = 10 | ||||
| MAX_RESOLVE_THREADS = 5 | ||||
| MAX_SECONDS_TO_RESOLVE_REQUEST = 5 | ||||
|  | ||||
|  | ||||
| # remove old db file (columns missing) | ||||
| @@ -126,10 +128,19 @@ def remove_image_from_cache(track_id=None,artist_id=None,album_id=None): | ||||
| 		with engine.begin() as conn: | ||||
| 			op = DB[table].delete().where( | ||||
| 				DB[table].c.id==entity_id, | ||||
| 			).returning( | ||||
| 				DB[table].c.id, | ||||
| 				DB[table].c.localproxyurl | ||||
| 			) | ||||
| 			result = conn.execute(op) | ||||
| 			result = conn.execute(op).all() | ||||
|  | ||||
| 		for row in result: | ||||
| 			targetpath = data_dir['cache']('images',row.localproxyurl.split('/')[-1]) | ||||
| 			try: | ||||
| 				os.remove(targetpath) | ||||
| 			except: | ||||
| 				pass | ||||
|  | ||||
| 	# TODO delete proxy | ||||
|  | ||||
| def dl_image(url): | ||||
| 	try: | ||||
| @@ -254,23 +265,39 @@ def resolve_image(artist_id=None,track_id=None,album_id=None): | ||||
|  | ||||
| # the actual http request for the full image | ||||
| def image_request(artist_id=None,track_id=None,album_id=None): | ||||
| 	# check cache | ||||
| 	result = get_image_from_cache(artist_id=artist_id,track_id=track_id,album_id=album_id) | ||||
| 	if result is not None: | ||||
| 		# we got an entry, even if it's that there is no image (value None) | ||||
| 		if result['value'] is None: | ||||
| 			# use placeholder | ||||
| 			placeholder_url = "https://generative-placeholders.glitch.me/image?width=300&height=300&style=" | ||||
| 			if artist_id: | ||||
| 				result['value'] = placeholder_url + f"tiles&colors={artist_id % 100}" | ||||
| 			if track_id: | ||||
| 				result['value'] = placeholder_url + f"triangles&colors={track_id % 100}" | ||||
| 			if album_id: | ||||
| 				result['value'] = placeholder_url + f"joy-division&colors={album_id % 100}" | ||||
| 		return result | ||||
| 	else: | ||||
| 		# no entry, which means we're still working on it | ||||
| 		return {'type':'noimage','value':'wait'} | ||||
|  | ||||
| 	# because we use lazyload, we can allow our http requests to take a little while at least | ||||
| 	# not the full backend request, but a few seconds to give us time to fetch some images | ||||
| 	# because 503 retry-after doesn't seem to be honored | ||||
| 	attempt = 0 | ||||
| 	while attempt < MAX_SECONDS_TO_RESOLVE_REQUEST: | ||||
| 		attempt += 1 | ||||
| 		# check cache | ||||
| 		result = get_image_from_cache(artist_id=artist_id,track_id=track_id,album_id=album_id) | ||||
| 		if result is not None: | ||||
| 			# we got an entry, even if it's that there is no image (value None) | ||||
| 			if result['value'] is None: | ||||
| 				# use placeholder | ||||
| 				if malojaconfig["FANCY_PLACEHOLDER_ART"]: | ||||
| 					placeholder_url = "https://generative-placeholders.glitch.me/image?width=300&height=300&style=" | ||||
| 					if artist_id: | ||||
| 						result['value'] = placeholder_url + f"tiles&colors={artist_id % 100}" | ||||
| 					if track_id: | ||||
| 						result['value'] = placeholder_url + f"triangles&colors={track_id % 100}" | ||||
| 					if album_id: | ||||
| 						result['value'] = placeholder_url + f"joy-division&colors={album_id % 100}" | ||||
| 				else: | ||||
| 					if artist_id: | ||||
| 						result['value'] = "/static/svg/placeholder_artist.svg" | ||||
| 					if track_id: | ||||
| 						result['value'] = "/static/svg/placeholder_track.svg" | ||||
| 					if album_id: | ||||
| 						result['value'] = "/static/svg/placeholder_album.svg" | ||||
| 			return result | ||||
| 		time.sleep(1) | ||||
|  | ||||
| 	# no entry, which means we're still working on it | ||||
| 	return {'type':'noimage','value':'wait'} | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -197,6 +197,7 @@ malojaconfig = Configuration( | ||||
| 			"display_art_icons":(tp.Boolean(),									"Display Album/Artist Icons",	True), | ||||
| 			"default_album_artist":(tp.String(),								"Default Albumartist",			"Various Artists"), | ||||
| 			"use_album_artwork_for_tracks":(tp.Boolean(),						"Use Album Artwork for tracks",	True), | ||||
| 			"fancy_placeholder_art":(tp.Boolean(),								"Use fancy placeholder artwork",True), | ||||
| 			"discourage_cpu_heavy_stats":(tp.Boolean(),							"Discourage CPU-heavy stats",	False,					"Prevent visitors from mindlessly clicking on CPU-heavy options. Does not actually disable them for malicious actors!"), | ||||
| 			"use_local_images":(tp.Boolean(),									"Use Local Images",				True), | ||||
| 			#"local_image_rotate":(tp.Integer(),									"Local Image Rotate",			3600), | ||||
|   | ||||
							
								
								
									
										21
									
								
								maloja/web/static/svg/LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								maloja/web/static/svg/LICENSE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2015-present Ionic (http://ionic.io/) | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in | ||||
| all copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
| THE SOFTWARE. | ||||
							
								
								
									
										1
									
								
								maloja/web/static/svg/placeholder_album.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								maloja/web/static/svg/placeholder_album.svg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| <svg xmlns="http://www.w3.org/2000/svg" class="ionicon" viewBox="0 0 512 512"><circle cx="256" cy="256" r="208" fill="none" stroke="#f5f5dc" stroke-miterlimit="10" stroke-width="32"/><circle cx="256" cy="256" r="96" fill="none" stroke="#f5f5dc" stroke-miterlimit="10" stroke-width="32"/><circle cx="256" cy="256" r="32"/></svg> | ||||
| After Width: | Height: | Size: 328 B | 
							
								
								
									
										1
									
								
								maloja/web/static/svg/placeholder_artist.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								maloja/web/static/svg/placeholder_artist.svg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| <svg xmlns="http://www.w3.org/2000/svg" class="ionicon" viewBox="0 0 512 512"><path fill="none" stroke="#f5f5dc" stroke-linecap="round" stroke-linejoin="round" stroke-width="32" d="M192 448h128M384 208v32c0 70.4-57.6 128-128 128h0c-70.4 0-128-57.6-128-128v-32M256 368v80"/><path d="M256 64a63.68 63.68 0 00-64 64v111c0 35.2 29 65 64 65s64-29 64-65V128c0-36-28-64-64-64z" fill="none" stroke="#f5f5dc" stroke-linecap="round" stroke-linejoin="round" stroke-width="32"/></svg> | ||||
| After Width: | Height: | Size: 473 B | 
							
								
								
									
										1
									
								
								maloja/web/static/svg/placeholder_track.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								maloja/web/static/svg/placeholder_track.svg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| <svg xmlns="http://www.w3.org/2000/svg" class="ionicon" viewBox="0 0 512 512"><path d="M192 218v-6c0-14.84 10-27 24.24-30.59l174.59-46.68A20 20 0 01416 154v22" fill="none" stroke="#f5f5dc" stroke-linecap="round" stroke-linejoin="round" stroke-width="32"/><path d="M416 295.94v80c0 13.91-8.93 25.59-22 30l-22 8c-25.9 8.72-52-10.42-52-38h0a33.37 33.37 0 0123-32l51-18.15c13.07-4.4 22-15.94 22-29.85V58a10 10 0 00-12.6-9.61L204 102a16.48 16.48 0 00-12 16v226c0 13.91-8.93 25.6-22 30l-52 18c-13.88 4.68-22 17.22-22 32h0c0 27.58 26.52 46.55 52 38l22-8c13.07-4.4 22-16.08 22-30v-80" fill="none" stroke="#f5f5dc" stroke-linecap="round" stroke-linejoin="round" stroke-width="32"/></svg> | ||||
| After Width: | Height: | Size: 679 B | 
		Reference in New Issue
	
	Block a user
	 krateng
					krateng