mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 03:53:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			26 lines
		
	
	
		
			845 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			845 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import $ from "jquery";
 | |
| 
 | |
| export let csrf_token: string | undefined;
 | |
| 
 | |
| $(() => {
 | |
|     // This requires that we used Jinja2's {% csrf_input %} somewhere on the page.
 | |
|     const $csrf_input = $('input[name="csrfmiddlewaretoken"]');
 | |
|     csrf_token = $csrf_input.attr("value");
 | |
|     if (csrf_token === undefined) {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     $.ajaxSetup({
 | |
|         beforeSend(xhr: JQuery.jqXHR, settings: JQuery.AjaxSettings) {
 | |
|             if (settings.url === undefined || csrf_token === undefined) {
 | |
|                 throw new Error("settings.url and/or csrf_token are missing.");
 | |
|             }
 | |
| 
 | |
|             if (!(/^http:.*/.test(settings.url) || /^https:.*/.test(settings.url))) {
 | |
|                 // Only send the token to relative URLs i.e. locally.
 | |
|                 xhr.setRequestHeader("X-CSRFToken", csrf_token);
 | |
|             }
 | |
|         },
 | |
|     });
 | |
| });
 |