| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 | <?php namespace Laravel; use Laravel\Routing\Router;class Redirect extends Response {	/**	 * Create a redirect response to application root.	 *	 * @param  int       $status	 * @param  bool      $https	 * @return Redirect	 */	public static function home($status = 302, $https = null)	{		return static::to(URL::home($https), $status);	}	/**	 * Create a redirect response to the HTTP referrer.	 *	 * @param  int       $status	 * @return Redirect	 */	public static function back($status = 302)	{		return static::to(Request::referrer(), $status);	}	/**	 * Create a redirect response.	 *	 * <code>	 *		// Create a redirect response to a location within the application	 *		return Redirect::to('user/profile');	 *	 *		// Create a redirect response with a 301 status code	 *		return Redirect::to('user/profile', 301);	 * </code>	 *	 * @param  string    $url	 * @param  int       $status	 * @param  bool      $https	 * @return Redirect	 */	public static function to($url, $status = 302, $https = null)	{		return static::make('', $status)->header('Location', URL::to($url, $https));	}	/**	 * Create a redirect response to a HTTPS URL.	 *	 * @param  string    $url	 * @param  int       $status	 * @return Redirect	 */	public static function to_secure($url, $status = 302)	{		return static::to($url, $status, true);	}	/**	 * Create a redirect response to a controller action.	 *	 * @param  string    $action	 * @param  array     $parameters	 * @param  int       $status	 * @return Redirect	 */	public static function to_action($action, $parameters = array(), $status = 302)	{		return static::to(URL::to_action($action, $parameters), $status);	}	/**	 * Create a redirect response to a named route.	 *	 * <code>	 *		// Create a redirect response to the "login" named route	 *		return Redirect::to_route('login');	 *	 *		// Create a redirect response to the "profile" named route with parameters	 *		return Redirect::to_route('profile', array($username));	 * </code>	 *	 * @param  string    $route	 * @param  array     $parameters	 * @param  int       $status	 * @return Redirect	 */	public static function to_route($route, $parameters = array(), $status = 302)	{		return static::to(URL::to_route($route, $parameters), $status);	}	/**	 * Add an item to the session flash data.	 *	 * This is useful for "passing" status messages or other data to the next request.	 *	 * <code>	 *		// Create a redirect response and flash to the session	 *		return Redirect::to('profile')->with('message', 'Welcome Back!');	 * </code>	 *	 * @param  string          $key	 * @param  mixed           $value	 * @return Redirect	 */	public function with($key, $value)	{		if (Config::get('session.driver') == '')		{			throw new \Exception('A session driver must be set before setting flash data.');		}		Session::flash($key, $value);		return $this;	}	/**	 * Flash the old input to the session and return the Redirect instance.	 *	 * Once the input has been flashed, it can be retrieved via the Input::old method.	 *	 * <code>	 *		// Redirect and flash all of the input data to the session	 *		return Redirect::to('login')->with_input();	 *	 *		// Redirect and flash only a few of the input items	 *		return Redirect::to('login')->with_input('only', array('email', 'username'));	 *	 *		// Redirect and flash all but a few of the input items	 *		return Redirect::to('login')->with_input('except', array('password', 'ssn'));	 * </code>	 *	 * @param  string    $filter	 * @param  array     $items	 * @return Redirect	 */	public function with_input($filter = null, $items = array())	{		Input::flash($filter, $items);		return $this;	}	/**	 * Flash a Validator's errors to the session data.	 *	 * This method allows you to conveniently pass validation errors back to views.	 *	 * <code>	 *		// Redirect and flash validator errors the session	 *		return Redirect::to('register')->with_errors($validator);	 * </code>	 *	 * @param  Validator|Messages  $container	 * @return Redirect	 */	public function with_errors($container)	{		$errors = ($container instanceof Validator) ? $container->errors : $container;		return $this->with('errors', $errors);	}	/**	 * Send the headers and content of the response to the browser.	 *	 * @return void	 */	public function send()	{		// Dump all output buffering, this ensures		// that symphony will send our redirect headers		// properly if we've outputted any content from		// within Laravel.		while (ob_get_level() > 0)		{			ob_end_clean();		}		return parent::send();	}}
 |