172 lines
6.6 KiB
PHP
172 lines
6.6 KiB
PHP
![]() |
<?php
|
||
|
/* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
||
|
/*
|
||
|
# ***** BEGIN LICENSE BLOCK *****
|
||
|
# This file is part of InDefero, an open source project management application.
|
||
|
# Copyright (C) 2008-2011 Céondo Ltd and contributors.
|
||
|
#
|
||
|
# InDefero is free software; you can redistribute it and/or modify
|
||
|
# it under the terms of the GNU General Public License as published by
|
||
|
# the Free Software Foundation; either version 2 of the License, or
|
||
|
# (at your option) any later version.
|
||
|
#
|
||
|
# InDefero 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 General Public License for more details.
|
||
|
#
|
||
|
# You should have received a copy of the GNU General Public License
|
||
|
# along with this program; if not, write to the Free Software
|
||
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||
|
#
|
||
|
# ***** END LICENSE BLOCK ***** */
|
||
|
|
||
|
/**
|
||
|
* Upload and process an archive file.
|
||
|
*
|
||
|
*/
|
||
|
class IDF_Form_UploadArchive extends Pluf_Form
|
||
|
{
|
||
|
public $user = null;
|
||
|
public $project = null;
|
||
|
|
||
|
public function initFields($extra=array())
|
||
|
{
|
||
|
$this->user = $extra['user'];
|
||
|
$this->project = $extra['project'];
|
||
|
|
||
|
$this->fields['archive'] = new Pluf_Form_Field_File(
|
||
|
array('required' => true,
|
||
|
'label' => __('Archive file'),
|
||
|
'initial' => '',
|
||
|
'max_size' => Pluf::f('max_upload_archive_size', 20971520),
|
||
|
));
|
||
|
}
|
||
|
|
||
|
|
||
|
public function clean_archive()
|
||
|
{
|
||
|
$extra = strtolower(implode('|', explode(' ', Pluf::f('idf_extra_upload_ext'))));
|
||
|
if (strlen($extra)) $extra .= '|';
|
||
|
if (!preg_match('/\.('.$extra.'png|jpg|jpeg|gif|bmp|psd|tif|aiff|asf|avi|bz2|css|doc|eps|gz|jar|mdtext|mid|mov|mp3|mpg|ogg|pdf|ppt|ps|qt|ra|ram|rm|rtf|sdd|sdw|sit|sxi|sxw|swf|tgz|txt|wav|xls|xml|war|wmv|zip)$/i', $this->cleaned_data['file'])) {
|
||
|
@unlink(Pluf::f('upload_path').'/'.$this->project->shortname.'/files/'.$this->cleaned_data['file']);
|
||
|
throw new Pluf_Form_Invalid(__('For security reasons, you cannot upload a file with this extension.'));
|
||
|
}
|
||
|
return $this->cleaned_data['file'];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Validate the interconnection in the form.
|
||
|
*/
|
||
|
public function clean()
|
||
|
{
|
||
|
$conf = new IDF_Conf();
|
||
|
$conf->setProject($this->project);
|
||
|
$onemax = array();
|
||
|
foreach (explode(',', $conf->getVal('labels_download_one_max', IDF_Form_UploadConf::init_one_max)) as $class) {
|
||
|
if (trim($class) != '') {
|
||
|
$onemax[] = mb_strtolower(trim($class));
|
||
|
}
|
||
|
}
|
||
|
$count = array();
|
||
|
for ($i=1;$i<7;$i++) {
|
||
|
$this->cleaned_data['label'.$i] = trim($this->cleaned_data['label'.$i]);
|
||
|
if (strpos($this->cleaned_data['label'.$i], ':') !== false) {
|
||
|
list($class, $name) = explode(':', $this->cleaned_data['label'.$i], 2);
|
||
|
list($class, $name) = array(mb_strtolower(trim($class)),
|
||
|
trim($name));
|
||
|
} else {
|
||
|
$class = 'other';
|
||
|
$name = $this->cleaned_data['label'.$i];
|
||
|
}
|
||
|
if (!isset($count[$class])) $count[$class] = 1;
|
||
|
else $count[$class] += 1;
|
||
|
if (in_array($class, $onemax) and $count[$class] > 1) {
|
||
|
if (!isset($this->errors['label'.$i])) $this->errors['label'.$i] = array();
|
||
|
$this->errors['label'.$i][] = sprintf(__('You cannot provide more than label from the %s class to an issue.'), $class);
|
||
|
throw new Pluf_Form_Invalid(__('You provided an invalid label.'));
|
||
|
}
|
||
|
}
|
||
|
return $this->cleaned_data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* If we have uploaded a file, but the form failed remove it.
|
||
|
*
|
||
|
*/
|
||
|
function failed()
|
||
|
{
|
||
|
if (!empty($this->cleaned_data['file'])
|
||
|
and file_exists(Pluf::f('upload_path').'/'.$this->project->shortname.'/files/'.$this->cleaned_data['file'])) {
|
||
|
@unlink(Pluf::f('upload_path').'/'.$this->project->shortname.'/files/'.$this->cleaned_data['file']);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Save the model in the database.
|
||
|
*
|
||
|
* @param bool Commit in the database or not. If not, the object
|
||
|
* is returned but not saved in the database.
|
||
|
* @return Object Model with data set from the form.
|
||
|
*/
|
||
|
function save($commit=true)
|
||
|
{
|
||
|
if (!$this->isValid()) {
|
||
|
throw new Exception(__('Cannot save the model from an invalid form.'));
|
||
|
}
|
||
|
// Add a tag for each label
|
||
|
$tags = array();
|
||
|
for ($i=1;$i<7;$i++) {
|
||
|
if (strlen($this->cleaned_data['label'.$i]) > 0) {
|
||
|
if (strpos($this->cleaned_data['label'.$i], ':') !== false) {
|
||
|
list($class, $name) = explode(':', $this->cleaned_data['label'.$i], 2);
|
||
|
list($class, $name) = array(trim($class), trim($name));
|
||
|
} else {
|
||
|
$class = 'Other';
|
||
|
$name = trim($this->cleaned_data['label'.$i]);
|
||
|
}
|
||
|
$tags[] = IDF_Tag::add($name, $this->project, $class);
|
||
|
}
|
||
|
}
|
||
|
// Create the upload
|
||
|
$upload = new IDF_Upload();
|
||
|
$upload->project = $this->project;
|
||
|
$upload->submitter = $this->user;
|
||
|
$upload->summary = trim($this->cleaned_data['summary']);
|
||
|
$upload->changelog = trim($this->cleaned_data['changelog']);
|
||
|
$upload->file = $this->cleaned_data['file'];
|
||
|
$upload->filesize = filesize(Pluf::f('upload_path').'/'.$this->project->shortname.'/files/'.$this->cleaned_data['file']);
|
||
|
$upload->downloads = 0;
|
||
|
$upload->create();
|
||
|
foreach ($tags as $tag) {
|
||
|
$upload->setAssoc($tag);
|
||
|
}
|
||
|
// Send the notification
|
||
|
$upload->notify($this->project->getConf());
|
||
|
/**
|
||
|
* [signal]
|
||
|
*
|
||
|
* IDF_Upload::create
|
||
|
*
|
||
|
* [sender]
|
||
|
*
|
||
|
* IDF_Form_Upload
|
||
|
*
|
||
|
* [description]
|
||
|
*
|
||
|
* This signal allows an application to perform a set of tasks
|
||
|
* just after the upload of a file and after the notification run.
|
||
|
*
|
||
|
* [parameters]
|
||
|
*
|
||
|
* array('upload' => $upload);
|
||
|
*
|
||
|
*/
|
||
|
$params = array('upload' => $upload);
|
||
|
Pluf_Signal::send('IDF_Upload::create', 'IDF_Form_Upload',
|
||
|
$params);
|
||
|
return $upload;
|
||
|
}
|
||
|
}
|
||
|
|