mirror of https://github.com/grpc/grpc-web.git
				
				
				
			Also set timeout on HTTP request if deadline for grpc call is set
This commit is contained in:
		
							parent
							
								
									9c0169748a
								
							
						
					
					
						commit
						6c1a2ceda1
					
				|  | @ -325,9 +325,9 @@ class GrpcWebClientBase { | |||
|     xhr.headers.set('X-User-Agent', 'grpc-web-javascript/0.1'); | ||||
|     xhr.headers.set('X-Grpc-Web', '1'); | ||||
|     if (xhr.headers.containsKey('deadline')) { | ||||
|       var deadline = xhr.headers.get('deadline');  // in ms
 | ||||
|       var currentTime = (new Date()).getTime(); | ||||
|       var timeout = Math.round(deadline - currentTime); | ||||
|       const deadline = xhr.headers.get('deadline');  // in ms
 | ||||
|       const currentTime = (new Date()).getTime(); | ||||
|       let timeout = Math.ceil(deadline - currentTime); | ||||
|       xhr.headers.remove('deadline'); | ||||
|       if (timeout === Infinity) { | ||||
|         // grpc-timeout header defaults to infinity if not set.
 | ||||
|  | @ -335,6 +335,12 @@ class GrpcWebClientBase { | |||
|       } | ||||
|       if (timeout > 0) { | ||||
|         xhr.headers.set('grpc-timeout', timeout + 'm'); | ||||
|         // Also set timeout on the xhr request to terminate the HTTP request
 | ||||
|         // if the server doesn't respond within the deadline. We use 110% of
 | ||||
|         // grpc-timeout for this to allow the server to terminate the connection
 | ||||
|         // with DEADLINE_EXCEEDED rather than terminating it in the Browser, but
 | ||||
|         // at least 1 second in case the user is on a high-latency network.
 | ||||
|         xhr.setTimeoutInterval(Math.max(1000, Math.ceil(timeout * 1.1))); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue