123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- <?php
- /**
- * GNU Social
- * Copyright (C) 2011, Free Software Foundation, Inc.
- *
- * PHP version 5
- *
- * LICENCE:
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- * @package GNU Social
- * @author Ian Denhardt <ian@zenhack.net>
- * @copyright 2011 Free Software Foundation, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
- */
- if(!defined('STATUSNET')){
- exit(1);
- }
- class NewphotoAction extends Action
- {
- var $user = null;
- function prepare(array $args = array())
- {
- parent::prepare($args);
- $this->user = common_current_user();
- if(empty($this->user)){
- throw new ClientException(_('Must be logged in to post a photo'),
- 403);
- }
- if($this->isPost()){
- $this->checkSessionToken();
- }
- return true;
- }
- function handle()
- {
- parent::handle();
- if ($this->isPost()) {
- $this->handlePost($args);
- } else {
- $this->showPage();
- }
- }
-
- function handlePost($args)
- {
- /*
- // Workaround for PHP returning empty $_POST and $_FILES when POST
- // length > post_max_size in php.ini
- if (empty($_FILES)
- && empty($_POST)
- && ($_SERVER['CONTENT_LENGTH'] > 0)
- ) {
- $msg = _('The server was unable to handle that much POST ' .
- 'data (%s bytes) due to its current configuration.');
- $this->showForm(sprintf($msg, $_SERVER['CONTENT_LENGTH']));
- return;
- } */
- $profile = $this->user->getProfile();
- $options = array();
-
- ToSelector::fillOptions($this, $options);
- try {
- $this->handleUpload();
- } catch (Exception $e) {
- $this->showForm($e->getMessage());
- return;
- }
-
- common_redirect($photo->uri, 303);
- }
- function getUpload()
- {
- $imagefile = ImageFile::fromUpload('photo_upload');
- if($imagefile === null) {
- throw new Exception(_('No file uploaded'));
- }
- $title = $this->trimmed('title');
- $description = $this->trimmed('description');
- $new_filename = UUID::gen() . image_type_to_extension($imagefile->type);
- move_uploaded_file($imagefile->filepath, INSTALLDIR . '/file/' . $new_filename);
-
- // XXX: we should be using https where we can. TODO: detect whether the server
- // supports this.
- $photo_uri = 'http://' . common_config('site', 'server') . '/file/'
- . $new_filename;
- $thumb_uri = $photo_uri;
-
- $photo = Photo::saveNew($profile, $photo_uri, $thumb_uri, $title,
- $description, $options);
-
- }
- function showContent()
- {
- $form = new NewPhotoForm();
- $form->show();
- }
- }
|