X-Git-Url: https://jasonwoof.com/gitweb/?p=wfpl.git;a=blobdiff_plain;f=upload.php;h=b21af6ffc1d0c9daee027cb1e9c92e9d8f292c6f;hp=8beca1c0976571f7557a49171ae21b33a69a6aba;hb=HEAD;hpb=e6a41aa2c0b3bdf17ec5c734074665488f0cef43 diff --git a/upload.php b/upload.php index 8beca1c..b21af6f 100644 --- a/upload.php +++ b/upload.php @@ -1,19 +1,9 @@ . +# This program is in the public domain within the United States. Additionally, +# we waive copyright and related rights in the work worldwide through the CC0 +# 1.0 Universal public domain dedication, which can be found at +# http://creativecommons.org/publicdomain/zero/1.0/ # This file contains functions to accept files being uplodad with the tag # # mime time used to generate extension ONLY IF it doesn't have one already. -function generate_filename($path, $mime = 'text/plain') { +function generate_filename($path, $mime = 'text/plain', $default_ext = '.txt') { # lower case $filename = strtolower($path); @@ -111,32 +134,23 @@ function generate_filename($path, $mime = 'text/plain') { } # replace symbols with underscores - $filename = ereg_replace('[^a-z0-9_.]', '_', $filename); - - # remove dots from the beginning (no invisible files) - $filename = ereg_replace('^\.*', '', $filename); + $filename = preg_replace('|[^a-z0-9_.]|', '_', $filename); + # limit length if(strlen($filename > 80)) { $filename = substr($filename, -80); } - # fix extension - $last_dot = strrpos($filename, '.'); - if($last_dot === false) { - #no extension - if(isset($GLOBALS['mime_to_ext'][$mime])) { - $filename .= '.' . $GLOBALS['mime_to_ext'][$mime]; - } else { - $filename .= '.bin'; - } - } else { - $basename = substr($filename, 0, $last_dot); - $ext = substr($filename, $last_dot + 1); - if(isset($GLOBALS['ext_to_ext'][$ext])) { - $ext .= $GLOBALS['ext_to_ext'][$ext]; - } - $filename = $basename . '.' . $ext; + # remove dots from the beginning (no invisible files) + $filename = preg_replace('|^\.*|', '', $filename); + + # make sure there's something before the extension + if ($filename == '') { + return '_'; } + + $filename = path_fix_ext($filename, $mime, $default_ext); + return $filename; } @@ -181,8 +195,8 @@ function save_uploaded_file($key, $path) { # standard places (like /usr/bin or /usr/local bin) and PHP's PATH environment # variable is not set appropriately. function path_to($prog, $or_die = true) { - $prog = ereg_replace('[^a-zA-Z0-9_.-]', '', $prog); - $prog = ereg_replace('^[-.]*', '', $prog); + $prog = preg_replace('|[^a-z0-9_.-]|i', '', $prog); + $prog = preg_replace('|^[-.]*|', '', $prog); if($prog == '') { die('Invalid argument to path_to()'); } @@ -224,7 +238,7 @@ function gif_to_png($filename, $new_filename = 'just change extension') { $new_filename .= '.png'; } - imagemagick_convert($filename, $new_filename, "-colorspace sRGB", 'GIF to PNG conversion'); + imagemagick_convert($filename.'[0]', $new_filename, "-colorspace sRGB", 'GIF to PNG conversion'); unlink($filename); return $new_filename; @@ -258,7 +272,7 @@ function make_thumbnail($filename, $max_width = '70', $max_height = '70') { function exec_or_die($command, $doing_what) { exec($command, $dummy, $ret); if($ret != 0) { - $base = basename(ereg_replace(' .*', '', $command)); + $base = basename(preg_replace('| .*|', '', $command)); die("$doing_what failed. $base called exit($ret)"); } } @@ -280,7 +294,7 @@ function imagemagick_mogrify($in_filename, $args, $doing_what = "Image conversio } function format_int_70($str) { - $str = ereg_replace('[^0-9]', '', $str); + $str = preg_replace('|[^0-9]|', '', $str); if($str == '') { $str = '70'; } @@ -352,7 +366,7 @@ function image_w_h_or_die($filename) { # and names, call convert_uploaded_image(). function save_uploaded_image($key, $path, $image_width = 0, $image_height = 0, $thumbnail_width = 0, $thumbnail_height = 0) { $image_w_h_thumb_w_h = convert_uploaded_image($key, $path, $image_width, $image_height, $thumbnail_width, $thumbnail_height); - return ereg_replace(' .*', '', $image_w_h_thumb_w_h); + return preg_replace('| .*|', '', $image_w_h_thumb_w_h); } function ext_to_web_image_ext($in) { @@ -396,7 +410,7 @@ function convert_uploaded_image($key, $path, $image_width = 0, $image_height = 0 if($image_width > 0 && $image_height > 0) { $convert_params .= " -geometry ${image_width}x$image_height"; } - imagemagick_convert($tmp_filename, $filename, $convert_params); + imagemagick_convert($tmp_filename.'[0]', $filename, $convert_params); unlink($tmp_filename); list($w, $h) = image_w_h_or_die($filename); $ret = "$filename $w $h";