diff --git a/system/Database/Database.php b/system/Database/Database.php index f5b18720d89f..60c5de4fc431 100644 --- a/system/Database/Database.php +++ b/system/Database/Database.php @@ -41,8 +41,13 @@ class Database * @return mixed * @internal param bool $useBuilder */ - public function load(array $params = [], string $alias) + public function load(array $params = [], string $alias = '') { + if (empty($alias)) + { + throw new InvalidArgumentException('You must supply the parameter: alias.'); + } + // Handle universal DSN connection string if (! empty($params['DSN']) && strpos($params['DSN'], '://') !== false) { diff --git a/system/HTTP/IncomingRequest.php b/system/HTTP/IncomingRequest.php index 6e4a8b999c7f..c3b04fab7426 100755 --- a/system/HTTP/IncomingRequest.php +++ b/system/HTTP/IncomingRequest.php @@ -16,6 +16,7 @@ use CodeIgniter\HTTP\Files\UploadedFile; use Config\App; use Config\Services; +use InvalidArgumentException; use Locale; /** @@ -128,8 +129,13 @@ class IncomingRequest extends Request * @param string|null $body * @param UserAgent $userAgent */ - public function __construct($config, URI $uri = null, $body = 'php://input', UserAgent $userAgent) + public function __construct($config, URI $uri = null, $body = 'php://input', UserAgent $userAgent = null) { + if (empty($uri) || empty($userAgent)) + { + throw new InvalidArgumentException('You must supply the parameters: uri, userAgent.'); + } + // Get our body from php://input if ($body === 'php://input') { diff --git a/system/Images/Handlers/BaseHandler.php b/system/Images/Handlers/BaseHandler.php index c4e9146c0d2b..f591cd693e40 100644 --- a/system/Images/Handlers/BaseHandler.php +++ b/system/Images/Handlers/BaseHandler.php @@ -15,6 +15,7 @@ use CodeIgniter\Images\Image; use CodeIgniter\Images\ImageHandlerInterface; use Config\Images; +use InvalidArgumentException; /** * Base image handling implementation @@ -662,8 +663,13 @@ public function fit(int $width, int $height = null, string $position = 'center') * * @return array */ - protected function calcAspectRatio($width, $height = null, $origWidth, $origHeight): array + protected function calcAspectRatio($width, $height = null, $origWidth = 0, $origHeight = 0): array { + if (empty($origWidth) || empty($origHeight)) + { + throw new InvalidArgumentException('You must supply the parameters: origWidth, origHeight.'); + } + // If $height is null, then we have it easy. // Calc based on full image size and be done. if (is_null($height)) diff --git a/system/Log/Logger.php b/system/Log/Logger.php index d289480dfe5e..d3054ef0f6ed 100644 --- a/system/Log/Logger.php +++ b/system/Log/Logger.php @@ -462,7 +462,7 @@ public function determineFile(): array ]; // Generate Backtrace info - $trace = \debug_backtrace(false); + $trace = \debug_backtrace(0); // So we search from the bottom (earliest) of the stack frames $stackFrames = \array_reverse($trace); diff --git a/system/Router/RouteCollection.php b/system/Router/RouteCollection.php index f8d0d392a702..0c4c99a97af7 100644 --- a/system/Router/RouteCollection.php +++ b/system/Router/RouteCollection.php @@ -17,6 +17,7 @@ use CodeIgniter\Router\Exceptions\RouterException; use Config\Modules; use Config\Services; +use InvalidArgumentException; /** * Class RouteCollection @@ -988,8 +989,13 @@ public function presenter(string $name, array $options = null): RouteCollectionI * * @return RouteCollectionInterface */ - public function match(array $verbs = [], string $from, $to, array $options = null): RouteCollectionInterface + public function match(array $verbs = [], string $from = '', $to = '', array $options = null): RouteCollectionInterface { + if (empty($from) || empty($to)) + { + throw new InvalidArgumentException('You must supply the parameters: from, to.'); + } + foreach ($verbs as $verb) { $verb = strtolower($verb); diff --git a/system/Validation/Rules.php b/system/Validation/Rules.php index b7a106770b59..d6bdf3591a46 100644 --- a/system/Validation/Rules.php +++ b/system/Validation/Rules.php @@ -12,6 +12,7 @@ namespace CodeIgniter\Validation; use Config\Database; +use InvalidArgumentException; /** * Validation Rules. @@ -352,13 +353,18 @@ public function required($str = null): bool * required_with[password] * * @param string|null $str - * @param string $fields List of fields that we should check if present + * @param string|null $fields List of fields that we should check if present * @param array $data Complete list of fields from the form * * @return boolean */ - public function required_with($str = null, string $fields, array $data): bool + public function required_with($str = null, string $fields = null, array $data = []): bool { + if (is_null($fields) || empty($data)) + { + throw new InvalidArgumentException('You must supply the parameters: fields, data.'); + } + $fields = explode(',', $fields); // If the field is present we can safely assume that @@ -404,13 +410,18 @@ public function required_with($str = null, string $fields, array $data): bool * required_without[id,email] * * @param string|null $str - * @param string $fields + * @param string|null $fields * @param array $data * * @return boolean */ - public function required_without($str = null, string $fields, array $data): bool + public function required_without($str = null, string $fields = null, array $data = []): bool { + if (is_null($fields) || empty($data)) + { + throw new InvalidArgumentException('You must supply the parameters: fields, data.'); + } + $fields = explode(',', $fields); // If the field is present we can safely assume that diff --git a/system/Validation/Validation.php b/system/Validation/Validation.php index 31b8456d301e..558323c3499a 100644 --- a/system/Validation/Validation.php +++ b/system/Validation/Validation.php @@ -206,8 +206,13 @@ public function check($value, string $rule, array $errors = []): bool * * @return boolean */ - protected function processRules(string $field, string $label = null, $value, $rules = null, array $data): bool + protected function processRules(string $field, string $label = null, $value, $rules = null, array $data = null): bool { + if (is_null($data)) + { + throw new InvalidArgumentException('You must supply the parameter: data.'); + } + // If the if_exist rule is defined... if (in_array('if_exist', $rules, true)) {