Make this usage of $sql_backquotes less cryptic
[phpmyadmin.git] / transformation_wrapper.php
blob577a4353a07c8aefc94379e1259fd7b8c3a6f09d
1 <?php
2 /* vim: set expandtab sw=4 ts=4 sts=4: */
3 /**
5 * @package phpMyAdmin
6 */
8 /**
11 define('IS_TRANSFORMATION_WRAPPER', true);
13 /**
14 * Gets a core script and starts output buffering work
16 require_once './libraries/common.inc.php';
17 require_once './libraries/transformations.lib.php'; // Transformations
18 $cfgRelation = PMA_getRelationsParam();
20 /**
21 * Ensures db and table are valid, else moves to the "parent" script
23 require_once './libraries/db_table_exists.lib.php';
26 /**
27 * Get the list of the fields of the current table
29 PMA_DBI_select_db($db);
30 $table_def = PMA_DBI_query('SHOW FIELDS FROM ' . PMA_backquote($table), null, PMA_DBI_QUERY_STORE);
31 if (isset($where_clause)) {
32 $result = PMA_DBI_query('SELECT * FROM ' . PMA_backquote($table) . ' WHERE ' . $where_clause . ';', null, PMA_DBI_QUERY_STORE);
33 $row = PMA_DBI_fetch_assoc($result);
34 } else {
35 $result = PMA_DBI_query('SELECT * FROM ' . PMA_backquote($table) . ' LIMIT 1;', null, PMA_DBI_QUERY_STORE);
36 $row = PMA_DBI_fetch_assoc($result);
39 // No row returned
40 if (!$row) {
41 exit;
42 } // end if (no record returned)
44 $default_ct = 'application/octet-stream';
46 if ($cfgRelation['commwork'] && $cfgRelation['mimework']) {
47 $mime_map = PMA_getMime($db, $table);
48 $mime_options = PMA_transformation_getOptions((isset($mime_map[$transform_key]['transformation_options']) ? $mime_map[$transform_key]['transformation_options'] : ''));
50 foreach ($mime_options AS $key => $option) {
51 if (substr($option, 0, 10) == '; charset=') {
52 $mime_options['charset'] = $option;
57 // For re-usability, moved http-headers and stylesheets
58 // to a seperate file. It can now be included by libraries/header.inc.php,
59 // querywindow.php.
61 require_once './libraries/header_http.inc.php';
62 // [MIME]
63 if (isset($ct) && !empty($ct)) {
64 $mime_type = $ct;
65 } else {
66 $mime_type = (isset($mime_map[$transform_key]['mimetype']) ? str_replace('_', '/', $mime_map[$transform_key]['mimetype']) : $default_ct) . (isset($mime_options['charset']) ? $mime_options['charset'] : '');
69 if (empty($cn)) {
70 $cn = 'download.bin';
73 PMA_download_header($mime_type, $cn);
75 if (! isset($resize)) {
76 echo $row[$transform_key];
77 } else {
78 // if image_*__inline.inc.php finds that we can resize,
79 // it sets $resize to jpeg or png
81 $srcImage = imagecreatefromstring($row[$transform_key]);
82 $srcWidth = ImageSX($srcImage);
83 $srcHeight = ImageSY($srcImage);
85 // Check to see if the width > height or if width < height
86 // if so adjust accordingly to make sure the image
87 // stays smaller then the $newWidth and $newHeight
89 $ratioWidth = $srcWidth/$newWidth;
90 $ratioHeight = $srcHeight/$newHeight;
92 if ($ratioWidth < $ratioHeight) {
93 $destWidth = $srcWidth/$ratioHeight;
94 $destHeight = $newHeight;
95 } else {
96 $destWidth = $newWidth;
97 $destHeight = $srcHeight/$ratioWidth;
100 if ($resize) {
101 $destImage = ImageCreateTrueColor($destWidth, $destHeight);
104 // ImageCopyResized($destImage, $srcImage, 0, 0, 0, 0, $destWidth, $destHeight, $srcWidth, $srcHeight);
105 // better quality but slower:
106 ImageCopyResampled($destImage, $srcImage, 0, 0, 0, 0, $destWidth, $destHeight, $srcWidth, $srcHeight);
108 if ($resize == 'jpeg') {
109 ImageJPEG($destImage, '', 75);
111 if ($resize == 'png') {
112 ImagePNG($destImage);
114 ImageDestroy($srcImage);
115 ImageDestroy($destImage);