123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- <?php
- /* vim: set expandtab sw=4 ts=4 sts=4: */
- /**
- * Wrapper script for rendering transformations
- *
- * @package PhpMyAdmin
- */
- use PhpMyAdmin\Core;
- use PhpMyAdmin\Relation;
- use PhpMyAdmin\Response;
- use PhpMyAdmin\Transformations;
- /**
- *
- */
- define('IS_TRANSFORMATION_WRAPPER', true);
- /**
- * Gets a core script and starts output buffering work
- */
- require_once './libraries/common.inc.php';
- $relation = new Relation();
- $cfgRelation = $relation->getRelationsParam();
- /**
- * Ensures db and table are valid, else moves to the "parent" script
- */
- require_once './libraries/db_table_exists.inc.php';
- /**
- * Sets globals from $_REQUEST
- */
- $request_params = array(
- 'cn',
- 'ct',
- 'sql_query',
- 'transform_key',
- 'where_clause'
- );
- $size_params = array(
- 'newHeight',
- 'newWidth',
- );
- foreach ($request_params as $one_request_param) {
- if (isset($_REQUEST[$one_request_param])) {
- if (in_array($one_request_param, $size_params)) {
- $GLOBALS[$one_request_param] = intval($_REQUEST[$one_request_param]);
- if ($GLOBALS[$one_request_param] > 2000) {
- $GLOBALS[$one_request_param] = 2000;
- }
- } else {
- $GLOBALS[$one_request_param] = $_REQUEST[$one_request_param];
- }
- }
- }
- /**
- * Get the list of the fields of the current table
- */
- $GLOBALS['dbi']->selectDb($db);
- if (isset($where_clause)) {
- if (! Core::checkSqlQuerySignature($where_clause, isset($_GET['where_clause_sign']) ? $_GET['where_clause_sign'] : '')) {
- /* l10n: In case a SQL query did not pass a security check */
- Core::fatalError(__('There is an issue with your request.'));
- exit;
- }
- $result = $GLOBALS['dbi']->query(
- 'SELECT * FROM ' . PhpMyAdmin\Util::backquote($table)
- . ' WHERE ' . $where_clause . ';',
- PhpMyAdmin\DatabaseInterface::CONNECT_USER,
- PhpMyAdmin\DatabaseInterface::QUERY_STORE
- );
- $row = $GLOBALS['dbi']->fetchAssoc($result);
- } else {
- $result = $GLOBALS['dbi']->query(
- 'SELECT * FROM ' . PhpMyAdmin\Util::backquote($table) . ' LIMIT 1;',
- PhpMyAdmin\DatabaseInterface::CONNECT_USER,
- PhpMyAdmin\DatabaseInterface::QUERY_STORE
- );
- $row = $GLOBALS['dbi']->fetchAssoc($result);
- }
- // No row returned
- if (! $row) {
- exit;
- } // end if (no record returned)
- $default_ct = 'application/octet-stream';
- if ($cfgRelation['commwork'] && $cfgRelation['mimework']) {
- $mime_map = Transformations::getMIME($db, $table);
- $mime_options = Transformations::getOptions(
- isset($mime_map[$transform_key]['transformation_options'])
- ? $mime_map[$transform_key]['transformation_options'] : ''
- );
- foreach ($mime_options as $key => $option) {
- if (substr($option, 0, 10) == '; charset=') {
- $mime_options['charset'] = $option;
- }
- }
- }
- // Only output the http headers
- $response = Response::getInstance();
- $response->getHeader()->sendHttpHeaders();
- // [MIME]
- if (isset($ct) && ! empty($ct)) {
- $mime_type = $ct;
- } else {
- $mime_type = (!empty($mime_map[$transform_key]['mimetype'])
- ? str_replace('_', '/', $mime_map[$transform_key]['mimetype'])
- : $default_ct)
- . (isset($mime_options['charset']) ? $mime_options['charset'] : '');
- }
- Core::downloadHeader($cn, $mime_type);
- if (! isset($_REQUEST['resize'])) {
- if (stripos($mime_type, 'html') === false) {
- echo $row[$transform_key];
- } else {
- echo htmlspecialchars($row[$transform_key]);
- }
- } else {
- // if image_*__inline.inc.php finds that we can resize,
- // it sets the resize parameter to jpeg or png
- $srcImage = imagecreatefromstring($row[$transform_key]);
- $srcWidth = ImageSX($srcImage);
- $srcHeight = ImageSY($srcImage);
- // Check to see if the width > height or if width < height
- // if so adjust accordingly to make sure the image
- // stays smaller than the new width and new height
- $ratioWidth = $srcWidth/$_REQUEST['newWidth'];
- $ratioHeight = $srcHeight/$_REQUEST['newHeight'];
- if ($ratioWidth < $ratioHeight) {
- $destWidth = $srcWidth/$ratioHeight;
- $destHeight = $_REQUEST['newHeight'];
- } else {
- $destWidth = $_REQUEST['newWidth'];
- $destHeight = $srcHeight/$ratioWidth;
- }
- if ($_REQUEST['resize']) {
- $destImage = ImageCreateTrueColor($destWidth, $destHeight);
- }
- // ImageCopyResized($destImage, $srcImage, 0, 0, 0, 0,
- // $destWidth, $destHeight, $srcWidth, $srcHeight);
- // better quality but slower:
- ImageCopyResampled(
- $destImage, $srcImage, 0, 0, 0, 0, $destWidth,
- $destHeight, $srcWidth, $srcHeight
- );
- if ($_REQUEST['resize'] == 'jpeg') {
- ImageJPEG($destImage, null, 75);
- }
- if ($_REQUEST['resize'] == 'png') {
- ImagePNG($destImage);
- }
- ImageDestroy($srcImage);
- ImageDestroy($destImage);
- }
|