| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- <?php
- class DB_Image {
- public static function conf_get( $key ) {
- static $conf;
- if (empty($conf)) {
- $conf['table_name'] = 'CRM_IMAGE';
- $conf['max_size'] = 1024 * 1024 * 16;// MAX for MEDIUMBLOB field
- $conf['allowed_types'] = array();
- $conf['allowed_types'] []= 'image/png';
- $conf['allowed_types'] []= 'image/jpeg';
- $conf['allowed_types'] []= 'image/gif';
- $conf['remote_tables'] = array();
- $conf['remote_tables'] []= 'CRM_LISTA_ZASOBOW';
- $conf['remote_tables'] []= 'CRM_PROCES';
- $conf['remote_tables'] []= 'CRM_WSKAZNIK';
- $conf['desc_options'] = array();
- $conf['desc_options']['CRM_LISTA_ZASOBOW'] = array();
- $conf['desc_options']['CRM_PROCES'] = array();
- $conf['desc_options']['CRM_WSKAZNIK'] = array();
- $conf['desc_options_conf'] = array();
- $conf['desc_options_conf']['CRM_LISTA_ZASOBOW'] = array();
- $conf['desc_options_conf']['CRM_PROCES'] = array();
- $conf['desc_options_conf']['CRM_WSKAZNIK'] = array();
- $options = array();
- $options['screenshot'] = "screenshot (800x600)";
- $options['icon'] = "icon (16x16)";
- $conf['desc_options']['CRM_LISTA_ZASOBOW'] = $options;
- $conf['desc_options']['CRM_PROCES'] = $options;
- $conf['desc_options']['CRM_WSKAZNIK'] = $options;
- $desc_options_conf = array();
- $desc_options_conf['screenshot']['max_width'] = 800;
- $desc_options_conf['screenshot']['max_height'] = 600;
- $desc_options_conf['icon']['max_width'] = 16;
- $desc_options_conf['icon']['max_height'] = 16;
- $conf['desc_options_conf']['CRM_LISTA_ZASOBOW'] = $desc_options_conf;
- $conf['desc_options_conf']['CRM_PROCES'] = $desc_options_conf;
- $conf['desc_options_conf']['CRM_WSKAZNIK'] = $desc_options_conf;
- }
- if (array_key_exists($key, $conf)) {
- return $conf[ $key ];
- }
- return null;
- }
- public static function conf_get_table_name() {
- return self::conf_get('table_name');
- }
- /*
- * Get options for table.
- */
- public static function conf_get_options( $table ) {
- $ret = array();
- $arr = self::conf_get('desc_options');
- if (array_key_exists($table, $arr)) {
- return $arr[$table];
- }
- return $ret;
- }
- /*
- * Get config for all options.
- */
- public static function conf_get_options_conf( $table ) {
- $ret = array();
- $arr = self::conf_get('desc_options_conf');
- if (array_key_exists($table, $arr)) {
- return $arr[$table];
- }
- return $ret;
- }
- /*
- * Get config for selected option.
- */
- public static function conf_get_option_conf( $table, $key ) {
- $ret = array();
- $arr = self::conf_get('desc_options_conf');
- if (array_key_exists($table, $arr)) {
- if (array_key_exists($key, $arr[$table])) {
- return $arr[$table][$key];
- }
- }
- return $ret;
- }
- public static function is_allowed_type( $type ) {
- $allowed_types = self::conf_get('allowed_types');
- if (in_array($type, $allowed_types)) {
- return true;
- }
- return false;
- }
- public static function read_image_data( $file, $mime_type ){
- $im = null;
- if ($mime_type == 'image/jpeg') {
- $im = imagecreatefromjpeg( $file );
- } else if ($mime_type == 'image/png') {
- $im = imagecreatefrompng( $file );
- } else if ($mime_type == 'image/gif') {
- $im = imagecreatefromgif( $file );
- }
- return $im;
- }
- public static function get_images($remote_table, $remote_id) {
- $db = DB::getDB();
- $images = array();
- $sql = "select
- t.`ID`, t.`NAME`, t.`SIZE`, t.`TYPE`, t.`WIDTH`, t.`HEIGHT`
- , t.`DEST`, t.`A_CREATE_DATE`
- , t.`REMOTE_TABLE`, t.`REMOTE_ID`
- , UNIX_TIMESTAMP(`A_CREATE_DATE`) as A_CREATE_DATE_TS
- from `".self::conf_get_table_name()."` as t
- where
- t.`REMOTE_TABLE`='".$remote_table."'
- and t.`REMOTE_ID`='".$remote_id."'
- ";
- $res = $db->query($sql);
- while ($r = $db->fetch( $res )) {
- $images []= $r;
- }
- return $images;
- }
- /**
- * Try to upload image to DB.
- * @returns Array of errors
- */
- public static function upload_image($remote_table, $remote_id, $req_file_data) {
- $errors = array();
- $maxsize = self::conf_get('max_size');
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">$_FILES = ';print_r($_FILES);echo'</pre>';
- if (is_uploaded_file($req_file_data['tmp_name'])) {
- // check the file is less than the maximum file size
- if ($req_file_data['size'] < $maxsize) {
- // prepare the image for insertion
- //$imgData = mysql_real_escape_string(file_get_contents($req_file_data['tmp_name']), $conn);// nie dziala mysql_real_escape_string
- $fp = fopen($req_file_data['tmp_name'], 'r');
- $imgData = fread($fp, filesize($req_file_data['tmp_name']));
- $imgData = addslashes($imgData);
- fclose($fp);
- // get the image info..
- $size = getimagesize($req_file_data['tmp_name']);
- $obj = array();
- $obj['DEST'] = (isset($_REQUEST['DEST']))? $_REQUEST['DEST'] : '';
- $obj['TYPE'] = $size['mime'];
- $obj['IMAGE'] = $imgData;
- $obj['WIDTH'] = $size[0];
- $obj['HEIGHT'] = $size[1];
- $obj['NAME'] = $req_file_data['name'];
- $obj['SIZE'] = $req_file_data['size'];
- $obj['REMOTE_TABLE'] = $remote_table;
- $obj['REMOTE_ID'] = $remote_id;
- // check if type is allowed to upload
- if (!DB_Image::is_allowed_type($obj['TYPE'])) {
- $errors []= 'File type "'.$obj['TYPE'].'" is not allowed.';
- return $errors;
- }
- // convert image if selected option
- if ($obj['DEST']) {
- $options_conf = DB_Image::conf_get_option_conf( $remote_table, $obj['DEST'] );
- if (!empty($options_conf)) {
- $max_width = 0;
- $max_height = 0;
- if (isset($options_conf['max_height']) && $obj['HEIGHT'] > $options_conf['max_height']) {
- $max_height = $options_conf['max_height'];
- }
- if (isset($options_conf['max_width']) && $obj['WIDTH'] > $options_conf['max_width']) {
- $max_width = $options_conf['max_width'];
- }
- if ($max_height || $max_width) {
- //$img = DB_Image::resize_image($req_file_data['tmp_name'], $max_width, $max_height);
- //open image, from file to data
- // read data
- $im = DB_Image::read_image_data($req_file_data['tmp_name'], $obj['TYPE']);
- // resize image
- $im = DB_Image::resize_image_from_data($im, $max_width, $max_height);
- ob_start();
- imagejpeg($im);
- $obj['IMAGE'] = ob_get_clean();
- $obj['SIZE'] = strlen($obj['IMAGE']);
- $obj['IMAGE'] = addslashes($obj['IMAGE']);
- $obj['WIDTH'] = imagesx($im);
- $obj['HEIGHT'] = imagesy($im);
- }
- }
- }
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">size = ';print_r($size);echo'</pre>';
- $sql_arr = array();
- foreach ($obj as $key => $val) {
- $sql_arr["`".$key."`"] = "'".$val."'";
- }//end foreach
- $sql = "insert into `".self::conf_get_table_name()."` (".implode(",", array_keys($sql_arr)).") values (".implode(",", array_values($sql_arr)).") ; ";
- // insert the image
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">sql = ';print_r($sql);echo'</pre>';
- $db = DB::getDB();
- if (!$db->query($sql)) {
- $errors []= 'Unable to upload file - sql error';
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">mysql err: '.mysql_errno($conn);var_dump(mysql_error($conn));echo'</pre>';
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">sql: ';print_r($sql);echo'</pre>';
- }
- self::update_remote_table_stat( $remote_table, $remote_id );
- }
- }
- else {
- // if the file is not less than the maximum allowed, print an error
- $errors []= 'File exceeds the Maximum File limit';
- }
- return $errors;
- }
- public static function delete_image($id, $remote_table, $remote_id) {
- $db = DB::getDB();
- $sql = "delete from `".self::conf_get_table_name()."`
- where
- `ID`='".$id."'
- and `REMOTE_ID`='".$remote_id."'
- and `REMOTE_TABLE`='".$remote_table."'
- limit 1
- ";
- //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;">sql delete = ';print_r($sql);echo'</pre>';
- $db->query( $sql );
- $affected = $db->affected_rows();
- self::update_remote_table_stat( $remote_table, $remote_id );
- return $affected;
- }
- /**
- * Updates field ITEM_IMAGE_REMOTE in remote table.
- * TODO: check if field exists!
- */
- public static function update_remote_table_stat($remote_table, $remote_id) {
- // update stat `ITEM_IMAGE_REMOTE`
- $sql = "update `".$remote_table."`
- set `A_HAS_IMAGE`=(
- select count(1)
- from `".self::conf_get('table_name')."`
- where
- `REMOTE_ID`='".$remote_id."'
- and `REMOTE_TABLE`='".$remote_table."'
- )
- where `ID`='".$remote_id."'
- limit 1;
- ";
- $db = DB::getDB();
- $res = $db->query( $sql );
- $affected = $db->affected_rows();
- }
- public static function resize_image($file, $w, $h, $crop=FALSE) {
- // TODO: image type
- $im = imagecreatefromjpeg($file);
- return self::resize_image_from_data($im, $w, $h, $crop);
- }
- public static function resize_image_from_data($im, $w, $h, $crop=FALSE) {
- if ($w == 0) $w = $h;
- if ($h == 0) $h = $w;
- $width = imagesx($im);
- $height = imagesy($im);
- if ($width < $w && $height < $h) {
- return $im;
- }
- $r = $width / $height;
- if ($crop) {
- if ($width > $height) {
- $width = ceil($width-($width*($r-$w/$h)));
- } else {
- $height = ceil($height-($height*($r-$w/$h)));
- }
- $newwidth = $w;
- $newheight = $h;
- } else {
- if ($w/$h > $r) {
- $newwidth = $h*$r;
- $newheight = $h;
- } else {
- $newheight = $w/$r;
- $newwidth = $w;
- }
- }
- $dst = imagecreatetruecolor($newwidth, $newheight);
- imagecopyresampled($dst, $im, 0, 0, 0, 0, $newwidth, $newheight, $width, $height);
- return $dst;
- }
- public static function show_size( $size ) {
- $ret_unit = 'B';
- if ($size > 1024 * 1024) {
- $size = $size / (1024 * 1024);
- $ret_unit = 'MB';
- } else if ($size > 1024) {
- $size = $size / 1024;
- $ret_unit = 'KB';
- }
- return number_format($size, 2, '.', ' ').''.$ret_unit;
- }
- }
|