/home/mjc1/public_html/db_admin/transformation_wrapper.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php
/* $Id: transformation_wrapper.php,v 2.7 2004/08/21 13:41:41 lem9 Exp $ */
// vim: expandtab sw=4 ts=4 sts=4:

$is_transformation_wrapper true;

/**
 * Get the variables sent or posted to this script and displays the header
 */
require_once('./libraries/grab_globals.lib.php');

/**
 * Gets a core script and starts output buffering work
 */
require_once('./libraries/common.lib.php');
require_once(
'./libraries/relation.lib.php'); // foreign keys
require_once('./libraries/transformations.lib.php'); // Transformations
$cfgRelation PMA_getRelationsParam();

/**
 * Ensures db and table are valid, else moves to the "parent" script
 */
require_once('./libraries/db_table_exists.lib.php');


/**
 * Get the list of the fields of the current table
 */
PMA_DBI_select_db($db);
$table_def PMA_DBI_query('SHOW FIELDS FROM ' PMA_backquote($table), NULLPMA_DBI_QUERY_STORE);
if (isset(
$primary_key)) {
    
$result      PMA_DBI_query('SELECT * FROM ' PMA_backquote($table) . ' WHERE ' $primary_key ';'NULLPMA_DBI_QUERY_STORE);
    
$row         PMA_DBI_fetch_assoc($result);
} else {
    
$result      PMA_DBI_query('SELECT * FROM ' PMA_backquote($table) . ' LIMIT 1;'NULLPMA_DBI_QUERY_STORE);
    
$row         PMA_DBI_fetch_assoc($result);
}

// No row returned
if (!$row) {
    exit;
// end if (no record returned)

$default_ct 'application/octet-stream';

if (
$cfgRelation['commwork'] && $cfgRelation['mimework']) {
    
$mime_map PMA_getMime($db$table);
    
$mime_options PMA_transformation_getOptions((isset($mime_map[urldecode($transform_key)]['transformation_options']) ? $mime_map[urldecode($transform_key)]['transformation_options'] : ''));

    foreach (
$mime_options AS $key => $option) {
        if (
substr($option010) == '; charset=') {
            
$mime_options['charset'] = $option;
        }
    }
}

// garvin: For re-usability, moved http-headers and stylesheets
// to a seperate file. It can now be included by header.inc.php,
// queryframe.php, querywindow.php.

require_once('./libraries/header_http.inc.php');
// [MIME]
if (isset($ct) && !empty($ct)) {
    
$content_type 'Content-Type: ' urldecode($ct);
} else {
    
$content_type 'Content-Type: ' . (isset($mime_map[urldecode($transform_key)]['mimetype']) ? str_replace('_''/'$mime_map[urldecode($transform_key)]['mimetype']) : $default_ct) . (isset($mime_options['charset']) ? $mime_options['charset'] : '');
}

if (isset(
$cn) && !empty($cn)) {
    
$content_type .= "\n" 'Content-Disposition: attachment; filename=' urldecode($cn);
}

header($content_type);

if (!isset(
$resize)) {
    echo 
$row[urldecode($transform_key)];
} else {
    
// if image_*__inline.inc.php finds that we can resize,
    // it sets $resize to jpeg or png

    
$srcImage imagecreatefromstring($row[urldecode($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 then the $newWidth and $newHeight

    
$ratioWidth $srcWidth/$newWidth;
    
$ratioHeight $srcHeight/$newHeight;

    if (
$ratioWidth $ratioHeight){
        
$destWidth $srcWidth/$ratioHeight;
        
$destHeight $newHeight;
    }else{
        
$destWidth $newWidth;
        
$destHeight $srcHeight/$ratioWidth;
    }

    if (
$resize) {
        
$destImage ImageCreateTrueColor$destWidth$destHeight);
    }

//    ImageCopyResized( $destImage, $srcImage, 0, 0, 0, 0, $destWidth, $destHeight, $srcWidth, $srcHeight );
// better quality but slower:
    
ImageCopyResampled$destImage$srcImage0000$destWidth$destHeight$srcWidth$srcHeight );

    if (
$resize == 'jpeg') {
        
ImageJPEG$destImage,'',75 );
    }
    if (
$resize == 'png') {
        
ImagePNG$destImage);
    }
    
ImageDestroy$srcImage );
    
ImageDestroy$destImage );
}

/**
 * Close MySql non-persistent connections
 */
if (isset($GLOBALS['dbh']) && $GLOBALS['dbh']) {
    @
PMA_DBI_close($GLOBALS['dbh']);
}
if (isset(
$GLOBALS['userlink']) && $GLOBALS['userlink']) {
    @
PMA_DBI_close($GLOBALS['userlink']);
}
?>