mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 12:03:46 +00:00 
			
		
		
		
	Refactor `report_csp_violations` view to use `typed_endpoint` decorator instead of `has_request_variables`. This change improves code consistency and enhances codebase comprehension.
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # System documented in https://zulip.readthedocs.io/en/latest/subsystems/logging.html
 | |
| import logging
 | |
| 
 | |
| from django.http import HttpRequest, HttpResponse
 | |
| from django.views.decorators.csrf import csrf_exempt
 | |
| from django.views.decorators.http import require_POST
 | |
| 
 | |
| from zerver.lib.response import json_success
 | |
| from zerver.lib.typed_endpoint import JsonBodyPayload, typed_endpoint
 | |
| from zerver.lib.validator import WildValue, check_string
 | |
| 
 | |
| 
 | |
| @csrf_exempt
 | |
| @require_POST
 | |
| @typed_endpoint
 | |
| def report_csp_violations(
 | |
|     request: HttpRequest, *, csp_report: JsonBodyPayload[WildValue]
 | |
| ) -> HttpResponse:
 | |
|     def get_attr(csp_report_attr: str) -> str:
 | |
|         return csp_report.get(csp_report_attr, "").tame(check_string)
 | |
| 
 | |
|     logging.warning(
 | |
|         "CSP violation in document('%s'). "
 | |
|         "blocked URI('%s'), original policy('%s'), "
 | |
|         "violated directive('%s'), effective directive('%s'), "
 | |
|         "disposition('%s'), referrer('%s'), "
 | |
|         "status code('%s'), script sample('%s')",
 | |
|         get_attr("document-uri"),
 | |
|         get_attr("blocked-uri"),
 | |
|         get_attr("original-policy"),
 | |
|         get_attr("violated-directive"),
 | |
|         get_attr("effective-directive"),
 | |
|         get_attr("disposition"),
 | |
|         get_attr("referrer"),
 | |
|         get_attr("status-code"),
 | |
|         get_attr("script-sample"),
 | |
|     )
 | |
| 
 | |
|     return json_success(request)
 |