input.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php namespace System;
  2. class Input {
  3. /**
  4. * The input data for the request.
  5. *
  6. * @var array
  7. */
  8. public static $input;
  9. /**
  10. * Determine if the input data contains an item.
  11. *
  12. * @param string $key
  13. * @return bool
  14. */
  15. public static function has($key)
  16. {
  17. return ( ! is_null(static::get($key)));
  18. }
  19. /**
  20. * Determine if the old input data contains an item.
  21. *
  22. * @param string $key
  23. * @return bool
  24. */
  25. public static function has_old($key)
  26. {
  27. return ( ! is_null(static::old($key)));
  28. }
  29. /**
  30. * Get an item from the input data.
  31. *
  32. * @param string $key
  33. * @param mixed $default
  34. * @return string
  35. */
  36. public static function get($key = null, $default = null)
  37. {
  38. // -------------------------------------------------
  39. // Hydrate the input data for the request.
  40. // -------------------------------------------------
  41. static::hydrate();
  42. return static::from_array(static::$input, $key, $default);
  43. }
  44. /**
  45. * Get input data from the previous request.
  46. *
  47. * @param string $key
  48. * @param mixed $default
  49. * @return string
  50. */
  51. public static function old($key = null, $default = null)
  52. {
  53. // -------------------------------------------------
  54. // Verify that sessions are enabled.
  55. // -------------------------------------------------
  56. if (Config::get('session.driver') == '')
  57. {
  58. throw new \Exception("Sessions must be enabled to retrieve old input data.");
  59. }
  60. return static::from_array(Session::get('laravel_old_input', array()), $key, $default);
  61. }
  62. /**
  63. * Get an item from an array.
  64. *
  65. * @param array $array
  66. * @param string $key
  67. * @param mixed $default
  68. * @return string
  69. */
  70. private static function from_array($array, $key, $default)
  71. {
  72. // -------------------------------------------------
  73. // If no key is given, return the entire array.
  74. // -------------------------------------------------
  75. if (is_null($key))
  76. {
  77. return $array;
  78. }
  79. return (array_key_exists($key, $array)) ? $array[$key] : $default;
  80. }
  81. /**
  82. * Hydrate the input data for the request.
  83. *
  84. * @return void
  85. */
  86. public static function hydrate()
  87. {
  88. if (is_null(static::$input))
  89. {
  90. switch (Request::method())
  91. {
  92. case 'GET':
  93. static::$input =& $_GET;
  94. break;
  95. case 'POST':
  96. static::$input =& $_POST;
  97. break;
  98. case 'PUT':
  99. case 'DELETE':
  100. // ----------------------------------------------------------------------
  101. // Typically, browsers do not support PUT and DELETE methods on HTML
  102. // forms. So, we simulate them using a hidden POST variable.
  103. //
  104. // If the request method is being "spoofed", we'll move the POST array
  105. // into the PUT / DELETE array.
  106. // ----------------------------------------------------------------------
  107. if (isset($_POST['request_method']) and ($_POST['request_method'] == 'PUT' or $_POST['request_method'] == 'DELETE'))
  108. {
  109. static::$input =& $_POST;
  110. }
  111. // ----------------------------------------------------------------------
  112. // If the request is a true PUT request, read the php://input file.
  113. // ----------------------------------------------------------------------
  114. else
  115. {
  116. parse_str(file_get_contents('php://input'), static::$input);
  117. }
  118. }
  119. }
  120. }
  121. }