response = $response; } /** * Create a redirect response. * * @param string $url * @param string $method * @param int $status * @param bool $https * @return Response */ public static function to($url, $method = 'location', $status = 302, $https = false) { $url = URL::to($url, $https); return ($method == 'refresh') ? new static(Response::make('', $status)->header('Refresh', '0;url='.$url)) : new static(Response::make('', $status)->header('Location', $url)); } /** * Add an item to the session flash data. * * @param string $key * @param mixed $value * @return Response */ public function with($key, $value) { // ---------------------------------------------------- // Since this method uses sessions, make sure a driver // has been specified in the configuration file. // ---------------------------------------------------- if (Config::get('session.driver') != '') { Session::flash($key, $value); } return $this; } /** * Create a redirect response to a HTTPS URL. * * @param string $url * @param string $method * @param int $status * @return Response */ public static function to_secure($url, $method = 'location', $status = 302) { return static::to($url, $method, $status, true); } /** * Magic Method to handle redirecting to routes. */ public static function __callStatic($method, $parameters) { // ---------------------------------------------------- // Dynamically redirect to a secure route URL. // ---------------------------------------------------- if (strpos($method, 'to_secure_') === 0) { return static::to(URL::to_route(substr($method, 10), $parameters, true)); } // ---------------------------------------------------- // Dynamically redirect a route URL. // ---------------------------------------------------- if (strpos($method, 'to_') === 0) { return static::to(URL::to_route(substr($method, 3), $parameters)); } throw new \Exception("Method [$method] is not defined on the Redirect class."); } }