mirror of
https://github.com/vichan-devel/vichan.git
synced 2025-01-19 01:24:05 +01:00
Merge branch 'master' of https://github.com/savetheinternet/Tinyboard
This commit is contained in:
commit
f128811dd3
@ -524,6 +524,11 @@
|
|||||||
// this value doesn't matter as $config['redraw_image'] attempts to correct orientation too.)
|
// this value doesn't matter as $config['redraw_image'] attempts to correct orientation too.)
|
||||||
$config['convert_auto_orient'] = false;
|
$config['convert_auto_orient'] = false;
|
||||||
|
|
||||||
|
// Is your version of ImageMagick or GraphicsMagick old? Older versions may not include the -auto-orient
|
||||||
|
// switch. This is a manual replacement for that switch. This is independent from the above switch;
|
||||||
|
// -auto-orrient is applied when thumbnailing too.
|
||||||
|
$config['convert_manual_orient'] = false;
|
||||||
|
|
||||||
// Regular expression to check for an XSS exploit with IE 6 and 7. To disable, set to false.
|
// Regular expression to check for an XSS exploit with IE 6 and 7. To disable, set to false.
|
||||||
// Details: https://github.com/savetheinternet/Tinyboard/issues/20
|
// Details: https://github.com/savetheinternet/Tinyboard/issues/20
|
||||||
$config['ie_mime_type_detection'] = '/<(?:body|head|html|img|plaintext|pre|script|table|title|a href|channel|scriptlet)/i';
|
$config['ie_mime_type_detection'] = '/<(?:body|head|html|img|plaintext|pre|script|table|title|a href|channel|scriptlet)/i';
|
||||||
|
@ -320,19 +320,23 @@ class ImageConvert extends ImageBase {
|
|||||||
|
|
||||||
if ($this->format == 'gif' && ($config['thumb_ext'] == 'gif' || $config['thumb_ext'] == '') && $config['thumb_keep_animation_frames'] > 1) {
|
if ($this->format == 'gif' && ($config['thumb_ext'] == 'gif' || $config['thumb_ext'] == '') && $config['thumb_keep_animation_frames'] > 1) {
|
||||||
if ($this->gifsicle) {
|
if ($this->gifsicle) {
|
||||||
if (trim($error = shell_exec("gifsicle --unoptimize -O2 --resize {$this->width}x{$this->height} < " .
|
if (($error = shell_exec_error("gifsicle --unoptimize -O2 --resize {$this->width}x{$this->height} < " .
|
||||||
escapeshellarg($this->src . '') . " \"#0-{$config['thumb_keep_animation_frames']}\" > " .
|
escapeshellarg($this->src . '') . " \"#0-{$config['thumb_keep_animation_frames']}\" > " .
|
||||||
escapeshellarg($this->temp) . '2>&1 &&echo $?') !== '0') || !file_exists($this->temp))
|
escapeshellarg($this->temp))) || !file_exists($this->temp))
|
||||||
error('Failed to resize image!', null, $error);
|
error('Failed to resize image!', null, $error);
|
||||||
} else {
|
} else {
|
||||||
if ($error = shell_exec_error(($this->gm ? 'gm ' : '') . 'convert ' .
|
if ($config['convert_manual_orient'])
|
||||||
sprintf($config['convert_args'],
|
$convert_args = str_replace('-auto-orient', ImageConvert::jpeg_exif_orientation($this->src), $config['convert_args']);
|
||||||
|
else
|
||||||
|
$convert_args = &$config['convert_args'];
|
||||||
|
if (($error = shell_exec_error(($this->gm ? 'gm ' : '') . 'convert ' .
|
||||||
|
sprintf($convert_args,
|
||||||
$this->width,
|
$this->width,
|
||||||
$this->height,
|
$this->height,
|
||||||
escapeshellarg($this->src),
|
escapeshellarg($this->src),
|
||||||
$this->width,
|
$this->width,
|
||||||
$this->height,
|
$this->height,
|
||||||
escapeshellarg($this->temp))) || !file_exists($this->temp))
|
escapeshellarg($this->temp)))) || !file_exists($this->temp))
|
||||||
error('Failed to resize image!', null, $error);
|
error('Failed to resize image!', null, $error);
|
||||||
if ($size = $this->get_size($this->temp)) {
|
if ($size = $this->get_size($this->temp)) {
|
||||||
$this->width = $size[0];
|
$this->width = $size[0];
|
||||||
@ -340,14 +344,18 @@ class ImageConvert extends ImageBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ($error = shell_exec_error(($this->gm ? 'gm ' : '') . 'convert ' .
|
if ($config['convert_manual_orient'])
|
||||||
sprintf($config['convert_args'],
|
$convert_args = str_replace('-auto-orient', ImageConvert::jpeg_exif_orientation($this->src), $config['convert_args']);
|
||||||
|
else
|
||||||
|
$convert_args = &$config['convert_args'];
|
||||||
|
if (($error = shell_exec_error(($this->gm ? 'gm ' : '') . 'convert ' .
|
||||||
|
sprintf($convert_args,
|
||||||
$this->width,
|
$this->width,
|
||||||
$this->height,
|
$this->height,
|
||||||
escapeshellarg($this->src . '[0]'),
|
escapeshellarg($this->src . '[0]'),
|
||||||
$this->width,
|
$this->width,
|
||||||
$this->height,
|
$this->height,
|
||||||
escapeshellarg($this->temp))) || !file_exists($this->temp))
|
escapeshellarg($this->temp)))) || !file_exists($this->temp))
|
||||||
error('Failed to resize image!', null, $error);
|
error('Failed to resize image!', null, $error);
|
||||||
if ($size = $this->get_size($this->temp)) {
|
if ($size = $this->get_size($this->temp)) {
|
||||||
$this->width = $size[0];
|
$this->width = $size[0];
|
||||||
@ -355,6 +363,69 @@ class ImageConvert extends ImageBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For when -auto-orient doesn't exist (older versions)
|
||||||
|
static public function jpeg_exif_orientation($src, $exif = false) {
|
||||||
|
if (!$exif) {
|
||||||
|
$exif = exif_read_data($src);
|
||||||
|
if (!isset($exif['Orientation']))
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
switch($exif['Orientation']) {
|
||||||
|
case 1:
|
||||||
|
// Normal
|
||||||
|
return false;
|
||||||
|
case 2:
|
||||||
|
// 888888
|
||||||
|
// 88
|
||||||
|
// 8888
|
||||||
|
// 88
|
||||||
|
// 88
|
||||||
|
|
||||||
|
return '-flop';
|
||||||
|
case 3:
|
||||||
|
|
||||||
|
// 88
|
||||||
|
// 88
|
||||||
|
// 8888
|
||||||
|
// 88
|
||||||
|
// 888888
|
||||||
|
|
||||||
|
return '-flip -flop';
|
||||||
|
case 4:
|
||||||
|
// 88
|
||||||
|
// 88
|
||||||
|
// 8888
|
||||||
|
// 88
|
||||||
|
// 888888
|
||||||
|
|
||||||
|
return '-flip';
|
||||||
|
case 5:
|
||||||
|
// 8888888888
|
||||||
|
// 88 88
|
||||||
|
// 88
|
||||||
|
|
||||||
|
return '-rotate 90 -flop';
|
||||||
|
case 6:
|
||||||
|
// 88
|
||||||
|
// 88 88
|
||||||
|
// 8888888888
|
||||||
|
|
||||||
|
return '-rotate 90';
|
||||||
|
case 7:
|
||||||
|
// 88
|
||||||
|
// 88 88
|
||||||
|
// 8888888888
|
||||||
|
|
||||||
|
return '-rotate "-90" -flop';
|
||||||
|
case 8:
|
||||||
|
// 8888888888
|
||||||
|
// 88 88
|
||||||
|
// 88
|
||||||
|
|
||||||
|
return '-rotate "-90"';
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class ImagePNG extends ImageBase {
|
class ImagePNG extends ImageBase {
|
||||||
|
12
post.php
12
post.php
@ -457,8 +457,16 @@ if (isset($_POST['delete'])) {
|
|||||||
$exif = exif_read_data($upload);
|
$exif = exif_read_data($upload);
|
||||||
$gm = in_array($config['thumb_method'], array('gm', 'gm+gifsicle'));
|
$gm = in_array($config['thumb_method'], array('gm', 'gm+gifsicle'));
|
||||||
if (isset($exif['Orientation']) && $exif['Orientation'] != 1) {
|
if (isset($exif['Orientation']) && $exif['Orientation'] != 1) {
|
||||||
if($error = shell_exec_error(($gm ? 'gm ' : '') . 'convert ' .
|
if ($config['convert_manual_orient']) {
|
||||||
escapeshellarg($upload) . ' -auto-orient ' . escapeshellarg($upload)))
|
$error = shell_exec_error(($gm ? 'gm ' : '') . 'convert ' .
|
||||||
|
escapeshellarg($upload) . ' ' .
|
||||||
|
ImageConvert::jpeg_exif_orientation(false, $exif) . ' +profile "*" ' .
|
||||||
|
escapeshellarg($upload));
|
||||||
|
} else {
|
||||||
|
$error = shell_exec_error(($gm ? 'gm ' : '') . 'convert ' .
|
||||||
|
escapeshellarg($upload) . ' -auto-orient ' . escapeshellarg($upload));
|
||||||
|
}
|
||||||
|
if ($error)
|
||||||
error('Could not auto-orient image!', null, $error);
|
error('Could not auto-orient image!', null, $error);
|
||||||
$size = @getimagesize($upload);
|
$size = @getimagesize($upload);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user