Add Cache-Control headers to all JSON APIs
It is especially important that sync requests don't get cached, as if a sync returns the same token given then the client will call sync with the same parameters again. If the previous response was cached it will get reused, resulting in the client tight looping making the same request and never making any progress. In general, clients will expect to get up to date data when requesting APIs, and so its safer to do a blanket no cache policy than only whitelisting APIs that we know will break things if they get cached.pull/3017/head
							parent
							
								
									5bdb57cb66
								
							
						
					
					
						commit
						1c41b05c8c
					
				|  | @ -488,6 +488,7 @@ def respond_with_json_bytes(request, code, json_bytes, send_cors=False, | |||
|     request.setHeader(b"Content-Type", b"application/json") | ||||
|     request.setHeader(b"Server", version_string) | ||||
|     request.setHeader(b"Content-Length", b"%d" % (len(json_bytes),)) | ||||
|     request.setHeader(b"Cache-Control", b"no-cache, no-store, must-revalidate") | ||||
| 
 | ||||
|     if send_cors: | ||||
|         set_cors_headers(request) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Erik Johnston
						Erik Johnston