mirror of
https://github.com/Dolibarr/dolibarr.git
synced 2026-01-26 10:43:22 +01:00
Merge branch '18.0' of git@github.com:Dolibarr/dolibarr.git into 19.0
This commit is contained in:
@@ -57,8 +57,11 @@ class FileUpload
|
||||
$this->element = $element;
|
||||
|
||||
$pathname = str_replace('/class', '', $element_prop['classpath']);
|
||||
|
||||
|
||||
$filename = dol_sanitizeFileName($element_prop['classfile']);
|
||||
$dir_output = dol_sanitizePathName($element_prop['dir_output']);
|
||||
$savingDocMask = '';
|
||||
|
||||
//print 'fileupload.class.php: element='.$element.' pathname='.$pathname.' filename='.$filename.' dir_output='.$dir_output."\n";
|
||||
|
||||
@@ -74,6 +77,11 @@ class FileUpload
|
||||
|
||||
$object_ref = dol_sanitizeFileName($object->ref);
|
||||
|
||||
// add object reference as file name prefix if const MAIN_DISABLE_SUGGEST_REF_AS_PREFIX is not enabled
|
||||
if (!getDolGlobalInt('MAIN_DISABLE_SUGGEST_REF_AS_PREFIX')) {
|
||||
$savingDocMask = $object_ref.'-__file__';
|
||||
}
|
||||
|
||||
// Special cases to forge $object_ref used to forge $upload_dir
|
||||
if ($element == 'invoice_supplier') {
|
||||
$object_ref = get_exdir($object->id, 2, 0, 0, $object, 'invoice_supplier').$object_ref;
|
||||
@@ -99,6 +107,7 @@ class FileUpload
|
||||
'script_url' => $_SERVER['PHP_SELF'],
|
||||
'upload_dir' => $dir_output.'/'.$object_ref.'/',
|
||||
'upload_url' => DOL_URL_ROOT.'/document.php?modulepart='.$element.'&attachment=1&file=/'.$object_ref.'/',
|
||||
'saving_doc_mask' => $savingDocMask,
|
||||
'param_name' => 'files',
|
||||
// Set the following option to 'POST', if your server does not support
|
||||
// DELETE requests. This is a parameter sent to the client:
|
||||
@@ -423,6 +432,14 @@ class FileUpload
|
||||
|
||||
if ($validate) {
|
||||
if (dol_mkdir($this->options['upload_dir']) >= 0) {
|
||||
// add object reference as file name prefix if const MAIN_DISABLE_SUGGEST_REF_AS_PREFIX is not enabled
|
||||
$fileNameWithoutExt = preg_replace('/\.[^\.]+$/', '', $file->name);
|
||||
$savingDocMask = $this->options['saving_doc_mask'];
|
||||
if ($savingDocMask && strpos($savingDocMask, $fileNameWithoutExt) !== 0) {
|
||||
$fileNameWithPrefix = preg_replace('/__file__/', $file->name, $savingDocMask);
|
||||
$file->name = $fileNameWithPrefix;
|
||||
}
|
||||
|
||||
$file_path = dol_sanitizePathName($this->options['upload_dir']).dol_sanitizeFileName($file->name);
|
||||
$append_file = !$this->options['discard_aborted_uploads'] && dol_is_file($file_path) && $file->size > dol_filesize($file_path);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user