3 * Laconica, the distributed open-source microblogging tool
5 * Abstraction for an image file
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Evan Prodromou <evan@controlyourself.ca>
25 * @author Zach Copley <zach@controlyourself.ca>
26 * @copyright 2008-2009 Control Yourself, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
28 * @link http://laconi.ca/
31 if (!defined('LACONICA')) {
36 * A wrapper on uploaded files
38 * Makes it slightly easier to accept an image file from upload.
42 * @author Evan Prodromou <evan@controlyourself.ca>
43 * @author Zach Copley <zach@controlyourself.ca>
44 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
45 * @link http://laconi.ca/
53 function __construct($filename=null, $type=null)
55 $this->filename = $filename;
59 static function fromUpload($param='upload')
61 switch ($_FILES[$param]['error']) {
62 case UPLOAD_ERR_OK: // success, jump out
64 case UPLOAD_ERR_INI_SIZE:
65 case UPLOAD_ERR_FORM_SIZE:
66 throw new Exception(_('That file is too big.'));
68 case UPLOAD_ERR_PARTIAL:
69 @unlink($_FILES[$param]['tmp_name']);
70 throw new Exception(_('Partial upload.'));
73 throw new Exception(_('System error uploading file.'));
77 $imagefile = new ImageFile($_FILES[$param]['tmp_name']);
78 $info = @getimagesize($imagefile->filename);
81 @unlink($imagefile->filename);
82 throw new Exception(_('Not an image or corrupt file.'));
90 $imagefile->type = $info[2];
93 @unlink($imagefile->filename);
94 throw new Exception(_('Unsupported image file format.'));
103 @unlink($this->filename);