fix: disallow non-strings in GET parameters (#2908)

This commit is contained in:
Dag 2022-07-10 19:50:51 +02:00 committed by GitHub
parent 003ab58514
commit c33f84fcc2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 22 additions and 13 deletions

View file

@ -2,18 +2,24 @@
require_once __DIR__ . '/lib/rssbridge.php';
/*
Move the CLI arguments to the $_GET array, in order to be able to use
rss-bridge from the command line
*/
if (isset($argv)) {
parse_str(implode('&', array_slice($argv, 1)), $cliArgs);
$request = array_merge($_GET, $cliArgs);
} else {
$request = $_GET;
}
try {
if (isset($argv)) {
parse_str(implode('&', array_slice($argv, 1)), $cliArgs);
$request = $cliArgs;
} else {
$request = $_GET;
}
foreach ($request as $key => $value) {
if (! is_string($value)) {
http_response_code(400);
print render('error.html.php', [
'title' => '400 Bad Request',
'message' => "Query parameter \"$key\" is not a string.",
]);
exit(1);
}
}
$actionFactory = new ActionFactory();
if (array_key_exists('action', $request)) {