| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | '''
 | 
					
						
							|  |  |  | searx is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  | the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | searx is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | GNU Affero General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  | along with searx. If not, see < http://www.gnu.org/licenses/ >. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (C) 2015 by Adam Tauber, <asciimoo@gmail.com> | 
					
						
							|  |  |  | '''
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-04 22:46:43 +02:00
										 |  |  | from flask_babel import gettext | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | import re | 
					
						
							| 
									
										
										
										
											2016-11-30 18:43:03 +01:00
										 |  |  | from searx.url_utils import urlunparse | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-15 20:34:02 +02:00
										 |  |  | regexes = {re.compile(r'utm_[^&]+&?'), | 
					
						
							|  |  |  |            re.compile(r'(wkey|wemail)[^&]+&?'), | 
					
						
							|  |  |  |            re.compile(r'&$')} | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | name = gettext('Tracker URL remover') | 
					
						
							|  |  |  | description = gettext('Remove trackers arguments from the returned URL') | 
					
						
							|  |  |  | default_on = True | 
					
						
							| 
									
										
										
										
											2017-02-12 15:06:01 +01:00
										 |  |  | preference_section = 'privacy' | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-22 14:01:53 +02:00
										 |  |  | def on_result(request, search, result): | 
					
						
							|  |  |  |     query = result['parsed_url'].query | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 14:27:15 +02:00
										 |  |  |     if query == "": | 
					
						
							| 
									
										
										
										
											2015-06-15 20:34:02 +02:00
										 |  |  |         return True | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for reg in regexes: | 
					
						
							| 
									
										
										
										
											2015-06-18 14:27:15 +02:00
										 |  |  |         query = reg.sub('', query) | 
					
						
							| 
									
										
										
										
											2015-06-15 20:34:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-22 14:01:53 +02:00
										 |  |  |     if query != result['parsed_url'].query: | 
					
						
							|  |  |  |         result['parsed_url'] = result['parsed_url']._replace(query=query) | 
					
						
							|  |  |  |         result['url'] = urlunparse(result['parsed_url']) | 
					
						
							| 
									
										
										
										
											2015-06-09 16:16:07 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return True |