mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-25 17:14:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import re
 | |
| from typing import Any
 | |
| 
 | |
| from django.http import HttpRequest
 | |
| from django.views.debug import SafeExceptionReporterFilter
 | |
| from typing_extensions import override
 | |
| 
 | |
| 
 | |
| class ZulipExceptionReporterFilter(SafeExceptionReporterFilter):
 | |
|     # Add _SALT to the standard list
 | |
|     hidden_settings = re.compile(
 | |
|         r"API|TOKEN|KEY|SECRET|PASS|SIGNATURE|HTTP_COOKIE|_SALT", flags=re.IGNORECASE
 | |
|     )
 | |
| 
 | |
|     @override
 | |
|     def get_post_parameters(self, request: HttpRequest | None) -> dict[str, Any]:
 | |
|         post_data = SafeExceptionReporterFilter.get_post_parameters(self, request)
 | |
|         assert isinstance(post_data, dict)
 | |
|         filtered_post = post_data.copy()
 | |
|         filtered_vars = [
 | |
|             "content",
 | |
|             "secret",
 | |
|             "password",
 | |
|             "key",
 | |
|             "api-key",
 | |
|             "subject",
 | |
|             "stream",
 | |
|             "subscriptions",
 | |
|             "to",
 | |
|             "csrfmiddlewaretoken",
 | |
|             "api_key",
 | |
|             "realm_counts",
 | |
|             "installation_counts",
 | |
|         ]
 | |
| 
 | |
|         for var in filtered_vars:
 | |
|             if var in filtered_post:
 | |
|                 filtered_post[var] = "**********"
 | |
|         return filtered_post
 |