mirror of
				https://github.com/krateng/maloja.git
				synced 2023-08-10 21:12:55 +03:00 
			
		
		
		
	Website performance improvements: Image scaling and caching
This commit is contained in:
		
							
								
								
									
										34
									
								
								server.py
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								server.py
									
									
									
									
									
								
							| @@ -15,6 +15,7 @@ import os | |||||||
| import setproctitle | import setproctitle | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| MAIN_PORT = 42010 | MAIN_PORT = 42010 | ||||||
| DATABASE_PORT = 42011 | DATABASE_PORT = 42011 | ||||||
|  |  | ||||||
| @@ -75,18 +76,41 @@ def graceful_exit(sig=None,frame=None): | |||||||
| @webserver.route("/images/<pth:re:.*\\.jpg>") | @webserver.route("/images/<pth:re:.*\\.jpg>") | ||||||
| @webserver.route("/images/<pth:re:.*\\.png>") | @webserver.route("/images/<pth:re:.*\\.png>") | ||||||
| def static_image(pth): | def static_image(pth): | ||||||
| 	return static_file("images/" + pth,root="") | 	small_pth = pth.split(".") | ||||||
|  | 	small_pth.insert(-1,"small") | ||||||
|  | 	small_pth = ".".join(small_pth) | ||||||
|  | 	if os.path.exists("images/" + small_pth): | ||||||
|  | 		response = static_file("images/" + small_pth,root="") | ||||||
|  | 	else: | ||||||
|  | 		try: | ||||||
|  | 			from wand.image import Image | ||||||
|  | 			img = Image(filename="images/" + pth) | ||||||
|  | 			x,y = img.size[0], img.size[1] | ||||||
|  | 			smaller = min(x,y) | ||||||
|  | 			if smaller > 300: | ||||||
|  | 				ratio = 300/smaller | ||||||
|  | 				img.resize(int(ratio*x),int(ratio*y)) | ||||||
|  | 				img.save(filename="images/" + small_pth) | ||||||
|  | 				response = static_file("images/" + small_pth,root="") | ||||||
|  | 			else: | ||||||
|  | 				response = static_file("images/" + pth,root="") | ||||||
|  | 		except: | ||||||
|  | 			response = static_file("images/" + pth,root="") | ||||||
| 			 | 			 | ||||||
| @webserver.route("/<name:re:.*\\.html>") | 	#response = static_file("images/" + pth,root="") | ||||||
|  | 	response.set_header("Cache-Control", "public, max-age=604800") | ||||||
|  | 	return response | ||||||
|  |  | ||||||
|  | #@webserver.route("/<name:re:.*\\.html>") | ||||||
| @webserver.route("/<name:re:.*\\.js>") | @webserver.route("/<name:re:.*\\.js>") | ||||||
| @webserver.route("/<name:re:.*\\.css>") | @webserver.route("/<name:re:.*\\.css>") | ||||||
| @webserver.route("/<name:re:.*\\.png>") | @webserver.route("/<name:re:.*\\.png>") | ||||||
| @webserver.route("/<name:re:.*\\.jpeg>") | @webserver.route("/<name:re:.*\\.jpeg>") | ||||||
| @webserver.route("/<name:re:.*\\.ico>") | @webserver.route("/<name:re:.*\\.ico>") | ||||||
| def static(name):	 | def static(name):	 | ||||||
| 	return static_file("website/" + name,root="") | 	response = static_file("website/" + name,root="") | ||||||
| 	 | 	response.set_header("Cache-Control", "public, max-age=604800") | ||||||
|  | 	return response | ||||||
| 	 | 	 | ||||||
| @webserver.route("/<name>") | @webserver.route("/<name>") | ||||||
| def static_html(name): | def static_html(name): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Krateng
					Krateng