diff --git a/.github/mergeable.yml b/.github/mergeable.yml
index d23053efa3e2..122651b0a8da 100644
--- a/.github/mergeable.yml
+++ b/.github/mergeable.yml
@@ -2,40 +2,33 @@
version: 2
mergeable:
- - when: issues.opened
+ - when: issues.opened, issues.reopened
validate:
- - do: description
- and:
- - must_include:
- regex: '^### PHP Version'
- - must_include:
- regex: '^### CodeIgniter4 Version'
- - do: author
- and:
- - must_exclude:
- regex: 'kenjis'
- - must_exclude:
- regex: 'lonnieezell'
- - must_exclude:
- regex: 'MGatner'
- - must_exclude:
- regex: 'michalsn'
- - must_exclude:
- regex: 'paulbalandan'
- - must_exclude:
- regex: 'samsonasik'
+ - do: or
+ validate:
+ - do: and
+ validate:
+ - do: description
+ must_include:
+ regex: '### PHP Version'
+ - do: description
+ must_include:
+ regex: '### CodeIgniter Version'
+ - do: author
+ must_include:
+ regex: ^kenjis|lonnieezell|MGatner|michalsn|paulbalandan|samsonasik$
fail:
- do: comment
- payload: |
- Hi there! :wave:
+ payload:
+ body: |
+ Hi there, @@author! :wave:
- It looks like you opened an issue without following the bug report template:
+ It looks like you opened an issue without following the bug report template:
- Bug report ([open an issue](https://github.com/codeigniter4/CodeIgniter4/issues/new?assignees=&labels=bug&projects=&template=bug_report.yml&title=Bug%3A+))
+ * Bug report ([open an issue](https://github.com/codeigniter4/CodeIgniter4/issues/new?assignees=&labels=bug&projects=&template=bug_report.yml&title=Bug%3A+))
+ * For feature request or support question, please use the [forums](https://forum.codeigniter.com/forum-30.html).
- If you are opening a feature request or support question, please do so in the [forums](https://forum.codeigniter.com/forum-30.html).
+ The current issue will be closed. This is a precaution to save maintainers' time, I hope you'll understand.
- The current issue will be closed. This is a precaution to save maintainers' time, I hope you'll understand.
-
- Sincerely, the mergeable bot π€
+ Sincerely, the mergeable bot π€
- do: close
diff --git a/.php-cs-fixer.dist.php b/.php-cs-fixer.dist.php
index a50b126db075..c9c24c7a06f8 100644
--- a/.php-cs-fixer.dist.php
+++ b/.php-cs-fixer.dist.php
@@ -39,7 +39,19 @@
__DIR__ . '/spark',
]);
-$overrides = [];
+$overrides = [
+ 'get_class_to_class_keyword' => true,
+ 'trailing_comma_in_multiline' => [
+ 'after_heredoc' => true,
+ 'elements' => [
+ 'arguments',
+ 'array_destructuring',
+ 'arrays',
+ 'match',
+ 'parameters',
+ ],
+ ],
+];
$options = [
'cacheFile' => 'build/.php-cs-fixer.cache',
@@ -53,5 +65,5 @@
return Factory::create(new CodeIgniter4(), $overrides, $options)->forLibrary(
'CodeIgniter 4 framework',
'CodeIgniter Foundation',
- 'admin@codeigniter.com'
+ 'admin@codeigniter.com',
);
diff --git a/LICENSE b/LICENSE
index 148e7f737ff6..24728f607f02 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,7 +1,7 @@
The MIT License (MIT)
Copyright (c) 2014-2019 British Columbia Institute of Technology
-Copyright (c) 2019-2024 CodeIgniter Foundation
+Copyright (c) 2019-present CodeIgniter Foundation
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
diff --git a/admin/create-new-changelog.php b/admin/create-new-changelog.php
index ff333f42693f..cc7f8359a570 100644
--- a/admin/create-new-changelog.php
+++ b/admin/create-new-changelog.php
@@ -47,7 +47,7 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
$changelogIndex,
'/\.\. toctree::\n :titlesonly:\n/u',
- ".. toctree::\n :titlesonly:\n\n v{$version}"
+ ".. toctree::\n :titlesonly:\n\n v{$version}",
);
// Replace {version}
$length = mb_strlen("Version {$version}");
@@ -55,12 +55,12 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
$changelog,
'/#################\nVersion {version}\n#################/u',
- "{$underline}\nVersion {$version}\n{$underline}"
+ "{$underline}\nVersion {$version}\n{$underline}",
);
replace_file_content(
$changelog,
'/{version}/u',
- "{$version}"
+ "{$version}",
);
// Copy upgrading
@@ -72,7 +72,7 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
$upgradingIndex,
'/ backward_compatibility_notes\n/u',
- " backward_compatibility_notes\n\n upgrade_{$versionWithoutDots}"
+ " backward_compatibility_notes\n\n upgrade_{$versionWithoutDots}",
);
// Replace {version}
$length = mb_strlen("Upgrading from {$versionCurrent} to {$version}");
@@ -80,7 +80,7 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
$upgrading,
'/##############################\nUpgrading from {version} to {version}\n##############################/u',
- "{$underline}\nUpgrading from {$versionCurrent} to {$version}\n{$underline}"
+ "{$underline}\nUpgrading from {$versionCurrent} to {$version}\n{$underline}",
);
// Commits
diff --git a/admin/prepare-release.php b/admin/prepare-release.php
index c0dcab6866ce..5d66a43b8c86 100644
--- a/admin/prepare-release.php
+++ b/admin/prepare-release.php
@@ -33,31 +33,31 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
'./system/CodeIgniter.php',
'/public const CI_VERSION = \'.*?\';/u',
- "public const CI_VERSION = '{$version}';"
+ "public const CI_VERSION = '{$version}';",
);
// Updates version number in "conf.py".
replace_file_content(
'./user_guide_src/source/conf.py',
'/^version = \'.*?\'/mu',
- "version = '{$minor}'"
+ "version = '{$minor}'",
);
replace_file_content(
'./user_guide_src/source/conf.py',
'/^release = \'.*?\'/mu',
- "release = '{$version}'"
+ "release = '{$version}'",
);
// Updates version number in "phpdoc.dist.xml".
replace_file_content(
'./phpdoc.dist.xml',
'!
CodeIgniter v.*? API!mu',
- "CodeIgniter v{$minor} API"
+ "CodeIgniter v{$minor} API",
);
replace_file_content(
'./phpdoc.dist.xml',
'//mu',
- ""
+ "",
);
// Updates release date in changelogs.
@@ -65,7 +65,7 @@ function replace_file_content(string $path, string $pattern, string $replace): v
replace_file_content(
"./user_guide_src/source/changelogs/v{$version}.rst",
'/^Release Date: .*/mu',
- "Release Date: {$date}"
+ "Release Date: {$date}",
);
// Commits
diff --git a/admin/starter/tests/unit/HealthTest.php b/admin/starter/tests/unit/HealthTest.php
index f6a5a804802f..b3e480f4b0bf 100644
--- a/admin/starter/tests/unit/HealthTest.php
+++ b/admin/starter/tests/unit/HealthTest.php
@@ -32,7 +32,7 @@ public function testBaseUrlHasBeenSet(): void
$config = new App();
$this->assertTrue(
$validation->check($config->baseURL, 'valid_url'),
- 'baseURL "' . $config->baseURL . '" in .env is not valid URL'
+ 'baseURL "' . $config->baseURL . '" in .env is not valid URL',
);
}
@@ -43,7 +43,7 @@ public function testBaseUrlHasBeenSet(): void
// BaseURL in app/Config/App.php is a valid URL?
$this->assertTrue(
$validation->check($reader->baseURL, 'valid_url'),
- 'baseURL "' . $reader->baseURL . '" in app/Config/App.php is not valid URL'
+ 'baseURL "' . $reader->baseURL . '" in app/Config/App.php is not valid URL',
);
}
}
diff --git a/composer.json b/composer.json
index 76362069c615..80fe952c9089 100644
--- a/composer.json
+++ b/composer.json
@@ -28,7 +28,7 @@
"phpunit/phpcov": "^9.0.2 || ^10.0",
"phpunit/phpunit": "^10.5.16 || ^11.2",
"predis/predis": "^1.1 || ^2.0",
- "rector/rector": "2.0.4",
+ "rector/rector": "2.0.6",
"shipmonk/phpstan-baseline-per-identifier": "^2.0"
},
"replace": {
diff --git a/phpunit.xml.dist b/phpunit.xml.dist
index 7464323e4078..0e5c9e24f82c 100644
--- a/phpunit.xml.dist
+++ b/phpunit.xml.dist
@@ -11,7 +11,6 @@
failOnWarning="true"
cacheDirectory="build/.phpunit.cache">
diff --git a/preload.php b/preload.php
index 755df5e4a4ed..0b453122345e 100644
--- a/preload.php
+++ b/preload.php
@@ -86,7 +86,7 @@ public function load(): void
$phpFiles = new RegexIterator(
$fullTree,
'/.+((? $file) {
diff --git a/public/index.php b/public/index.php
index 5ec58a7729c3..eb7f5c988838 100644
--- a/public/index.php
+++ b/public/index.php
@@ -11,7 +11,7 @@
$message = sprintf(
'Your PHP version must be %s or higher to run CodeIgniter. Current version: %s',
$minPhpVersion,
- PHP_VERSION
+ PHP_VERSION,
);
header('HTTP/1.1 503 Service Unavailable.', true, 503);
diff --git a/rector.php b/rector.php
index 486685959c70..e5c21c814ab2 100644
--- a/rector.php
+++ b/rector.php
@@ -62,7 +62,7 @@
->withCache(
// Github action cache or local
is_dir('/tmp') ? '/tmp/rector' : null,
- FileCacheStorage::class
+ FileCacheStorage::class,
)
// paths to refactor; solid alternative to CLI arguments
->withPaths([
diff --git a/spark b/spark
index 992d044c9ee2..856dc3f8a227 100755
--- a/spark
+++ b/spark
@@ -40,7 +40,7 @@ if (version_compare(PHP_VERSION, $minPhpVersion, '<')) {
$message = sprintf(
'Your PHP version must be %s or higher to run CodeIgniter. Current version: %s',
$minPhpVersion,
- PHP_VERSION
+ PHP_VERSION,
);
exit($message);
diff --git a/system/API/ResponseTrait.php b/system/API/ResponseTrait.php
index 01ce42860b32..dbfa83dc88dc 100644
--- a/system/API/ResponseTrait.php
+++ b/system/API/ResponseTrait.php
@@ -319,7 +319,7 @@ protected function format($data = null)
$mime = $this->request->negotiate(
'media',
$format->getConfig()->supportedResponseFormats,
- false
+ false,
);
}
diff --git a/system/Autoloader/Autoloader.php b/system/Autoloader/Autoloader.php
index b338027c9c8a..50e6eaed2337 100644
--- a/system/Autoloader/Autoloader.php
+++ b/system/Autoloader/Autoloader.php
@@ -347,7 +347,7 @@ public function sanitizeFilename(string $filename): string
throw new InvalidArgumentException(
'The file path contains special characters "' . $chars
- . '" that are not allowed: "' . $filename . '"'
+ . '" that are not allowed: "' . $filename . '"',
);
}
if ($result === false) {
@@ -386,7 +386,7 @@ private function loadComposerNamespaces(ClassLoader $composer, array $composerPa
throw new RuntimeException(
'Your Composer version is too old.'
. ' Please update Composer (run `composer self-update`) to v2.0.14 or later'
- . ' and remove your vendor/ directory, and run `composer update`.'
+ . ' and remove your vendor/ directory, and run `composer update`.',
);
}
// This method requires Composer 2.0.14 or later.
diff --git a/system/Autoloader/FileLocator.php b/system/Autoloader/FileLocator.php
index 8e2564e00941..844ac7fc4cc9 100644
--- a/system/Autoloader/FileLocator.php
+++ b/system/Autoloader/FileLocator.php
@@ -295,9 +295,9 @@ public function findQualifiedNameFromPath(string $path)
str_replace(
'/',
'\\',
- mb_substr($path, mb_strlen($namespace['path']))
+ mb_substr($path, mb_strlen($namespace['path'])),
),
- '\\'
+ '\\',
);
// Remove the file extension (.php)
$className = mb_substr($className, 0, -4);
diff --git a/system/BaseModel.php b/system/BaseModel.php
index 05c5459d8c4b..a10acef72e2e 100644
--- a/system/BaseModel.php
+++ b/system/BaseModel.php
@@ -379,7 +379,7 @@ protected function createDataConverter(): void
$this->converter = new DataConverter(
$this->casts,
$this->castHandlers,
- $this->db
+ $this->db,
);
}
}
@@ -1081,7 +1081,7 @@ public function updateBatch(?array $set = null, ?string $index = null, int $batc
if ($updateIndex === null) {
throw new InvalidArgumentException(
'The index ("' . $index . '") for updateBatch() is missing in the data: '
- . json_encode($row)
+ . json_encode($row),
);
}
diff --git a/system/Boot.php b/system/Boot.php
index 4b2d20ca95b6..502692249b06 100644
--- a/system/Boot.php
+++ b/system/Boot.php
@@ -288,7 +288,7 @@ protected static function checkMissingExtensions(): void
$message = sprintf(
'The framework needs the following extension(s) installed and loaded: %s.',
- implode(', ', $missingExtensions)
+ implode(', ', $missingExtensions),
);
header('HTTP/1.1 503 Service Unavailable.', true, 503);
diff --git a/system/CLI/CLI.php b/system/CLI/CLI.php
index fa77515e1ba8..b8b90d77ba2d 100644
--- a/system/CLI/CLI.php
+++ b/system/CLI/CLI.php
@@ -289,7 +289,7 @@ public static function promptByKey($text, array $options, $validation = null): s
CLI::isZeroOptions($options);
- if ($line = array_shift($text)) {
+ if (($line = array_shift($text)) !== null) {
CLI::write($line);
}
@@ -610,11 +610,11 @@ public static function color(string $text, string $foreground, ?string $backgrou
$nonColoredText = preg_replace(
$pattern,
'<<__colored_string__>>',
- $text
+ $text,
);
$nonColoredChunks = preg_split(
'/<<__colored_string__>>/u',
- $nonColoredText
+ $nonColoredText,
);
foreach ($nonColoredChunks as $i => $chunk) {
diff --git a/system/CLI/Console.php b/system/CLI/Console.php
index 725193d424b5..5cb8b57a0ad3 100644
--- a/system/CLI/Console.php
+++ b/system/CLI/Console.php
@@ -63,7 +63,7 @@ public function showHeader(bool $suppress = false)
'CodeIgniter v%s Command Line Tool - Server Time: %s UTC%s',
CodeIgniter::CI_VERSION,
date('Y-m-d H:i:s'),
- date('P')
+ date('P'),
), 'green');
CLI::newLine();
}
diff --git a/system/CLI/GeneratorTrait.php b/system/CLI/GeneratorTrait.php
index 6a061a36b8b3..1024fa695259 100644
--- a/system/CLI/GeneratorTrait.php
+++ b/system/CLI/GeneratorTrait.php
@@ -171,7 +171,7 @@ private function generateFile(string $target, string $content): void
CLI::prompt(
'Are you sure you want to continue?',
['y', 'n'],
- 'required'
+ 'required',
) === 'n'
) {
CLI::newLine();
@@ -193,7 +193,7 @@ private function generateFile(string $target, string $content): void
CLI::error(
lang('CLI.generator.fileExist', [clean_path($target)]),
'light_gray',
- 'red'
+ 'red',
);
CLI::newLine();
@@ -216,7 +216,7 @@ private function generateFile(string $target, string $content): void
CLI::error(
lang('CLI.generator.fileError', [clean_path($target)]),
'light_gray',
- 'red'
+ 'red',
);
CLI::newLine();
@@ -227,7 +227,7 @@ private function generateFile(string $target, string $content): void
if ($this->getOption('force') && $isFile) {
CLI::write(
lang('CLI.generator.fileOverwrite', [clean_path($target)]),
- 'yellow'
+ 'yellow',
);
CLI::newLine();
@@ -236,7 +236,7 @@ private function generateFile(string $target, string $content): void
CLI::write(
lang('CLI.generator.fileCreate', [clean_path($target)]),
- 'green'
+ 'green',
);
CLI::newLine();
}
@@ -326,10 +326,10 @@ private function normalizeInputClassName(): string
'\\',
array_map(
pascalize(...),
- explode('\\', str_replace('/', '\\', trim($class)))
- )
+ explode('\\', str_replace('/', '\\', trim($class))),
+ ),
),
- '\\/'
+ '\\/',
);
}
@@ -351,7 +351,7 @@ protected function renderTemplate(array $data = []): string
return view(
"CodeIgniter\\Commands\\Generators\\Views\\{$this->template}",
$data,
- ['debug' => false]
+ ['debug' => false],
);
}
}
@@ -370,15 +370,15 @@ protected function parseTemplate(
string $class,
array $search = [],
array $replace = [],
- array $data = []
+ array $data = [],
): string {
// Retrieves the namespace part from the fully qualified class name.
$namespace = trim(
implode(
'\\',
- array_slice(explode('\\', $class), 0, -1)
+ array_slice(explode('\\', $class), 0, -1),
),
- '\\'
+ '\\',
);
$search[] = '<@php';
$search[] = '{namespace}';
@@ -404,7 +404,7 @@ protected function buildContent(string $class): string
&& preg_match(
'/(?P(?:^use [^;]+;$\n?)+)/m',
$template,
- $match
+ $match,
)
) {
$imports = explode("\n", trim($match['imports']));
@@ -432,7 +432,7 @@ protected function buildPath(string $class): string
CLI::error(
lang('CLI.namespaceNotDefined', [$namespace]),
'light_gray',
- 'red'
+ 'red',
);
CLI::newLine();
@@ -446,7 +446,7 @@ protected function buildPath(string $class): string
. str_replace(
'\\',
DIRECTORY_SEPARATOR,
- trim(str_replace($namespace . '\\', '', $class), '\\')
+ trim(str_replace($namespace . '\\', '', $class), '\\'),
) . '.php';
return implode(
@@ -454,8 +454,8 @@ protected function buildPath(string $class): string
array_slice(
explode(DIRECTORY_SEPARATOR, $file),
0,
- -1
- )
+ -1,
+ ),
) . DIRECTORY_SEPARATOR . $this->basename($file);
}
@@ -470,9 +470,9 @@ protected function getNamespace(): string
str_replace(
'/',
'\\',
- $this->getOption('namespace') ?? APP_NAMESPACE
+ $this->getOption('namespace') ?? APP_NAMESPACE,
),
- '\\'
+ '\\',
);
}
diff --git a/system/Cache/Handlers/MemcachedHandler.php b/system/Cache/Handlers/MemcachedHandler.php
index e1048004077a..f3bc00f40ba1 100644
--- a/system/Cache/Handlers/MemcachedHandler.php
+++ b/system/Cache/Handlers/MemcachedHandler.php
@@ -85,7 +85,7 @@ public function initialize()
$this->memcached->addServer(
$this->config['host'],
$this->config['port'],
- $this->config['weight']
+ $this->config['weight'],
);
// attempt to get status of servers
@@ -103,7 +103,7 @@ public function initialize()
// Check if we can connect to the server
$canConnect = $this->memcached->connect(
$this->config['host'],
- $this->config['port']
+ $this->config['port'],
);
// If we can't connect, throw a CriticalError exception
@@ -116,7 +116,7 @@ public function initialize()
$this->config['host'],
$this->config['port'],
true,
- $this->config['weight']
+ $this->config['weight'],
);
} else {
throw new CriticalError('Cache: Not support Memcache(d) extension.');
diff --git a/system/Cache/Handlers/PredisHandler.php b/system/Cache/Handlers/PredisHandler.php
index fc0185033d64..bdf5afe0f22f 100644
--- a/system/Cache/Handlers/PredisHandler.php
+++ b/system/Cache/Handlers/PredisHandler.php
@@ -82,7 +82,7 @@ public function get(string $key)
$data = array_combine(
['__ci_type', '__ci_value'],
- $this->redis->hmget($key, ['__ci_type', '__ci_value'])
+ $this->redis->hmget($key, ['__ci_type', '__ci_value']),
);
if (! isset($data['__ci_type'], $data['__ci_value']) || $data['__ci_value'] === false) {
diff --git a/system/Cache/ResponseCache.php b/system/Cache/ResponseCache.php
index 388931813c7c..448e7b83dfd4 100644
--- a/system/Cache/ResponseCache.php
+++ b/system/Cache/ResponseCache.php
@@ -112,7 +112,7 @@ public function make($request, ResponseInterface $response): bool
return $this->cache->save(
$this->generateCacheKey($request),
serialize(['headers' => $headers, 'output' => $response->getBody()]),
- $this->ttl
+ $this->ttl,
);
}
diff --git a/system/CodeIgniter.php b/system/CodeIgniter.php
index e92a6a10ae8c..716d3701d1a4 100644
--- a/system/CodeIgniter.php
+++ b/system/CodeIgniter.php
@@ -325,7 +325,7 @@ public function run(?RouteCollectionInterface $routes = null, bool $returnRespon
if ($this->context === null) {
throw new LogicException(
'Context must be set before run() is called. If you are upgrading from 4.1.x, '
- . 'you need to merge `public/index.php` and `spark` file from `vendor/codeigniter4/framework`.'
+ . 'you need to merge `public/index.php` and `spark` file from `vendor/codeigniter4/framework`.',
);
}
@@ -799,7 +799,7 @@ public function displayPerformanceMetrics(string $output): string
return str_replace(
['{elapsed_time}', '{memory_usage}'],
[(string) $this->totalTime, number_format(memory_get_peak_usage() / 1024 / 1024, 3)],
- $output
+ $output,
);
}
@@ -979,7 +979,7 @@ protected function display404errors(PageNotFoundException $e)
// Throws new PageNotFoundException and remove exception message on production.
throw PageNotFoundException::forPageNotFound(
- (ENVIRONMENT !== 'production' || ! $this->isWeb()) ? $e->getMessage() : null
+ (ENVIRONMENT !== 'production' || ! $this->isWeb()) ? $e->getMessage() : null,
);
}
@@ -1064,7 +1064,7 @@ public function storePreviousURL($uri)
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
));
}
}
diff --git a/system/Commands/Database/ShowTableInfo.php b/system/Commands/Database/ShowTableInfo.php
index 147b6eb61446..2367bbff4dff 100644
--- a/system/Commands/Database/ShowTableInfo.php
+++ b/system/Commands/Database/ShowTableInfo.php
@@ -144,7 +144,7 @@ public function run(array $params)
$tableNameNo = CLI::promptByKey(
['Here is the list of your database tables:', 'Which table do you want to see?'],
$tables,
- 'required'
+ 'required',
);
CLI::newLine();
@@ -174,7 +174,7 @@ private function showDBConfig(): void
]];
CLI::table(
$data,
- ['hostname', 'database', 'username', 'DBDriver', 'DBPrefix', 'port']
+ ['hostname', 'database', 'username', 'DBDriver', 'DBPrefix', 'port'],
);
}
@@ -272,7 +272,7 @@ private function makeTableRows(
string $tableName,
int $limitRows,
int $limitFieldValue,
- ?string $sortField = null
+ ?string $sortField = null,
): array {
$this->tbody = [];
@@ -290,7 +290,7 @@ private function makeTableRows(
static fn ($item): string => mb_strlen((string) $item) > $limitFieldValue
? mb_substr((string) $item, 0, $limitFieldValue) . '...'
: (string) $item,
- $row
+ $row,
);
$this->tbody[] = $row;
}
diff --git a/system/Commands/Encryption/GenerateKey.php b/system/Commands/Encryption/GenerateKey.php
index 21a582a06725..a3fdbd4393a9 100644
--- a/system/Commands/Encryption/GenerateKey.php
+++ b/system/Commands/Encryption/GenerateKey.php
@@ -182,7 +182,7 @@ protected function writeNewEncryptionKeyToFile(string $oldKey, string $newKey):
$newFileContents = preg_replace(
'/^[#\s]*encryption.key[=\s]*(?:hex2bin\:[a-f0-9]{64}|base64\:(?:[A-Za-z0-9+\/]{4})*(?:[A-Za-z0-9+\/]{2}==|[A-Za-z0-9+\/]{3}=)?)$/m',
$replacementKey,
- $oldFileContents
+ $oldFileContents,
);
}
diff --git a/system/Commands/Generators/CellGenerator.php b/system/Commands/Generators/CellGenerator.php
index 57d79ac8902b..04c5bd8adf04 100644
--- a/system/Commands/Generators/CellGenerator.php
+++ b/system/Commands/Generators/CellGenerator.php
@@ -96,7 +96,7 @@ public function run(array $params)
$viewName = preg_replace(
'/([a-z][a-z0-9_\/\\\\]+)(_cell)$/i',
'$1',
- $viewName
+ $viewName,
) ?? $viewName;
$namespace = substr($className, 0, strrpos($className, '\\') + 1);
diff --git a/system/Commands/Generators/CommandGenerator.php b/system/Commands/Generators/CommandGenerator.php
index 8c2ebcfb5d44..a0872f63c2ba 100644
--- a/system/Commands/Generators/CommandGenerator.php
+++ b/system/Commands/Generators/CommandGenerator.php
@@ -115,7 +115,7 @@ protected function prepare(string $class): string
$class,
['{group}', '{command}'],
[$group, $command],
- ['type' => $type]
+ ['type' => $type],
);
}
}
diff --git a/system/Commands/Generators/ControllerGenerator.php b/system/Commands/Generators/ControllerGenerator.php
index c6f54cac2888..287f92f87c30 100644
--- a/system/Commands/Generators/ControllerGenerator.php
+++ b/system/Commands/Generators/ControllerGenerator.php
@@ -130,7 +130,7 @@ protected function prepare(string $class): string
$class,
['{useStatement}', '{extends}'],
[$useStatement, $extends],
- ['type' => $rest]
+ ['type' => $rest],
);
}
}
diff --git a/system/Commands/Generators/TestGenerator.php b/system/Commands/Generators/TestGenerator.php
index 35019c72b826..7ab6859ed9a9 100644
--- a/system/Commands/Generators/TestGenerator.php
+++ b/system/Commands/Generators/TestGenerator.php
@@ -102,9 +102,9 @@ protected function getNamespace(): string
str_replace(
'/',
'\\',
- $this->getOption('namespace')
+ $this->getOption('namespace'),
),
- '\\'
+ '\\',
);
}
@@ -143,7 +143,7 @@ protected function buildPath(string $class): string
CLI::error(
lang('CLI.namespaceNotDefined', [$namespace]),
'light_gray',
- 'red'
+ 'red',
);
CLI::newLine();
@@ -157,7 +157,7 @@ protected function buildPath(string $class): string
. str_replace(
'\\',
DIRECTORY_SEPARATOR,
- trim(str_replace($namespace . '\\', '', $class), '\\')
+ trim(str_replace($namespace . '\\', '', $class), '\\'),
) . '.php';
return implode(
@@ -165,8 +165,8 @@ protected function buildPath(string $class): string
array_slice(
explode(DIRECTORY_SEPARATOR, $file),
0,
- -1
- )
+ -1,
+ ),
) . DIRECTORY_SEPARATOR . $this->basename($file);
}
diff --git a/system/Commands/Translation/LocalizationFinder.php b/system/Commands/Translation/LocalizationFinder.php
index e7d4eff69663..3307dab8a4e4 100644
--- a/system/Commands/Translation/LocalizationFinder.php
+++ b/system/Commands/Translation/LocalizationFinder.php
@@ -70,7 +70,7 @@ public function run(array $params)
if (! in_array($optionLocale, config(App::class)->supportedLocales, true)) {
CLI::error(
'Error: "' . $optionLocale . '" is not supported. Supported locales: '
- . implode(', ', config(App::class)->supportedLocales)
+ . implode(', ', config(App::class)->supportedLocales),
);
return EXIT_USER_INPUT;
@@ -116,7 +116,7 @@ private function process(string $currentDir, string $currentLocale): void
[
'foundLanguageKeys' => $foundLanguageKeys,
'badLanguageKeys' => $badLanguageKeys,
- 'countFiles' => $countFiles
+ 'countFiles' => $countFiles,
] = $this->findLanguageKeysInFiles($files);
ksort($foundLanguageKeys);
diff --git a/system/Commands/Utilities/ConfigCheck.php b/system/Commands/Utilities/ConfigCheck.php
index 7d6dc332ca45..fa84cb287caa 100644
--- a/system/Commands/Utilities/ConfigCheck.php
+++ b/system/Commands/Utilities/ConfigCheck.php
@@ -109,7 +109,7 @@ public function run(array $params)
CLI::write($this->getKintD($config));
} else {
CLI::write(
- CLI::color($this->getVarDump($config), 'cyan')
+ CLI::color($this->getVarDump($config), 'cyan'),
);
}
@@ -150,7 +150,7 @@ private function getVarDump(object $config): string
return preg_replace(
'!.*system/Commands/Utilities/ConfigCheck.php.*\n!u',
'',
- $output
+ $output,
);
}
}
diff --git a/system/Commands/Utilities/Environment.php b/system/Commands/Utilities/Environment.php
index 17a08d21d2ce..103591209d1e 100644
--- a/system/Commands/Utilities/Environment.php
+++ b/system/Commands/Utilities/Environment.php
@@ -151,7 +151,7 @@ private function writeNewEnvironmentToEnvFile(string $newEnv): bool
return file_put_contents(
$envFile,
- preg_replace($pattern, "\nCI_ENVIRONMENT = {$newEnv}", file_get_contents($envFile), -1, $count)
+ preg_replace($pattern, "\nCI_ENVIRONMENT = {$newEnv}", file_get_contents($envFile), -1, $count),
) !== false && $count > 0;
}
}
diff --git a/system/Commands/Utilities/FilterCheck.php b/system/Commands/Utilities/FilterCheck.php
index 56fcdb00b971..a7a8803bd776 100644
--- a/system/Commands/Utilities/FilterCheck.php
+++ b/system/Commands/Utilities/FilterCheck.php
@@ -100,7 +100,7 @@ public function run(array $params)
CLI::color(
'"' . strtoupper($method) . ' ' . $route . '"',
'black',
- 'light_gray'
+ 'light_gray',
),
);
diff --git a/system/Commands/Utilities/Optimize.php b/system/Commands/Utilities/Optimize.php
index fa7612d524a6..2c147de6c3f1 100644
--- a/system/Commands/Utilities/Optimize.php
+++ b/system/Commands/Utilities/Optimize.php
@@ -110,13 +110,13 @@ private function enableCaching(): void
[
'public bool $configCacheEnabled = false;' => 'public bool $configCacheEnabled = true;',
'public bool $locatorCacheEnabled = false;' => 'public bool $locatorCacheEnabled = true;',
- ]
+ ],
);
if ($result) {
CLI::write(
'Config Caching and FileLocator Caching are enabled in "app/Config/Optimize.php".',
- 'green'
+ 'green',
);
return;
diff --git a/system/Commands/Utilities/Routes.php b/system/Commands/Utilities/Routes.php
index d7a6c0b55744..2a6122cab01c 100644
--- a/system/Commands/Utilities/Routes.php
+++ b/system/Commands/Utilities/Routes.php
@@ -133,7 +133,7 @@ public function run(array $params)
$collection->getDefaultController(),
$collection->getDefaultMethod(),
$methods,
- $collection->getRegisteredControllers('*')
+ $collection->getRegisteredControllers('*'),
);
$autoRoutes = $autoRouteCollector->get();
@@ -149,7 +149,7 @@ public function run(array $params)
$collection->getDefaultMethod(),
$methods,
$collection->getRegisteredControllers('*'),
- $uri
+ $uri,
);
$autoRoutes = [...$autoRoutes, ...$autoRouteCollector->get()];
@@ -159,7 +159,7 @@ public function run(array $params)
$autoRouteCollector = new AutoRouteCollector(
$collection->getDefaultNamespace(),
$collection->getDefaultController(),
- $collection->getDefaultMethod()
+ $collection->getDefaultMethod(),
);
$autoRoutes = $autoRouteCollector->get();
diff --git a/system/Commands/Utilities/Routes/AutoRouteCollector.php b/system/Commands/Utilities/Routes/AutoRouteCollector.php
index 73009b9c9eb8..3b91d365ac80 100644
--- a/system/Commands/Utilities/Routes/AutoRouteCollector.php
+++ b/system/Commands/Utilities/Routes/AutoRouteCollector.php
@@ -41,7 +41,7 @@ public function get(): array
$output = $reader->read(
$class,
$this->defaultController,
- $this->defaultMethod
+ $this->defaultMethod,
);
foreach ($output as $item) {
diff --git a/system/Commands/Utilities/Routes/AutoRouterImproved/AutoRouteCollector.php b/system/Commands/Utilities/Routes/AutoRouterImproved/AutoRouteCollector.php
index f6a4f371858a..f4a5204fb49b 100644
--- a/system/Commands/Utilities/Routes/AutoRouterImproved/AutoRouteCollector.php
+++ b/system/Commands/Utilities/Routes/AutoRouterImproved/AutoRouteCollector.php
@@ -36,7 +36,7 @@ public function __construct(
private readonly string $defaultMethod,
private readonly array $httpMethods,
private readonly array $protectedControllers,
- private readonly string $prefix = ''
+ private readonly string $prefix = '',
) {
}
@@ -59,7 +59,7 @@ public function get(): array
$routes = $reader->read(
$class,
$this->defaultController,
- $this->defaultMethod
+ $this->defaultMethod,
);
if ($routes === []) {
diff --git a/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReader.php b/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReader.php
index 2755a389ffc3..a0a98afc829a 100644
--- a/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReader.php
+++ b/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReader.php
@@ -33,7 +33,7 @@ final class ControllerMethodReader
*/
public function __construct(
private readonly string $namespace,
- private readonly array $httpMethods
+ private readonly array $httpMethods,
) {
$config = config(Routing::class);
$this->translateURIDashes = $config->translateURIDashes;
@@ -78,7 +78,7 @@ public function read(string $class, string $defaultController = 'Home', string $
$classname,
$methodName,
$httpVerb,
- $method
+ $method,
);
if ($routeForDefaultController !== []) {
@@ -193,7 +193,7 @@ private function translateToUri(string $string): string
{
if ($this->translateUriToCamelCase) {
$string = strtolower(
- preg_replace('/([a-z\d])([A-Z])/', '$1-$2', $string)
+ preg_replace('/([a-z\d])([A-Z])/', '$1-$2', $string),
);
} elseif ($this->translateURIDashes) {
$string = str_replace('_', '-', $string);
@@ -214,7 +214,7 @@ private function getRouteForDefaultController(
string $classname,
string $methodName,
string $httpVerb,
- ReflectionMethod $method
+ ReflectionMethod $method,
): array {
$output = [];
diff --git a/system/Commands/Utilities/Routes/ControllerFinder.php b/system/Commands/Utilities/Routes/ControllerFinder.php
index 71de1681b547..400e30e82d2e 100644
--- a/system/Commands/Utilities/Routes/ControllerFinder.php
+++ b/system/Commands/Utilities/Routes/ControllerFinder.php
@@ -28,7 +28,7 @@ final class ControllerFinder
* @param string $namespace namespace to search
*/
public function __construct(
- private readonly string $namespace
+ private readonly string $namespace,
) {
$this->locator = service('locator');
}
diff --git a/system/Commands/Utilities/Routes/ControllerMethodReader.php b/system/Commands/Utilities/Routes/ControllerMethodReader.php
index b40a832b4f48..cd47085932bb 100644
--- a/system/Commands/Utilities/Routes/ControllerMethodReader.php
+++ b/system/Commands/Utilities/Routes/ControllerMethodReader.php
@@ -57,7 +57,7 @@ public function read(string $class, string $defaultController = 'Home', string $
$defaultController,
$uriByClass,
$classname,
- $methodName
+ $methodName,
);
$output = [...$output, ...$routeWithoutController];
@@ -89,7 +89,7 @@ public function read(string $class, string $defaultController = 'Home', string $
$defaultController,
$uriByClass,
$classname,
- $methodName
+ $methodName,
);
$output = [...$output, ...$routeWithoutController];
@@ -153,7 +153,7 @@ private function getRouteWithoutController(
string $defaultController,
string $uriByClass,
string $classname,
- string $methodName
+ string $methodName,
): array {
if ($classShortname !== $defaultController) {
return [];
diff --git a/system/Commands/Utilities/Routes/FilterCollector.php b/system/Commands/Utilities/Routes/FilterCollector.php
index b646dcb250a1..51b36662f490 100644
--- a/system/Commands/Utilities/Routes/FilterCollector.php
+++ b/system/Commands/Utilities/Routes/FilterCollector.php
@@ -32,7 +32,7 @@ public function __construct(
*
* If set to true, route filters are not found.
*/
- private readonly bool $resetRoutes = false
+ private readonly bool $resetRoutes = false,
) {
}
@@ -50,7 +50,7 @@ public function get(string $method, string $uri): array
@trigger_error(
'Passing lowercase HTTP method "' . $method . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($method) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
diff --git a/system/Commands/Utilities/Routes/SampleURIGenerator.php b/system/Commands/Utilities/Routes/SampleURIGenerator.php
index 45eb2f93201b..a0e5f09bc2cb 100644
--- a/system/Commands/Utilities/Routes/SampleURIGenerator.php
+++ b/system/Commands/Utilities/Routes/SampleURIGenerator.php
@@ -57,7 +57,7 @@ public function get(string $routeKey): string
$sampleUri = str_replace(
'{locale}',
config(App::class)->defaultLocale,
- $routeKey
+ $routeKey,
);
}
diff --git a/system/Common.php b/system/Common.php
index d5880acf0363..863ff3cdbabb 100644
--- a/system/Common.php
+++ b/system/Common.php
@@ -146,7 +146,7 @@ function command(string $command)
// @codeCoverageIgnoreStart
throw new InvalidArgumentException(sprintf(
'Unable to parse input near "... %s ...".',
- substr($command, $cursor, 10)
+ substr($command, $cursor, 10),
));
// @codeCoverageIgnoreEnd
}
@@ -470,7 +470,7 @@ function esc($data, string $context = 'html', ?string $encoding = null)
function force_https(
int $duration = 31_536_000,
?RequestInterface $request = null,
- ?ResponseInterface $response = null
+ ?ResponseInterface $response = null,
): void {
$request ??= service('request');
@@ -1065,7 +1065,7 @@ function slash_item(string $item): ?string
'Cannot convert "%s::$%s" of type "%s" to type "string".',
App::class,
$item,
- gettype($configItem)
+ gettype($configItem),
));
}
diff --git a/system/ComposerScripts.php b/system/ComposerScripts.php
index 661247dab532..993483c5775a 100644
--- a/system/ComposerScripts.php
+++ b/system/ComposerScripts.php
@@ -102,7 +102,7 @@ private static function recursiveDelete(string $directory): void
/** @var SplFileInfo $file */
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator(rtrim($directory, '\\/'), FilesystemIterator::SKIP_DOTS),
- RecursiveIteratorIterator::CHILD_FIRST
+ RecursiveIteratorIterator::CHILD_FIRST,
) as $file) {
$path = $file->getPathname();
@@ -146,7 +146,7 @@ private static function recursiveMirror(string $originDir, string $targetDir): v
/** @var SplFileInfo $file */
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($originDir, FilesystemIterator::SKIP_DOTS),
- RecursiveIteratorIterator::SELF_FIRST
+ RecursiveIteratorIterator::SELF_FIRST,
) as $file) {
$origin = $file->getPathname();
$target = $targetDir . substr($origin, $dirLen);
diff --git a/system/Config/DotEnv.php b/system/Config/DotEnv.php
index d4a7d9e87389..7e95d1352f00 100644
--- a/system/Config/DotEnv.php
+++ b/system/Config/DotEnv.php
@@ -164,7 +164,7 @@ protected function sanitizeValue(string $value): string
%1$s # and the closing quote
.*$ # and discard any string after the closing quote
/mx',
- $quote
+ $quote,
);
$value = preg_replace($regexPattern, '$1', $value);
@@ -206,7 +206,7 @@ function ($matchedPatterns) {
return $nestedVariable;
},
- $value
+ $value,
);
}
diff --git a/system/Config/Factories.php b/system/Config/Factories.php
index b845d5825f43..fd7d6a32397b 100644
--- a/system/Config/Factories.php
+++ b/system/Config/Factories.php
@@ -106,7 +106,7 @@ public static function define(string $component, string $alias, string $classnam
}
throw new InvalidArgumentException(
- 'Already defined in Factories: ' . $component . ' ' . $alias . ' -> ' . self::$aliases[$component][$alias]
+ 'Already defined in Factories: ' . $component . ' ' . $alias . ' -> ' . self::$aliases[$component][$alias],
);
}
@@ -448,7 +448,7 @@ public static function reset(?string $component = null)
self::$options[$component],
self::$aliases[$component],
self::$instances[$component],
- self::$updated[$component]
+ self::$updated[$component],
);
return;
diff --git a/system/Config/Services.php b/system/Config/Services.php
index aa8c180a3388..f5c5a2db4a99 100644
--- a/system/Config/Services.php
+++ b/system/Config/Services.php
@@ -213,7 +213,7 @@ public static function curlrequest(array $options = [], ?ResponseInterface $resp
$config,
new URI($options['baseURI'] ?? null),
$response,
- $options
+ $options,
);
}
@@ -267,7 +267,7 @@ public static function encrypter(?EncryptionConfig $config = null, $getShared =
*/
public static function exceptions(
?ExceptionsConfig $config = null,
- bool $getShared = true
+ bool $getShared = true,
) {
if ($getShared) {
return static::getSharedInstance('exceptions', $config);
@@ -569,7 +569,7 @@ public static function incomingrequest(?App $config = null, bool $getShared = tr
$config,
AppServices::get('uri'),
'php://input',
- new UserAgent()
+ new UserAgent(),
);
}
@@ -619,7 +619,7 @@ public static function routes(bool $getShared = true)
return static::getSharedInstance('routes');
}
- return new RouteCollection(AppServices::get('locator'), config(Modules::class), config(Routing::class));
+ return new RouteCollection(AppServices::get('locator'), new Modules(), config(Routing::class));
}
/**
@@ -689,7 +689,7 @@ public static function session(?SessionConfig $config = null, bool $getShared =
if (! class_exists($driverName) || ! is_a($driverName, SessionBaseHandler::class, true)) {
throw new InvalidArgumentException(sprintf(
'Invalid session handler "%s" provided.',
- $driverName
+ $driverName,
));
}
@@ -721,7 +721,7 @@ public static function session(?SessionConfig $config = null, bool $getShared =
public static function siteurifactory(
?App $config = null,
?Superglobals $superglobals = null,
- bool $getShared = true
+ bool $getShared = true,
) {
if ($getShared) {
return static::getSharedInstance('siteurifactory', $config, $superglobals);
@@ -741,7 +741,7 @@ public static function siteurifactory(
public static function superglobals(
?array $server = null,
?array $get = null,
- bool $getShared = true
+ bool $getShared = true,
) {
if ($getShared) {
return static::getSharedInstance('superglobals', $server, $get);
diff --git a/system/DataCaster/Cast/ArrayCast.php b/system/DataCaster/Cast/ArrayCast.php
index 4bb0f4c74093..1deddea6fc8e 100644
--- a/system/DataCaster/Cast/ArrayCast.php
+++ b/system/DataCaster/Cast/ArrayCast.php
@@ -24,7 +24,7 @@ class ArrayCast extends BaseCast implements CastInterface
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): array {
if (! is_string($value)) {
self::invalidTypeValueError($value);
@@ -40,7 +40,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): string {
return serialize($value);
}
diff --git a/system/DataCaster/Cast/BaseCast.php b/system/DataCaster/Cast/BaseCast.php
index c3df0efee103..afe80982e3ba 100644
--- a/system/DataCaster/Cast/BaseCast.php
+++ b/system/DataCaster/Cast/BaseCast.php
@@ -20,7 +20,7 @@ abstract class BaseCast implements CastInterface
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): mixed {
return $value;
}
@@ -28,7 +28,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): mixed {
return $value;
}
diff --git a/system/DataCaster/Cast/BooleanCast.php b/system/DataCaster/Cast/BooleanCast.php
index e4a3fde09345..6554081e155d 100644
--- a/system/DataCaster/Cast/BooleanCast.php
+++ b/system/DataCaster/Cast/BooleanCast.php
@@ -24,7 +24,7 @@ class BooleanCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): bool {
// For PostgreSQL
if ($value === 't') {
diff --git a/system/DataCaster/Cast/CSVCast.php b/system/DataCaster/Cast/CSVCast.php
index 42dd3709a1db..d77c64c87b57 100644
--- a/system/DataCaster/Cast/CSVCast.php
+++ b/system/DataCaster/Cast/CSVCast.php
@@ -24,7 +24,7 @@ class CSVCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): array {
if (! is_string($value)) {
self::invalidTypeValueError($value);
@@ -36,7 +36,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): string {
if (! is_array($value)) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/CastInterface.php b/system/DataCaster/Cast/CastInterface.php
index ff93dc2860bc..f90f2b227e1d 100644
--- a/system/DataCaster/Cast/CastInterface.php
+++ b/system/DataCaster/Cast/CastInterface.php
@@ -27,7 +27,7 @@ interface CastInterface
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): mixed;
/**
@@ -42,6 +42,6 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): mixed;
}
diff --git a/system/DataCaster/Cast/DatetimeCast.php b/system/DataCaster/Cast/DatetimeCast.php
index 83e66d02217c..2953debfbf2e 100644
--- a/system/DataCaster/Cast/DatetimeCast.php
+++ b/system/DataCaster/Cast/DatetimeCast.php
@@ -28,7 +28,7 @@ class DatetimeCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): Time {
if (! is_string($value)) {
self::invalidTypeValueError($value);
@@ -56,7 +56,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): string {
if (! $value instanceof Time) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/FloatCast.php b/system/DataCaster/Cast/FloatCast.php
index 7ced2e2653a7..d2173826265a 100644
--- a/system/DataCaster/Cast/FloatCast.php
+++ b/system/DataCaster/Cast/FloatCast.php
@@ -24,7 +24,7 @@ class FloatCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): float {
if (! is_float($value) && ! is_string($value)) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/IntBoolCast.php b/system/DataCaster/Cast/IntBoolCast.php
index 56977c842f0e..5aa1f2b2eb93 100644
--- a/system/DataCaster/Cast/IntBoolCast.php
+++ b/system/DataCaster/Cast/IntBoolCast.php
@@ -24,7 +24,7 @@ final class IntBoolCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): bool {
if (! is_int($value) && ! is_string($value)) {
self::invalidTypeValueError($value);
@@ -36,7 +36,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): int {
if (! is_bool($value)) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/IntegerCast.php b/system/DataCaster/Cast/IntegerCast.php
index e16683b1fb8f..f65baf83150f 100644
--- a/system/DataCaster/Cast/IntegerCast.php
+++ b/system/DataCaster/Cast/IntegerCast.php
@@ -24,7 +24,7 @@ class IntegerCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): int {
if (! is_string($value) && ! is_int($value)) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/JsonCast.php b/system/DataCaster/Cast/JsonCast.php
index 316070aaedee..5ca10b385ba6 100644
--- a/system/DataCaster/Cast/JsonCast.php
+++ b/system/DataCaster/Cast/JsonCast.php
@@ -28,7 +28,7 @@ class JsonCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): array|stdClass {
if (! is_string($value)) {
self::invalidTypeValueError($value);
@@ -50,7 +50,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): string {
try {
$output = json_encode($value, JSON_UNESCAPED_UNICODE | JSON_THROW_ON_ERROR);
diff --git a/system/DataCaster/Cast/TimestampCast.php b/system/DataCaster/Cast/TimestampCast.php
index 52a4d88f9e46..e33938d3e2ba 100644
--- a/system/DataCaster/Cast/TimestampCast.php
+++ b/system/DataCaster/Cast/TimestampCast.php
@@ -26,7 +26,7 @@ class TimestampCast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): Time {
if (! is_int($value) && ! is_string($value)) {
self::invalidTypeValueError($value);
@@ -38,7 +38,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): int {
if (! $value instanceof Time) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/Cast/URICast.php b/system/DataCaster/Cast/URICast.php
index 63f4d2271a78..f9e2f561a2b2 100644
--- a/system/DataCaster/Cast/URICast.php
+++ b/system/DataCaster/Cast/URICast.php
@@ -26,7 +26,7 @@ class URICast extends BaseCast
public static function get(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): URI {
if (! is_string($value)) {
self::invalidTypeValueError($value);
@@ -38,7 +38,7 @@ public static function get(
public static function set(
mixed $value,
array $params = [],
- ?object $helper = null
+ ?object $helper = null,
): string {
if (! $value instanceof URI) {
self::invalidTypeValueError($value);
diff --git a/system/DataCaster/DataCaster.php b/system/DataCaster/DataCaster.php
index 5a6786a03331..47eac2ff7bde 100644
--- a/system/DataCaster/DataCaster.php
+++ b/system/DataCaster/DataCaster.php
@@ -68,7 +68,7 @@ public function __construct(
?array $castHandlers = null,
?array $types = null,
private readonly ?object $helper = null,
- private readonly bool $strict = true
+ private readonly bool $strict = true,
) {
$this->castHandlers = array_merge($this->castHandlers, $castHandlers);
@@ -83,7 +83,7 @@ public function __construct(
&& ! is_subclass_of($handler, EntityCastInterface::class)
) {
throw new InvalidArgumentException(
- 'Invalid class type. It must implement CastInterface. class: ' . $handler
+ 'Invalid class type. It must implement CastInterface. class: ' . $handler,
);
}
}
@@ -169,7 +169,7 @@ public function castAs(mixed $value, string $field, string $method = 'get'): mix
if (! isset($handlers[$type])) {
throw new InvalidArgumentException(
- 'No such handler for "' . $field . '". Invalid type: ' . $type
+ 'No such handler for "' . $field . '". Invalid type: ' . $type,
);
}
diff --git a/system/Database/BaseBuilder.php b/system/Database/BaseBuilder.php
index ca64800463a2..010ac17b195f 100644
--- a/system/Database/BaseBuilder.php
+++ b/system/Database/BaseBuilder.php
@@ -807,7 +807,7 @@ protected function whereHaving(string $qbKey, $key, $value = null, string $type
'/\s*(!?=|<>|IS(?:\s+NOT)?)\s*$/i',
$k,
$match,
- PREG_OFFSET_CAPTURE
+ PREG_OFFSET_CAPTURE,
)
) {
$k = substr($k, 0, $match[0][1]);
@@ -2022,8 +2022,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
' = ' . $value :
' = VALUES(' . $value . ')'),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -2198,7 +2198,7 @@ protected function formatValues(array $values): array
*
* @param array|object|null $set a dataset
*
- * @return false|int|list Number of rows inserted or FALSE on failure, SQL array when testMode
+ * @return false|int|list Number of rows inserted or FALSE on no data to perform an insert operation, SQL array when testMode
*/
public function insertBatch($set = null, ?bool $escape = null, int $batchSize = 100)
{
@@ -2291,10 +2291,10 @@ public function getCompiledInsert(bool $reset = true)
$this->removeAlias($this->QBFrom[0]),
true,
null,
- false
+ false,
),
array_keys($this->QBSet),
- array_values($this->QBSet)
+ array_values($this->QBSet),
);
if ($reset) {
@@ -2328,10 +2328,10 @@ public function insert($set = null, ?bool $escape = null)
$this->removeAlias($this->QBFrom[0]),
true,
$escape,
- false
+ false,
),
array_keys($this->QBSet),
- array_values($this->QBSet)
+ array_values($this->QBSet),
);
if (! $this->testMode) {
@@ -2653,8 +2653,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
' = ' . $value :
' = ' . $alias . '.' . $value),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
) . "\n";
$sql .= "FROM (\n{:_table_:}";
@@ -2678,8 +2678,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -2694,10 +2694,10 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
@@ -2924,8 +2924,8 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
);
// convert binds in where
@@ -2949,10 +2949,10 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
@@ -3160,7 +3160,7 @@ protected function compileWhereHaving(string $qbKey): string
'/((?:^|\s+)AND\s+|(?:^|\s+)OR\s+)/i',
$qbkey['condition'],
-1,
- PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY
+ PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY,
);
foreach ($conditions as &$condition) {
@@ -3170,11 +3170,12 @@ protected function compileWhereHaving(string $qbKey): string
|| preg_match(
'/^(\(?)(.*)(' . preg_quote($op, '/') . ')\s*(.*(? '(test <= foo)', /* the whole thing */
// 1 => '(', /* optional */
@@ -3184,7 +3185,7 @@ protected function compileWhereHaving(string $qbKey): string
// 5 => ')' /* optional */
// ];
- if (isset($matches[4]) && $matches[4] !== '') {
+ if ($matches[4] !== '') {
$protectIdentifiers = false;
if (str_contains($matches[4], '.')) {
$protectIdentifiers = true;
@@ -3435,7 +3436,7 @@ protected function hasOperator(string $str): bool
{
return preg_match(
'/(<|>|!|=|\sIS NULL|\sIS NOT NULL|\sEXISTS|\sBETWEEN|\sLIKE|\sIN\s*\(|\s)/i',
- trim($str)
+ trim($str),
) === 1;
}
@@ -3469,7 +3470,7 @@ protected function getOperator(string $str, bool $list = false)
return preg_match_all(
'/' . implode('|', $this->pregOperators) . '/i',
$str,
- $match
+ $match,
) >= 1 ? ($list ? $match[0] : $match[0][0]) : false;
}
@@ -3500,7 +3501,7 @@ private function getOperatorFromWhereKey(string $whereKey)
return preg_match_all(
'/' . implode('|', $pregOperators) . '/i',
$whereKey,
- $match
+ $match,
) >= 1 ? $match[0] : false;
}
diff --git a/system/Database/BaseConnection.php b/system/Database/BaseConnection.php
index e38c682adb09..b7107d19a34d 100644
--- a/system/Database/BaseConnection.php
+++ b/system/Database/BaseConnection.php
@@ -424,7 +424,7 @@ public function initialize()
$connectionErrors[] = sprintf(
'Main connection [%s]: %s',
$this->DBDriver,
- $e->getMessage()
+ $e->getMessage(),
);
log_message('error', 'Error connecting to the database: ' . $e);
}
@@ -450,7 +450,7 @@ public function initialize()
'Failover #%d [%s]: %s',
++$index,
$this->DBDriver,
- $e->getMessage()
+ $e->getMessage(),
);
log_message('error', 'Error connecting to the database: ' . $e);
}
@@ -467,7 +467,7 @@ public function initialize()
throw new DatabaseException(sprintf(
'Unable to connect to the database.%s%s',
PHP_EOL,
- implode(PHP_EOL, $connectionErrors)
+ implode(PHP_EOL, $connectionErrors),
));
}
}
@@ -688,7 +688,7 @@ public function query(string $sql, $binds = null, bool $setEscapeFlags = true, s
throw new DatabaseException(
$exception->getMessage(),
$exception->getCode(),
- $exception
+ $exception,
);
}
@@ -1220,7 +1220,7 @@ public function escapeIdentifier(string $item): string
. str_replace(
$this->escapeChar,
$this->escapeChar . $this->escapeChar,
- $item
+ $item,
)
. $this->escapeChar;
}
@@ -1277,7 +1277,7 @@ public function escapeIdentifiers($item)
return preg_replace(
'/' . $this->pregEscapeChar[0] . '?([^' . $this->pregEscapeChar[1] . '\.]+)' . $this->pregEscapeChar[1] . '?\./i',
$this->pregEscapeChar[2] . '$1' . $this->pregEscapeChar[3] . '.',
- $item
+ $item,
);
}
}
@@ -1286,7 +1286,7 @@ public function escapeIdentifiers($item)
return preg_replace(
'/' . $this->pregEscapeChar[0] . '?([^' . $this->pregEscapeChar[1] . '\.]+)' . $this->pregEscapeChar[1] . '?(\.)?/i',
$this->pregEscapeChar[2] . '$1' . $this->pregEscapeChar[3] . '$2',
- $item
+ $item,
);
}
@@ -1386,7 +1386,7 @@ public function escapeString($str, bool $like = false)
$this->likeEscapeChar . '%',
$this->likeEscapeChar . '_',
],
- $str
+ $str,
);
}
@@ -1522,7 +1522,7 @@ public function tableExists(string $tableName, bool $cached = true): bool
$key = array_search(
strtolower($tableName),
array_map(strtolower(...), $this->dataCache['table_names']),
- true
+ true,
);
// table doesn't exist but still in cache - lets reset cache, it can be rebuilt later
diff --git a/system/Database/BaseUtils.php b/system/Database/BaseUtils.php
index 27b369c5cb7e..26957ffe01f1 100644
--- a/system/Database/BaseUtils.php
+++ b/system/Database/BaseUtils.php
@@ -217,7 +217,7 @@ public function getCSVFromResult(ResultInterface $query, string $delim = ',', st
$line[] = $enclosure . str_replace(
$enclosure,
$enclosure . $enclosure,
- (string) $item
+ (string) $item,
) . $enclosure;
}
diff --git a/system/Database/Forge.php b/system/Database/Forge.php
index 974c45848d1c..83cf1b88d9f4 100644
--- a/system/Database/Forge.php
+++ b/system/Database/Forge.php
@@ -234,8 +234,8 @@ public function createDatabase(string $dbName, bool $ifNotExists = false): bool
$ifNotExists ? $this->createDatabaseIfStr : $this->createDatabaseStr,
$this->db->escapeIdentifier($dbName),
$this->db->charset,
- $this->db->DBCollat
- )
+ $this->db->DBCollat,
+ ),
)) {
// @codeCoverageIgnoreStart
if ($this->db->DBDebug) {
@@ -294,7 +294,7 @@ public function dropDatabase(string $dbName): bool
}
if (! $this->db->query(
- sprintf($this->dropDatabaseStr, $this->db->escapeIdentifier($dbName))
+ sprintf($this->dropDatabaseStr, $this->db->escapeIdentifier($dbName)),
)) {
if ($this->db->DBDebug) {
throw new DatabaseException('Unable to drop the specified database.');
@@ -307,7 +307,7 @@ public function dropDatabase(string $dbName): bool
$key = array_search(
strtolower($dbName),
array_map(strtolower(...), $this->db->dataCache['db_names']),
- true
+ true,
);
if ($key !== false) {
unset($this->db->dataCache['db_names'][$key]);
@@ -425,7 +425,7 @@ public function addForeignKey(
$tableField = '',
string $onUpdate = '',
string $onDelete = '',
- string $fkName = ''
+ string $fkName = '',
): Forge {
$fieldName = (array) $fieldName;
$tableField = (array) $tableField;
@@ -525,7 +525,7 @@ public function dropForeignKey(string $table, string $foreignName)
$sql = sprintf(
(string) $this->dropConstraintStr,
$this->db->escapeIdentifiers($this->db->DBPrefix . $table),
- $this->db->escapeIdentifiers($foreignName)
+ $this->db->escapeIdentifiers($foreignName),
);
if ($sql === '') {
@@ -618,7 +618,7 @@ protected function _createTable(string $table, bool $ifNotExists, array $attribu
'CREATE TABLE',
$this->db->escapeIdentifiers($table),
$processedFields,
- $this->_createTableAttributes($attributes)
+ $this->_createTableAttributes($attributes),
);
}
@@ -668,7 +668,7 @@ public function dropTable(string $tableName, bool $ifExists = false, bool $casca
$key = array_search(
strtolower($this->db->DBPrefix . $tableName),
array_map(strtolower(...), $this->db->dataCache['table_names']),
- true
+ true,
);
if ($key !== false) {
@@ -723,14 +723,14 @@ public function renameTable(string $tableName, string $newTableName)
$result = $this->db->query(sprintf(
$this->renameTableStr,
$this->db->escapeIdentifiers($this->db->DBPrefix . $tableName),
- $this->db->escapeIdentifiers($this->db->DBPrefix . $newTableName)
+ $this->db->escapeIdentifiers($this->db->DBPrefix . $newTableName),
));
if ($result && ! empty($this->db->dataCache['table_names'])) {
$key = array_search(
strtolower($this->db->DBPrefix . $tableName),
array_map(strtolower(...), $this->db->dataCache['table_names']),
- true
+ true,
);
if ($key !== false) {
@@ -1112,7 +1112,7 @@ public function processIndexes(string $table): bool
$this->fields = array_combine(
array_map(static fn ($columnName) => $columnName->name, $fieldData),
- array_fill(0, count($fieldData), [])
+ array_fill(0, count($fieldData), []),
);
}
diff --git a/system/Database/MigrationRunner.php b/system/Database/MigrationRunner.php
index 13919c785372..0411e1593a68 100644
--- a/system/Database/MigrationRunner.php
+++ b/system/Database/MigrationRunner.php
@@ -605,7 +605,7 @@ protected function addHistory($migration, int $batch)
CLI::color(lang('Migrations.added'), 'yellow'),
$migration->namespace,
$migration->version,
- $migration->class
+ $migration->class,
);
}
}
@@ -625,7 +625,7 @@ protected function removeHistory($history)
CLI::color(lang('Migrations.removed'), 'yellow'),
$history->namespace,
$history->version,
- $history->class
+ $history->class,
);
}
}
diff --git a/system/Database/MySQLi/Builder.php b/system/Database/MySQLi/Builder.php
index 8c1de9d9f987..b8d0fa545d4f 100644
--- a/system/Database/MySQLi/Builder.php
+++ b/system/Database/MySQLi/Builder.php
@@ -106,8 +106,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
) . "\n";
$sql .= "SET\n";
@@ -119,8 +119,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
' = ' . $value :
' = ' . $alias . '.' . $value),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -135,10 +135,10 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
diff --git a/system/Database/MySQLi/Connection.php b/system/Database/MySQLi/Connection.php
index f98f51fb3e19..fa542e5708bb 100644
--- a/system/Database/MySQLi/Connection.php
+++ b/system/Database/MySQLi/Connection.php
@@ -116,7 +116,7 @@ public function connect(bool $persistent = false)
if ($this->strictOn) {
$this->mysqli->options(
MYSQLI_INIT_COMMAND,
- "SET SESSION sql_mode = CONCAT(@@sql_mode, ',', 'STRICT_ALL_TABLES')"
+ "SET SESSION sql_mode = CONCAT(@@sql_mode, ',', 'STRICT_ALL_TABLES')",
);
} else {
$this->mysqli->options(
@@ -128,7 +128,7 @@ public function connect(bool $persistent = false)
'STRICT_ALL_TABLES', ''),
'STRICT_TRANS_TABLES,', ''),
',STRICT_TRANS_TABLES', ''),
- 'STRICT_TRANS_TABLES', '')"
+ 'STRICT_TRANS_TABLES', '')",
);
}
}
@@ -175,7 +175,7 @@ public function connect(bool $persistent = false)
$ssl['cert'] ?? null,
$ssl['ca'] ?? null,
$ssl['capath'] ?? null,
- $ssl['cipher'] ?? null
+ $ssl['cipher'] ?? null,
);
}
@@ -190,7 +190,7 @@ public function connect(bool $persistent = false)
$this->database,
$port,
$socket,
- $clientFlags
+ $clientFlags,
)) {
// Prior to version 5.7.3, MySQL silently downgrades to an unencrypted connection if SSL setup fails
if (($clientFlags & MYSQLI_CLIENT_SSL) !== 0 && version_compare($this->mysqli->client_info, 'mysqlnd 5.7.3', '<=')
@@ -381,7 +381,7 @@ public function escapeLikeStringDirect($str)
return str_replace(
[$this->likeEscapeChar, '%', '_'],
['\\' . $this->likeEscapeChar, '\\%', '\\_'],
- $str
+ $str,
);
}
diff --git a/system/Database/MySQLi/Forge.php b/system/Database/MySQLi/Forge.php
index c47ff4ded393..fe207f5267a5 100644
--- a/system/Database/MySQLi/Forge.php
+++ b/system/Database/MySQLi/Forge.php
@@ -258,7 +258,7 @@ public function dropPrimaryKey(string $table, string $keyName = ''): bool
{
$sql = sprintf(
'ALTER TABLE %s DROP PRIMARY KEY',
- $this->db->escapeIdentifiers($this->db->DBPrefix . $table)
+ $this->db->escapeIdentifiers($this->db->DBPrefix . $table),
);
return $this->db->query($sql);
diff --git a/system/Database/OCI8/Builder.php b/system/Database/OCI8/Builder.php
index 5a65ffe9b75d..5b586761e2c0 100644
--- a/system/Database/OCI8/Builder.php
+++ b/system/Database/OCI8/Builder.php
@@ -92,10 +92,10 @@ protected function _insertBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . " FROM DUAL\n";
}
@@ -287,8 +287,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
) . ")\n";
$sql .= "WHEN MATCHED THEN UPDATE\n";
@@ -302,8 +302,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
' = ' . $value :
' = ' . $alias . '.' . $value),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -318,10 +318,10 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)) . ' FROM DUAL',
- $values
- )
+ $values,
+ ),
) . "\n";
}
@@ -392,8 +392,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
) . ")\n";
$sql .= "WHEN MATCHED THEN UPDATE SET\n";
@@ -405,8 +405,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
" = {$value}" :
" = {$alias}.{$value}"),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$sql .= "\nWHEN NOT MATCHED THEN INSERT (" . implode(', ', $keys) . ")\nVALUES ";
@@ -427,10 +427,10 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . " FROM DUAL\n";
}
@@ -477,8 +477,8 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
);
// convert binds in where
@@ -491,7 +491,7 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
$sql .= ' ' . str_replace(
'WHERE ',
'AND ',
- $this->compileWhereHaving('QBWhere')
+ $this->compileWhereHaving('QBWhere'),
) . ')';
$this->QBOptions['sql'] = $sql;
@@ -506,10 +506,10 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . " FROM DUAL\n";
}
diff --git a/system/Database/OCI8/Connection.php b/system/Database/OCI8/Connection.php
index c59d588ccec1..0ad7b66815e7 100644
--- a/system/Database/OCI8/Connection.php
+++ b/system/Database/OCI8/Connection.php
@@ -523,7 +523,7 @@ public function storedProcedure(string $procedureName, array $params)
$sql = sprintf(
'BEGIN %s (' . substr(str_repeat(',%s', count($params)), 1) . '); END;',
$procedureName,
- ...array_map(static fn ($row) => $row['name'], $params)
+ ...array_map(static fn ($row) => $row['name'], $params),
);
$this->resetStmtId = false;
@@ -554,7 +554,7 @@ protected function bindParams($params)
$param['name'],
$param['value'],
$param['length'] ?? -1,
- $param['type'] ?? SQLT_CHR
+ $param['type'] ?? SQLT_CHR,
);
}
}
diff --git a/system/Database/OCI8/Forge.php b/system/Database/OCI8/Forge.php
index 7d81cff8b506..4b09372d778e 100644
--- a/system/Database/OCI8/Forge.php
+++ b/system/Database/OCI8/Forge.php
@@ -112,7 +112,7 @@ protected function _alterTable(string $alterType, string $table, $processedField
$fields = array_map(
fn ($field) => $this->db->escapeIdentifiers(trim($field)),
- is_string($columnNamesToDrop) ? explode(',', $columnNamesToDrop) : $columnNamesToDrop
+ is_string($columnNamesToDrop) ? explode(',', $columnNamesToDrop) : $columnNamesToDrop,
);
return $sql . ' DROP (' . implode(',', $fields) . ') CASCADE CONSTRAINT INVALIDATE';
diff --git a/system/Database/Postgre/Builder.php b/system/Database/Postgre/Builder.php
index 21fa222c7544..bf6e9416dc2c 100644
--- a/system/Database/Postgre/Builder.php
+++ b/system/Database/Postgre/Builder.php
@@ -357,8 +357,8 @@ protected function _updateBatch(string $table, array $keys, array $values): stri
' = ' . $value :
' = ' . $that->cast($alias . '.' . $value, $that->getFieldType($table, $key))),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
) . "\n";
$sql .= "FROM (\n{:_table_:}";
@@ -381,8 +381,8 @@ static function ($key, $value) use ($table, $alias, $that): string|RawSql {
. $that->cast($alias . '.' . $value, $that->getFieldType($table, $value));
},
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -397,10 +397,10 @@ static function ($key, $value) use ($table, $alias, $that): string|RawSql {
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
@@ -528,8 +528,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
" = {$value}" :
" = {$alias}.{$value}"),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -584,15 +584,15 @@ static function ($key, $value) use ($table, $alias, $that): RawSql|string {
return $table . '.' . $key . ' = '
. $that->cast(
$alias . '.' . $value,
- $that->getFieldType($table, $key)
+ $that->getFieldType($table, $key),
);
}
return $table . '.' . $value . ' = ' . $alias . '.' . $value;
},
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
);
// convert binds in where
@@ -605,7 +605,7 @@ static function ($key, $value) use ($table, $alias, $that): RawSql|string {
$sql .= ' ' . str_replace(
'WHERE ',
'AND ',
- $this->compileWhereHaving('QBWhere')
+ $this->compileWhereHaving('QBWhere'),
);
$this->QBOptions['sql'] = $sql;
@@ -620,10 +620,10 @@ static function ($key, $value) use ($table, $alias, $that): RawSql|string {
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
diff --git a/system/Database/Postgre/Connection.php b/system/Database/Postgre/Connection.php
index ad278145afef..64b85eafb064 100644
--- a/system/Database/Postgre/Connection.php
+++ b/system/Database/Postgre/Connection.php
@@ -227,6 +227,10 @@ protected function getDriverFunctionPrefix(): string
*/
public function affectedRows(): int
{
+ if ($this->resultID === false) {
+ return 0;
+ }
+
return pg_affected_rows($this->resultID);
}
diff --git a/system/Database/SQLSRV/Builder.php b/system/Database/SQLSRV/Builder.php
index 1aeaf0a4e6ee..ec4d41195626 100644
--- a/system/Database/SQLSRV/Builder.php
+++ b/system/Database/SQLSRV/Builder.php
@@ -764,8 +764,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
)
),
array_keys($constraints),
- $constraints
- )
+ $constraints,
+ ),
) . ")\n";
$sql .= "WHEN MATCHED THEN UPDATE SET\n";
@@ -777,8 +777,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
' = ' . $value :
" = {$alias}.{$value}"),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$sql .= "\nWHEN NOT MATCHED THEN INSERT (" . implode(', ', $keys) . ")\nVALUES ";
@@ -792,8 +792,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
. 'isnull(IDENT_CURRENT(\'' . $fullTableName . '\')+IDENT_INCR(\''
. $fullTableName . "'),1)) ELSE {$alias}.{$columnName} END"
: "{$alias}.{$columnName}",
- $keys
- )
+ $keys,
+ ),
) . ');'
);
diff --git a/system/Database/SQLSRV/Connection.php b/system/Database/SQLSRV/Connection.php
index 6903f42eebac..26b4983dba0a 100644
--- a/system/Database/SQLSRV/Connection.php
+++ b/system/Database/SQLSRV/Connection.php
@@ -444,6 +444,10 @@ public function error(): array
*/
public function affectedRows(): int
{
+ if ($this->resultID === false) {
+ return 0;
+ }
+
return sqlsrv_rows_affected($this->resultID);
}
diff --git a/system/Database/SQLSRV/Forge.php b/system/Database/SQLSRV/Forge.php
index 18d792a6eea8..f187b9981f88 100644
--- a/system/Database/SQLSRV/Forge.php
+++ b/system/Database/SQLSRV/Forge.php
@@ -134,12 +134,12 @@ public function createDatabase(string $dbName, bool $ifNotExists = false): bool
$sql = sprintf(
$this->createDatabaseIfStr,
$dbName,
- $this->db->escapeIdentifier($dbName)
+ $this->db->escapeIdentifier($dbName),
);
} else {
$sql = sprintf(
$this->createDatabaseStr,
- $this->db->escapeIdentifier($dbName)
+ $this->db->escapeIdentifier($dbName),
);
}
@@ -381,8 +381,8 @@ protected function _attributeType(array &$attributes)
$maxLength = max(
array_map(
static fn ($value): int => strlen($value),
- $attributes['CONSTRAINT']
- )
+ $attributes['CONSTRAINT'],
+ ),
);
$attributes['TYPE'] = 'VARCHAR';
diff --git a/system/Database/SQLite3/Builder.php b/system/Database/SQLite3/Builder.php
index 744b64448fc6..64091cf8a2fb 100644
--- a/system/Database/SQLite3/Builder.php
+++ b/system/Database/SQLite3/Builder.php
@@ -196,8 +196,8 @@ protected function _upsertBatch(string $table, array $keys, array $values): stri
" = {$value}" :
" = {$alias}.{$value}"),
array_keys($updateFields),
- $updateFields
- )
+ $updateFields,
+ ),
);
$this->QBOptions['sql'] = $sql;
@@ -268,10 +268,10 @@ protected function _deleteBatch(string $table, array $keys, array $values): stri
static fn ($value): string => 'SELECT ' . implode(', ', array_map(
static fn ($key, $index): string => $index . ' ' . $key,
$keys,
- $value
+ $value,
)),
- $values
- )
+ $values,
+ ),
) . "\n";
}
diff --git a/system/Database/SQLite3/Table.php b/system/Database/SQLite3/Table.php
index 61d4aee7535b..095d96a2d333 100644
--- a/system/Database/SQLite3/Table.php
+++ b/system/Database/SQLite3/Table.php
@@ -308,7 +308,7 @@ protected function createTable()
$this->keys = array_filter(
$this->keys,
- static fn ($index): bool => count(array_intersect($index['fields'], $fieldNames)) === count($index['fields'])
+ static fn ($index): bool => count(array_intersect($index['fields'], $fieldNames)) === count($index['fields']),
);
// Unique/Index keys
@@ -334,7 +334,7 @@ protected function createTable()
$this->forge->addForeignKey(
$foreignKey->column_name,
trim($foreignKey->foreign_table_name, $this->db->DBPrefix),
- $foreignKey->foreign_column_name
+ $foreignKey->foreign_column_name,
);
}
@@ -358,15 +358,15 @@ protected function copyData()
$exFields = implode(
', ',
- array_map(fn ($item) => $this->db->protectIdentifiers($item), $exFields)
+ array_map(fn ($item) => $this->db->protectIdentifiers($item), $exFields),
);
$newFields = implode(
', ',
- array_map(fn ($item) => $this->db->protectIdentifiers($item), $newFields)
+ array_map(fn ($item) => $this->db->protectIdentifiers($item), $newFields),
);
$this->db->query(
- "INSERT INTO {$this->prefixedTableName}({$newFields}) SELECT {$exFields} FROM {$this->db->DBPrefix}temp_{$this->tableName}"
+ "INSERT INTO {$this->prefixedTableName}({$newFields}) SELECT {$exFields} FROM {$this->db->DBPrefix}temp_{$this->tableName}",
);
}
diff --git a/system/Debug/BaseExceptionHandler.php b/system/Debug/BaseExceptionHandler.php
index 4305265d2d2c..3966b2ee1bae 100644
--- a/system/Debug/BaseExceptionHandler.php
+++ b/system/Debug/BaseExceptionHandler.php
@@ -61,7 +61,7 @@ abstract public function handle(
RequestInterface $request,
ResponseInterface $response,
int $statusCode,
- int $exitCode
+ int $exitCode,
);
/**
@@ -221,7 +221,7 @@ protected static function highlightFile(string $file, int $lineNumber, int $line
"{$format} %s\n%s",
$n + $start + 1,
strip_tags($row),
- implode('', $tags[0])
+ implode('', $tags[0]),
);
} else {
$out .= sprintf('' . $format . ' %s', $n + $start + 1, $row) . "\n";
diff --git a/system/Debug/ExceptionHandler.php b/system/Debug/ExceptionHandler.php
index d6f97b76a32b..8283e1ff5362 100644
--- a/system/Debug/ExceptionHandler.php
+++ b/system/Debug/ExceptionHandler.php
@@ -47,7 +47,7 @@ public function handle(
RequestInterface $request,
ResponseInterface $response,
int $statusCode,
- int $exitCode
+ int $exitCode,
): void {
// ResponseTrait needs these properties.
$this->request = $request;
@@ -68,10 +68,10 @@ public function handle(
'HTTP/%s %s %s',
$request->getProtocolVersion(),
$response->getStatusCode(),
- $response->getReasonPhrase()
+ $response->getReasonPhrase(),
),
true,
- $statusCode
+ $statusCode,
);
}
@@ -129,7 +129,7 @@ public function handle(
protected function determineView(
Throwable $exception,
string $templatePath,
- int $statusCode = 500
+ int $statusCode = 500,
): string {
// Production environments should have a custom exception file.
$view = 'production.php';
@@ -138,7 +138,7 @@ protected function determineView(
in_array(
strtolower(ini_get('display_errors')),
['1', 'true', 'on', 'yes'],
- true
+ true,
)
) {
$view = 'error_exception.php';
diff --git a/system/Debug/ExceptionHandlerInterface.php b/system/Debug/ExceptionHandlerInterface.php
index d0379e2abd63..05915c638f36 100644
--- a/system/Debug/ExceptionHandlerInterface.php
+++ b/system/Debug/ExceptionHandlerInterface.php
@@ -27,6 +27,6 @@ public function handle(
RequestInterface $request,
ResponseInterface $response,
int $statusCode,
- int $exitCode
+ int $exitCode,
): void;
}
diff --git a/system/Debug/Exceptions.php b/system/Debug/Exceptions.php
index aa353732c197..3293d75929a3 100644
--- a/system/Debug/Exceptions.php
+++ b/system/Debug/Exceptions.php
@@ -164,7 +164,7 @@ public function exceptionHandler(Throwable $exception)
$this->request,
$this->response,
$statusCode,
- $exitCode
+ $exitCode,
);
return;
@@ -270,7 +270,7 @@ protected function determineView(Throwable $exception, string $templatePath): st
in_array(
strtolower(ini_get('display_errors')),
['1', 'true', 'on', 'yes'],
- true
+ true,
)
) {
$view = 'error_exception.php';
@@ -462,7 +462,7 @@ private function handleDeprecationError(string $message, ?string $file = null, ?
'errFile' => clean_path($file ?? ''),
'errLine' => $line ?? 0,
'trace' => self::renderBacktrace($trace),
- ]
+ ],
);
return true;
@@ -567,7 +567,7 @@ public static function highlightFile(string $file, int $lineNumber, int $lines =
"{$format} %s\n%s",
$n + $start + 1,
strip_tags($row),
- implode('', $tags[0])
+ implode('', $tags[0]),
);
} else {
$out .= sprintf('' . $format . ' %s', $n + $start + 1, $row) . "\n";
@@ -611,7 +611,7 @@ private static function renderBacktrace(array $backtrace): string
$frame['class'],
$frame['type'],
$frame['function'],
- $args
+ $args,
);
}
diff --git a/system/Debug/Toolbar.php b/system/Debug/Toolbar.php
index b939e208fd21..9a884b60f5b3 100644
--- a/system/Debug/Toolbar.php
+++ b/system/Debug/Toolbar.php
@@ -58,7 +58,7 @@ public function __construct(ToolbarConfig $config)
log_message(
'critical',
'Toolbar collector does not exist (' . $collector . ').'
- . ' Please check $collectors in the app/Config/Toolbar.php file.'
+ . ' Please check $collectors in the app/Config/Toolbar.php file.',
);
continue;
@@ -391,7 +391,7 @@ public function prepare(?RequestInterface $request = null, ?ResponseInterface $r
$stats['startTime'],
$stats['totalTime'],
$request,
- $response
+ $response,
);
helper('filesystem');
@@ -439,8 +439,8 @@ public function prepare(?RequestInterface $request = null, ?ResponseInterface $r
'//',
'' . $script,
$response->getBody(),
- 1
- )
+ 1,
+ ),
);
return;
@@ -516,7 +516,7 @@ protected function format(string $data, string $format = 'html'): string
$history = new History();
$history->setFiles(
$debugbarTime[0],
- $this->config->maxHistory
+ $this->config->maxHistory,
);
$data['collectors'][] = $history->getAsArray();
diff --git a/system/Debug/Toolbar/Collectors/Database.php b/system/Debug/Toolbar/Collectors/Database.php
index 32f7f07091b3..df876422aaf1 100644
--- a/system/Debug/Toolbar/Collectors/Database.php
+++ b/system/Debug/Toolbar/Collectors/Database.php
@@ -228,7 +228,7 @@ public function getTitleDetails(): string
$uniqueCount,
$uniqueCount > 1 ? 'of them' : '',
$connectionCount,
- $connectionCount > 1 ? 's' : ''
+ $connectionCount > 1 ? 's' : '',
);
}
diff --git a/system/Debug/Toolbar/Collectors/Routes.php b/system/Debug/Toolbar/Collectors/Routes.php
index 561399fbf37f..47c808e7ac40 100644
--- a/system/Debug/Toolbar/Collectors/Routes.php
+++ b/system/Debug/Toolbar/Collectors/Routes.php
@@ -109,7 +109,7 @@ public function display(): array
' | default: '
. var_export(
$param->isDefaultValueAvailable() ? $param->getDefaultValue() : null,
- true
+ true,
),
];
}
diff --git a/system/Email/Email.php b/system/Email/Email.php
index c52c36230866..17b24c9de575 100644
--- a/system/Email/Email.php
+++ b/system/Email/Email.php
@@ -1659,7 +1659,7 @@ protected function unwrapSpecials()
$this->finalBody = preg_replace_callback(
'/\{unwrap\}(.*?)\{\/unwrap\}/si',
$this->removeNLCallback(...),
- $this->finalBody
+ $this->finalBody,
);
}
@@ -1900,7 +1900,7 @@ protected function SMTPConnect()
$this->SMTPPort,
$errno,
$errstr,
- $this->SMTPTimeout
+ $this->SMTPTimeout,
);
if (! is_resource($this->SMTPConnect)) {
@@ -1921,7 +1921,7 @@ protected function SMTPConnect()
STREAM_CRYPTO_METHOD_TLSv1_0_CLIENT
| STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT
| STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT
- | STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT
+ | STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT,
);
if ($crypto !== true) {
diff --git a/system/Entity/Entity.php b/system/Entity/Entity.php
index ff2fba1f7062..0e54c722e354 100644
--- a/system/Entity/Entity.php
+++ b/system/Entity/Entity.php
@@ -138,7 +138,7 @@ public function __construct(?array $data = null)
array_merge($this->defaultCastHandlers, $this->castHandlers),
null,
null,
- false
+ false,
);
$this->syncOriginal();
@@ -185,7 +185,7 @@ public function toArray(bool $onlyChanged = false, bool $cast = true, bool $recu
if (is_array($this->datamap)) {
$keys = array_unique(
- [...array_diff($keys, $this->datamap), ...array_keys($this->datamap)]
+ [...array_diff($keys, $this->datamap), ...array_keys($this->datamap)],
);
}
diff --git a/system/Events/Events.php b/system/Events/Events.php
index ad8efed62f9e..97f4e81d0369 100644
--- a/system/Events/Events.php
+++ b/system/Events/Events.php
@@ -76,7 +76,7 @@ public static function initialize()
return;
}
- $config = config(Modules::class);
+ $config = new Modules();
$events = APPPATH . 'Config' . DIRECTORY_SEPARATOR . 'Events.php';
$files = [];
@@ -212,7 +212,7 @@ public static function removeListener($eventName, callable $listener): bool
if ($check === $listener) {
unset(
static::$listeners[$eventName][1][$index],
- static::$listeners[$eventName][2][$index]
+ static::$listeners[$eventName][2][$index],
);
return true;
diff --git a/system/Exceptions/FrameworkException.php b/system/Exceptions/FrameworkException.php
index 1fe47be49a6b..7ea9e6d7d51f 100644
--- a/system/Exceptions/FrameworkException.php
+++ b/system/Exceptions/FrameworkException.php
@@ -68,7 +68,7 @@ public static function forMissingExtension(string $extension)
// @codeCoverageIgnoreStart
$message = sprintf(
'The framework needs the following extension(s) installed and loaded: %s.',
- $extension
+ $extension,
);
// @codeCoverageIgnoreEnd
} else {
diff --git a/system/Files/FileCollection.php b/system/Files/FileCollection.php
index 179bbc1d4997..369cea9ddd02 100644
--- a/system/Files/FileCollection.php
+++ b/system/Files/FileCollection.php
@@ -103,7 +103,7 @@ final protected static function matchFiles(array $files, string $pattern): array
$pattern = str_replace(
['#', '.', '*', '?'],
['\#', '\.', '.*', '.'],
- $pattern
+ $pattern,
);
$pattern = "#\\A{$pattern}\\z#";
}
diff --git a/system/Filters/Filters.php b/system/Filters/Filters.php
index fd252fe1fa26..28f712f66114 100644
--- a/system/Filters/Filters.php
+++ b/system/Filters/Filters.php
@@ -116,7 +116,7 @@ public function __construct($config, RequestInterface $request, ResponseInterfac
$this->request = &$request;
$this->setResponse($response);
- $this->modules = $modules ?? config(Modules::class);
+ $this->modules = $modules instanceof Modules ? $modules : new Modules();
if ($this->modules->shouldDiscover('filters')) {
$this->discoverFilters();
@@ -202,7 +202,7 @@ private function runBefore(array $filterClasses)
$result = $class->before(
$this->request,
- $this->argumentsClass[$className] ?? null
+ $this->argumentsClass[$className] ?? null,
);
if ($result instanceof RequestInterface) {
@@ -241,7 +241,7 @@ private function runAfter(array $filterClasses): ResponseInterface
$result = $class->after(
$this->request,
$this->response,
- $this->argumentsClass[$className] ?? null
+ $this->argumentsClass[$className] ?? null,
);
if ($result instanceof ResponseInterface) {
@@ -648,7 +648,7 @@ protected function processMethods()
@trigger_error(
'Setting lowercase HTTP method key "' . strtolower($method) . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($method) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
$found = true;
@@ -744,7 +744,7 @@ private function registerArguments(string $name, array $arguments, bool $check =
if ($check && array_key_exists($name, $this->arguments)) {
throw new ConfigException(
'"' . $name . '" already has arguments: '
- . (($this->arguments[$name] === null) ? 'null' : implode(',', $this->arguments[$name]))
+ . (($this->arguments[$name] === null) ? 'null' : implode(',', $this->arguments[$name])),
);
}
diff --git a/system/Filters/PerformanceMetrics.php b/system/Filters/PerformanceMetrics.php
index f2371c7a8d6d..51b3fa9f57d5 100644
--- a/system/Filters/PerformanceMetrics.php
+++ b/system/Filters/PerformanceMetrics.php
@@ -53,7 +53,7 @@ public function after(RequestInterface $request, ResponseInterface $response, $a
(string) $benchmark->getElapsedTime('total_execution'),
number_format(memory_get_peak_usage() / 1024 / 1024, 3),
],
- $body
+ $body,
);
$response->setBody($output);
diff --git a/system/HTTP/CURLRequest.php b/system/HTTP/CURLRequest.php
index 90157e4e05d4..9ce664f80865 100644
--- a/system/HTTP/CURLRequest.php
+++ b/system/HTTP/CURLRequest.php
@@ -342,7 +342,7 @@ protected function prepareURL(string $url): string
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
diff --git a/system/HTTP/Cors.php b/system/HTTP/Cors.php
index f7619c9f83a4..2f151a738344 100644
--- a/system/HTTP/Cors.php
+++ b/system/HTTP/Cors.php
@@ -107,7 +107,7 @@ private function checkWildcard(string $name, int $count): void
if (in_array('*', $this->config[$name], true) && $count > 1) {
throw new ConfigException(
"If wildcard is specified, you must set `'{$name}' => ['*']`."
- . ' But using wildcard is not recommended.'
+ . ' But using wildcard is not recommended.',
);
}
}
@@ -121,7 +121,7 @@ private function checkWildcardAndCredentials(string $name, string $header): void
throw new ConfigException(
'When responding to a credentialed request, '
. 'the server must not specify the "*" wildcard for the '
- . $header . ' response-header value.'
+ . $header . ' response-header value.',
);
}
}
@@ -176,7 +176,7 @@ private function setAllowHeaders(ResponseInterface $response): void
$response->setHeader(
'Access-Control-Allow-Headers',
- implode(', ', $this->config['allowedHeaders'])
+ implode(', ', $this->config['allowedHeaders']),
);
}
@@ -187,7 +187,7 @@ private function setAllowMethods(ResponseInterface $response): void
$response->setHeader(
'Access-Control-Allow-Methods',
- implode(', ', $this->config['allowedMethods'])
+ implode(', ', $this->config['allowedMethods']),
);
}
@@ -223,7 +223,7 @@ private function setExposeHeaders(ResponseInterface $response): void
if ($this->config['exposedHeaders'] !== []) {
$response->setHeader(
'Access-Control-Expose-Headers',
- implode(', ', $this->config['exposedHeaders'])
+ implode(', ', $this->config['exposedHeaders']),
);
}
}
diff --git a/system/HTTP/Exceptions/RedirectException.php b/system/HTTP/Exceptions/RedirectException.php
index 3047bf9603eb..5ebec8e1f7a4 100644
--- a/system/HTTP/Exceptions/RedirectException.php
+++ b/system/HTTP/Exceptions/RedirectException.php
@@ -45,7 +45,7 @@ public function __construct($message = '', int $code = 0, ?Throwable $previous =
throw new InvalidArgumentException(
'RedirectException::__construct() first argument must be a string or ResponseInterface',
0,
- $this
+ $this,
);
}
@@ -55,7 +55,7 @@ public function __construct($message = '', int $code = 0, ?Throwable $previous =
if ($this->response->getHeaderLine('Location') === '' && $this->response->getHeaderLine('Refresh') === '') {
throw new LogicException(
- 'The Response object passed to RedirectException does not contain a redirect address.'
+ 'The Response object passed to RedirectException does not contain a redirect address.',
);
}
@@ -76,7 +76,7 @@ public function getResponse(): ResponseInterface
service('logger')->info(
'REDIRECTED ROUTE at '
- . ($this->response->getHeaderLine('Location') ?: substr($this->response->getHeaderLine('Refresh'), 6))
+ . ($this->response->getHeaderLine('Location') ?: substr($this->response->getHeaderLine('Refresh'), 6)),
);
return $this->response;
diff --git a/system/HTTP/Files/FileCollection.php b/system/HTTP/Files/FileCollection.php
index add2c3c03f9c..120652e8bd87 100644
--- a/system/HTTP/Files/FileCollection.php
+++ b/system/HTTP/Files/FileCollection.php
@@ -189,7 +189,7 @@ protected function createFileObject(array $array)
$array['type'] ?? null,
($array['size'] ?? null) === null ? null : (int) $array['size'],
$array['error'] ?? null,
- $array['full_path'] ?? null
+ $array['full_path'] ?? null,
);
}
@@ -219,7 +219,7 @@ protected function fixFilesArray(array $data): array
$stack = [&$pointer];
$iterator = new RecursiveIteratorIterator(
new RecursiveArrayIterator($value),
- RecursiveIteratorIterator::SELF_FIRST
+ RecursiveIteratorIterator::SELF_FIRST,
);
foreach ($iterator as $key => $val) {
diff --git a/system/HTTP/Files/UploadedFile.php b/system/HTTP/Files/UploadedFile.php
index c17a9e5af8e5..b43923026021 100644
--- a/system/HTTP/Files/UploadedFile.php
+++ b/system/HTTP/Files/UploadedFile.php
@@ -325,7 +325,7 @@ public function guessExtension(): string
*/
public function getClientExtension(): string
{
- return pathinfo($this->originalName, PATHINFO_EXTENSION) ?? '';
+ return pathinfo($this->originalName, PATHINFO_EXTENSION);
}
/**
diff --git a/system/HTTP/Message.php b/system/HTTP/Message.php
index 71c4429f28ee..6b2a5e8ba2c4 100644
--- a/system/HTTP/Message.php
+++ b/system/HTTP/Message.php
@@ -119,7 +119,7 @@ public function getHeaderLine(string $name): string
if ($this->hasMultipleHeaders($name)) {
throw new InvalidArgumentException(
'The header "' . $name . '" already has multiple headers.'
- . ' You cannot use getHeaderLine().'
+ . ' You cannot use getHeaderLine().',
);
}
diff --git a/system/HTTP/MessageTrait.php b/system/HTTP/MessageTrait.php
index 2f6e57a90c57..9ae7737a8e8f 100644
--- a/system/HTTP/MessageTrait.php
+++ b/system/HTTP/MessageTrait.php
@@ -182,7 +182,7 @@ private function checkMultipleHeaders(string $name): void
if ($this->hasMultipleHeaders($name)) {
throw new InvalidArgumentException(
'The header "' . $name . '" already has multiple headers.'
- . ' You cannot change them. If you really need to change, remove the header first.'
+ . ' You cannot change them. If you really need to change, remove the header first.',
);
}
}
diff --git a/system/HTTP/Negotiate.php b/system/HTTP/Negotiate.php
index 33938c8f0741..ff4d2998766b 100644
--- a/system/HTTP/Negotiate.php
+++ b/system/HTTP/Negotiate.php
@@ -90,7 +90,7 @@ public function charset(array $supported): string
$supported,
$this->request->getHeaderLine('accept-charset'),
false,
- true
+ true,
);
// If no charset is shown as a match, ignore the directive
@@ -154,7 +154,7 @@ protected function getBestMatch(
?string $header = null,
bool $enforceTypes = false,
bool $strictMatch = false,
- bool $matchLocales = false
+ bool $matchLocales = false,
): string {
if ($supported === []) {
throw HTTPException::forEmptySupportedNegotiations();
@@ -212,7 +212,7 @@ public function parseHeader(string $header): array
if (preg_match(
'/^(?P.+?)=(?P"|\')?(?P.*?)(?:\k)?$/',
$pair,
- $param
+ $param,
)) {
$parameters[trim($param['name'])] = trim($param['value']);
}
diff --git a/system/HTTP/OutgoingRequest.php b/system/HTTP/OutgoingRequest.php
index e62f07241558..eba5babdf6bb 100644
--- a/system/HTTP/OutgoingRequest.php
+++ b/system/HTTP/OutgoingRequest.php
@@ -43,7 +43,7 @@ public function __construct(
?URI $uri = null,
array $headers = [],
$body = null,
- string $version = '1.1'
+ string $version = '1.1',
) {
$this->method = $method;
$this->uri = $uri;
diff --git a/system/HTTP/RequestTrait.php b/system/HTTP/RequestTrait.php
index dfa4b663dbaf..39f4269ef1df 100644
--- a/system/HTTP/RequestTrait.php
+++ b/system/HTTP/RequestTrait.php
@@ -72,7 +72,7 @@ public function getIPAddress(): string
if (! empty($proxyIPs) && (! is_array($proxyIPs) || is_int(array_key_first($proxyIPs)))) {
throw new ConfigException(
- 'You must set an array with Proxy IP address key and HTTP header name value in Config\App::$proxyIPs.'
+ 'You must set an array with Proxy IP address key and HTTP header name value in Config\App::$proxyIPs.',
);
}
diff --git a/system/HTTP/ResponseInterface.php b/system/HTTP/ResponseInterface.php
index 382a2847c503..58f11a0f9065 100644
--- a/system/HTTP/ResponseInterface.php
+++ b/system/HTTP/ResponseInterface.php
@@ -341,7 +341,7 @@ public function setCookie(
$prefix = '',
$secure = false,
$httponly = false,
- $samesite = null
+ $samesite = null,
);
/**
diff --git a/system/HTTP/ResponseTrait.php b/system/HTTP/ResponseTrait.php
index eaf60f2b38b4..b23e40a9046b 100644
--- a/system/HTTP/ResponseTrait.php
+++ b/system/HTTP/ResponseTrait.php
@@ -407,14 +407,14 @@ public function sendHeaders()
header(
$name . ': ' . $value->getValueLine(),
false,
- $this->getStatusCode()
+ $this->getStatusCode(),
);
} else {
foreach ($value as $header) {
header(
$name . ': ' . $header->getValueLine(),
false,
- $this->getStatusCode()
+ $this->getStatusCode(),
);
}
}
@@ -512,7 +512,7 @@ public function setCookie(
$prefix = '',
$secure = null,
$httponly = null,
- $samesite = null
+ $samesite = null,
) {
if ($name instanceof Cookie) {
$this->cookieStore = $this->cookieStore->put($name);
diff --git a/system/HTTP/SiteURI.php b/system/HTTP/SiteURI.php
index 2be70a7773ef..63181b89fead 100644
--- a/system/HTTP/SiteURI.php
+++ b/system/HTTP/SiteURI.php
@@ -95,7 +95,7 @@ public function __construct(
App $configApp,
string $relativePath = '',
?string $host = null,
- ?string $scheme = null
+ ?string $scheme = null,
) {
$this->indexPage = $configApp->indexPage;
@@ -142,7 +142,7 @@ private function parseRelativePath(string $relativePath): array
private function determineBaseURL(
App $configApp,
?string $host,
- ?string $scheme
+ ?string $scheme,
): URI {
$baseURL = $this->normalizeBaseURL($configApp);
@@ -199,7 +199,7 @@ private function normalizeBaseURL(App $configApp): string
// Validate baseURL
if (filter_var($baseURL, FILTER_VALIDATE_URL) === false) {
throw new ConfigException(
- 'Config\App::$baseURL "' . $baseURL . '" is not a valid URL.'
+ 'Config\App::$baseURL "' . $baseURL . '" is not a valid URL.',
);
}
@@ -266,7 +266,7 @@ public function __toString(): string
$this->getAuthority(),
$this->getPath(),
$this->getQuery(),
- $this->getFragment()
+ $this->getFragment(),
);
}
diff --git a/system/HTTP/URI.php b/system/HTTP/URI.php
index 2b386797fecd..c9d634d3846d 100644
--- a/system/HTTP/URI.php
+++ b/system/HTTP/URI.php
@@ -163,7 +163,7 @@ public static function createURIString(
?string $authority = null,
?string $path = null,
?string $query = null,
- ?string $fragment = null
+ ?string $fragment = null,
): string {
$uri = '';
if ($scheme !== null && $scheme !== '') {
@@ -638,7 +638,7 @@ public function __toString(): string
$this->getAuthority(),
$path, // Absolute URIs should use a "/" for an empty path
$this->getQuery(),
- $this->getFragment()
+ $this->getFragment(),
);
}
@@ -1022,7 +1022,7 @@ protected function filterPath(?string $path = null): string
$path = preg_replace_callback(
'/(?:[^' . static::CHAR_UNRESERVED . ':@&=\+\$,\/;%]+|%(?![A-Fa-f0-9]{2}))/',
static fn (array $matches): string => rawurlencode($matches[0]),
- $path
+ $path,
);
return $path;
@@ -1170,7 +1170,7 @@ protected function parseStr(string $query): array
$params = array_map(static fn (string $chunk): ?string => preg_replace_callback(
'/^(?[^&=]+?)(?:\[[^&=]*\])?=(?[^&=]+)/',
static fn (array $match): string => str_replace($match['key'], bin2hex($match['key']), $match[0]),
- urldecode($chunk)
+ urldecode($chunk),
), $query);
$params = implode('&', $params);
diff --git a/system/Helpers/Array/ArrayHelper.php b/system/Helpers/Array/ArrayHelper.php
index fc5bc462956e..1b812e6a5123 100644
--- a/system/Helpers/Array/ArrayHelper.php
+++ b/system/Helpers/Array/ArrayHelper.php
@@ -54,12 +54,12 @@ private static function convertToArray(string $index): array
'/(? str_replace('\.', '.', $key),
- $segments
+ $segments,
);
}
@@ -130,7 +130,7 @@ public static function dotKeyExists(string $index, array $array): bool
{
if (str_ends_with($index, '*') || str_contains($index, '*.*')) {
throw new InvalidArgumentException(
- 'You must set key right after "*". Invalid index: "' . $index . '"'
+ 'You must set key right after "*". Invalid index: "' . $index . '"',
);
}
@@ -210,7 +210,7 @@ private static function arrayAttachIndexedValue(
array $result,
array $row,
array $indexes,
- bool $includeEmpty
+ bool $includeEmpty,
): array {
if (($index = array_shift($indexes)) === null) {
$result[] = $row;
diff --git a/system/Helpers/cookie_helper.php b/system/Helpers/cookie_helper.php
index 27007104e68e..18239fe2ebff 100644
--- a/system/Helpers/cookie_helper.php
+++ b/system/Helpers/cookie_helper.php
@@ -46,7 +46,7 @@ function set_cookie(
string $prefix = '',
?bool $secure = null,
?bool $httpOnly = null,
- ?string $sameSite = null
+ ?string $sameSite = null,
): void {
$response = service('response');
$response->setCookie($name, $value, $expire, $domain, $path, $prefix, $secure, $httpOnly, $sameSite);
diff --git a/system/Helpers/date_helper.php b/system/Helpers/date_helper.php
index c0b4d5ebe17a..c16da6592886 100644
--- a/system/Helpers/date_helper.php
+++ b/system/Helpers/date_helper.php
@@ -43,7 +43,7 @@ function now(?string $timezone = null): int
$year,
$hour,
$minute,
- $second
+ $second,
);
return mktime($hour, $minute, $second, $month, $day, $year);
diff --git a/system/Helpers/filesystem_helper.php b/system/Helpers/filesystem_helper.php
index d5f2d974e4ad..9c0196b4752f 100644
--- a/system/Helpers/filesystem_helper.php
+++ b/system/Helpers/filesystem_helper.php
@@ -87,7 +87,7 @@ function directory_mirror(string $originDir, string $targetDir, bool $overwrite
*/
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($originDir, FilesystemIterator::SKIP_DOTS),
- RecursiveIteratorIterator::SELF_FIRST
+ RecursiveIteratorIterator::SELF_FIRST,
) as $file) {
$origin = $file->getPathname();
$target = $targetDir . substr($origin, $dirLen);
@@ -96,7 +96,7 @@ function directory_mirror(string $originDir, string $targetDir, bool $overwrite
if (! is_dir($target)) {
mkdir($target, 0755);
}
- } elseif (! is_file($target) || ($overwrite && is_file($target))) {
+ } elseif ($overwrite || ! is_file($target)) {
copy($origin, $target);
}
}
@@ -159,7 +159,7 @@ function delete_files(string $path, bool $delDir = false, bool $htdocs = false,
try {
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($path, RecursiveDirectoryIterator::SKIP_DOTS),
- RecursiveIteratorIterator::CHILD_FIRST
+ RecursiveIteratorIterator::CHILD_FIRST,
) as $object) {
$filename = $object->getFilename();
if (! $hidden && $filename[0] === '.') {
@@ -202,7 +202,7 @@ function get_filenames(
string $sourceDir,
?bool $includePath = false,
bool $hidden = false,
- bool $includeDir = true
+ bool $includeDir = true,
): array {
$files = [];
@@ -212,7 +212,7 @@ function get_filenames(
try {
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($sourceDir, RecursiveDirectoryIterator::SKIP_DOTS | FilesystemIterator::FOLLOW_SYMLINKS),
- RecursiveIteratorIterator::SELF_FIRST
+ RecursiveIteratorIterator::SELF_FIRST,
) as $name => $object) {
$basename = pathinfo($name, PATHINFO_BASENAME);
if (! $hidden && $basename[0] === '.') {
diff --git a/system/Helpers/form_helper.php b/system/Helpers/form_helper.php
index 679008c9731a..ae4505c26597 100644
--- a/system/Helpers/form_helper.php
+++ b/system/Helpers/form_helper.php
@@ -741,7 +741,7 @@ function validation_show_error(string $field, string $template = 'single'): stri
$errors = array_filter(validation_errors(), static fn ($key): bool => preg_match(
'/^' . str_replace(['\.\*', '\*\.'], ['\..+', '.+\.'], preg_quote($field, '/')) . '$/',
- $key
+ $key,
) === 1, ARRAY_FILTER_USE_KEY);
if ($errors === []) {
diff --git a/system/Helpers/html_helper.php b/system/Helpers/html_helper.php
index 3eb55a6d5150..9dcf82536eeb 100644
--- a/system/Helpers/html_helper.php
+++ b/system/Helpers/html_helper.php
@@ -238,7 +238,7 @@ function link_tag(
string $title = '',
string $media = '',
bool $indexPage = false,
- string $hreflang = ''
+ string $hreflang = '',
): string {
$attributes = [];
// extract fields if needed
diff --git a/system/Helpers/inflector_helper.php b/system/Helpers/inflector_helper.php
index abc565652ecb..fb4ef6cb3924 100644
--- a/system/Helpers/inflector_helper.php
+++ b/system/Helpers/inflector_helper.php
@@ -278,7 +278,7 @@ function is_pluralizable(string $word): bool
'wisdom',
'work',
],
- true
+ true,
);
return ! $uncountables;
diff --git a/system/Helpers/security_helper.php b/system/Helpers/security_helper.php
index af6257e5e39c..d42ac0dda777 100644
--- a/system/Helpers/security_helper.php
+++ b/system/Helpers/security_helper.php
@@ -35,7 +35,7 @@ function strip_image_tags(string $str): string
'#`]+)).*?\>#i',
],
'\\2',
- $str
+ $str,
);
}
}
diff --git a/system/Helpers/text_helper.php b/system/Helpers/text_helper.php
index 8733049c88a4..6e9db747305c 100644
--- a/system/Helpers/text_helper.php
+++ b/system/Helpers/text_helper.php
@@ -152,7 +152,7 @@ function entities_to_ascii(string $str, bool $all = true): string
return str_replace(
['&', '<', '>', '"', ''', '-'],
['&', '<', '>', '"', "'", '-'],
- $str
+ $str,
);
}
@@ -193,7 +193,7 @@ function word_censor(string $str, array $censored, string $replacement = ''): st
$str = preg_replace(
"/({$delim})(" . $badword . ")({$delim})/i",
"\\1{$replacement}\\3",
- $str
+ $str,
);
} elseif (preg_match_all("/{$delim}(" . $badword . "){$delim}/i", $str, $matches, PREG_PATTERN_ORDER | PREG_OFFSET_CAPTURE) >= 1) {
$matches = $matches[1];
@@ -205,7 +205,7 @@ function word_censor(string $str, array $censored, string $replacement = ''): st
$str,
str_repeat('#', $length),
$matches[$i][1],
- $length
+ $length,
);
}
}
@@ -235,7 +235,7 @@ function highlight_code(string $str): string
$str = str_replace(
['<', '>', '', '?>', '<%', '%>', '\\', ''],
['<', '>', 'phptagopen', 'phptagclose', 'asptagopen', 'asptagclose', 'backslashtmp', 'scriptclose'],
- $str
+ $str,
);
// The highlight_string function requires that the text be surrounded
@@ -254,7 +254,7 @@ function highlight_code(string $str): string
"$1\n\n",
'',
],
- $str
+ $str,
);
// Replace our markers back to PHP tags.
@@ -275,7 +275,7 @@ function highlight_code(string $str): string
'\\',
'</script>',
],
- $str
+ $str,
);
}
}
@@ -581,7 +581,7 @@ function random_string(string $type = 'alnum', int $len = 8): string
case 'crypto':
if ($len % 2 !== 0) {
throw new InvalidArgumentException(
- 'You must set an even number to the second parameter when you use `crypto`.'
+ 'You must set an even number to the second parameter when you use `crypto`.',
);
}
@@ -611,7 +611,7 @@ function _from_random(int $length, string $pool): string
{
if ($length <= 0) {
throw new InvalidArgumentException(
- sprintf('A strictly positive length is expected, "%d" given.', $length)
+ sprintf('A strictly positive length is expected, "%d" given.', $length),
);
}
@@ -619,7 +619,7 @@ function _from_random(int $length, string $pool): string
$bits = (int) ceil(log($poolSize, 2.0));
if ($bits <= 0 || $bits > 56) {
throw new InvalidArgumentException(
- 'The length of the alphabet must in the [2^1, 2^56] range.'
+ 'The length of the alphabet must in the [2^1, 2^56] range.',
);
}
diff --git a/system/Helpers/url_helper.php b/system/Helpers/url_helper.php
index b6df3edc3c3d..4d49447bf33a 100644
--- a/system/Helpers/url_helper.php
+++ b/system/Helpers/url_helper.php
@@ -359,7 +359,7 @@ function auto_link(string $str, string $type = 'both', bool $popup = false): str
'#([a-z][a-z0-9+\-.]*://|www\.)[a-z0-9]+(-+[a-z0-9]+)*(\.[a-z0-9]+(-+[a-z0-9]+)*)+(/([^\s()<>;]+\w)?/?)?#i',
$str,
$matches,
- PREG_OFFSET_CAPTURE | PREG_SET_ORDER
+ PREG_OFFSET_CAPTURE | PREG_SET_ORDER,
) >= 1
) {
// Set our target HTML if using popup links.
@@ -386,7 +386,7 @@ function auto_link(string $str, string $type = 'both', bool $popup = false): str
'#([\w\.\-\+]+@[a-z0-9\-]+\.[a-z0-9\-\.]+[^[:punct:]\s])#i',
$str,
$matches,
- PREG_OFFSET_CAPTURE
+ PREG_OFFSET_CAPTURE,
) >= 1
) {
foreach (array_reverse($matches[0]) as $match) {
diff --git a/system/Honeypot/Honeypot.php b/system/Honeypot/Honeypot.php
index 2e79daadb096..1b09da4d1a68 100644
--- a/system/Honeypot/Honeypot.php
+++ b/system/Honeypot/Honeypot.php
@@ -85,7 +85,7 @@ public function attachHoneypot(ResponseInterface $response)
$this->config->container = str_ireplace(
'>{template}',
' id="' . $this->config->containerId . '">{template}',
- $this->config->container
+ $this->config->container,
);
}
diff --git a/system/I18n/TimeTrait.php b/system/I18n/TimeTrait.php
index 354b7542e755..bcdc86314974 100644
--- a/system/I18n/TimeTrait.php
+++ b/system/I18n/TimeTrait.php
@@ -222,7 +222,7 @@ public static function create(
?int $minutes = null,
?int $seconds = null,
$timezone = null,
- ?string $locale = null
+ ?string $locale = null,
) {
$year ??= date('Y');
$month ??= date('m');
@@ -665,7 +665,7 @@ protected function setValue(string $name, $value)
(int) $minute,
(int) $second,
$this->getTimezoneName(),
- $this->locale
+ $this->locale,
);
}
diff --git a/system/Images/Handlers/BaseHandler.php b/system/Images/Handlers/BaseHandler.php
index eb704b564670..30c87535479e 100644
--- a/system/Images/Handlers/BaseHandler.php
+++ b/system/Images/Handlers/BaseHandler.php
@@ -396,23 +396,6 @@ public function flip(string $dir = 'vertical')
*/
abstract protected function _flip(string $direction);
- /**
- * Overlays a string of text over the image.
- *
- * Valid options:
- *
- * - color Text Color (hex number)
- * - shadowColor Color of the shadow (hex number)
- * - hAlign Horizontal alignment: left, center, right
- * - vAlign Vertical alignment: top, middle, bottom
- * - hOffset
- * - vOffset
- * - fontPath
- * - fontSize
- * - shadowOffset
- *
- * @return $this
- */
public function text(string $text, array $options = [])
{
$options = array_merge($this->textDefaults, $options);
@@ -427,6 +410,21 @@ public function text(string $text, array $options = [])
/**
* Handler-specific method for overlaying text on an image.
*
+ * @param array{
+ * color?: string,
+ * shadowColor?: string,
+ * hAlign?: string,
+ * vAlign?: string,
+ * hOffset?: int,
+ * vOffset?: int,
+ * fontPath?: string,
+ * fontSize?: int,
+ * shadowOffset?: int,
+ * opacity?: float,
+ * padding?: int,
+ * withShadow?: bool|string
+ * } $options
+ *
* @return void
*/
abstract protected function _text(string $text, array $options = []);
diff --git a/system/Images/Handlers/GDHandler.php b/system/Images/Handlers/GDHandler.php
index 062a69d89212..12ea4e1a72e2 100644
--- a/system/Images/Handlers/GDHandler.php
+++ b/system/Images/Handlers/GDHandler.php
@@ -322,7 +322,7 @@ protected function ensureResource()
// if valid image type, make corresponding image resource
$this->resource = $this->getImageResource(
$this->image()->getPathname(),
- $this->image()->imageType
+ $this->image()->imageType,
);
}
}
diff --git a/system/Images/Handlers/ImageMagickHandler.php b/system/Images/Handlers/ImageMagickHandler.php
index 583a2759fd31..f1448efa7f8a 100644
--- a/system/Images/Handlers/ImageMagickHandler.php
+++ b/system/Images/Handlers/ImageMagickHandler.php
@@ -329,8 +329,6 @@ protected function supportedFormatCheck()
/**
* Handler-specific method for overlaying text on an image.
*
- * @return void
- *
* @throws Exception
*/
protected function _text(string $text, array $options = [])
diff --git a/system/Images/ImageHandlerInterface.php b/system/Images/ImageHandlerInterface.php
index 7cb635be3738..93b2009d6a93 100644
--- a/system/Images/ImageHandlerInterface.php
+++ b/system/Images/ImageHandlerInterface.php
@@ -117,11 +117,21 @@ public function fit(int $width, int $height, string $position);
* - shadowColor Color of the shadow (hex number)
* - hAlign Horizontal alignment: left, center, right
* - vAlign Vertical alignment: top, middle, bottom
- * - hOffset
- * - vOffset
- * - fontPath
- * - fontSize
- * - shadowOffset
+ *
+ * @param array{
+ * color?: string,
+ * shadowColor?: string,
+ * hAlign?: string,
+ * vAlign?: string,
+ * hOffset?: int,
+ * vOffset?: int,
+ * fontPath?: string,
+ * fontSize?: int,
+ * shadowOffset?: int,
+ * opacity?: float,
+ * padding?: int,
+ * withShadow?: bool|string
+ * } $options
*
* @return $this
*/
diff --git a/system/Language/Language.php b/system/Language/Language.php
index cbea4a53324e..9847553127fe 100644
--- a/system/Language/Language.php
+++ b/system/Language/Language.php
@@ -206,11 +206,11 @@ protected function formatMessage($message, array $args = [])
$argsString = implode(
', ',
- array_map(static fn ($element): string => '"' . $element . '"', $args)
+ array_map(static fn ($element): string => '"' . $element . '"', $args),
);
$argsUrlEncoded = implode(
', ',
- array_map(static fn ($element): string => '"' . rawurlencode($element) . '"', $args)
+ array_map(static fn ($element): string => '"' . rawurlencode($element) . '"', $args),
);
log_message(
@@ -218,7 +218,7 @@ protected function formatMessage($message, array $args = [])
'Language.invalidMessageFormat: $message: "' . $message
. '", $args: ' . $argsString
. ' (urlencoded: ' . $argsUrlEncoded . '),'
- . ' MessageFormatter Error: ' . $fmtError
+ . ' MessageFormatter Error: ' . $fmtError,
);
return $message . "\nγWarningγAlso, invalid string(s) was passed to the Language class. See log file for details.";
diff --git a/system/Log/Handlers/ChromeLoggerHandler.php b/system/Log/Handlers/ChromeLoggerHandler.php
index 37c7c0ffeddf..eedea60a1558 100644
--- a/system/Log/Handlers/ChromeLoggerHandler.php
+++ b/system/Log/Handlers/ChromeLoggerHandler.php
@@ -160,7 +160,7 @@ public function sendLogs(?ResponseInterface &$response = null)
}
$data = base64_encode(
- mb_convert_encoding(json_encode($this->json), 'UTF-8', mb_list_encodings())
+ mb_convert_encoding(json_encode($this->json), 'UTF-8', mb_list_encodings()),
);
$response->setHeader($this->header, $data);
diff --git a/system/Model.php b/system/Model.php
index 98e3be0b1f68..8734ceec954a 100644
--- a/system/Model.php
+++ b/system/Model.php
@@ -373,17 +373,17 @@ protected function doInsert(array $row)
$allFields = $this->db->protectIdentifiers(
array_map(
static fn ($row) => $row->name,
- $this->db->getFieldData($this->table)
+ $this->db->getFieldData($this->table),
),
false,
- true
+ true,
);
$sql = sprintf(
'INSERT INTO %s (%s) VALUES (%s)',
$table,
implode(',', $allFields),
- substr(str_repeat(',DEFAULT', count($allFields)), 1)
+ substr(str_repeat(',DEFAULT', count($allFields)), 1),
);
} else {
$sql = 'INSERT INTO ' . $table . ' DEFAULT VALUES';
@@ -454,7 +454,7 @@ protected function doUpdate($id = null, $row = null): bool
if ($builder->getCompiledQBWhere() === []) {
throw new DatabaseException(
- 'Updates are not allowed unless they contain a "where" or "like" clause.'
+ 'Updates are not allowed unless they contain a "where" or "like" clause.',
);
}
@@ -503,7 +503,7 @@ protected function doDelete($id = null, bool $purge = false)
if ($this->useSoftDeletes && ! $purge) {
if ($builder->getCompiledQBWhere() === []) {
throw new DatabaseException(
- 'Deletes are not allowed unless they contain a "where" or "like" clause.'
+ 'Deletes are not allowed unless they contain a "where" or "like" clause.',
);
}
diff --git a/system/Pager/Pager.php b/system/Pager/Pager.php
index 3bdc85388c18..6d0f54d14a00 100644
--- a/system/Pager/Pager.php
+++ b/system/Pager/Pager.php
@@ -295,7 +295,7 @@ public function getPageURI(?int $page = null, string $group = 'default', bool $r
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
diff --git a/system/Pager/PagerRenderer.php b/system/Pager/PagerRenderer.php
index 64c4c40c531d..7257f2becf31 100644
--- a/system/Pager/PagerRenderer.php
+++ b/system/Pager/PagerRenderer.php
@@ -148,7 +148,7 @@ public function getPrevious()
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -186,7 +186,7 @@ public function getNext()
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -208,7 +208,7 @@ public function getFirst(): string
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -230,7 +230,7 @@ public function getLast(): string
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -252,7 +252,7 @@ public function getCurrent(): string
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -278,7 +278,7 @@ public function links(): array
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
),
'title' => $i,
'active' => ($i === $this->current),
@@ -341,7 +341,7 @@ public function getPreviousPage()
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
@@ -379,7 +379,7 @@ public function getNextPage()
$uri->getAuthority(),
$uri->getPath(),
$uri->getQuery(),
- $uri->getFragment()
+ $uri->getFragment(),
);
}
diff --git a/system/Router/AutoRouter.php b/system/Router/AutoRouter.php
index cad9ecbc1746..3a81f3a7bc6b 100644
--- a/system/Router/AutoRouter.php
+++ b/system/Router/AutoRouter.php
@@ -51,7 +51,7 @@ public function __construct(
* Whether dashes in URI's should be converted
* to underscores when determining method names.
*/
- private bool $translateURIDashes
+ private bool $translateURIDashes,
) {
}
@@ -118,19 +118,19 @@ public function getRoute(string $uri, string $httpVerb): array
// Like $routes->cli('hello/(:segment)', 'Home::$1')
if (str_contains($handler, '::$')) {
throw new PageNotFoundException(
- 'Cannot access CLI Route: ' . $uri
+ 'Cannot access CLI Route: ' . $uri,
);
}
if (str_starts_with($handler, $controller . '::' . $methodName)) {
throw new PageNotFoundException(
- 'Cannot access CLI Route: ' . $uri
+ 'Cannot access CLI Route: ' . $uri,
);
}
if ($handler === $controller) {
throw new PageNotFoundException(
- 'Cannot access CLI Route: ' . $uri
+ 'Cannot access CLI Route: ' . $uri,
);
}
}
@@ -153,9 +153,9 @@ public function getRoute(string $uri, string $httpVerb): array
str_replace(
'/',
'\\',
- $this->defaultNamespace . $this->directory . $controllerName
+ $this->defaultNamespace . $this->directory . $controllerName,
),
- '\\'
+ '\\',
);
}
@@ -199,7 +199,7 @@ private function scanControllers(array $segments): array
while ($c-- > 0) {
$segmentConvert = ucfirst(
- $this->translateURIDashes ? str_replace('-', '_', $segments[0]) : $segments[0]
+ $this->translateURIDashes ? str_replace('-', '_', $segments[0]) : $segments[0],
);
// as soon as we encounter any segment that is not PSR-4 compliant, stop searching
if (! $this->isValidSegment($segmentConvert)) {
diff --git a/system/Router/AutoRouterImproved.php b/system/Router/AutoRouterImproved.php
index 6160c0555dae..c14c8fe97ebe 100644
--- a/system/Router/AutoRouterImproved.php
+++ b/system/Router/AutoRouterImproved.php
@@ -121,7 +121,7 @@ public function __construct(
* Whether dashes in URI's should be converted
* to underscores when determining method names.
*/
- private readonly bool $translateURIDashes
+ private readonly bool $translateURIDashes,
) {
$this->namespace = rtrim($namespace, '\\');
@@ -210,7 +210,7 @@ private function searchLastDefaultController(): bool
$namespaces = array_map(
fn ($segment): string => $this->translateURI($segment),
- $segments
+ $segments,
);
$controller = '\\' . $this->namespace
@@ -288,7 +288,7 @@ public function getRoute(string $uri, string $httpVerb): array
strtolower($baseControllerName) === strtolower($this->defaultController)
) {
throw new PageNotFoundException(
- 'Cannot access the default controller "' . $this->controller . '" with the controller name URI path.'
+ 'Cannot access the default controller "' . $this->controller . '" with the controller name URI path.',
);
}
} elseif ($this->searchLastDefaultController()) {
@@ -329,14 +329,14 @@ public function getRoute(string $uri, string $httpVerb): array
// Prevent access to default controller's method
if (strtolower($baseControllerName) === strtolower($this->defaultController)) {
throw new PageNotFoundException(
- 'Cannot access the default controller "' . $this->controller . '::' . $this->method . '"'
+ 'Cannot access the default controller "' . $this->controller . '::' . $this->method . '"',
);
}
// Prevent access to default method path
if (strtolower($this->method) === strtolower($defaultMethod)) {
throw new PageNotFoundException(
- 'Cannot access the default method "' . $this->method . '" with the method name URI path.'
+ 'Cannot access the default method "' . $this->method . '" with the method name URI path.',
);
}
} elseif (method_exists($this->controller, $defaultMethod)) {
@@ -400,7 +400,7 @@ private function setDirectory()
$dir = str_replace(
'\\',
'/',
- ltrim(substr($namespaces, strlen($this->namespace)), '\\')
+ ltrim(substr($namespaces, strlen($this->namespace)), '\\'),
);
if ($dir !== '') {
@@ -417,7 +417,7 @@ private function protectDefinedRoutes(): void
if ($routeLowerCase === $controller) {
throw new PageNotFoundException(
- 'Cannot access the controller in Defined Routes. Controller: ' . $controllerInRoutes
+ 'Cannot access the controller in Defined Routes. Controller: ' . $controllerInRoutes,
);
}
}
@@ -446,7 +446,7 @@ private function checkParameters(): void
throw new PageNotFoundException(
'The param count in the URI are greater than the controller method params.'
. ' Handler:' . $this->controller . '::' . $this->method
- . ', URI:' . $this->uri
+ . ', URI:' . $this->uri,
);
}
}
@@ -459,7 +459,7 @@ private function checkRemap(): void
throw new PageNotFoundException(
'AutoRouterImproved does not support `_remap()` method.'
- . ' Controller:' . $this->controller
+ . ' Controller:' . $this->controller,
);
} catch (ReflectionException) {
// Do nothing.
@@ -482,7 +482,7 @@ private function checkUnderscore(): void
. ' when $translateURIDashes is enabled.'
. ' Please use the dash.'
. ' Handler:' . $this->controller . '::' . $this->method
- . ', URI:' . $this->uri
+ . ', URI:' . $this->uri,
);
}
}
@@ -502,7 +502,7 @@ private function checkUriForController(string $classname): void
if (! in_array(ltrim($classname, '\\'), get_declared_classes(), true)) {
throw new PageNotFoundException(
- '"' . $classname . '" is not found.'
+ '"' . $classname . '" is not found.',
);
}
}
@@ -531,7 +531,7 @@ private function checkUriForMethod(string $method): void
&& ! in_array($method, get_class_methods($this->controller), true)
) {
throw new PageNotFoundException(
- '"' . $this->controller . '::' . $method . '()" is not found.'
+ '"' . $this->controller . '::' . $method . '()" is not found.',
);
}
}
@@ -558,7 +558,7 @@ private function translateURI(string $segment): string
. ' containing uppercase letters ("' . $segment . '")'
. ' when $translateUriToCamelCase is enabled.'
. ' Please use the dash.'
- . ' URI:' . $this->uri
+ . ' URI:' . $this->uri,
);
}
@@ -568,7 +568,7 @@ private function translateURI(string $segment): string
. ' containing double dash ("' . $segment . '")'
. ' when $translateUriToCamelCase is enabled.'
. ' Please use the single dash.'
- . ' URI:' . $this->uri
+ . ' URI:' . $this->uri,
);
}
@@ -576,8 +576,8 @@ private function translateURI(string $segment): string
' ',
'',
ucwords(
- preg_replace('/[\-]+/', ' ', $segment)
- )
+ preg_replace('/[\-]+/', ' ', $segment),
+ ),
);
}
diff --git a/system/Router/RouteCollection.php b/system/Router/RouteCollection.php
index faee291a8213..400ef6773b0d 100644
--- a/system/Router/RouteCollection.php
+++ b/system/Router/RouteCollection.php
@@ -634,7 +634,7 @@ public function setHTTPVerb(string $verb)
@trigger_error(
'Passing lowercase HTTP method "' . $verb . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($verb) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
@@ -791,7 +791,7 @@ public function group(string $name, ...$params)
// Merge options other than filters.
$this->currentOptions = array_merge(
$this->currentOptions ?? [],
- $options
+ $options,
);
}
@@ -1026,7 +1026,7 @@ public function match(array $verbs = [], string $from = '', $to = '', ?array $op
@trigger_error(
'Passing lowercase HTTP method "' . $verb . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($verb) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
@@ -1382,7 +1382,7 @@ protected function buildReverseRoute(string $from, array $params): string
foreach ($placeholders as $index => $placeholder) {
if (! isset($params[$index])) {
throw new InvalidArgumentException(
- 'Missing argument for "' . $placeholder . '" in route "' . $from . '".'
+ 'Missing argument for "' . $placeholder . '" in route "' . $from . '".',
);
}
@@ -1506,7 +1506,7 @@ protected function create(string $verb, string $from, $to, ?array $options = nul
'/\$X/',
static fn ($m): string => '$' . $i,
$to,
- 1
+ 1,
);
}
}
@@ -1773,7 +1773,7 @@ public function getRegisteredControllers(?string $verb = '*'): array
@trigger_error(
'Passing lowercase HTTP method "' . $verb . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($verb) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
diff --git a/system/Router/Router.php b/system/Router/Router.php
index 4e8c08852f79..8de447d6cc3c 100644
--- a/system/Router/Router.php
+++ b/system/Router/Router.php
@@ -144,6 +144,7 @@ class Router implements RouterInterface
public function __construct(RouteCollectionInterface $routes, ?Request $request = null)
{
$config = config(App::class);
+
if (isset($config->permittedURIChars)) {
$this->permittedURIChars = $config->permittedURIChars;
}
@@ -154,7 +155,7 @@ public function __construct(RouteCollectionInterface $routes, ?Request $request
$this->controller = $this->collection->getDefaultController();
$this->method = $this->collection->getDefaultMethod();
- $this->collection->setHTTPVerb($request->getMethod() ?? $_SERVER['REQUEST_METHOD']);
+ $this->collection->setHTTPVerb($request->getMethod() === '' ? $_SERVER['REQUEST_METHOD'] : $request->getMethod());
$this->translateURIDashes = $this->collection->shouldTranslateURIDashes();
@@ -166,7 +167,7 @@ public function __construct(RouteCollectionInterface $routes, ?Request $request
$this->collection->getDefaultNamespace(),
$this->collection->getDefaultController(),
$this->collection->getDefaultMethod(),
- $this->translateURIDashes
+ $this->translateURIDashes,
);
} else {
$this->autoRouter = new AutoRouter(
@@ -174,7 +175,7 @@ public function __construct(RouteCollectionInterface $routes, ?Request $request
$this->collection->getDefaultNamespace(),
$this->collection->getDefaultController(),
$this->collection->getDefaultMethod(),
- $this->translateURIDashes
+ $this->translateURIDashes,
);
}
}
@@ -220,7 +221,7 @@ public function handle(?string $uri = null)
// want this, like in the case of API's.
if (! $this->collection->shouldAutoRoute()) {
throw new PageNotFoundException(
- "Can't find a route for '{$this->collection->getHTTPVerb()}: {$uri}'."
+ "Can't find a route for '{$this->collection->getHTTPVerb()}: {$uri}'.",
);
}
@@ -441,7 +442,7 @@ protected function checkRoutes(string $uri): bool
throw new RedirectException(
preg_replace('#\A' . $routeKey . '\z#u', $redirectTo, $uri),
- $this->collection->getRedirectCode($routeKey)
+ $this->collection->getRedirectCode($routeKey),
);
}
// Store our locale so CodeIgniter object can
@@ -450,7 +451,7 @@ protected function checkRoutes(string $uri): bool
preg_match(
'#^' . str_replace('{locale}', '(?[^/]+)', $matchedKey) . '$#u',
$uri,
- $matched
+ $matched,
);
if ($this->collection->shouldUseSupportedLocalesOnly()
@@ -545,7 +546,7 @@ static function ($match) use ($matches) {
return $matches[$index] ?? '';
},
- $input
+ $input,
);
}
@@ -735,7 +736,7 @@ private function checkDisallowedChars(string $uri): void
&& preg_match('/\A[' . $this->permittedURIChars . ']+\z/iu', $segment) !== 1
) {
throw new BadRequestException(
- 'The URI you submitted has disallowed characters: "' . $segment . '"'
+ 'The URI you submitted has disallowed characters: "' . $segment . '"',
);
}
}
diff --git a/system/Security/Exceptions/SecurityException.php b/system/Security/Exceptions/SecurityException.php
index ed1d76825036..09ecc26e6bc8 100644
--- a/system/Security/Exceptions/SecurityException.php
+++ b/system/Security/Exceptions/SecurityException.php
@@ -50,7 +50,7 @@ public static function forInvalidUTF8Chars(string $source, string $string)
{
return new static(
'Invalid UTF-8 characters in ' . $source . ': ' . $string,
- 400
+ 400,
);
}
@@ -66,7 +66,7 @@ public static function forInvalidControlChars(string $source, string $string)
{
return new static(
'Invalid Control characters in ' . $source . ': ' . $string,
- 400
+ 400,
);
}
diff --git a/system/Security/Security.php b/system/Security/Security.php
index bdbff2c759b3..5bf90d879c32 100644
--- a/system/Security/Security.php
+++ b/system/Security/Security.php
@@ -533,7 +533,7 @@ private function saveHashInCookie(): void
$this->hash,
[
'expires' => $this->config->expires === 0 ? 0 : Time::now()->getTimestamp() + $this->config->expires,
- ]
+ ],
);
$response = service('response');
diff --git a/system/Session/Handlers/BaseHandler.php b/system/Session/Handlers/BaseHandler.php
index 6d7e09e4b6eb..bc2cdc17af11 100644
--- a/system/Session/Handlers/BaseHandler.php
+++ b/system/Session/Handlers/BaseHandler.php
@@ -132,7 +132,7 @@ protected function destroyCookie(): bool
return setcookie(
$this->cookieName,
'',
- ['expires' => 1, 'path' => $this->cookiePath, 'domain' => $this->cookieDomain, 'secure' => $this->cookieSecure, 'httponly' => true]
+ ['expires' => 1, 'path' => $this->cookiePath, 'domain' => $this->cookieDomain, 'secure' => $this->cookieSecure, 'httponly' => true],
);
}
diff --git a/system/Session/Handlers/DatabaseHandler.php b/system/Session/Handlers/DatabaseHandler.php
index d36e9592cec0..aeafc48c39b9 100644
--- a/system/Session/Handlers/DatabaseHandler.php
+++ b/system/Session/Handlers/DatabaseHandler.php
@@ -285,7 +285,7 @@ public function gc($max_lifetime)
return $this->db->table($this->table)->where(
'timestamp <',
"now() - INTERVAL {$max_lifetime} second",
- false
+ false,
)->delete() ? 1 : $this->fail();
}
diff --git a/system/Session/Handlers/FileHandler.php b/system/Session/Handlers/FileHandler.php
index 6931ab1c581f..5a2e864453bf 100644
--- a/system/Session/Handlers/FileHandler.php
+++ b/system/Session/Handlers/FileHandler.php
@@ -283,7 +283,7 @@ public function gc($max_lifetime)
$pattern = sprintf(
'#\A%s' . $pattern . $this->sessionIDRegex . '\z#',
- preg_quote($this->cookieName, '#')
+ preg_quote($this->cookieName, '#'),
);
$collected = 0;
diff --git a/system/Session/Handlers/MemcachedHandler.php b/system/Session/Handlers/MemcachedHandler.php
index 73133e88d959..744d9556ee02 100644
--- a/system/Session/Handlers/MemcachedHandler.php
+++ b/system/Session/Handlers/MemcachedHandler.php
@@ -97,7 +97,7 @@ public function open($path, $name): bool
'#,?([^,:]+)\:(\d{1,5})(?:\:(\d+))?#',
$this->savePath,
$matches,
- PREG_SET_ORDER
+ PREG_SET_ORDER,
) < 1
) {
$this->memcached = null;
@@ -110,7 +110,7 @@ public function open($path, $name): bool
// If Memcached already has this server (or if the port is invalid), skip it
if (in_array($match[1] . ':' . $match[2], $serverList, true)) {
$this->logger->debug(
- 'Session: Memcached server pool already has ' . $match[1] . ':' . $match[2]
+ 'Session: Memcached server pool already has ' . $match[1] . ':' . $match[2],
);
continue;
@@ -118,7 +118,7 @@ public function open($path, $name): bool
if (! $this->memcached->addServer($match[1], (int) $match[2], $match[3] ?? 0)) {
$this->logger->error(
- 'Could not add ' . $match[1] . ':' . $match[2] . ' to Memcached server pool.'
+ 'Could not add ' . $match[1] . ':' . $match[2] . ' to Memcached server pool.',
);
} else {
$serverList[] = $match[1] . ':' . $match[2];
@@ -275,7 +275,7 @@ protected function lockSession(string $sessionID): bool
if (! $this->memcached->set($lockKey, Time::now()->getTimestamp(), 300)) {
$this->logger->error(
- 'Session: Error while trying to obtain lock for ' . $this->keyPrefix . $sessionID
+ 'Session: Error while trying to obtain lock for ' . $this->keyPrefix . $sessionID,
);
return false;
@@ -287,7 +287,7 @@ protected function lockSession(string $sessionID): bool
if ($attempt === 30) {
$this->logger->error(
- 'Session: Unable to obtain lock for ' . $this->keyPrefix . $sessionID . ' after 30 attempts, aborting.'
+ 'Session: Unable to obtain lock for ' . $this->keyPrefix . $sessionID . ' after 30 attempts, aborting.',
);
return false;
@@ -309,7 +309,7 @@ protected function releaseLock(): bool
&& $this->memcached->getResultCode() !== Memcached::RES_NOTFOUND
) {
$this->logger->error(
- 'Session: Error while trying to free lock for ' . $this->lockKey
+ 'Session: Error while trying to free lock for ' . $this->lockKey,
);
return false;
diff --git a/system/Session/Handlers/RedisHandler.php b/system/Session/Handlers/RedisHandler.php
index 5e44a2a2bef8..eeb06043321b 100644
--- a/system/Session/Handlers/RedisHandler.php
+++ b/system/Session/Handlers/RedisHandler.php
@@ -180,7 +180,7 @@ public function open($path, $name): bool
! $redis->connect(
$this->savePath['host'],
$this->savePath['port'],
- $this->savePath['timeout']
+ $this->savePath['timeout'],
)
) {
$this->logger->error('Session: Unable to connect to Redis with the configured settings.');
@@ -188,7 +188,7 @@ public function open($path, $name): bool
$this->logger->error('Session: Unable to authenticate to Redis instance.');
} elseif (isset($this->savePath['database']) && ! $redis->select($this->savePath['database'])) {
$this->logger->error(
- 'Session: Unable to select Redis database with index ' . $this->savePath['database']
+ 'Session: Unable to select Redis database with index ' . $this->savePath['database'],
);
} else {
$this->redis = $redis;
@@ -318,7 +318,7 @@ public function destroy($id): bool
if (isset($this->redis, $this->lockKey)) {
if (($result = $this->redis->del($this->keyPrefix . $id)) !== 1) {
$this->logger->debug(
- 'Session: Redis::del() expected to return 1, got ' . var_export($result, true) . ' instead.'
+ 'Session: Redis::del() expected to return 1, got ' . var_export($result, true) . ' instead.',
);
}
@@ -369,7 +369,7 @@ protected function lockSession(string $sessionID): bool
(string) Time::now()->getTimestamp(),
// NX -- Only set the key if it does not already exist.
// EX seconds -- Set the specified expire time, in seconds.
- ['nx', 'ex' => 300]
+ ['nx', 'ex' => 300],
);
if (! $result) {
@@ -385,7 +385,7 @@ protected function lockSession(string $sessionID): bool
if ($attempt === 300) {
$this->logger->error(
'Session: Unable to obtain lock for ' . $this->keyPrefix . $sessionID
- . ' after 300 attempts, aborting.'
+ . ' after 300 attempts, aborting.',
);
return false;
diff --git a/system/Test/CIUnitTestCase.php b/system/Test/CIUnitTestCase.php
index 467e3a61bdf7..2797e63d8193 100644
--- a/system/Test/CIUnitTestCase.php
+++ b/system/Test/CIUnitTestCase.php
@@ -361,7 +361,7 @@ public function assertLogged(string $level, $expectedMessage = null)
$this->assertTrue($result, sprintf(
'Failed asserting that expected message "%s" with level "%s" was logged.',
$expectedMessage ?? '',
- $level
+ $level,
));
return $result;
@@ -377,8 +377,8 @@ public function assertLogContains(string $level, string $logMessage, string $mes
$message !== '' ? $message : sprintf(
'Failed asserting that logs have a record of message containing "%s" with level "%s".',
$logMessage,
- $level
- )
+ $level,
+ ),
);
}
@@ -417,7 +417,7 @@ public function assertHeaderEmitted(string $header, bool $ignoreCase = false): v
{
$this->assertNotNull(
$this->getHeaderEmitted($header, $ignoreCase, __METHOD__),
- "Didn't find header for {$header}"
+ "Didn't find header for {$header}",
);
}
@@ -431,7 +431,7 @@ public function assertHeaderNotEmitted(string $header, bool $ignoreCase = false)
{
$this->assertNull(
$this->getHeaderEmitted($header, $ignoreCase, __METHOD__),
- "Found header for {$header}"
+ "Found header for {$header}",
);
}
diff --git a/system/Test/ConfigFromArrayTrait.php b/system/Test/ConfigFromArrayTrait.php
index 3652fa1074a1..c6beb6e63795 100644
--- a/system/Test/ConfigFromArrayTrait.php
+++ b/system/Test/ConfigFromArrayTrait.php
@@ -39,7 +39,7 @@ private function createConfigFromArray(string $classname, array $config)
}
throw new LogicException(
- 'No such property: ' . $classname . '::$' . $key
+ 'No such property: ' . $classname . '::$' . $key,
);
}
diff --git a/system/Test/Constraints/SeeInDatabase.php b/system/Test/Constraints/SeeInDatabase.php
index faf874be9ce8..d1025bc13d08 100644
--- a/system/Test/Constraints/SeeInDatabase.php
+++ b/system/Test/Constraints/SeeInDatabase.php
@@ -68,7 +68,7 @@ protected function failureDescription($table): string
"a row in the table [%s] matches the attributes \n%s\n\n%s",
$table,
$this->toString(false, JSON_PRETTY_PRINT),
- $this->getAdditionalInfo($table)
+ $this->getAdditionalInfo($table),
);
}
@@ -81,7 +81,7 @@ protected function getAdditionalInfo(string $table): string
$similar = $builder->where(
array_key_first($this->data),
- $this->data[array_key_first($this->data)]
+ $this->data[array_key_first($this->data)],
)->limit($this->show)->get()->getResultArray();
if ($similar !== []) {
diff --git a/system/Test/Fabricator.php b/system/Test/Fabricator.php
index 8da0c60fc089..f80ea201b9e9 100644
--- a/system/Test/Fabricator.php
+++ b/system/Test/Fabricator.php
@@ -437,21 +437,21 @@ public function makeArray()
if (isset($this->modifiedFields['unique'][$field])) {
$faker = $faker->unique(
$this->modifiedFields['unique'][$field]['reset'],
- $this->modifiedFields['unique'][$field]['maxRetries']
+ $this->modifiedFields['unique'][$field]['maxRetries'],
);
}
if (isset($this->modifiedFields['optional'][$field])) {
$faker = $faker->optional(
$this->modifiedFields['optional'][$field]['weight'],
- $this->modifiedFields['optional'][$field]['default']
+ $this->modifiedFields['optional'][$field]['default'],
);
}
if (isset($this->modifiedFields['valid'][$field])) {
$faker = $faker->valid(
$this->modifiedFields['valid'][$field]['validator'],
- $this->modifiedFields['valid'][$field]['maxRetries']
+ $this->modifiedFields['valid'][$field]['maxRetries'],
);
}
diff --git a/system/Test/FeatureTestTrait.php b/system/Test/FeatureTestTrait.php
index 13522d8758f3..eaf49a0a9147 100644
--- a/system/Test/FeatureTestTrait.php
+++ b/system/Test/FeatureTestTrait.php
@@ -58,7 +58,7 @@ protected function withRoutes(?array $routes = null)
@trigger_error(
'Passing lowercase HTTP method "' . $route[0] . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($route[0]) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
@@ -168,7 +168,7 @@ public function call(string $method, string $path, ?array $params = null)
@trigger_error(
'Passing lowercase HTTP method "' . $method . '" is deprecated.'
. ' Use uppercase HTTP method like "' . strtoupper($method) . '".',
- E_USER_DEPRECATED
+ E_USER_DEPRECATED,
);
}
@@ -385,7 +385,7 @@ protected function populateGlobals(string $name, Request $request, ?array $param
$request->setGlobal($name, $params);
$request->setGlobal(
'request',
- $request->fetchGlobal('post') + $request->fetchGlobal('get')
+ $request->fetchGlobal('post') + $request->fetchGlobal('get'),
);
}
diff --git a/system/Test/Mock/MockCache.php b/system/Test/Mock/MockCache.php
index 85b5fd9e7e14..b410df874243 100644
--- a/system/Test/Mock/MockCache.php
+++ b/system/Test/Mock/MockCache.php
@@ -31,7 +31,7 @@ class MockCache extends BaseHandler implements CacheInterface
/**
* Expiration times.
*
- * @var ?list
+ * @var array
*/
protected $expirations = [];
diff --git a/system/Test/Mock/MockInputOutput.php b/system/Test/Mock/MockInputOutput.php
index 750f142a00e7..87d09832df56 100644
--- a/system/Test/Mock/MockInputOutput.php
+++ b/system/Test/Mock/MockInputOutput.php
@@ -74,7 +74,7 @@ public function getOutput(?int $index = null): string
throw new InvalidArgumentException(
'No such index in output: ' . $index . ', the last index is: '
- . (count($this->outputs) - 1)
+ . (count($this->outputs) - 1),
);
}
@@ -103,7 +103,7 @@ public function input(?string $prefix = null): string
{
if ($this->inputs === []) {
throw new LogicException(
- 'No input data. Specifiy input data with `MockInputOutput::setInputs()`.'
+ 'No input data. Specifiy input data with `MockInputOutput::setInputs()`.',
);
}
diff --git a/system/Test/Mock/MockResult.php b/system/Test/Mock/MockResult.php
index f3ca02651bfc..9c5f55e98fdc 100644
--- a/system/Test/Mock/MockResult.php
+++ b/system/Test/Mock/MockResult.php
@@ -77,6 +77,7 @@ public function dataSeek($n = 0)
*/
protected function fetchAssoc()
{
+ return [];
}
/**
diff --git a/system/Test/TestResponse.php b/system/Test/TestResponse.php
index f36a9f8ff5e5..13b1df3abaf0 100644
--- a/system/Test/TestResponse.php
+++ b/system/Test/TestResponse.php
@@ -153,7 +153,7 @@ public function assertOK(): void
{
Assert::assertTrue(
$this->isOK(),
- "{$this->response->getStatusCode()} is not a successful status code, or Response has an empty body."
+ "{$this->response->getStatusCode()} is not a successful status code, or Response has an empty body.",
);
}
@@ -164,7 +164,7 @@ public function assertNotOK(): void
{
Assert::assertFalse(
$this->isOK(),
- "{$this->response->getStatusCode()} is an unexpected successful status code, or Response body has content."
+ "{$this->response->getStatusCode()} is an unexpected successful status code, or Response body has content.",
);
}
@@ -287,7 +287,7 @@ public function assertHeader(string $key, $value = null): void
Assert::assertSame(
$value,
$this->response->getHeaderLine($key),
- "The value of '{$key}' header ({$this->response->getHeaderLine($key)}) does not match expected value."
+ "The value of '{$key}' header ({$this->response->getHeaderLine($key)}) does not match expected value.",
);
}
}
@@ -331,7 +331,7 @@ public function assertCookieExpired(string $key, string $prefix = ''): void
Assert::assertGreaterThan(
Time::now()->getTimestamp(),
- $this->response->getCookie($key, $prefix)->getExpiresTimestamp()
+ $this->response->getCookie($key, $prefix)->getExpiresTimestamp(),
);
}
@@ -420,7 +420,7 @@ public function assertSee(?string $search = null, ?string $element = null): void
{
Assert::assertTrue(
$this->domParser->see($search, $element),
- "Text '{$search}' is not seen in response."
+ "Text '{$search}' is not seen in response.",
);
}
@@ -431,7 +431,7 @@ public function assertDontSee(?string $search = null, ?string $element = null):
{
Assert::assertTrue(
$this->domParser->dontSee($search, $element),
- "Text '{$search}' is unexpectedly seen in response."
+ "Text '{$search}' is unexpectedly seen in response.",
);
}
@@ -442,7 +442,7 @@ public function assertSeeElement(string $search): void
{
Assert::assertTrue(
$this->domParser->seeElement($search),
- "Element with selector '{$search}' is not seen in response."
+ "Element with selector '{$search}' is not seen in response.",
);
}
@@ -453,7 +453,7 @@ public function assertDontSeeElement(string $search): void
{
Assert::assertTrue(
$this->domParser->dontSeeElement($search),
- "Element with selector '{$search}' is unexpectedly seen in response.'"
+ "Element with selector '{$search}' is unexpectedly seen in response.'",
);
}
@@ -464,7 +464,7 @@ public function assertSeeLink(string $text, ?string $details = null): void
{
Assert::assertTrue(
$this->domParser->seeLink($text, $details),
- "Anchor tag with text '{$text}' is not seen in response."
+ "Anchor tag with text '{$text}' is not seen in response.",
);
}
@@ -475,7 +475,7 @@ public function assertSeeInField(string $field, ?string $value = null): void
{
Assert::assertTrue(
$this->domParser->seeInField($field, $value),
- "Input named '{$field}' with value '{$value}' is not seen in response."
+ "Input named '{$field}' with value '{$value}' is not seen in response.",
);
}
diff --git a/system/Validation/FormatRules.php b/system/Validation/FormatRules.php
index 7fe16d9d2772..502f3ae09c82 100644
--- a/system/Validation/FormatRules.php
+++ b/system/Validation/FormatRules.php
@@ -428,7 +428,7 @@ public function valid_url_strict($str = null, ?string $validSchemes = null): boo
$scheme = strtolower((string) parse_url($str, PHP_URL_SCHEME));
$validSchemes = explode(
',',
- strtolower($validSchemes ?? 'http,https')
+ strtolower($validSchemes ?? 'http,https'),
);
return in_array($scheme, $validSchemes, true)
diff --git a/system/Validation/Rules.php b/system/Validation/Rules.php
index 7f2f0bd941ec..e12b8227df9e 100644
--- a/system/Validation/Rules.php
+++ b/system/Validation/Rules.php
@@ -125,7 +125,7 @@ public function is_not_unique($str, string $field, array $data): bool
[$field, $whereField, $whereValue] = array_pad(
explode(',', $field),
3,
- null
+ null,
);
// Break the table and field apart
@@ -184,7 +184,7 @@ public function is_unique($str, string $field, array $data): bool
[$field, $ignoreField, $ignoreValue] = array_pad(
explode(',', $field),
3,
- null
+ null,
);
sscanf($field, '%[^.].%[^.]', $table, $field);
@@ -386,7 +386,7 @@ public function required_without(
?string $otherFields = null,
array $data = [],
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
if ($otherFields === null || $data === []) {
throw new InvalidArgumentException('You must supply the parameters: otherFields, data.');
@@ -447,7 +447,7 @@ public function field_exists(
?string $param = null,
array $data = [],
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
if (str_contains($field, '.')) {
return ArrayHelper::dotKeyExists($field, $data);
diff --git a/system/Validation/StrictRules/Rules.php b/system/Validation/StrictRules/Rules.php
index c9b98c479875..2c2a861ca97c 100644
--- a/system/Validation/StrictRules/Rules.php
+++ b/system/Validation/StrictRules/Rules.php
@@ -42,7 +42,7 @@ public function differs(
string $otherField,
array $data,
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
if (str_contains($otherField, '.')) {
return $str !== dot_array_search($otherField, $data);
@@ -149,7 +149,7 @@ public function is_not_unique($str, string $field, array $data): bool
[$field, $whereField, $whereValue] = array_pad(
explode(',', $field),
3,
- null
+ null,
);
// Break the table and field apart
@@ -210,7 +210,7 @@ public function is_unique($str, string $field, array $data): bool
[$field, $ignoreField, $ignoreValue] = array_pad(
explode(',', $field),
3,
- null
+ null,
);
sscanf($field, '%[^.].%[^.]', $table, $field);
@@ -279,7 +279,7 @@ public function matches(
string $otherField,
array $data,
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
if (str_contains($otherField, '.')) {
return $str === dot_array_search($otherField, $data);
@@ -410,7 +410,7 @@ public function required_without(
?string $otherFields = null,
array $data = [],
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
return $this->nonStrictRules->required_without($str, $otherFields, $data, $error, $field);
}
@@ -428,7 +428,7 @@ public function field_exists(
?string $param = null,
array $data = [],
?string $error = null,
- ?string $field = null
+ ?string $field = null,
): bool {
if (str_contains($field, '.')) {
return ArrayHelper::dotKeyExists($field, $data);
diff --git a/system/Validation/Validation.php b/system/Validation/Validation.php
index 5b51b403fef9..880d3508bb45 100644
--- a/system/Validation/Validation.php
+++ b/system/Validation/Validation.php
@@ -177,7 +177,7 @@ public function run(?array $data = null, ?string $group = null, $dbGroup = null)
$values = array_filter(
$flattenedArray,
static fn ($key): bool => preg_match(self::getRegex($field), $key) === 1,
- ARRAY_FILTER_USE_KEY
+ ARRAY_FILTER_USE_KEY,
);
// if keys not found
@@ -208,7 +208,7 @@ public function run(?array $data = null, ?string $group = null, $dbGroup = null)
// Store data that was actually validated.
$this->validated = DotArrayFilter::run(
array_keys($this->rules),
- $this->data
+ $this->data,
);
return true;
@@ -226,7 +226,7 @@ private static function getRegex(string $field): string
. str_replace(
['\.\*', '\*\.'],
['\.[^.]+', '[^.]+\.'],
- preg_quote($field, '/')
+ preg_quote($field, '/'),
)
. '\z/';
}
@@ -248,11 +248,11 @@ public function check($value, $rules, array $errors = [], $dbGroup = null): bool
'check',
null,
$rules,
- $errors
+ $errors,
)->run(
['check' => $value],
null,
- $dbGroup
+ $dbGroup,
);
}
@@ -281,7 +281,7 @@ protected function processRules(
$value,
$rules = null, // @TODO remove `= null`
?array $data = null, // @TODO remove `= null`
- ?string $originalField = null
+ ?string $originalField = null,
): bool {
if ($data === null) {
throw new InvalidArgumentException('You must supply the parameter: data.');
@@ -368,7 +368,7 @@ protected function processRules(
$label,
$param,
(string) $value,
- $originalField
+ $originalField,
);
return false;
@@ -805,7 +805,7 @@ protected function fillPlaceholders(array $rules, array $data): array
throw new LogicException(
'No validation rules for the placeholder: "' . $field
. '". You must set the validation rules for the field.'
- . ' See .'
+ . ' See .',
);
}
@@ -813,7 +813,7 @@ protected function fillPlaceholders(array $rules, array $data): array
foreach ($placeholderRules as $placeholderRule) {
if ($this->retrievePlaceholders($placeholderRule, $data) !== []) {
throw new LogicException(
- 'The placeholder field cannot use placeholder: ' . $field
+ 'The placeholder field cannot use placeholder: ' . $field,
);
}
}
@@ -868,7 +868,7 @@ public function getError(?string $field = null): string
$errors = array_filter(
$this->getErrors(),
static fn ($key): bool => preg_match(self::getRegex($field), $key) === 1,
- ARRAY_FILTER_USE_KEY
+ ARRAY_FILTER_USE_KEY,
);
return $errors === [] ? '' : implode("\n", $errors);
@@ -914,7 +914,7 @@ protected function getErrorMessage(
?string $label = null,
?string $param = null,
?string $value = null,
- ?string $originalField = null
+ ?string $originalField = null,
): string {
$param ??= '';
diff --git a/system/View/Cells/Cell.php b/system/View/Cells/Cell.php
index ddf7ef4ccf63..26eb1d3220f0 100644
--- a/system/View/Cells/Cell.php
+++ b/system/View/Cells/Cell.php
@@ -97,13 +97,13 @@ final protected function view(?string $view, array $data = []): string
$candidateViews = array_filter(
[$view, $possibleView1 ?? '', $possibleView2 ?? ''],
- static fn (string $path): bool => $path !== '' && is_file($path)
+ static fn (string $path): bool => $path !== '' && is_file($path),
);
if ($candidateViews === []) {
throw new LogicException(sprintf(
'Cannot locate the view file for the "%s" cell.',
- static::class
+ static::class,
));
}
diff --git a/system/View/Parser.php b/system/View/Parser.php
index 5990658addad..a2393bb4b7e5 100644
--- a/system/View/Parser.php
+++ b/system/View/Parser.php
@@ -86,7 +86,7 @@ public function __construct(
?string $viewPath = null,
$loader = null,
?bool $debug = null,
- ?LoggerInterface $logger = null
+ ?LoggerInterface $logger = null,
) {
// Ensure user plugins override core plugins.
$this->plugins = $config->plugins;
@@ -329,7 +329,7 @@ protected function parsePair(string $variable, array $data, string $template): a
$this->leftDelimiter . '\s*/' . preg_quote($variable, '#') . '\s*' . $this->rightDelimiter . '#us',
$template,
$matches,
- PREG_SET_ORDER
+ PREG_SET_ORDER,
);
/*
@@ -484,12 +484,12 @@ protected function parseConditionals(string $template): string
$template = preg_replace(
'/' . $leftDelimiter . '\s*else\s*' . $rightDelimiter . '/ums',
'',
- $template
+ $template,
);
$template = preg_replace(
'/' . $leftDelimiter . '\s*endif\s*' . $rightDelimiter . '/ums',
'',
- $template
+ $template,
);
// Parse the PHP itself, or insert an error so they can debug
diff --git a/system/View/View.php b/system/View/View.php
index 7b6bfea0bba5..5c5d0feff86e 100644
--- a/system/View/View.php
+++ b/system/View/View.php
@@ -147,7 +147,7 @@ public function __construct(
?string $viewPath = null,
?FileLocatorInterface $loader = null,
?bool $debug = null,
- ?LoggerInterface $logger = null
+ ?LoggerInterface $logger = null,
) {
$this->config = $config;
$this->viewPath = rtrim($viewPath, '\\/ ') . DIRECTORY_SEPARATOR;
@@ -200,7 +200,7 @@ public function render(string $view, ?array $options = null, ?bool $saveData = n
$this->logPerformance(
$this->renderVars['start'],
microtime(true),
- $this->renderVars['view']
+ $this->renderVars['view'],
);
return $output;
@@ -213,7 +213,7 @@ public function render(string $view, ?array $options = null, ?bool $saveData = n
$this->renderVars['file'] = $this->loader->locateFile(
$this->renderVars['view'],
'Views',
- ($fileExt === '') ? 'php' : $fileExt
+ ($fileExt === '') ? 'php' : $fileExt,
);
}
@@ -257,7 +257,7 @@ public function render(string $view, ?array $options = null, ?bool $saveData = n
$this->logPerformance(
$this->renderVars['start'],
microtime(true),
- $this->renderVars['view']
+ $this->renderVars['view'],
);
// Check if DebugToolbar is enabled.
@@ -292,7 +292,7 @@ public function render(string $view, ?array $options = null, ?bool $saveData = n
cache()->save(
$this->renderVars['cacheName'],
$output,
- (int) $this->renderVars['options']['cache']
+ (int) $this->renderVars['options']['cache'],
);
}
diff --git a/system/rewrite.php b/system/rewrite.php
index aba4560446fc..4f9b79ade95c 100644
--- a/system/rewrite.php
+++ b/system/rewrite.php
@@ -22,7 +22,7 @@
// @codeCoverageIgnoreStart
$uri = urldecode(
- parse_url('https://codeigniter.com' . $_SERVER['REQUEST_URI'], PHP_URL_PATH) ?? ''
+ parse_url('https://codeigniter.com' . $_SERVER['REQUEST_URI'], PHP_URL_PATH) ?? '',
);
// All request handle by index.php file.
diff --git a/tests/_support/Database/Migrations/20160428212500_Create_test_tables.php b/tests/_support/Database/Migrations/20160428212500_Create_test_tables.php
index 434644bef280..8a7cb5b7d11c 100644
--- a/tests/_support/Database/Migrations/20160428212500_Create_test_tables.php
+++ b/tests/_support/Database/Migrations/20160428212500_Create_test_tables.php
@@ -99,7 +99,7 @@ public function up(): void
unset(
$dataTypeFields['type_set'],
$dataTypeFields['type_mediumtext'],
- $dataTypeFields['type_double']
+ $dataTypeFields['type_double'],
);
}
diff --git a/tests/_support/Database/Seeds/CITestSeeder.php b/tests/_support/Database/Seeds/CITestSeeder.php
index 45b70a7fdd19..9ce0bce4f1c3 100644
--- a/tests/_support/Database/Seeds/CITestSeeder.php
+++ b/tests/_support/Database/Seeds/CITestSeeder.php
@@ -151,7 +151,7 @@ public function run(): void
$data['type_test'][0]['type_real'],
$data['type_test'][0]['type_double'],
$data['type_test'][0]['type_decimal'],
- $data['type_test'][0]['type_blob']
+ $data['type_test'][0]['type_blob'],
);
}
@@ -166,7 +166,7 @@ public function run(): void
$data['type_test'][0]['type_set'],
$data['type_test'][0]['type_mediumtext'],
$data['type_test'][0]['type_double'],
- $data['type_test'][0]['type_blob']
+ $data['type_test'][0]['type_blob'],
);
}
diff --git a/tests/_support/Test/TestForReflectionHelper.php b/tests/_support/Test/TestForReflectionHelper.php
index c056777e30ec..b277509aebdf 100644
--- a/tests/_support/Test/TestForReflectionHelper.php
+++ b/tests/_support/Test/TestForReflectionHelper.php
@@ -28,12 +28,12 @@ public static function getStaticPrivate()
return self::$static_private;
}
- private function privateMethod($param1, $param2)
+ private function privateMethod($param1, $param2) // @phpstan-ignore method.unused
{
return 'private ' . $param1 . $param2;
}
- private static function privateStaticMethod($param1, $param2)
+ private static function privateStaticMethod($param1, $param2) // @phpstan-ignore method.unused
{
return 'private_static ' . $param1 . $param2;
}
diff --git a/tests/system/API/ResponseTraitTest.php b/tests/system/API/ResponseTraitTest.php
index 25cccfbfca2a..9613e23fce8e 100644
--- a/tests/system/API/ResponseTraitTest.php
+++ b/tests/system/API/ResponseTraitTest.php
@@ -92,7 +92,7 @@ private function createRequestAndResponse(string $routePath = '', array $userHea
$config,
new SiteURI($config, $routePath),
null,
- new UserAgent()
+ new UserAgent(),
);
$this->response = new MockResponse($config);
}
@@ -116,14 +116,10 @@ protected function makeController(string $routePath = '', array $userHeaders = [
return new class ($this->request, $this->response, $this->formatter) {
use ResponseTrait;
- protected $request;
- protected $response;
protected $formatter;
- public function __construct($request, $response, $formatter)
+ public function __construct(protected $request, protected $response, $formatter)
{
- $this->request = $request;
- $this->response = $response;
$this->formatter = $formatter;
}
@@ -139,7 +135,7 @@ public function testNoFormatterJSON(): void
$this->formatter = null;
$controller = $this->makeController(
'',
- ['Accept' => 'application/json']
+ ['Accept' => 'application/json'],
);
$this->invoke($controller, 'respondCreated', [['id' => 3], 'A Custom Reason']);
@@ -160,7 +156,7 @@ public function testNoFormatter(): void
$this->formatter = null;
$controller = $this->makeController(
'',
- ['Accept' => 'application/json']
+ ['Accept' => 'application/json'],
);
$this->invoke($controller, 'respondCreated', ['A Custom Reason']);
@@ -177,15 +173,11 @@ public function testNoFormatterWithStringAsHtmlTrue(): void
$controller = new class ($this->request, $this->response, $this->formatter) {
use ResponseTrait;
- protected $request;
- protected $response;
protected $formatter;
protected bool $stringAsHtml = true;
- public function __construct($request, $response, $formatter)
+ public function __construct(protected $request, protected $response, $formatter)
{
- $this->request = $request;
- $this->response = $response;
$this->formatter = $formatter;
}
};
@@ -195,7 +187,7 @@ public function __construct($request, $response, $formatter)
$this->assertSame('A Custom Reason', $this->response->getBody());
$this->assertStringStartsWith(
'text/html',
- $this->response->getHeaderLine('Content-Type')
+ $this->response->getHeaderLine('Content-Type'),
);
}
@@ -287,7 +279,7 @@ public function testRespondSetsCorrectBodyAndStatus(): void
$this->assertSame('"something"', $this->response->getBody());
$this->assertStringStartsWith(
'application/json',
- $this->response->getHeaderLine('Content-Type')
+ $this->response->getHeaderLine('Content-Type'),
);
$this->assertSame('Created', $this->response->getReasonPhrase());
}
@@ -299,15 +291,11 @@ public function testRespondSetsCorrectBodyAndStatusWithStringAsHtmlTrue(): void
$controller = new class ($this->request, $this->response, $this->formatter) {
use ResponseTrait;
- protected $request;
- protected $response;
protected $formatter;
protected bool $stringAsHtml = true;
- public function __construct($request, $response, $formatter)
+ public function __construct(protected $request, protected $response, $formatter)
{
- $this->request = $request;
- $this->response = $response;
$this->formatter = $formatter;
}
};
@@ -472,7 +460,7 @@ public function testValidationErrors(): void
$this->invoke(
$controller,
'failValidationErrors',
- [['foo' => 'Nope', 'bar' => 'No way'], 'FAT CHANCE', 'A Custom Reason']
+ [['foo' => 'Nope', 'bar' => 'No way'], 'FAT CHANCE', 'A Custom Reason'],
);
$expected = [
@@ -583,14 +571,14 @@ private function tryValidContentType(string $mimeType, string $contentType): voi
$this->assertSame(
$mimeType,
$this->request->getHeaderLine('Accept'),
- 'Request header...'
+ 'Request header...',
);
$this->response->setContentType($contentType);
$this->assertSame(
$contentType,
$this->response->getHeaderLine('Content-Type'),
- 'Response header pre-response...'
+ 'Response header pre-response...',
);
$_SERVER = $original;
@@ -639,14 +627,8 @@ public function testFormatByRequestNegotiateIfFormatIsNotJsonOrXML(): void
$controller = new class ($request, $response) {
use ResponseTrait;
- protected $request;
- protected $response;
-
- public function __construct($request, $response)
+ public function __construct(protected $request, protected $response)
{
- $this->request = $request;
- $this->response = $response;
-
$this->format = 'txt';
}
};
@@ -655,7 +637,7 @@ public function __construct($request, $response)
$this->assertStringStartsWith(
config('Format')->supportedResponseFormats[0],
- $response->getHeaderLine('Content-Type')
+ $response->getHeaderLine('Content-Type'),
);
}
@@ -669,7 +651,7 @@ public function testResponseFormat(): void
$this->assertStringStartsWith(
'application/json',
- $this->response->getHeaderLine('Content-Type')
+ $this->response->getHeaderLine('Content-Type'),
);
$this->assertSame($this->formatter->format($data), $this->response->getJSON());
@@ -678,7 +660,7 @@ public function testResponseFormat(): void
$this->assertStringStartsWith(
'application/xml',
- $this->response->getHeaderLine('Content-Type')
+ $this->response->getHeaderLine('Content-Type'),
);
}
diff --git a/tests/system/AutoReview/ComposerJsonTest.php b/tests/system/AutoReview/ComposerJsonTest.php
index 995ef99f4f2b..8d4dfefab596 100644
--- a/tests/system/AutoReview/ComposerJsonTest.php
+++ b/tests/system/AutoReview/ComposerJsonTest.php
@@ -62,7 +62,7 @@ public function testFrameworkRequireDevIsTheSameWithDevRequireDev(): void
$dependency,
$expectedVersion,
$fwRequireDev[$dependency],
- clean_path(dirname(__DIR__, 3) . '/admin/framework/composer.json')
+ clean_path(dirname(__DIR__, 3) . '/admin/framework/composer.json'),
));
}
}
@@ -77,7 +77,7 @@ public function testFrameworkConfigIsTheSameWithDevSuggest(): void
$this->checkConfig(
$this->devComposer['config'],
$this->frameworkComposer['config'],
- 'framework'
+ 'framework',
);
}
@@ -86,7 +86,7 @@ public function testStarterConfigIsTheSameWithDevSuggest(): void
$this->checkConfig(
$this->devComposer['config'],
$this->starterComposer['config'],
- 'starter'
+ 'starter',
);
}
@@ -101,7 +101,7 @@ private function checkSection(string $section, string $component): void
$this->assertSame(
$this->devComposer[$section],
$sectionContent,
- sprintf('The %s\'s "%s" section is not updated with the main composer.json', strtolower($component), $section)
+ sprintf('The %s\'s "%s" section is not updated with the main composer.json', strtolower($component), $section),
);
}
@@ -119,7 +119,7 @@ private function checkConfig(array $fromMain, array $fromComponent, string $comp
$this->assertSame($expectedValue, $actualValue, sprintf(
'%s\'s value for config property "%s" is not same with the main composer.json\'s config.',
ucfirst($component),
- $key
+ $key,
));
}
}
@@ -132,7 +132,7 @@ private function getComposerJson(string $path): array
$this->fail(sprintf(
'The composer.json at "%s" is not readable or does not exist. Error was "%s".',
clean_path($path),
- $e->getMessage()
+ $e->getMessage(),
));
}
}
diff --git a/tests/system/AutoReview/FrameworkCodeTest.php b/tests/system/AutoReview/FrameworkCodeTest.php
index 7473d26e5880..137839b024e5 100644
--- a/tests/system/AutoReview/FrameworkCodeTest.php
+++ b/tests/system/AutoReview/FrameworkCodeTest.php
@@ -66,7 +66,7 @@ public function testEachTestClassHasCorrectGroupAttributeName(string $class): vo
return $groupAttribute->name();
}, $attributes),
- self::$recognizedGroupAttributeNames
+ self::$recognizedGroupAttributeNames,
);
$this->assertEmpty($unrecognizedGroups, sprintf(
"[%s] Unexpected #[Group] attribute%s:\n%s\nExpected group names to be in \"%s\".",
@@ -74,9 +74,9 @@ public function testEachTestClassHasCorrectGroupAttributeName(string $class): vo
count($unrecognizedGroups) > 1 ? 's' : '',
implode("\n", array_map(
static fn (string $group): string => sprintf(' * #[Group(\'%s\')]', $group),
- $unrecognizedGroups
+ $unrecognizedGroups,
)),
- implode(', ', self::$recognizedGroupAttributeNames)
+ implode(', ', self::$recognizedGroupAttributeNames),
));
}
@@ -100,9 +100,9 @@ private static function getTestClasses(): array
$iterator = new RecursiveIteratorIterator(
new RecursiveDirectoryIterator(
$directory,
- FilesystemIterator::SKIP_DOTS
+ FilesystemIterator::SKIP_DOTS,
),
- RecursiveIteratorIterator::CHILD_FIRST
+ RecursiveIteratorIterator::CHILD_FIRST,
);
$testClasses = array_map(
@@ -111,32 +111,32 @@ static function (SplFileInfo $file) use ($directory): string {
$file->getPathname(),
'',
0,
- strlen($directory)
+ strlen($directory),
);
$relativePath = substr_replace(
$relativePath,
'',
- strlen($relativePath) - strlen(DIRECTORY_SEPARATOR . $file->getBasename())
+ strlen($relativePath) - strlen(DIRECTORY_SEPARATOR . $file->getBasename()),
);
return sprintf(
'CodeIgniter\\%s%s%s',
strtr($relativePath, DIRECTORY_SEPARATOR, '\\'),
$relativePath === '' ? '' : '\\',
- $file->getBasename('.' . $file->getExtension())
+ $file->getBasename('.' . $file->getExtension()),
);
},
array_filter(
iterator_to_array($iterator, false),
static fn (SplFileInfo $file): bool => $file->isFile()
&& ! str_contains($file->getPathname(), DIRECTORY_SEPARATOR . 'fixtures' . DIRECTORY_SEPARATOR)
- && ! str_contains($file->getPathname(), DIRECTORY_SEPARATOR . 'Views' . DIRECTORY_SEPARATOR)
- )
+ && ! str_contains($file->getPathname(), DIRECTORY_SEPARATOR . 'Views' . DIRECTORY_SEPARATOR),
+ ),
);
$testClasses = array_filter(
$testClasses,
- static fn (string $class): bool => is_subclass_of($class, TestCase::class)
+ static fn (string $class): bool => is_subclass_of($class, TestCase::class),
);
sort($testClasses);
diff --git a/tests/system/Autoloader/AutoloaderTest.php b/tests/system/Autoloader/AutoloaderTest.php
index 19d482890b75..0715dd98b5f8 100644
--- a/tests/system/Autoloader/AutoloaderTest.php
+++ b/tests/system/Autoloader/AutoloaderTest.php
@@ -202,7 +202,7 @@ public function testAddNamespaceStringToArray(): void
$this->assertSame(
__FILE__,
- ($this->classLoader)('App\Controllers\AutoloaderTest')
+ ($this->classLoader)('App\Controllers\AutoloaderTest'),
);
}
@@ -235,7 +235,7 @@ public function testSanitizationContailsSpecialChars(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'The file path contains special characters "${}!#" that are not allowed: "${../path}!#/to/some/file.php_"'
+ 'The file path contains special characters "${}!#" that are not allowed: "${../path}!#/to/some/file.php_"',
);
$test = '${../path}!#/to/some/file.php_';
@@ -247,7 +247,7 @@ public function testSanitizationFilenameEdges(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'The characters ".-_" are not allowed in filename edges: "/path/to/some/file.php_"'
+ 'The characters ".-_" are not allowed in filename edges: "/path/to/some/file.php_"',
);
$test = '/path/to/some/file.php_';
diff --git a/tests/system/Autoloader/FileLocatorTest.php b/tests/system/Autoloader/FileLocatorTest.php
index 90580864fc47..fc7925724add 100644
--- a/tests/system/Autoloader/FileLocatorTest.php
+++ b/tests/system/Autoloader/FileLocatorTest.php
@@ -218,7 +218,7 @@ public function testSearchPrioritizeSystemOverApp(): void
SYSTEMPATH . 'Language/en/Validation.php',
APPPATH . 'Language/en/Validation.php',
],
- $foundFiles
+ $foundFiles,
);
}
@@ -243,7 +243,7 @@ public function testListFilesDoesNotContainDirectories(): void
$directory = str_replace(
'/',
DIRECTORY_SEPARATOR,
- APPPATH . 'Config/Boot'
+ APPPATH . 'Config/Boot',
);
$this->assertNotContains($directory, $files);
}
@@ -308,7 +308,7 @@ public function testGetClassNameFromClassFile(): void
{
$this->assertSame(
self::class,
- $this->locator->getClassname(__FILE__)
+ $this->locator->getClassname(__FILE__),
);
}
@@ -316,7 +316,7 @@ public function testGetClassNameFromNonClassFile(): void
{
$this->assertSame(
'',
- $this->locator->getClassname(SYSTEMPATH . 'bootstrap.php')
+ $this->locator->getClassname(SYSTEMPATH . 'bootstrap.php'),
);
}
@@ -324,7 +324,7 @@ public function testGetClassNameFromDirectory(): void
{
$this->assertSame(
'',
- $this->locator->getClassname(SYSTEMPATH)
+ $this->locator->getClassname(SYSTEMPATH),
);
}
}
diff --git a/tests/system/CLI/CLITest.php b/tests/system/CLI/CLITest.php
index 413fd71c85f4..7ee9279afe22 100644
--- a/tests/system/CLI/CLITest.php
+++ b/tests/system/CLI/CLITest.php
@@ -283,7 +283,7 @@ public function testColor(): void
$this->assertSame(
"\033[1;37m\033[42m\033[4mtest\033[0m",
- CLI::color('test', 'white', 'green', 'underline')
+ CLI::color('test', 'white', 'green', 'underline'),
);
}
@@ -291,7 +291,7 @@ public function testColorEmtpyString(): void
{
$this->assertSame(
'',
- CLI::color('', 'white', 'green', 'underline')
+ CLI::color('', 'white', 'green', 'underline'),
);
}
@@ -358,7 +358,7 @@ public function testWriteForegroundWithColorTwice(): void
{
CLI::write(
CLI::color('green', 'green') . ' red ' . CLI::color('green', 'green'),
- 'red'
+ 'red',
);
$expected = "\033[0;32mgreen\033[0m\033[0;31m red \033[0m\033[0;32mgreen\033[0m" . PHP_EOL;
@@ -440,15 +440,15 @@ public function testWrap(): void
$this->assertSame('', CLI::wrap(''));
$this->assertSame(
'1234' . PHP_EOL . ' 5678' . PHP_EOL . ' 90' . PHP_EOL . ' abc' . PHP_EOL . ' de' . PHP_EOL . ' fghij' . PHP_EOL . ' 0987654321',
- CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321', 5, 1)
+ CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321', 5, 1),
);
$this->assertSame(
'1234 5678 90' . PHP_EOL . ' abc de fghij' . PHP_EOL . ' 0987654321',
- CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321', 999, 2)
+ CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321', 999, 2),
);
$this->assertSame(
'1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321',
- CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321')
+ CLI::wrap('1234 5678 90' . PHP_EOL . 'abc de fghij' . PHP_EOL . '0987654321'),
);
}
diff --git a/tests/system/CLI/ConsoleTest.php b/tests/system/CLI/ConsoleTest.php
index c6773a07894f..5962f3a9b21e 100644
--- a/tests/system/CLI/ConsoleTest.php
+++ b/tests/system/CLI/ConsoleTest.php
@@ -54,8 +54,8 @@ public function testHeader(): void
0,
strpos(
$this->getStreamFilterBuffer(),
- sprintf('CodeIgniter v%s Command Line Tool', CodeIgniter::CI_VERSION)
- )
+ sprintf('CodeIgniter v%s Command Line Tool', CodeIgniter::CI_VERSION),
+ ),
);
}
@@ -143,7 +143,7 @@ public function testHelpCommandUsingHelpOption(): void
$this->assertStringContainsString('env []', $this->getStreamFilterBuffer());
$this->assertStringContainsString(
'Retrieves the current environment, or set a new one.',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
}
diff --git a/tests/system/Cache/ResponseCacheTest.php b/tests/system/Cache/ResponseCacheTest.php
index b0b73855231a..734221114185 100644
--- a/tests/system/Cache/ResponseCacheTest.php
+++ b/tests/system/Cache/ResponseCacheTest.php
@@ -46,7 +46,7 @@ protected function setUp(): void
private function createIncomingRequest(
string $uri = '',
array $query = [],
- ?AppConfig $appConfig = null
+ ?AppConfig $appConfig = null,
): IncomingRequest {
$_POST = $_GET = $_SERVER = $_REQUEST = $_ENV = $_COOKIE = $_SESSION = [];
@@ -65,7 +65,7 @@ private function createIncomingRequest(
$appConfig,
$siteUri,
null,
- new UserAgent()
+ new UserAgent(),
);
}
diff --git a/tests/system/CodeIgniterTest.php b/tests/system/CodeIgniterTest.php
index afddc7dbb30e..2dec61da4be3 100644
--- a/tests/system/CodeIgniterTest.php
+++ b/tests/system/CodeIgniterTest.php
@@ -214,7 +214,7 @@ public function testControllersCanReturnString(): void
$routes = service('routes');
$routes->add(
'pages/(:segment)',
- static fn ($segment): string => 'You want to see "' . esc($segment) . '" page.'
+ static fn ($segment): string => 'You want to see "' . esc($segment) . '" page.',
);
$router = service('router', $routes, service('incomingrequest'));
Services::injectMock('router', $router);
@@ -293,7 +293,7 @@ public function testRunExecuteFilterByClassName(): void
$routes->add(
'pages/about',
static fn () => service('incomingrequest')->getBody(),
- ['filter' => Customfilter::class]
+ ['filter' => Customfilter::class],
);
$router = service('router', $routes, service('incomingrequest'));
@@ -324,7 +324,7 @@ public function testRegisterSameFilterTwiceWithDifferentArgument(): void
'pages/about',
static fn () => service('incomingrequest')->getBody(),
// Set filter with no argument.
- ['filter' => 'test-customfilter']
+ ['filter' => 'test-customfilter'],
);
$router = service('router', $routes, service('incomingrequest'));
@@ -358,7 +358,7 @@ public function testDisableControllerFilters(): void
$routes->add(
'pages/about',
static fn () => service('incomingrequest')->getBody(),
- ['filter' => Customfilter::class]
+ ['filter' => Customfilter::class],
);
$router = service('router', $routes, service('incomingrequest'));
Services::injectMock('router', $router);
@@ -843,7 +843,7 @@ public function testPageCacheSendSecureHeaders(): void
public function testPageCacheWithCacheQueryString(
$cacheQueryStringValue,
int $expectedPagesInCache,
- array $testingUrls
+ array $testingUrls,
): void {
// Suppress command() output
CITestStreamFilter::registration();
diff --git a/tests/system/Commands/Database/MigrateStatusTest.php b/tests/system/Commands/Database/MigrateStatusTest.php
index 5e54b380fdee..b08557790de0 100644
--- a/tests/system/Commands/Database/MigrateStatusTest.php
+++ b/tests/system/Commands/Database/MigrateStatusTest.php
@@ -51,7 +51,7 @@ protected function setUp(): void
$contents = str_replace(
'namespace Tests\Support\MigrationTestMigrations\Database\Migrations;',
'namespace App\Database\Migrations;',
- $contents
+ $contents,
);
file_put_contents($this->migrationFileTo, $contents);
diff --git a/tests/system/Commands/EnvironmentCommandTest.php b/tests/system/Commands/EnvironmentCommandTest.php
index 177becf34f9f..8bab8db12cc0 100644
--- a/tests/system/Commands/EnvironmentCommandTest.php
+++ b/tests/system/Commands/EnvironmentCommandTest.php
@@ -64,7 +64,7 @@ public function testProvidingTestingAsEnvGivesErrorMessage(): void
command('env testing');
$this->assertStringContainsString(
'The "testing" environment is reserved for PHPUnit testing.',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
}
@@ -83,7 +83,7 @@ public function testDefaultShippedEnvIsMissing(): void
$this->assertStringContainsString('Both default shipped', $this->getStreamFilterBuffer());
$this->assertStringContainsString(
'It is impossible to write the new environment type.',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
}
diff --git a/tests/system/Commands/FilterCheckTest.php b/tests/system/Commands/FilterCheckTest.php
index 0c26dd9bf349..9062f99bd88c 100644
--- a/tests/system/Commands/FilterCheckTest.php
+++ b/tests/system/Commands/FilterCheckTest.php
@@ -48,7 +48,7 @@ public function testFilterCheckDefinedRoute(): void
$this->assertStringContainsString(
'| GET | / | forcehttps pagecache | pagecache performance toolbar |',
- preg_replace('/\033\[.+?m/u', '', $this->getBuffer())
+ preg_replace('/\033\[.+?m/u', '', $this->getBuffer()),
);
}
@@ -61,8 +61,8 @@ public function testFilterCheckInvalidRoute(): void
str_replace(
["\033[0m", "\033[1;31m", "\033[0;30m", "\033[47m"],
'',
- $this->getBuffer()
- )
+ $this->getBuffer(),
+ ),
);
}
}
diff --git a/tests/system/Commands/GenerateKeyTest.php b/tests/system/Commands/GenerateKeyTest.php
index 40df8d1477c3..01e2b2c750df 100644
--- a/tests/system/Commands/GenerateKeyTest.php
+++ b/tests/system/Commands/GenerateKeyTest.php
@@ -137,7 +137,7 @@ public function testKeyGenerateWhenNewHexKeyIsSubsequentlyCommentedOut(): void
'encryption.key = ' . $key,
'# encryption.key = ' . $key,
file_get_contents($this->envPath),
- $count
+ $count,
));
$this->assertSame(1, $count, 'Failed commenting out the previously set application key.');
@@ -155,7 +155,7 @@ public function testKeyGenerateWhenNewBase64KeyIsSubsequentlyCommentedOut(): voi
'encryption.key = ' . $key,
'# encryption.key = ' . $key,
file_get_contents($this->envPath),
- $count
+ $count,
));
$this->assertSame(1, $count, 'Failed commenting out the previously set application key.');
diff --git a/tests/system/Commands/MigrationIntegrationTest.php b/tests/system/Commands/MigrationIntegrationTest.php
index 14b66ccb920a..12869f9092c6 100644
--- a/tests/system/Commands/MigrationIntegrationTest.php
+++ b/tests/system/Commands/MigrationIntegrationTest.php
@@ -61,7 +61,7 @@ public function testMigrationWithRollbackHasSameNameFormat(): void
command('migrate -n App');
$this->assertStringContainsString(
'(App) 20160428212500_App\Database\Migrations\Migration_Create_test_tables',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
$this->resetStreamFilterBuffer();
@@ -69,7 +69,7 @@ public function testMigrationWithRollbackHasSameNameFormat(): void
command('migrate:rollback -n App');
$this->assertStringContainsString(
'(App) 20160428212500_App\Database\Migrations\Migration_Create_test_tables',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
}
}
diff --git a/tests/system/Commands/RoutesTest.php b/tests/system/Commands/RoutesTest.php
index 7859156ccf93..a94ddbe2081c 100644
--- a/tests/system/Commands/RoutesTest.php
+++ b/tests/system/Commands/RoutesTest.php
@@ -85,7 +85,7 @@ public function testRoutesCommand(): void
EOL;
$this->assertStringContainsString(
$expected,
- preg_replace('/\033\[.+?m/u', '', $this->getBuffer())
+ preg_replace('/\033\[.+?m/u', '', $this->getBuffer()),
);
}
diff --git a/tests/system/Commands/Utilities/ConfigCheckTest.php b/tests/system/Commands/Utilities/ConfigCheckTest.php
index c69cfa948635..e49a8170ec08 100644
--- a/tests/system/Commands/Utilities/ConfigCheckTest.php
+++ b/tests/system/Commands/Utilities/ConfigCheckTest.php
@@ -73,7 +73,7 @@ public function testCommandConfigCheckWithNoArgumentPassed(): void
config:check 'CodeIgniter\Shield\Config\Auth'
EOF,
- str_replace("\n\n", "\n", $this->getStreamFilterBuffer())
+ str_replace("\n\n", "\n", $this->getStreamFilterBuffer()),
);
}
@@ -83,7 +83,7 @@ public function testCommandConfigCheckNonexistentClass(): void
$this->assertSame(
"No such Config class: Nonexistent\n",
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
}
@@ -92,14 +92,14 @@ public function testConfigCheckWithKintEnabledUsesKintD(): void
/** @var Closure(object): string $command */
$command = $this->getPrivateMethodInvoker(
new ConfigCheck(service('logger'), service('commands')),
- 'getKintD'
+ 'getKintD',
);
command('config:check App');
$this->assertSame(
$command(config('App')) . "\n",
- preg_replace('/\s+Config Caching: \S+/', '', $this->getStreamFilterBuffer())
+ preg_replace('/\s+Config Caching: \S+/', '', $this->getStreamFilterBuffer()),
);
}
@@ -108,12 +108,12 @@ public function testConfigCheckWithKintDisabledUsesVarDump(): void
/** @var Closure(object): string $command */
$command = $this->getPrivateMethodInvoker(
new ConfigCheck(service('logger'), service('commands')),
- 'getVarDump'
+ 'getVarDump',
);
$clean = static fn (string $input): string => trim(preg_replace(
'/(\033\[[0-9;]+m)|(\035\[[0-9;]+m)/u',
'',
- $input
+ $input,
));
try {
@@ -122,7 +122,7 @@ public function testConfigCheckWithKintDisabledUsesVarDump(): void
$this->assertSame(
$clean($command(config('App'))),
- $clean(preg_replace('/\s+Config Caching: \S+/', '', $this->getStreamFilterBuffer()))
+ $clean(preg_replace('/\s+Config Caching: \S+/', '', $this->getStreamFilterBuffer())),
);
} finally {
Kint::$enabled_mode = true;
diff --git a/tests/system/Commands/Utilities/NamespacesTest.php b/tests/system/Commands/Utilities/NamespacesTest.php
index ffdfa0ddcf8d..d2395fda891c 100644
--- a/tests/system/Commands/Utilities/NamespacesTest.php
+++ b/tests/system/Commands/Utilities/NamespacesTest.php
@@ -73,15 +73,15 @@ public function testNamespacesCommandAllNamespaces(): void
$this->assertStringContainsString(
'|CodeIgniter|ROOTPATH/system|Yes|',
- str_replace(' ', '', $this->getBuffer())
+ str_replace(' ', '', $this->getBuffer()),
);
$this->assertStringContainsString(
'|App|ROOTPATH/app|Yes|',
- str_replace(' ', '', $this->getBuffer())
+ str_replace(' ', '', $this->getBuffer()),
);
$this->assertStringContainsString(
'|Config|APPPATH/Config|Yes|',
- str_replace(' ', '', $this->getBuffer())
+ str_replace(' ', '', $this->getBuffer()),
);
}
}
diff --git a/tests/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReaderTest.php b/tests/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReaderTest.php
index 936b2b8fe184..33df69e6531e 100644
--- a/tests/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReaderTest.php
+++ b/tests/system/Commands/Utilities/Routes/AutoRouterImproved/ControllerMethodReaderTest.php
@@ -30,7 +30,7 @@
final class ControllerMethodReaderTest extends CIUnitTestCase
{
private function createControllerMethodReader(
- string $namespace = 'Tests\Support\Controllers'
+ string $namespace = 'Tests\Support\Controllers',
): ControllerMethodReader {
$methods = [
'get',
@@ -79,7 +79,7 @@ public function testReadTranslateURIDashes(): void
Factories::injectMock('config', Routing::class, $config);
$reader = $this->createControllerMethodReader(
- 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers'
+ 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers',
);
$routes = $reader->read(Dash_controller::class);
@@ -116,7 +116,7 @@ public function testReadTranslateUriToCamelCase(): void
Factories::injectMock('config', Routing::class, $config);
$reader = $this->createControllerMethodReader(
- 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers'
+ 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers',
);
$routes = $reader->read(BlogController::class);
@@ -147,7 +147,7 @@ public function testReadTranslateUriToCamelCase(): void
public function testReadDefaultController(): void
{
$reader = $this->createControllerMethodReader(
- 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers'
+ 'CodeIgniter\Commands\Utilities\Routes\AutoRouterImproved\Controllers',
);
$routes = $reader->read(Home::class);
diff --git a/tests/system/Commands/Utilities/Routes/FilterFinderTest.php b/tests/system/Commands/Utilities/Routes/FilterFinderTest.php
index 7bba11d9c968..d300c78993d1 100644
--- a/tests/system/Commands/Utilities/Routes/FilterFinderTest.php
+++ b/tests/system/Commands/Utilities/Routes/FilterFinderTest.php
@@ -21,6 +21,7 @@
use CodeIgniter\HTTP\IncomingRequest;
use CodeIgniter\HTTP\Response;
use CodeIgniter\Router\RouteCollection;
+use CodeIgniter\Router\RouteCollectionInterface;
use CodeIgniter\Router\Router;
use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\ConfigFromArrayTrait;
@@ -53,7 +54,7 @@ protected function setUp(): void
$this->moduleConfig->enabled = false;
}
- private function createRouteCollection(array $routes = []): RouteCollection
+ private function createRouteCollection(array $routes = []): RouteCollectionInterface
{
$collection = new RouteCollection(service('locator'), $this->moduleConfig, new Routing());
@@ -66,7 +67,7 @@ private function createRouteCollection(array $routes = []): RouteCollection
return $collection->map($routes);
}
- private function createRouter(RouteCollection $collection): Router
+ private function createRouter(RouteCollectionInterface $collection): Router
{
return new Router($collection, $this->request);
}
@@ -101,6 +102,9 @@ private function createFilters(array $config = []): Filters
public function testFindGlobalsFilters(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection();
$router = $this->createRouter($collection);
$filters = $this->createFilters();
@@ -118,6 +122,9 @@ public function testFindGlobalsFilters(): void
public function testFindGlobalsFiltersWithRedirectRoute(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection();
$collection->addRedirect('users/about', 'profile');
@@ -137,6 +144,9 @@ public function testFindGlobalsFiltersWithRedirectRoute(): void
public function testFindGlobalsAndRouteFilters(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection();
$collection->get('admin', ' AdminController::index', ['filter' => 'honeypot']);
$router = $this->createRouter($collection);
@@ -155,6 +165,9 @@ public function testFindGlobalsAndRouteFilters(): void
public function testFindGlobalsAndRouteClassnameFilters(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection();
$collection->get('admin', ' AdminController::index', ['filter' => InvalidChars::class]);
$router = $this->createRouter($collection);
@@ -173,6 +186,9 @@ public function testFindGlobalsAndRouteClassnameFilters(): void
public function testFindGlobalsAndRouteMultipleFilters(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection();
$collection->get('admin', ' AdminController::index', ['filter' => ['honeypot', InvalidChars::class]]);
$router = $this->createRouter($collection);
@@ -191,6 +207,9 @@ public function testFindGlobalsAndRouteMultipleFilters(): void
public function testFilterOrder(): void
{
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection([]);
$collection->get('/', ' Home::index', ['filter' => ['route1', 'route2']]);
$router = $this->createRouter($collection);
@@ -256,6 +275,9 @@ public function testFilterOrderWithOldFilterOrder(): void
$feature = config(Feature::class);
$feature->oldFilterOrder = true;
+ /**
+ * @var RouteCollection $collection
+ */
$collection = $this->createRouteCollection([]);
$collection->get('/', ' Home::index', ['filter' => ['route1', 'route2']]);
$router = $this->createRouter($collection);
diff --git a/tests/system/Commands/Utilities/Routes/SampleURIGeneratorTest.php b/tests/system/Commands/Utilities/Routes/SampleURIGeneratorTest.php
index 6b5c10e45ea0..1d67afae1ce4 100644
--- a/tests/system/Commands/Utilities/Routes/SampleURIGeneratorTest.php
+++ b/tests/system/Commands/Utilities/Routes/SampleURIGeneratorTest.php
@@ -51,7 +51,7 @@ public function testGetFromPlaceholderCustomPlaceholder(): void
$routes = service('routes');
$routes->addPlaceholder(
'uuid',
- '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}'
+ '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}',
);
$generator = new SampleURIGenerator();
diff --git a/tests/system/CommonFunctionsTest.php b/tests/system/CommonFunctionsTest.php
index d708b193f56b..ab13ac06ddb0 100644
--- a/tests/system/CommonFunctionsTest.php
+++ b/tests/system/CommonFunctionsTest.php
@@ -338,7 +338,7 @@ public function testRouteToInCliWithLocaleInRoute(): void
$this->assertSame(
'/en/path/string/to/13',
- route_to('path-to', 'string', 13, 'en')
+ route_to('path-to', 'string', 13, 'en'),
);
}
@@ -352,7 +352,7 @@ public function testRouteToWithUnsupportedLocale(): void
$this->assertSame(
'/en/path/string/to/13',
- route_to('path-to', 'string', 13, 'invalid')
+ route_to('path-to', 'string', 13, 'invalid'),
);
}
@@ -400,7 +400,7 @@ public function testCSRFMeta(): void
public function testModelNotExists(): void
{
- $this->assertNull(model(UnexsistenceClass::class));
+ $this->assertNull(model(UnexsistenceClass::class)); // @phpstan-ignore class.notFound
}
public function testModelExistsBasename(): void
@@ -642,7 +642,7 @@ public function testForceHttpsNullRequestAndResponse(): void
$this->assertInstanceOf(RedirectException::class, $e);
$this->assertSame(
'https://example.com/index.php/',
- $e->getResponse()->header('Location')->getValue()
+ $e->getResponse()->header('Location')->getValue(),
);
$this->assertFalse($e->getResponse()->hasCookie('force'));
$this->assertSame('header', $e->getResponse()->getHeaderLine('Force'));
@@ -668,7 +668,7 @@ public function testForceHttpsWithBaseUrlSubFolder(): void
$this->assertInstanceOf(RedirectException::class, $e);
$this->assertSame(
'https://example.jp/codeIgniter/index.php/en/home?foo=bar',
- $e->getResponse()->header('Location')->getValue()
+ $e->getResponse()->header('Location')->getValue(),
);
}
}
diff --git a/tests/system/CommonHelperTest.php b/tests/system/CommonHelperTest.php
index 8a41f7972a9e..83546e973be7 100644
--- a/tests/system/CommonHelperTest.php
+++ b/tests/system/CommonHelperTest.php
@@ -129,7 +129,7 @@ public function testHelperLoadsAppHelperFirst(): void
foreach ($this->dummyHelpers as $helper) {
$this->assertFileDoesNotExist($helper, sprintf(
'The dummy helper file "%s" should not be existing before it is tested.',
- $helper
+ $helper,
));
}
@@ -142,13 +142,13 @@ public function testHelperLoadsAppHelperFirst(): void
// this chunk is not needed really; just added so that IDEs will be happy
if (! function_exists('foo_bar_baz')) {
- function foo_bar_baz(): string
+ function foo_bar_baz(): string // @phpstan-ignore function.inner
{
return __FILE__;
}
}
- $this->assertSame($this->dummyHelpers[0], foo_bar_baz());
+ $this->assertSame($this->dummyHelpers[0], foo_bar_baz()); // @phpstan-ignore function.notFound
}
public function testNamespacedHelperNotFound(): void
diff --git a/tests/system/Config/FactoriesTest.php b/tests/system/Config/FactoriesTest.php
index 11a5e77a433e..4a73c7805b93 100644
--- a/tests/system/Config/FactoriesTest.php
+++ b/tests/system/Config/FactoriesTest.php
@@ -338,18 +338,18 @@ public function testDefineSameAliasTwiceWithDifferentClasses(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'Already defined in Factories: models CodeIgniter\Shield\Models\UserModel -> Tests\Support\Models\UserModel'
+ 'Already defined in Factories: models CodeIgniter\Shield\Models\UserModel -> Tests\Support\Models\UserModel',
);
Factories::define(
'models',
'CodeIgniter\Shield\Models\UserModel',
- UserModel::class
+ UserModel::class,
);
Factories::define(
'models',
'CodeIgniter\Shield\Models\UserModel',
- EntityModel::class
+ EntityModel::class,
);
}
@@ -358,12 +358,12 @@ public function testDefineSameAliasAndSameClassTwice(): void
Factories::define(
'models',
'CodeIgniter\Shield\Models\UserModel',
- UserModel::class
+ UserModel::class,
);
Factories::define(
'models',
'CodeIgniter\Shield\Models\UserModel',
- UserModel::class
+ UserModel::class,
);
$model = model('CodeIgniter\Shield\Models\UserModel');
@@ -379,7 +379,7 @@ public function testDefineNonExistentClass(): void
Factories::define(
'models',
'CodeIgniter\Shield\Models\UserModel',
- 'App\Models\UserModel'
+ 'App\Models\UserModel',
);
}
@@ -387,7 +387,7 @@ public function testDefineAfterLoading(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'Already defined in Factories: models Tests\Support\Models\UserModel -> Tests\Support\Models\UserModel'
+ 'Already defined in Factories: models Tests\Support\Models\UserModel -> Tests\Support\Models\UserModel',
);
model(UserModel::class);
@@ -395,7 +395,7 @@ public function testDefineAfterLoading(): void
Factories::define(
'models',
UserModel::class,
- 'App\Models\UserModel'
+ 'App\Models\UserModel',
);
}
@@ -404,7 +404,7 @@ public function testDefineAndLoad(): void
Factories::define(
'models',
UserModel::class,
- EntityModel::class
+ EntityModel::class,
);
$model = model(UserModel::class);
@@ -417,7 +417,7 @@ public function testDefineAndGet(): void
Factories::define(
'models',
UserModel::class,
- EntityModel::class
+ EntityModel::class,
);
$model = Factories::get('models', UserModel::class);
diff --git a/tests/system/ControllerTest.php b/tests/system/ControllerTest.php
index 55664c42c779..733705725258 100644
--- a/tests/system/ControllerTest.php
+++ b/tests/system/ControllerTest.php
@@ -195,7 +195,7 @@ public function testValidateData(): void
$this->assertFalse($method($data, $rule));
$this->assertSame(
'The password field must be at least 10 characters in length.',
- service('validation')->getError('password')
+ service('validation')->getError('password'),
);
}
@@ -224,11 +224,11 @@ public function testValidateDataWithCustomErrorMessage(): void
$this->assertFalse($method($data, $rules, $errors));
$this->assertSame(
'"username" must be 3 letters or longer.',
- service('validation')->getError('username')
+ service('validation')->getError('username'),
);
$this->assertSame(
'The password field must be at least 10 characters in length.',
- service('validation')->getError('password')
+ service('validation')->getError('password'),
);
}
@@ -262,11 +262,11 @@ public function testValidateDataWithCustomErrorMessageLabeledStyle(): void
$this->assertFalse($method($data, $rules));
$this->assertSame(
'"Username" must be 3 letters or longer.',
- service('validation')->getError('username')
+ service('validation')->getError('username'),
);
$this->assertSame(
'The Password field must be at least 10 characters in length.',
- service('validation')->getError('password')
+ service('validation')->getError('password'),
);
}
diff --git a/tests/system/Cookie/CookieTest.php b/tests/system/Cookie/CookieTest.php
index 51016ca0061e..e3907e8cefe7 100644
--- a/tests/system/Cookie/CookieTest.php
+++ b/tests/system/Cookie/CookieTest.php
@@ -93,7 +93,7 @@ public function testConfigPrefix(string $configPrefix, string $optionPrefix, str
'value',
[
'prefix' => $optionPrefix,
- ]
+ ],
);
$this->assertSame($expected, $cookie->getPrefixedName());
@@ -271,19 +271,19 @@ public function testStringCastingOfCookies(): void
$this->assertSame(
'cookie=lover; Path=/; HttpOnly; SameSite=Lax',
- $a->toHeaderString()
+ $a->toHeaderString(),
);
$this->assertSame(
"cookie=monster; Expires=Sun, 14-Feb-2021 00:00:00 GMT; Max-Age={$max}; Path=/web; Domain=localhost; HttpOnly; SameSite=Lax",
- (string) $b
+ (string) $b,
);
$this->assertSame(
'cookie=lover; Path=/; Secure; SameSite=Strict',
- (string) $c
+ (string) $c,
);
$this->assertSame(
'cookie=deleted; Expires=Thu, 01-Jan-1970 00:00:00 GMT; Max-Age=0; Path=/; HttpOnly; SameSite=Lax',
- (string) $d
+ (string) $d,
);
Cookie::setDefaults($old);
@@ -303,7 +303,7 @@ public function testArrayAccessOfCookie(): void
$this->assertSame($cookie['path'], $cookie->getPath());
$this->expectException('InvalidArgumentException');
- $cookie['expiry'];
+ $cookie['expiry']; // @phpstan-ignore expr.resultUnused
}
public function testCannotSetPropertyViaArrayAccess(): void
diff --git a/tests/system/DataConverter/DataConverterTest.php b/tests/system/DataConverter/DataConverterTest.php
index c57e8593af86..3bdfa2f51ea8 100644
--- a/tests/system/DataConverter/DataConverterTest.php
+++ b/tests/system/DataConverter/DataConverterTest.php
@@ -471,7 +471,7 @@ public function testInvalidValue(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- '[CodeIgniter\DataCaster\Cast\JsonCast] Invalid value type: bool, and its value: true'
+ '[CodeIgniter\DataCaster\Cast\JsonCast] Invalid value type: bool, and its value: true',
);
$types = [
@@ -491,7 +491,7 @@ public function testInvalidCastHandler(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'Invalid class type. It must implement CastInterface. class: CodeIgniter\DataConverter\DataConverter'
+ 'Invalid class type. It must implement CastInterface. class: CodeIgniter\DataConverter\DataConverter',
);
$types = [
@@ -530,7 +530,7 @@ private function createDataConverter(
array $handlers = [],
?object $helper = null,
Closure|string|null $reconstructor = 'reconstruct',
- Closure|string|null $extractor = null
+ Closure|string|null $extractor = null,
): DataConverter {
return new DataConverter($types, $handlers, $helper, $reconstructor, $extractor);
}
diff --git a/tests/system/Database/BaseConnectionTest.php b/tests/system/Database/BaseConnectionTest.php
index b36ec7ea022a..ba55129cc723 100644
--- a/tests/system/Database/BaseConnectionTest.php
+++ b/tests/system/Database/BaseConnectionTest.php
@@ -188,7 +188,7 @@ public function testProtectIdentifiers(
bool $protectIdentifiers,
bool $fieldExists,
string $item,
- string $expected
+ string $expected,
): void {
$db = new MockConnection($this->options);
diff --git a/tests/system/Database/BaseQueryTest.php b/tests/system/Database/BaseQueryTest.php
index a87bc64e727a..3c48e2526652 100644
--- a/tests/system/Database/BaseQueryTest.php
+++ b/tests/system/Database/BaseQueryTest.php
@@ -251,7 +251,7 @@ public function testBindingWithTwoColons(): void
$query->setQuery(
"SELECT mytable.id, DATE_FORMAT(mytable.created_at,'%d/%m/%Y %H:%i:%s') AS created_at_uk FROM mytable WHERE mytable.id = ?",
- [1]
+ [1],
);
$expected = "SELECT mytable.id, DATE_FORMAT(mytable.created_at,'%d/%m/%Y %H:%i:%s') AS created_at_uk FROM mytable WHERE mytable.id = 1";
@@ -326,7 +326,7 @@ public function testNamedBindsDontGetReplacedAgain(): void
$query->setQuery(
'SELECT * FROM posts WHERE content = :content: OR foobar = :foobar:',
- ['content' => 'a placeholder looks like :foobar:', 'foobar' => 'bazqux']
+ ['content' => 'a placeholder looks like :foobar:', 'foobar' => 'bazqux'],
);
$expected = "SELECT * FROM posts WHERE content = 'a placeholder looks like :foobar:' OR foobar = 'bazqux'";
@@ -381,7 +381,7 @@ public function testSetQueryBindsWithSetEscapeNegativeIntegers(): void
$query->setQuery(
'SELECT * FROM product WHERE date_pickup < DateAdd(month, ?, Convert(date, GetDate())',
[-6],
- true
+ true,
);
$expected = 'SELECT * FROM product WHERE date_pickup < DateAdd(month, -6, Convert(date, GetDate())';
@@ -395,7 +395,7 @@ public function testSetQueryNamedBindsWithNegativeIntegers(): void
$query->setQuery(
'SELECT * FROM product WHERE date_pickup < DateAdd(month, :num:, Convert(date, GetDate())',
- ['num' => -6]
+ ['num' => -6],
);
$expected = 'SELECT * FROM product WHERE date_pickup < DateAdd(month, -6, Convert(date, GetDate())';
diff --git a/tests/system/Database/Builder/InsertTest.php b/tests/system/Database/Builder/InsertTest.php
index e021472b72fc..a0a233440a2d 100644
--- a/tests/system/Database/Builder/InsertTest.php
+++ b/tests/system/Database/Builder/InsertTest.php
@@ -287,7 +287,7 @@ public function testSetIncorrectRawSqlUsage(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'RawSql "expires = DATE_ADD(NOW(), INTERVAL 2 HOUR)" cannot be used here.'
+ 'RawSql "expires = DATE_ADD(NOW(), INTERVAL 2 HOUR)" cannot be used here.',
);
$builder = $this->db->table('auth_bearer');
diff --git a/tests/system/Database/Builder/JoinTest.php b/tests/system/Database/Builder/JoinTest.php
index 377df4816e57..04145671e7df 100644
--- a/tests/system/Database/Builder/JoinTest.php
+++ b/tests/system/Database/Builder/JoinTest.php
@@ -90,7 +90,7 @@ public function testJoinMultipleConditionsBetween(): void
$builder->join(
'leases',
'units.unit_id = leases.unit_id AND CURDATE() BETWEEN lease_start_date AND lease_exp_date',
- 'LEFT'
+ 'LEFT',
);
// @TODO Should be `... CURDATE() BETWEEN "lease_start_date" AND "lease_exp_date"`
diff --git a/tests/system/Database/Builder/SelectTest.php b/tests/system/Database/Builder/SelectTest.php
index 411e26a695bf..57aa7eaf37ff 100644
--- a/tests/system/Database/Builder/SelectTest.php
+++ b/tests/system/Database/Builder/SelectTest.php
@@ -19,6 +19,7 @@
use CodeIgniter\Database\SQLSRV\Builder as SQLSRVBuilder;
use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\Mock\MockConnection;
+use Generator;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;
@@ -82,7 +83,7 @@ public function testSelectAcceptsArrayWithRawSql(array $select, string $expected
}
/**
- * @return list|string>
+ * @return Generator|string>
*/
public static function provideSelectAcceptsArrayWithRawSql(): iterable
{
@@ -219,7 +220,7 @@ public function testSelectRegularExpressionWorksWithEscpaeFalse(): void
$builder->select(
'REGEXP_SUBSTR(ral_anno,"[0-9]{1,2}([,.][0-9]{1,3})([,.][0-9]{1,3})") AS ral',
- false
+ false,
);
$expected = <<<'SQL'
@@ -404,7 +405,7 @@ public function testSelectResetQuery(): void
$sql = $builder->getCompiledSelect();
$this->assertSame(
'SELECT * FROM "users"',
- str_replace("\n", ' ', $sql)
+ str_replace("\n", ' ', $sql),
);
}
}
diff --git a/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce1Test.php b/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce1Test.php
index c3e744749909..d6cb6b503adb 100644
--- a/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce1Test.php
+++ b/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce1Test.php
@@ -69,7 +69,7 @@ protected function setUpAddNamespace(): void
{
service('autoloader')->addNamespace(
'Tests\Support\MigrationTestMigrations',
- SUPPORTPATH . 'MigrationTestMigrations'
+ SUPPORTPATH . 'MigrationTestMigrations',
);
}
diff --git a/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce2Test.php b/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce2Test.php
index 7820b83c06c7..b485093438ce 100644
--- a/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce2Test.php
+++ b/tests/system/Database/DatabaseTestCase/DatabaseTestCaseMigrationOnce2Test.php
@@ -69,7 +69,7 @@ protected function setUpAddNamespace(): void
{
service('autoloader')->addNamespace(
'Tests\Support\MigrationTestMigrations',
- SUPPORTPATH . 'MigrationTestMigrations'
+ SUPPORTPATH . 'MigrationTestMigrations',
);
}
diff --git a/tests/system/Database/DatabaseTestCaseTest.php b/tests/system/Database/DatabaseTestCaseTest.php
index 76867e852e23..b41aba3b76a7 100644
--- a/tests/system/Database/DatabaseTestCaseTest.php
+++ b/tests/system/Database/DatabaseTestCaseTest.php
@@ -74,7 +74,7 @@ protected function setUpAddNamespace(): void
{
service('autoloader')->addNamespace(
'Tests\Support\MigrationTestMigrations',
- SUPPORTPATH . 'MigrationTestMigrations'
+ SUPPORTPATH . 'MigrationTestMigrations',
);
}
diff --git a/tests/system/Database/Live/AbstractGetFieldDataTestCase.php b/tests/system/Database/Live/AbstractGetFieldDataTestCase.php
index 011564992922..4749fabd9de7 100644
--- a/tests/system/Database/Live/AbstractGetFieldDataTestCase.php
+++ b/tests/system/Database/Live/AbstractGetFieldDataTestCase.php
@@ -138,7 +138,7 @@ protected function createTableForType(): void
$fields['type_enum'],
$fields['type_set'],
$fields['type_mediumtext'],
- $fields['type_double']
+ $fields['type_double'],
);
}
@@ -146,7 +146,7 @@ protected function createTableForType(): void
unset(
$fields['type_set'],
$fields['type_mediumtext'],
- $fields['type_double']
+ $fields['type_double'],
);
}
diff --git a/tests/system/Database/Live/DbUtilsTest.php b/tests/system/Database/Live/DbUtilsTest.php
index b7fd56923334..e20a32d8bed2 100644
--- a/tests/system/Database/Live/DbUtilsTest.php
+++ b/tests/system/Database/Live/DbUtilsTest.php
@@ -102,7 +102,7 @@ public function testUtilsOptimizeDatabase(): void
if ($this->db->DBDriver === 'OCI8') {
$this->markTestSkipped(
- 'Unsupported feature of the oracle database platform.'
+ 'Unsupported feature of the oracle database platform.',
);
}
@@ -146,7 +146,7 @@ public function testUtilsOptimizeTable(): void
if ($this->db->DBDriver === 'OCI8') {
$this->markTestSkipped(
- 'Unsupported feature of the oracle database platform.'
+ 'Unsupported feature of the oracle database platform.',
);
}
diff --git a/tests/system/Database/Live/DeleteTest.php b/tests/system/Database/Live/DeleteTest.php
index 421f5c0f430f..896ab12c1d39 100644
--- a/tests/system/Database/Live/DeleteTest.php
+++ b/tests/system/Database/Live/DeleteTest.php
@@ -134,15 +134,15 @@ public function testDeleteBatchConstraintsDate(): void
$this->dontSeeInDatabase(
$table,
- ['type_date' => '2023-12-01', 'type_varchar' => 'test1']
+ ['type_date' => '2023-12-01', 'type_varchar' => 'test1'],
);
$this->dontSeeInDatabase(
$table,
- ['type_date' => '2023-12-02', 'type_varchar' => 'test2']
+ ['type_date' => '2023-12-02', 'type_varchar' => 'test2'],
);
$this->seeInDatabase(
$table,
- ['type_date' => '2023-12-03', 'type_varchar' => 'test3']
+ ['type_date' => '2023-12-03', 'type_varchar' => 'test3'],
);
}
diff --git a/tests/system/Database/Live/ForgeTest.php b/tests/system/Database/Live/ForgeTest.php
index 0ab672e72067..d7352480aad3 100644
--- a/tests/system/Database/Live/ForgeTest.php
+++ b/tests/system/Database/Live/ForgeTest.php
@@ -1457,7 +1457,7 @@ private function getMetaData(string $column, string $table): stdClass
$name = array_search(
$column,
array_column($fields, 'name'),
- true
+ true,
);
if ($name === false) {
@@ -1707,7 +1707,7 @@ public function testProcessIndexes(): void
$indexes = array_filter(
$allIndexes,
static fn ($index): bool => ($index->name === 'db_actions_name')
- && ($index->fields === [0 => 'name'])
+ && ($index->fields === [0 => 'name']),
);
$this->assertCount(1, $indexes);
@@ -1715,14 +1715,14 @@ public function testProcessIndexes(): void
$indexes = array_filter(
$allIndexes,
static fn ($index): bool => ($index->name === 'db_actions_category_name')
- && ($index->fields === [0 => 'category', 1 => 'name'])
+ && ($index->fields === [0 => 'category', 1 => 'name']),
);
$this->assertCount(1, $indexes);
// check that the primary key exists
$indexes = array_filter(
$allIndexes,
- static fn ($index): bool => $index->type === 'PRIMARY'
+ static fn ($index): bool => $index->type === 'PRIMARY',
);
$this->assertCount(1, $indexes);
@@ -1755,7 +1755,7 @@ public function testProcessIndexesWithKeyOnly(): void
$indexes = array_filter(
$allIndexes,
static fn ($index): bool => ($index->name === 'db_actions_name')
- && ($index->fields === [0 => 'name'])
+ && ($index->fields === [0 => 'name']),
);
$this->assertCount(1, $indexes);
@@ -1780,7 +1780,7 @@ public function testProcessIndexesWithPrimaryKeyOnly(): void
// check that the primary key exists
$indexes = array_filter(
$allIndexes,
- static fn ($index): bool => $index->type === 'PRIMARY'
+ static fn ($index): bool => $index->type === 'PRIMARY',
);
$this->assertCount(1, $indexes);
diff --git a/tests/system/Database/Live/InsertTest.php b/tests/system/Database/Live/InsertTest.php
index ca2117a06b35..79281a384e9a 100644
--- a/tests/system/Database/Live/InsertTest.php
+++ b/tests/system/Database/Live/InsertTest.php
@@ -13,6 +13,7 @@
namespace CodeIgniter\Database\Live;
+use CodeIgniter\Database\Exceptions\DatabaseException;
use CodeIgniter\Database\Forge;
use CodeIgniter\Database\RawSql;
use CodeIgniter\Test\CIUnitTestCase;
@@ -79,13 +80,41 @@ public function testInsertBatch(): void
],
];
- $this->db->table($table)->insertBatch($data);
+ $count = $this->db->table($table)->insertBatch($data);
+
+ $this->assertSame(2, $count);
$expected = $data;
$this->seeInDatabase($table, $expected[0]);
$this->seeInDatabase($table, $expected[1]);
}
+ public function testInsertBatchFailed(): void
+ {
+ $this->expectException(DatabaseException::class);
+
+ $data = [
+ [
+ 'name' => 'Grocery Sales',
+ ],
+ [
+ 'name' => null,
+ ],
+ ];
+
+ $db = $this->db;
+
+ if ($this->db->DBDriver === 'MySQLi') {
+ // strict mode is required for MySQLi to throw an exception here
+ $config = config('Database');
+ $config->tests['strictOn'] = true;
+
+ $db = Database::connect($config->tests);
+ }
+
+ $db->table('job')->insertBatch($data);
+ }
+
public function testReplaceWithNoMatchingData(): void
{
$data = [
diff --git a/tests/system/Database/Live/OCI8/GetFieldDataTestCase.php b/tests/system/Database/Live/OCI8/GetFieldDataTestCase.php
index 2ff1f103fb33..477bebe50113 100644
--- a/tests/system/Database/Live/OCI8/GetFieldDataTestCase.php
+++ b/tests/system/Database/Live/OCI8/GetFieldDataTestCase.php
@@ -41,7 +41,7 @@ private function getFieldMetaData(string $column, string $table): stdClass
$name = array_search(
$column,
array_column($fields, 'name'),
- true
+ true,
);
if ($name === false) {
diff --git a/tests/system/Database/Live/Postgre/ConnectTest.php b/tests/system/Database/Live/Postgre/ConnectTest.php
index 29de0976eb21..d616a60b968c 100644
--- a/tests/system/Database/Live/Postgre/ConnectTest.php
+++ b/tests/system/Database/Live/Postgre/ConnectTest.php
@@ -40,7 +40,7 @@ public function testShowErrorMessageWhenSettingInvalidCharset(): void
$this->expectException(DatabaseException::class);
$this->expectExceptionMessage(
'Unable to connect to the database.
-Main connection [Postgre]: ERROR: invalid value for parameter "client_encoding": "utf8mb4"'
+Main connection [Postgre]: ERROR: invalid value for parameter "client_encoding": "utf8mb4"',
);
$config = config('Database');
diff --git a/tests/system/Database/Live/TransactionTest.php b/tests/system/Database/Live/TransactionTest.php
index 3414d2dfffdf..74df4e3fd974 100644
--- a/tests/system/Database/Live/TransactionTest.php
+++ b/tests/system/Database/Live/TransactionTest.php
@@ -239,4 +239,40 @@ public function testTransStrictFalseAndDBDebugFalse(): void
$this->enableDBDebug();
}
+
+ /**
+ * @see https://github.com/codeigniter4/CodeIgniter4/issues/9362
+ */
+ public function testTransInsertBatchFailed(): void
+ {
+ $data = [
+ [
+ 'name' => 'Grocery Sales',
+ ],
+ [
+ 'name' => null,
+ ],
+ ];
+
+ $db = $this->db;
+
+ if ($this->db->DBDriver === 'MySQLi') {
+ // strict mode is required for MySQLi to throw an exception here
+ $config = config('Database');
+ $config->tests['strictOn'] = true;
+
+ $db = Database::connect($config->tests);
+ }
+
+ $db->transStrict(false)->transBegin();
+ $db->table('job')->insertBatch($data);
+
+ $this->assertFalse($db->transStatus());
+
+ $db->transComplete();
+
+ $db->transStrict();
+
+ $this->dontSeeInDatabase('job', ['name' => 'Grocery Sales']);
+ }
}
diff --git a/tests/system/Database/Live/UpdateTest.php b/tests/system/Database/Live/UpdateTest.php
index 565c8f83b909..64a84ad03242 100644
--- a/tests/system/Database/Live/UpdateTest.php
+++ b/tests/system/Database/Live/UpdateTest.php
@@ -443,7 +443,7 @@ public function testUpdateBatchConstraintsRawSqlAndAlias(): void
null,
['id', new RawSql($this->db->protectIdentifiers('d')
. '.' . $this->db->protectIdentifiers('country')
- . " LIKE 'U%'")]
+ . " LIKE 'U%'")],
);
$this->seeInDatabase('user', [
diff --git a/tests/system/Database/Migrations/MigrationRunnerTest.php b/tests/system/Database/Migrations/MigrationRunnerTest.php
index 0ecd2ca0b051..61517d9f7521 100644
--- a/tests/system/Database/Migrations/MigrationRunnerTest.php
+++ b/tests/system/Database/Migrations/MigrationRunnerTest.php
@@ -61,7 +61,7 @@ protected function setUpAddNamespace(): void
{
service('autoloader')->addNamespace(
'Tests\Support\MigrationTestMigrations',
- SUPPORTPATH . 'MigrationTestMigrations'
+ SUPPORTPATH . 'MigrationTestMigrations',
);
}
@@ -89,7 +89,7 @@ public function testLoadsDefaultDatabaseWhenNoneSpecified(): void
) . $dbConfig->tests['database'];
$this->assertSame(
$database,
- $this->getPrivateProperty($db, 'database')
+ $this->getPrivateProperty($db, 'database'),
);
$this->assertSame($dbConfig->tests['DBDriver'], $this->getPrivateProperty($db, 'DBDriver'));
}
@@ -297,7 +297,7 @@ public function testMigrationThrowsDisabledException(): void
vfsStream::copyFromFileSystem(
TESTPATH . '_support/MigrationTestMigrations/Database/Migrations',
- $this->root
+ $this->root,
);
$this->expectException(ConfigException::class);
diff --git a/tests/system/Debug/ExceptionHandlerTest.php b/tests/system/Debug/ExceptionHandlerTest.php
index ddb1304c3d7e..619522d3c155 100644
--- a/tests/system/Debug/ExceptionHandlerTest.php
+++ b/tests/system/Debug/ExceptionHandlerTest.php
@@ -151,11 +151,11 @@ public function testHandleCLIPageNotFoundException(): void
$this->assertStringContainsString(
'ERROR: 404',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
$this->assertStringContainsString(
'Controller or its method is not found: Foo::bar',
- $this->getStreamFilterBuffer()
+ $this->getStreamFilterBuffer(),
);
$this->resetStreamFilterBuffer();
diff --git a/tests/system/Debug/ExceptionsTest.php b/tests/system/Debug/ExceptionsTest.php
index b8279fb8e190..86b4b061ff0e 100644
--- a/tests/system/Debug/ExceptionsTest.php
+++ b/tests/system/Debug/ExceptionsTest.php
@@ -124,7 +124,7 @@ public function testDetermineCodes(): void
$this->assertSame([500, EXIT_ERROR], $determineCodes(new RuntimeException('There.', 404)));
$this->assertSame([500, EXIT_ERROR], $determineCodes(new RuntimeException('This.', 167)));
$this->assertSame([500, EXIT_CONFIG], $determineCodes(new ConfigException('This.')));
- $this->assertSame([500, EXIT_CONFIG], $determineCodes(new CastException('This.')));
+ $this->assertSame([500, EXIT_CONFIG], $determineCodes(CastException::forInvalidInterface('This.')));
$this->assertSame([500, EXIT_DATABASE], $determineCodes(new DatabaseException('This.')));
}
@@ -139,7 +139,7 @@ public function testRenderBacktrace(): void
foreach ($renderedBacktrace as $trace) {
$this->assertMatchesRegularExpression(
'/^\s*\d* .+(?:\(\d+\))?: \S+(?:(?:\->|::)\S+)?\(.*\)$/',
- $trace
+ $trace,
);
}
}
diff --git a/tests/system/Debug/Toolbar/Collectors/DatabaseTest.php b/tests/system/Debug/Toolbar/Collectors/DatabaseTest.php
index 9c091ee4e530..2033a6e78639 100644
--- a/tests/system/Debug/Toolbar/Collectors/DatabaseTest.php
+++ b/tests/system/Debug/Toolbar/Collectors/DatabaseTest.php
@@ -48,7 +48,7 @@ public function testDisplay(): void
$this->assertArrayHasKey('index', $trace);
$this->assertSame(
sprintf('%s', $i + 1),
- preg_replace(sprintf('/%s/', chr(0xC2) . chr(0xA0)), '', $trace['index'])
+ preg_replace(sprintf('/%s/', chr(0xC2) . chr(0xA0)), '', $trace['index']),
);
// since we merged file & line together
diff --git a/tests/system/Debug/Toolbar/Collectors/HistoryTest.php b/tests/system/Debug/Toolbar/Collectors/HistoryTest.php
index 3a5411a96a0f..6e72f2726ef6 100644
--- a/tests/system/Debug/Toolbar/Collectors/HistoryTest.php
+++ b/tests/system/Debug/Toolbar/Collectors/HistoryTest.php
@@ -88,7 +88,7 @@ public function testSetFiles(): void
$this->assertSame($request['time'], sprintf('%.6f', $time));
$this->assertSame(
$request['datetime'],
- DateTime::createFromFormat('U.u', $time)->format('Y-m-d H:i:s.u')
+ DateTime::createFromFormat('U.u', $time)->format('Y-m-d H:i:s.u'),
);
$this->assertSame($request['active'], ($time === $activeRowTime));
diff --git a/tests/system/DebugTraceableTraitTest.php b/tests/system/DebugTraceableTraitTest.php
index 26161d8de683..623bb65cbefa 100644
--- a/tests/system/DebugTraceableTraitTest.php
+++ b/tests/system/DebugTraceableTraitTest.php
@@ -16,19 +16,17 @@
use CodeIgniter\Exceptions\DebugTraceableTrait;
use CodeIgniter\Exceptions\FrameworkException;
use CodeIgniter\Test\CIUnitTestCase;
-use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\Group;
/**
* @internal
*/
-#[CoversClass(DebugTraceableTrait::class)]
#[Group('Others')]
final class DebugTraceableTraitTest extends CIUnitTestCase
{
public function testFactoryInstanceReturnsWhereItIsRaised(): void
{
- $e1 = new FrameworkException('Hello.');
+ $e1 = new FrameworkException('Hello.'); // @phpstan-ignore codeigniter.frameworkExceptionInstance
$e2 = FrameworkException::forEnabledZlibOutputCompression();
$this->assertContainsEquals(DebugTraceableTrait::class, class_uses(FrameworkException::class));
diff --git a/tests/system/Email/EmailTest.php b/tests/system/Email/EmailTest.php
index 389b657e573a..ca26743c3ddc 100644
--- a/tests/system/Email/EmailTest.php
+++ b/tests/system/Email/EmailTest.php
@@ -182,11 +182,11 @@ public function testSetAttachmentCIDFile(): void
$this->assertStringStartsWith('ci-logo.png@', $cid);
$this->assertStringStartsWith(
'ci-logo.png@',
- $email->archive['attachments'][0]['cid']
+ $email->archive['attachments'][0]['cid'],
);
$this->assertMatchesRegularExpression(
'//u',
- $email->archive['body']
+ $email->archive['body'],
);
}
@@ -208,11 +208,11 @@ public function testSetAttachmentCIDBufferString(): void
$this->assertStringStartsWith('image001.png@', $cid);
$this->assertStringStartsWith(
'image001.png@',
- $email->archive['attachments'][0]['cid']
+ $email->archive['attachments'][0]['cid'],
);
$this->assertMatchesRegularExpression(
'//u',
- $email->archive['body']
+ $email->archive['body'],
);
}
}
diff --git a/tests/system/Entity/EntityTest.php b/tests/system/Entity/EntityTest.php
index 8dd7ceac31fa..6998ea48898d 100644
--- a/tests/system/Entity/EntityTest.php
+++ b/tests/system/Entity/EntityTest.php
@@ -479,7 +479,7 @@ public function testCastTimestampException(): void
$entity = $this->getCastEntity();
$entity->ninth = 'some string';
- $entity->ninth;
+ $entity->ninth; // @phpstan-ignore expr.resultUnused
}
public function testCastArray(): void
diff --git a/tests/system/Events/EventsTest.php b/tests/system/Events/EventsTest.php
index db975aaa1825..a659c3a3b460 100644
--- a/tests/system/Events/EventsTest.php
+++ b/tests/system/Events/EventsTest.php
@@ -20,6 +20,7 @@
use PHPUnit\Framework\Attributes\PreserveGlobalState;
use PHPUnit\Framework\Attributes\RunInSeparateProcess;
use PHPUnit\Framework\Attributes\WithoutErrorHandler;
+use stdClass;
/**
* @internal
@@ -29,6 +30,8 @@ final class EventsTest extends CIUnitTestCase
{
/**
* Accessible event manager instance
+ *
+ * @var MockEvents
*/
private Events $manager;
@@ -54,7 +57,7 @@ public function testInitialize(): void
/**
* @var Modules $config
*/
- $config = config('Modules');
+ $config = new Modules();
$config->aliases = [];
// it should start out empty
@@ -181,63 +184,68 @@ public function testPriorityWithMultiple(): void
public function testRemoveListener(): void
{
- $result = false;
+ $user = $this->getEditableObject();
- $callback = static function () use (&$result): void {
- $result = true;
+ $callback = static function () use (&$user): void {
+ $user->name = 'Boris';
+ $user->age = 40;
};
Events::on('foo', $callback);
- Events::trigger('foo');
- $this->assertTrue($result);
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Boris', $user->name);
+
+ $user = $this->getEditableObject();
- $result = false;
$this->assertTrue(Events::removeListener('foo', $callback));
- Events::trigger('foo');
- $this->assertFalse($result);
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Ivan', $user->name);
}
public function testRemoveListenerTwice(): void
{
- $result = false;
+ $user = $this->getEditableObject();
- $callback = static function () use (&$result): void {
- $result = true;
+ $callback = static function () use (&$user): void {
+ $user->name = 'Boris';
+ $user->age = 40;
};
Events::on('foo', $callback);
- Events::trigger('foo');
- $this->assertTrue($result);
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Boris', $user->name);
+
+ $user = $this->getEditableObject();
- $result = false;
$this->assertTrue(Events::removeListener('foo', $callback));
$this->assertFalse(Events::removeListener('foo', $callback));
- Events::trigger('foo');
- $this->assertFalse($result);
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Ivan', $user->name);
}
public function testRemoveUnknownListener(): void
{
- $result = false;
+ $user = $this->getEditableObject();
- $callback = static function () use (&$result): void {
- $result = true;
+ $callback = static function () use (&$user): void {
+ $user->name = 'Boris';
+ $user->age = 40;
};
Events::on('foo', $callback);
- Events::trigger('foo');
- $this->assertTrue($result);
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Boris', $user->name);
- $result = false;
- $this->assertFalse(Events::removeListener('bar', $callback));
+ $user = $this->getEditableObject();
- Events::trigger('foo');
- $this->assertTrue($result);
+ $this->assertFalse(Events::removeListener('bar', $callback));
+ $this->assertTrue(Events::trigger('foo'));
+ $this->assertSame('Boris', $user->name);
}
public function testRemoveAllListenersWithSingleEvent(): void
@@ -315,4 +323,13 @@ public function testSimulate(): void
$this->assertSame(0, $result);
}
+
+ private function getEditableObject(): stdClass
+ {
+ $user = new stdClass();
+ $user->name = 'Ivan';
+ $user->age = 30;
+
+ return clone $user;
+ }
}
diff --git a/tests/system/Filters/CorsTest.php b/tests/system/Filters/CorsTest.php
index bbbbefc0b413..5e25af0572f2 100644
--- a/tests/system/Filters/CorsTest.php
+++ b/tests/system/Filters/CorsTest.php
@@ -89,7 +89,7 @@ private function createCors(array $options = []): Cors
'maxAge' => 0,
'supportsCredentials' => false,
],
- $options
+ $options,
);
return new Cors($passedOptions);
@@ -119,7 +119,7 @@ public function testItDoesModifyOnARequestWithoutOrigin(): void
$this->assertHeader(
'Access-Control-Allow-Origin',
- 'http://localhost'
+ 'http://localhost',
);
}
@@ -208,7 +208,7 @@ public function testItDoesntPermitWildcardAllowedHeadersAndSupportsCredentials()
{
$this->expectException(ConfigException::class);
$this->expectExceptionMessage(
- 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Headers response-header value.'
+ 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Headers response-header value.',
);
$this->cors = $this->createCors(['allowedHeaders' => ['*'], 'supportsCredentials' => true]);
@@ -249,7 +249,7 @@ public function testItSetsExposedHeadersWhenConfiguredOnActualRequest(): void
$this->assertTrue($response->hasHeader('Access-Control-Expose-Headers'));
$this->assertHeader(
'Access-Control-Expose-Headers',
- 'x-exposed-header, x-another-exposed-header'
+ 'x-exposed-header, x-another-exposed-header',
);
}
@@ -257,7 +257,7 @@ public function testItDoesNotPermitWildcardAllowedOriginsAndSupportsCredentials(
{
$this->expectException(ConfigException::class);
$this->expectExceptionMessage(
- 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Origin response-header value.'
+ 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Origin response-header value.',
);
$this->cors = $this->createCors([
@@ -273,7 +273,7 @@ public function testItDoesNotPermitWildcardAllowedOriginsAllowedMethodAndSupport
{
$this->expectException(ConfigException::class);
$this->expectExceptionMessage(
- 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Origin response-header value.'
+ 'When responding to a credentialed request, the server must not specify the "*" wildcard for the Access-Control-Allow-Origin response-header value.',
);
$this->cors = $this->createCors([
@@ -303,7 +303,7 @@ public function testItDoesntPermitWildcardAndOrigin(): void
{
$this->expectException(ConfigException::class);
$this->expectExceptionMessage(
- "If wildcard is specified, you must set `'allowedOrigins' => ['*']`. But using wildcard is not recommended."
+ "If wildcard is specified, you must set `'allowedOrigins' => ['*']`. But using wildcard is not recommended.",
);
$this->cors = $this->createCors([
diff --git a/tests/system/Filters/FiltersTest.php b/tests/system/Filters/FiltersTest.php
index d4a390c113e0..3c44cc5c6787 100644
--- a/tests/system/Filters/FiltersTest.php
+++ b/tests/system/Filters/FiltersTest.php
@@ -97,7 +97,7 @@ public function testProcessMethodDetectsCLI(): void
$filtersConfig = $this->createConfigFromArray(FiltersConfig::class, $config);
$filters = $this->createFilters(
$filtersConfig,
- new CLIRequest(new MockAppConfig())
+ new CLIRequest(new MockAppConfig()),
);
$expected = [
diff --git a/tests/system/Format/FormatTest.php b/tests/system/Format/FormatTest.php
index 74252c7b56d8..91fb618209d7 100644
--- a/tests/system/Format/FormatTest.php
+++ b/tests/system/Format/FormatTest.php
@@ -56,7 +56,7 @@ public function testGetFormatterExpectsExceptionOnUndefinedClass(): void
{
$this->format->getConfig()->formatters = array_merge(
$this->format->getConfig()->formatters,
- ['text/xml' => 'App\Foo']
+ ['text/xml' => 'App\Foo'],
);
$this->expectException(FormatException::class);
@@ -68,7 +68,7 @@ public function testGetFormatterExpectsExceptionOnClassNotImplementingFormatterI
{
$this->format->getConfig()->formatters = array_merge(
$this->format->getConfig()->formatters,
- ['text/xml' => URI::class]
+ ['text/xml' => URI::class],
);
$this->expectException(FormatException::class);
diff --git a/tests/system/HTTP/CURLRequestTest.php b/tests/system/HTTP/CURLRequestTest.php
index 7c2d7b17138a..3d1543c15ee5 100644
--- a/tests/system/HTTP/CURLRequestTest.php
+++ b/tests/system/HTTP/CURLRequestTest.php
@@ -914,12 +914,12 @@ public function testResponseHeadersWithMultipleSetCookies(): void
$this->assertCount(3, $setCookieHeaders);
$this->assertSame(
'logged_in=no; Path=/; Domain=github.com; Expires=Mon, 11 Nov 2024 02:27:05 GMT; HttpOnly; Secure; SameSite=Lax',
- $setCookieHeaders[2]->getValue()
+ $setCookieHeaders[2]->getValue(),
);
$this->assertSame(
'_octo=GH1.1.599292127.1699669625; Path=/; Domain=github.com; Expires=Mon, 11 Nov 2024 02:27:05 GMT; Secure; SameSite=Lax',
- $setCookieHeaders[1]->getValueLine()
+ $setCookieHeaders[1]->getValueLine(),
);
}
@@ -1067,7 +1067,7 @@ public function testSetForm(): void
$this->assertSame(
http_build_query($params),
- $this->request->curl_options[CURLOPT_POSTFIELDS]
+ $this->request->curl_options[CURLOPT_POSTFIELDS],
);
$params['afile'] = new CURLFile(__FILE__);
@@ -1076,7 +1076,7 @@ public function testSetForm(): void
$this->assertSame(
$params,
- $this->request->curl_options[CURLOPT_POSTFIELDS]
+ $this->request->curl_options[CURLOPT_POSTFIELDS],
);
}
@@ -1098,7 +1098,7 @@ public function testJSONData(): void
$expected = json_encode($params);
$this->assertSame(
$expected,
- $this->request->curl_options[CURLOPT_POSTFIELDS]
+ $this->request->curl_options[CURLOPT_POSTFIELDS],
);
}
@@ -1116,11 +1116,11 @@ public function testSetJSON(): void
$expected = json_encode($params);
$this->assertSame(
$expected,
- $this->request->curl_options[CURLOPT_POSTFIELDS]
+ $this->request->curl_options[CURLOPT_POSTFIELDS],
);
$this->assertSame(
'Content-Type: application/json',
- $this->request->curl_options[CURLOPT_HTTPHEADER][0]
+ $this->request->curl_options[CURLOPT_HTTPHEADER][0],
);
}
diff --git a/tests/system/HTTP/ContentSecurityPolicyTest.php b/tests/system/HTTP/ContentSecurityPolicyTest.php
index c1d90554fc7c..c4e6688ef11f 100644
--- a/tests/system/HTTP/ContentSecurityPolicyTest.php
+++ b/tests/system/HTTP/ContentSecurityPolicyTest.php
@@ -441,7 +441,7 @@ public function testBodyScriptNonce(): void
$result = $this->work($body);
$nonceStyle = array_filter(
$this->getPrivateProperty($this->csp, 'styleSrc'),
- static fn ($value): bool => str_starts_with($value, 'nonce-')
+ static fn ($value): bool => str_starts_with($value, 'nonce-'),
);
$this->assertStringContainsString('nonce=', $this->response->getBody());
@@ -516,7 +516,7 @@ public function testBodyStyleNonce(): void
$result = $this->work($body);
$nonceScript = array_filter(
$this->getPrivateProperty($this->csp, 'scriptSrc'),
- static fn ($value): bool => str_starts_with($value, 'nonce-')
+ static fn ($value): bool => str_starts_with($value, 'nonce-'),
);
$this->assertStringContainsString('nonce=', $this->response->getBody());
diff --git a/tests/system/HTTP/CorsTest.php b/tests/system/HTTP/CorsTest.php
index bdb29567df59..1002c557d313 100644
--- a/tests/system/HTTP/CorsTest.php
+++ b/tests/system/HTTP/CorsTest.php
@@ -109,20 +109,20 @@ public function testHandlePreflightRequestSingleAllowedOrigin(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Headers',
- 'X-API-KEY, X-Requested-With, Content-Type, Accept'
+ 'X-API-KEY, X-Requested-With, Content-Type, Accept',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Methods',
- 'PUT'
+ 'PUT',
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Credentials')
+ $response->hasHeader('Access-Control-Allow-Credentials'),
);
}
@@ -144,22 +144,22 @@ public function testHandlePreflightRequestMultipleAllowedOriginsAllowed(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'https://api.example.com'
+ 'https://api.example.com',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Headers',
- 'X-API-KEY, X-Requested-With, Content-Type, Accept'
+ 'X-API-KEY, X-Requested-With, Content-Type, Accept',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Methods',
- 'PUT'
+ 'PUT',
);
$this->assertHeader(
$response,
'Vary',
- 'Origin'
+ 'Origin',
);
}
@@ -182,22 +182,22 @@ public function testHandlePreflightRequestMultipleAllowedOriginsAllowedAlreadyVa
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'https://api.example.com'
+ 'https://api.example.com',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Headers',
- 'X-API-KEY, X-Requested-With, Content-Type, Accept'
+ 'X-API-KEY, X-Requested-With, Content-Type, Accept',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Methods',
- 'PUT'
+ 'PUT',
);
$this->assertHeader(
$response,
'Vary',
- 'Accept-Language, Origin'
+ 'Accept-Language, Origin',
);
}
@@ -217,13 +217,13 @@ public function testHandlePreflightRequestMultipleAllowedOriginsNotAllowed(): vo
$response = $cors->handlePreflightRequest($request, $response);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Origin')
+ $response->hasHeader('Access-Control-Allow-Origin'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Headers')
+ $response->hasHeader('Access-Control-Allow-Headers'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Methods')
+ $response->hasHeader('Access-Control-Allow-Methods'),
);
}
@@ -245,22 +245,22 @@ public function testHandlePreflightRequestAllowedOriginsPatternsAllowed(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'https://api.example.com'
+ 'https://api.example.com',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Headers',
- 'X-API-KEY, X-Requested-With, Content-Type, Accept'
+ 'X-API-KEY, X-Requested-With, Content-Type, Accept',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Methods',
- 'PUT'
+ 'PUT',
);
$this->assertHeader(
$response,
'Vary',
- 'Origin'
+ 'Origin',
);
}
@@ -280,13 +280,13 @@ public function testHandlePreflightRequestAllowedOriginsPatternsNotAllowed(): vo
$response = $cors->handlePreflightRequest($request, $response);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Origin')
+ $response->hasHeader('Access-Control-Allow-Origin'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Headers')
+ $response->hasHeader('Access-Control-Allow-Headers'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Methods')
+ $response->hasHeader('Access-Control-Allow-Methods'),
);
}
@@ -309,22 +309,22 @@ public function testHandlePreflightRequestSingleAllowedOriginWithCredentials():
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Headers',
- 'X-API-KEY, X-Requested-With, Content-Type, Accept'
+ 'X-API-KEY, X-Requested-With, Content-Type, Accept',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Methods',
- 'PUT'
+ 'PUT',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Credentials',
- 'true'
+ 'true',
);
}
@@ -346,16 +346,16 @@ public function testAddResponseHeadersSingleAllowedOriginSimpleRequest(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Headers')
+ $response->hasHeader('Access-Control-Allow-Headers'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Methods')
+ $response->hasHeader('Access-Control-Allow-Methods'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Credentials')
+ $response->hasHeader('Access-Control-Allow-Credentials'),
);
}
@@ -377,7 +377,7 @@ public function testAddResponseHeadersSingleAllowedOriginRealRequest(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
}
@@ -401,12 +401,12 @@ public function testAddResponseHeadersSingleAllowedOriginWithCredentials(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
$this->assertHeader(
$response,
'Access-Control-Allow-Credentials',
- 'true'
+ 'true',
);
}
@@ -429,12 +429,12 @@ public function testAddResponseHeadersSingleAllowedOriginWithExposeHeaders(): vo
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'http://localhost:8080'
+ 'http://localhost:8080',
);
$this->assertHeader(
$response,
'Access-Control-Expose-Headers',
- 'Content-Length, X-Kuma-Revision'
+ 'Content-Length, X-Kuma-Revision',
);
}
@@ -455,18 +455,18 @@ public function testAddResponseHeadersMultipleAllowedOriginsAllowed(): void
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'https://api.example.com'
+ 'https://api.example.com',
);
$this->assertHeader(
$response,
'Vary',
- 'Origin'
+ 'Origin',
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Headers')
+ $response->hasHeader('Access-Control-Allow-Headers'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Methods')
+ $response->hasHeader('Access-Control-Allow-Methods'),
);
}
@@ -488,12 +488,12 @@ public function testAddResponseHeadersMultipleAllowedOriginsAllowedAlreadyVary()
$this->assertHeader(
$response,
'Access-Control-Allow-Origin',
- 'https://api.example.com'
+ 'https://api.example.com',
);
$this->assertHeader(
$response,
'Vary',
- 'Accept-Language, Origin'
+ 'Accept-Language, Origin',
);
}
@@ -512,13 +512,13 @@ public function testAddResponseHeadersMultipleAllowedOriginsNotAllowed(): void
$response = $cors->addResponseHeaders($request, $response);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Origin')
+ $response->hasHeader('Access-Control-Allow-Origin'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Headers')
+ $response->hasHeader('Access-Control-Allow-Headers'),
);
$this->assertFalse(
- $response->hasHeader('Access-Control-Allow-Methods')
+ $response->hasHeader('Access-Control-Allow-Methods'),
);
}
}
diff --git a/tests/system/HTTP/IncomingRequestTest.php b/tests/system/HTTP/IncomingRequestTest.php
index fa76e8289d46..d3e542b4accb 100644
--- a/tests/system/HTTP/IncomingRequestTest.php
+++ b/tests/system/HTTP/IncomingRequestTest.php
@@ -290,7 +290,7 @@ public function testNegotiatesCharset(): void
$this->assertSame(
'utf-8',
- $this->request->negotiate('charset', ['iso-8859', 'unicode-1-2'])
+ $this->request->negotiate('charset', ['iso-8859', 'unicode-1-2']),
);
}
@@ -299,7 +299,7 @@ public function testNegotiatesMedia(): void
$this->request->setHeader('Accept', 'text/plain; q=0.5, text/html, text/x-dvi; q=0.8, text/x-c');
$this->assertSame(
'text/html',
- $this->request->negotiate('media', ['text/html', 'text/x-c', 'text/x-dvi', 'text/plain'])
+ $this->request->negotiate('media', ['text/html', 'text/x-c', 'text/x-dvi', 'text/plain']),
);
}
@@ -436,17 +436,17 @@ public function testGetJsonVarCanFilterArray(): void
$this->assertSame(
$expected,
- $request->getJsonVar(null, true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION)
+ $request->getJsonVar(null, true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION),
);
$this->assertSame(
$expected['array'],
- $request->getJsonVar('array', true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION)
+ $request->getJsonVar('array', true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION),
);
$this->assertSame(
['array' => $expected['array'], 'float' => $expected['float']],
- $request->getJsonVar(['array', 'float'], true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION)
+ $request->getJsonVar(['array', 'float'], true, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION),
);
$result = $request->getJsonVar(['array', 'float'], false, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
@@ -1165,7 +1165,7 @@ public function testGetIPAddressThruProxyInvalidConfigArray(): void
{
$this->expectException(ConfigException::class);
$this->expectExceptionMessage(
- 'You must set an array with Proxy IP address key and HTTP header name value in Config\App::$proxyIPs.'
+ 'You must set an array with Proxy IP address key and HTTP header name value in Config\App::$proxyIPs.',
);
$config = new App();
diff --git a/tests/system/HTTP/MessageTest.php b/tests/system/HTTP/MessageTest.php
index d16224367a6f..ac33869396a1 100644
--- a/tests/system/HTTP/MessageTest.php
+++ b/tests/system/HTTP/MessageTest.php
@@ -311,7 +311,7 @@ public function testAddHeaderAddsFirstHeader(): void
{
$this->message->addHeader(
'Set-Cookie',
- 'logged_in=no; Path=/'
+ 'logged_in=no; Path=/',
);
$header = $this->message->header('Set-Cookie');
@@ -324,11 +324,11 @@ public function testAddHeaderAddsTwoHeaders(): void
{
$this->message->addHeader(
'Set-Cookie',
- 'logged_in=no; Path=/'
+ 'logged_in=no; Path=/',
);
$this->message->addHeader(
'Set-Cookie',
- 'sessid=123456; Path=/'
+ 'sessid=123456; Path=/',
);
$headers = $this->message->header('Set-Cookie');
@@ -342,16 +342,16 @@ public function testAppendHeaderWithMultipleHeaders(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'The header "Set-Cookie" already has multiple headers. You cannot change them. If you really need to change, remove the header first.'
+ 'The header "Set-Cookie" already has multiple headers. You cannot change them. If you really need to change, remove the header first.',
);
$this->message->addHeader(
'Set-Cookie',
- 'logged_in=no; Path=/'
+ 'logged_in=no; Path=/',
);
$this->message->addHeader(
'Set-Cookie',
- 'sessid=123456; Path=/'
+ 'sessid=123456; Path=/',
);
$this->message->appendHeader('Set-Cookie', 'HttpOnly');
@@ -361,16 +361,16 @@ public function testGetHeaderLineWithMultipleHeaders(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage(
- 'The header "Set-Cookie" already has multiple headers. You cannot use getHeaderLine().'
+ 'The header "Set-Cookie" already has multiple headers. You cannot use getHeaderLine().',
);
$this->message->addHeader(
'Set-Cookie',
- 'logged_in=no; Path=/'
+ 'logged_in=no; Path=/',
);
$this->message->addHeader(
'Set-Cookie',
- 'sessid=123456; Path=/'
+ 'sessid=123456; Path=/',
);
$this->message->getHeaderLine('Set-Cookie');
diff --git a/tests/system/HTTP/RedirectExceptionTest.php b/tests/system/HTTP/RedirectExceptionTest.php
index cd90a9aa148c..bde10ea8dfc1 100644
--- a/tests/system/HTTP/RedirectExceptionTest.php
+++ b/tests/system/HTTP/RedirectExceptionTest.php
@@ -49,7 +49,7 @@ public function testResponse(): void
service('response')
->redirect('redirect')
->setCookie('cookie', 'value')
- ->setHeader('Redirect-Header', 'value')
+ ->setHeader('Redirect-Header', 'value'),
))->getResponse();
$this->assertSame('redirect', $response->getHeaderLine('location'));
@@ -62,7 +62,7 @@ public function testResponseWithoutLocation(): void
{
$this->expectException(LogicException::class);
$this->expectExceptionMessage(
- 'The Response object passed to RedirectException does not contain a redirect address.'
+ 'The Response object passed to RedirectException does not contain a redirect address.',
);
new RedirectException(service('response'));
diff --git a/tests/system/HTTP/RedirectResponseTest.php b/tests/system/HTTP/RedirectResponseTest.php
index 1614244d762b..d6203aa935fd 100644
--- a/tests/system/HTTP/RedirectResponseTest.php
+++ b/tests/system/HTTP/RedirectResponseTest.php
@@ -61,7 +61,7 @@ protected function setUp(): void
$this->config,
new SiteURI($this->config),
null,
- new UserAgent()
+ new UserAgent(),
);
Services::injectMock('request', $this->request);
}
diff --git a/tests/system/HTTP/ResponseSendTest.php b/tests/system/HTTP/ResponseSendTest.php
index c7ad15195d97..db72de5d2f03 100644
--- a/tests/system/HTTP/ResponseSendTest.php
+++ b/tests/system/HTTP/ResponseSendTest.php
@@ -173,7 +173,7 @@ public function testDoNotSendUnSecureCookie(): void
'',
'/',
'',
- true
+ true,
);
// send it
diff --git a/tests/system/HTTP/ResponseTest.php b/tests/system/HTTP/ResponseTest.php
index 3137620029bc..eeac917c7c64 100644
--- a/tests/system/HTTP/ResponseTest.php
+++ b/tests/system/HTTP/ResponseTest.php
@@ -175,7 +175,7 @@ public function testSetLink(): void
$this->assertSame(
'; rel="first",; rel="prev",; rel="next",; rel="last"',
- $response->header('Link')->getValue()
+ $response->header('Link')->getValue(),
);
$pager->store('default', 1, 10, 200);
@@ -183,7 +183,7 @@ public function testSetLink(): void
$this->assertSame(
'; rel="next",; rel="last"',
- $response->header('Link')->getValue()
+ $response->header('Link')->getValue(),
);
$pager->store('default', 20, 10, 200);
@@ -191,7 +191,7 @@ public function testSetLink(): void
$this->assertSame(
'; rel="first",; rel="prev"',
- $response->header('Link')->getValue()
+ $response->header('Link')->getValue(),
);
}
@@ -276,7 +276,7 @@ public function testRedirect(
string $protocol,
string $method,
?int $code,
- int $expectedCode
+ int $expectedCode,
): void {
$_SERVER['SERVER_SOFTWARE'] = $server;
$_SERVER['SERVER_PROTOCOL'] = $protocol;
@@ -319,7 +319,7 @@ public function testRedirectWithIIS(
string $protocol,
string $method,
?int $code,
- int $expectedCode
+ int $expectedCode,
): void {
$_SERVER['SERVER_SOFTWARE'] = 'Microsoft-IIS';
$_SERVER['SERVER_PROTOCOL'] = 'HTTP/1.1';
diff --git a/tests/system/HTTP/SiteURIFactoryTest.php b/tests/system/HTTP/SiteURIFactoryTest.php
index 62e20639b5e0..b26fde04b245 100644
--- a/tests/system/HTTP/SiteURIFactoryTest.php
+++ b/tests/system/HTTP/SiteURIFactoryTest.php
@@ -93,7 +93,7 @@ public function testCreateFromStringWithIndexPage(
string $uriString,
string $expectUriString,
string $expectedPath,
- string $expectedRoutePath
+ string $expectedRoutePath,
): void {
$factory = $this->createSiteURIFactory();
@@ -134,7 +134,7 @@ public function testCreateFromStringWithoutIndexPage(
string $uriString,
string $expectUriString,
string $expectedPath,
- string $expectedRoutePath
+ string $expectedRoutePath,
): void {
$config = new App();
$config->indexPage = '';
diff --git a/tests/system/HTTP/SiteURITest.php b/tests/system/HTTP/SiteURITest.php
index 644aaa795b6d..bd7e9ca3d338 100644
--- a/tests/system/HTTP/SiteURITest.php
+++ b/tests/system/HTTP/SiteURITest.php
@@ -40,7 +40,7 @@ public function testConstructor(
string $expectedQuery,
string $expectedFragment,
array $expectedSegments,
- int $expectedTotalSegments
+ int $expectedTotalSegments,
): void {
$config = new App();
$config->indexPage = $indexPage;
@@ -337,7 +337,7 @@ public function testSetPath(
string $expectedQuery,
string $expectedFragment,
array $expectedSegments,
- int $expectedTotalSegments
+ int $expectedTotalSegments,
): void {
$config = new App();
$config->indexPage = $indexPage;
diff --git a/tests/system/HTTP/URITest.php b/tests/system/HTTP/URITest.php
index 517e2d888973..945b132876ef 100644
--- a/tests/system/HTTP/URITest.php
+++ b/tests/system/HTTP/URITest.php
@@ -953,15 +953,15 @@ public function testNoExtraSlashes(): void
{
$this->assertSame(
'http://entirely.different.com/subfolder',
- (string) (new URI('entirely.different.com/subfolder'))
+ (string) (new URI('entirely.different.com/subfolder')),
);
$this->assertSame(
'http://localhost/subfolder',
- (string) (new URI('localhost/subfolder'))
+ (string) (new URI('localhost/subfolder')),
);
$this->assertSame(
'http://localtest.me/subfolder',
- (string) (new URI('localtest.me/subfolder'))
+ (string) (new URI('localtest.me/subfolder')),
);
}
@@ -1052,7 +1052,7 @@ public function testBasedNoIndex(): void
// going through request
$this->assertSame(
'http://example.com/ci/v4/controller/method',
- (string) $request->getUri()
+ (string) $request->getUri(),
);
$this->assertSame('/ci/v4/controller/method', $request->getUri()->getPath());
$this->assertSame('controller/method', $request->getUri()->getRoutePath());
@@ -1086,18 +1086,18 @@ public function testBasedWithIndex(): void
// going through request
$this->assertSame(
'http://example.com/ci/v4/index.php/controller/method',
- (string) $request->getUri()
+ (string) $request->getUri(),
);
$this->assertSame(
'/ci/v4/index.php/controller/method',
- $request->getUri()->getPath()
+ $request->getUri()->getPath(),
);
// standalone
$uri = new URI('http://example.com/ci/v4/index.php/controller/method');
$this->assertSame(
'http://example.com/ci/v4/index.php/controller/method',
- (string) $uri
+ (string) $uri,
);
$this->assertSame('/ci/v4/index.php/controller/method', $uri->getPath());
@@ -1126,7 +1126,7 @@ public function testForceGlobalSecureRequests(): void
// Detected by request
$this->assertSame(
'https://example.com/ci/v4/controller/method',
- (string) $request->getUri()
+ (string) $request->getUri(),
);
// Standalone
@@ -1135,7 +1135,7 @@ public function testForceGlobalSecureRequests(): void
$this->assertSame(
trim($uri->getPath(), '/'),
- trim($request->getUri()->getPath(), '/')
+ trim($request->getUri()->getPath(), '/'),
);
}
diff --git a/tests/system/Helpers/DateHelperTest.php b/tests/system/Helpers/DateHelperTest.php
index 4e7acf649ae7..ec0d3ded0dc2 100644
--- a/tests/system/Helpers/DateHelperTest.php
+++ b/tests/system/Helpers/DateHelperTest.php
@@ -46,7 +46,7 @@ public function testNowSpecific(): void
// Chicago should be two hours ahead of Vancouver
$this->assertSame(
7200,
- now('America/Chicago') - now('America/Vancouver')
+ now('America/Chicago') - now('America/Vancouver'),
);
Time::setTestNow();
@@ -84,7 +84,7 @@ public function testTimezoneSelectSpecific(): void
$this->assertSame(
$expected,
- timezone_select('custom-select', 'Asia/Jakarta', $spesificRegion)
+ timezone_select('custom-select', 'Asia/Jakarta', $spesificRegion),
);
}
@@ -105,7 +105,7 @@ public function testTimezoneSelectSingle(): void
$this->assertSame(
$expected,
- timezone_select('custom-select', 'Asia/Jakarta', $spesificRegion, $country)
+ timezone_select('custom-select', 'Asia/Jakarta', $spesificRegion, $country),
);
}
}
diff --git a/tests/system/Helpers/FormHelperTest.php b/tests/system/Helpers/FormHelperTest.php
index 9023fd73ac6f..91d5aa2e8c7b 100644
--- a/tests/system/Helpers/FormHelperTest.php
+++ b/tests/system/Helpers/FormHelperTest.php
@@ -944,12 +944,12 @@ public function testSetCheckboxWithUnchecked(): void
$this->assertSame(
'',
- set_checkbox('fruit', 'apple', true)
+ set_checkbox('fruit', 'apple', true),
);
$this->assertSame(
'',
- set_checkbox('fruit', 'apple')
+ set_checkbox('fruit', 'apple'),
);
}
diff --git a/tests/system/Helpers/HTMLHelperTest.php b/tests/system/Helpers/HTMLHelperTest.php
index b7159253706e..b6d061072375 100644
--- a/tests/system/Helpers/HTMLHelperTest.php
+++ b/tests/system/Helpers/HTMLHelperTest.php
@@ -338,7 +338,7 @@ public function testScriptTagWithCsp(): void
$this->assertMatchesRegularExpression(
'!