| 
									
										
										
										
											2021-10-08 22:22:09 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace BookStack\Http\Middleware; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Closure; | 
					
						
							|  |  |  | use Symfony\Component\HttpFoundation\Response; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class PreventAuthenticatedResponseCaching | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Handle an incoming request. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-10-09 05:23:17 +08:00
										 |  |  |      * @param \Illuminate\Http\Request $request | 
					
						
							|  |  |  |      * @param \Closure                 $next | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-10-08 22:22:09 +08:00
										 |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function handle($request, Closure $next) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var Response $response */ | 
					
						
							|  |  |  |         $response = $next($request); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (signedInUser()) { | 
					
						
							|  |  |  |             $response->headers->set('Cache-Control', 'max-age=0, no-store, private'); | 
					
						
							|  |  |  |             $response->headers->set('Pragma', 'no-cache'); | 
					
						
							|  |  |  |             $response->headers->set('Expires', 'Sun, 12 Jul 2015 19:01:00 GMT'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $response; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |