Bug 122744 - charting fails taint checks

r=daa@distributed.net, gerv
This commit is contained in:
bbaetz%student.usyd.edu.au 2002-01-31 23:51:38 +00:00
Родитель 7b292700c5
Коммит 7387a117fc
1 изменённых файлов: 17 добавлений и 0 удалений

Просмотреть файл

@ -124,6 +124,10 @@ if (! defined $FORM{'product'}) {
|| DisplayError("You entered an invalid output type.")
&& exit;
# We've checked that the product exists, and that the user can see it
# This means that is OK to detaint
trick_taint($FORM{'product'});
# Output appropriate HTTP response headers
print "Content-type: text/html\n";
# Changing attachment to inline to resolve 46897 - zach@zachlipton.com
@ -516,6 +520,19 @@ sub chart_image_type {
sub chart_image_name {
my ($data_file, $type) = @_;
# This routine generates a filename from the requested fields. The problem
# is that we have to check the safety of doing this. We can't just require
# that the fields exist, because what stats were collected could change
# over time (eg by changing the resolutions available)
# Instead, just require that each field name consists only of letters
# and number
if ($FORM{'datasets'} !~ m/[A-Za-z0-9:]/) {
die "Invalid datasets $FORM{'datasets'}";
}
# Since we pass the tests, consider it OK
trick_taint($FORM{'datasets'});
# Cache charts by generating a unique filename based on what they
# show. Charts should be deleted by collectstats.pl nightly.
my $id = join ("_", split (":", $FORM{datasets}));