Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php /* +-----------------------------------------------------------------------+ | Th..
Decoded Output download
<?php
/*
+-----------------------------------------------------------------------+
| This file is part of the Roundcube Webmail client |
| |
| Copyright (C) The Roundcube Dev Team |
| |
| Licensed under the GNU General Public License version 3 or |
| any later version with exceptions for skins & plugins. |
| See the README file for a full license statement. |
| |
| PURPOSE: |
| Handles contact photo uploads |
+-----------------------------------------------------------------------+
| Author: Thomas Bruederli <[email protected]> |
+-----------------------------------------------------------------------+
*/
class rcmail_action_contacts_upload_photo extends rcmail_action_contacts_index
{
/**
* Supported image format types
* ImageMagick works with other non-image types (e.g. pdf), we don't want that here
*
* @var array
*/
public static $IMAGE_TYPES = ['jpeg', 'jpg', 'jp2', 'tiff', 'tif', 'bmp', 'eps', 'gif', 'png', 'png8', 'png24', 'png32', 'svg', 'ico'];
/**
* Request handler.
*
* @param array $args Arguments from the previous step(s)
*/
#[Override]
public function run($args = [])
{
$rcmail = rcmail::get_instance();
// clear all stored output properties (like scripts and env vars)
$rcmail->output->reset();
if (!empty($_FILES['_photo']['tmp_name'])) {
$filepath = $_FILES['_photo']['tmp_name'];
// check file type and resize image
$image = new rcube_image($_FILES['_photo']['tmp_name']);
$imageprop = $image->props();
$inserted = false;
if (
in_array(strtolower($imageprop['type']), self::$IMAGE_TYPES)
&& !empty($imageprop['width'])
&& !empty($imageprop['height'])
) {
$maxsize = intval($rcmail->config->get('contact_photo_size', 160));
$tmpfname = rcube_utils::temp_filename('imgconvert');
$save_hook = 'attachment_upload';
// scale image to a maximum size
if (($imageprop['width'] > $maxsize || $imageprop['height'] > $maxsize) && $image->resize($maxsize, $tmpfname)) {
$filepath = $tmpfname;
$save_hook = 'attachment_save';
}
// save uploaded file in storage backend
$attachment = [
'path' => $filepath,
'size' => $_FILES['_photo']['size'],
'name' => $_FILES['_photo']['name'],
'mimetype' => 'image/' . $imageprop['type'],
'group' => 'contact',
];
$inserted = $rcmail->insert_uploaded_file($attachment, $save_hook);
} else {
$attachment = ['error' => $rcmail->gettext('invalidimageformat')];
}
if ($inserted) {
$rcmail->output->command('replace_contact_photo', $attachment['id']);
} else {
// upload failed
self::upload_error($_FILES['_photo']['error'], $attachment);
}
} else {
self::upload_failure();
}
$rcmail->output->command('photo_upload_end');
$rcmail->output->send('iframe');
}
}
?>
Did this file decode correctly?
Original Code
<?php
/*
+-----------------------------------------------------------------------+
| This file is part of the Roundcube Webmail client |
| |
| Copyright (C) The Roundcube Dev Team |
| |
| Licensed under the GNU General Public License version 3 or |
| any later version with exceptions for skins & plugins. |
| See the README file for a full license statement. |
| |
| PURPOSE: |
| Handles contact photo uploads |
+-----------------------------------------------------------------------+
| Author: Thomas Bruederli <[email protected]> |
+-----------------------------------------------------------------------+
*/
class rcmail_action_contacts_upload_photo extends rcmail_action_contacts_index
{
/**
* Supported image format types
* ImageMagick works with other non-image types (e.g. pdf), we don't want that here
*
* @var array
*/
public static $IMAGE_TYPES = ['jpeg', 'jpg', 'jp2', 'tiff', 'tif', 'bmp', 'eps', 'gif', 'png', 'png8', 'png24', 'png32', 'svg', 'ico'];
/**
* Request handler.
*
* @param array $args Arguments from the previous step(s)
*/
#[Override]
public function run($args = [])
{
$rcmail = rcmail::get_instance();
// clear all stored output properties (like scripts and env vars)
$rcmail->output->reset();
if (!empty($_FILES['_photo']['tmp_name'])) {
$filepath = $_FILES['_photo']['tmp_name'];
// check file type and resize image
$image = new rcube_image($_FILES['_photo']['tmp_name']);
$imageprop = $image->props();
$inserted = false;
if (
in_array(strtolower($imageprop['type']), self::$IMAGE_TYPES)
&& !empty($imageprop['width'])
&& !empty($imageprop['height'])
) {
$maxsize = intval($rcmail->config->get('contact_photo_size', 160));
$tmpfname = rcube_utils::temp_filename('imgconvert');
$save_hook = 'attachment_upload';
// scale image to a maximum size
if (($imageprop['width'] > $maxsize || $imageprop['height'] > $maxsize) && $image->resize($maxsize, $tmpfname)) {
$filepath = $tmpfname;
$save_hook = 'attachment_save';
}
// save uploaded file in storage backend
$attachment = [
'path' => $filepath,
'size' => $_FILES['_photo']['size'],
'name' => $_FILES['_photo']['name'],
'mimetype' => 'image/' . $imageprop['type'],
'group' => 'contact',
];
$inserted = $rcmail->insert_uploaded_file($attachment, $save_hook);
} else {
$attachment = ['error' => $rcmail->gettext('invalidimageformat')];
}
if ($inserted) {
$rcmail->output->command('replace_contact_photo', $attachment['id']);
} else {
// upload failed
self::upload_error($_FILES['_photo']['error'], $attachment);
}
} else {
self::upload_failure();
}
$rcmail->output->command('photo_upload_end');
$rcmail->output->send('iframe');
}
}
Function Calls
None |
Stats
MD5 | d96665e7ab156fe9f01e07d519eb780d |
Eval Count | 0 |
Decode Time | 101 ms |