2008-09-29 05:18:23 +02:00
|
|
|
<?php
|
2012-04-14 08:36:50 +02:00
|
|
|
|
2008-09-29 05:18:23 +02:00
|
|
|
/**
|
2012-04-14 08:36:50 +02:00
|
|
|
* Allows a user to add a field that can be used to upload a file.
|
2009-04-17 04:26:40 +02:00
|
|
|
*
|
|
|
|
* @package userforms
|
2008-09-29 05:18:23 +02:00
|
|
|
*/
|
2016-07-21 07:53:59 +02:00
|
|
|
class EditableFileField extends EditableFormField
|
|
|
|
{
|
|
|
|
|
|
|
|
private static $singular_name = 'File Upload Field';
|
|
|
|
|
|
|
|
private static $plural_names = 'File Fields';
|
|
|
|
|
2016-08-12 00:51:47 +02:00
|
|
|
private static $db = array(
|
|
|
|
'MaxFileSizeMB' => 'Float',
|
|
|
|
);
|
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
private static $has_one = array(
|
|
|
|
'Folder' => 'Folder' // From CustomFields
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Further limit uploadable file extensions in addition to the restrictions
|
|
|
|
* imposed by the File.allowed_extensions global configuration.
|
|
|
|
* @config
|
|
|
|
*/
|
|
|
|
private static $allowed_extensions_blacklist = array(
|
|
|
|
'htm', 'html', 'xhtml', 'swf', 'xml'
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return FieldList
|
|
|
|
*/
|
|
|
|
public function getCMSFields()
|
|
|
|
{
|
|
|
|
$fields = parent::getCMSFields();
|
|
|
|
|
|
|
|
$fields->addFieldToTab(
|
|
|
|
'Root.Main',
|
|
|
|
TreeDropdownField::create(
|
|
|
|
'FolderID',
|
|
|
|
_t('EditableUploadField.SELECTUPLOADFOLDER', 'Select upload folder'),
|
|
|
|
'Folder'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2017-08-01 00:05:07 +02:00
|
|
|
$fields->addFieldToTab("Root.Main", new LiteralField(
|
|
|
|
"FileUploadWarning",
|
|
|
|
"<p class=\"message notice\">"
|
|
|
|
. _t(
|
|
|
|
"UserDefinedForm.FileUploadWarning",
|
|
|
|
"Files uploaded through this field could be publicly accessible if the exact URL is known"
|
|
|
|
) . "</p>"
|
|
|
|
), "Type");
|
2016-08-12 00:51:47 +02:00
|
|
|
|
|
|
|
$fields->addFieldToTab(
|
|
|
|
'Root.Main',
|
|
|
|
NumericField::create('MaxFileSizeMB')
|
|
|
|
->setTitle('Max File Size MB')
|
2016-10-13 06:34:23 +02:00
|
|
|
->setDescription("Note: Maximum php allowed size is {$this->getPHPMaxFileSizeMB()} MB")
|
2016-08-12 00:51:47 +02:00
|
|
|
);
|
2016-07-21 07:53:59 +02:00
|
|
|
|
2017-08-01 00:05:07 +02:00
|
|
|
$fields->removeByName('Default');
|
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
return $fields;
|
|
|
|
}
|
|
|
|
|
2016-08-12 00:51:47 +02:00
|
|
|
/**
|
|
|
|
* @return ValidationResult
|
|
|
|
*/
|
|
|
|
public function validate()
|
|
|
|
{
|
|
|
|
$result = parent::validate();
|
|
|
|
|
|
|
|
$max = static::get_php_max_file_size();
|
|
|
|
if ($this->MaxFileSizeMB * 1024 > $max) {
|
|
|
|
$result->error("Your max file size limit can't be larger than the server's limit of {$this->getPHPMaxFileSizeMB()}.");
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
public function getFormField()
|
|
|
|
{
|
2016-04-28 08:05:19 +02:00
|
|
|
$field = FileField::create($this->Name, $this->EscapedTitle)
|
2016-07-21 07:53:59 +02:00
|
|
|
->setFieldHolderTemplate('UserFormsField_holder')
|
|
|
|
->setTemplate('UserFormsFileField');
|
|
|
|
|
|
|
|
$field->setFieldHolderTemplate('UserFormsField_holder')
|
2016-08-12 00:51:47 +02:00
|
|
|
->setTemplate('UserFormsFileField');
|
2016-07-21 07:53:59 +02:00
|
|
|
|
|
|
|
$field->getValidator()->setAllowedExtensions(
|
|
|
|
array_diff(
|
2016-08-12 00:51:47 +02:00
|
|
|
// filter out '' since this would be a regex problem on JS end
|
2016-07-21 07:53:59 +02:00
|
|
|
array_filter(Config::inst()->get('File', 'allowed_extensions')),
|
|
|
|
$this->config()->allowed_extensions_blacklist
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2016-08-12 00:51:47 +02:00
|
|
|
if ($this->MaxFileSizeMB > 0) {
|
2017-05-24 08:31:25 +02:00
|
|
|
$field->getValidator()->setAllowedMaxFileSize($this->MaxFileSizeMB * 1024 * 1024);
|
2016-08-12 00:51:47 +02:00
|
|
|
} else {
|
|
|
|
$field->getValidator()->setAllowedMaxFileSize(static::get_php_max_file_size());
|
|
|
|
}
|
|
|
|
|
2016-07-21 07:53:59 +02:00
|
|
|
$folder = $this->Folder();
|
|
|
|
if ($folder && $folder->exists()) {
|
|
|
|
$field->setFolderName(
|
|
|
|
preg_replace("/^assets\//", "", $folder->Filename)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->doUpdateFormField($field);
|
|
|
|
|
|
|
|
return $field;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the value for the database, link to the file is stored as a
|
|
|
|
* relation so value for the field can be null.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getValueFromData()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSubmittedFormField()
|
|
|
|
{
|
|
|
|
return new SubmittedFileField();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function migrateSettings($data)
|
|
|
|
{
|
|
|
|
// Migrate 'Folder' setting to 'FolderID'
|
|
|
|
if (isset($data['Folder'])) {
|
|
|
|
$this->FolderID = $data['Folder'];
|
|
|
|
unset($data['Folder']);
|
|
|
|
}
|
|
|
|
|
|
|
|
parent::migrateSettings($data);
|
|
|
|
}
|
2016-08-12 00:51:47 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return float
|
|
|
|
*/
|
|
|
|
public static function get_php_max_file_size()
|
|
|
|
{
|
|
|
|
$maxUpload = File::ini2bytes(ini_get('upload_max_filesize'));
|
|
|
|
$maxPost = File::ini2bytes(ini_get('post_max_size'));
|
|
|
|
return min($maxUpload, $maxPost);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPHPMaxFileSizeMB()
|
|
|
|
{
|
|
|
|
return round(static::get_php_max_file_size() / 1024.0, 1);
|
|
|
|
}
|
|
|
|
|
2013-12-20 09:07:35 +01:00
|
|
|
}
|