Commit c7bb724e authored by lpsolit%gmail.com's avatar lpsolit%gmail.com

Bug 319089: editkeywords.cgi throws an error when action="edit" or "delete" and…

Bug 319089: editkeywords.cgi throws an error when action="edit" or "delete" and the "id" parameter is invalid - Patch by Frédéric Buclin <LpSolit@gmail.com> r=wicked a=justdave
parent 71c304a8
...@@ -53,6 +53,14 @@ sub Validate { ...@@ -53,6 +53,14 @@ sub Validate {
$_[1] = $description; $_[1] = $description;
} }
sub ValidateKeyID {
my $id = shift;
$id = trim($id || 0);
detaint_natural($id) || ThrowCodeError('invalid_keyword_id');
return $id;
}
# #
# Preliminary checks: # Preliminary checks:
...@@ -165,8 +173,7 @@ if ($action eq 'new') { ...@@ -165,8 +173,7 @@ if ($action eq 'new') {
# #
if ($action eq 'edit') { if ($action eq 'edit') {
my $id = trim($cgi->param('id')); my $id = ValidateKeyID(scalar $cgi->param('id'));
detaint_natural($id);
# get data of keyword # get data of keyword
my ($name, $description) = my ($name, $description) =
...@@ -201,8 +208,7 @@ if ($action eq 'edit') { ...@@ -201,8 +208,7 @@ if ($action eq 'edit') {
# #
if ($action eq 'update') { if ($action eq 'update') {
my $id = $cgi->param('id'); my $id = ValidateKeyID(scalar $cgi->param('id'));
detaint_natural($id);
my $name = trim($cgi->param('name') || ''); my $name = trim($cgi->param('name') || '');
my $description = trim($cgi->param('description') || ''); my $description = trim($cgi->param('description') || '');
...@@ -234,8 +240,7 @@ if ($action eq 'update') { ...@@ -234,8 +240,7 @@ if ($action eq 'update') {
if ($action eq 'delete') { if ($action eq 'delete') {
my $id = $cgi->param('id'); my $id = ValidateKeyID(scalar $cgi->param('id'));
detaint_natural($id);
my $name = $dbh->selectrow_array('SELECT name FROM keyworddefs my $name = $dbh->selectrow_array('SELECT name FROM keyworddefs
WHERE id= ?', undef, $id); WHERE id= ?', undef, $id);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment