32function SetXmlHeaders()
38 header(
'Expires: Mon, 26 Jul 1997 05:00:00 GMT');
40 header(
'Last-Modified: '.gmdate(
'D, d M Y H:i:s').
' GMT');
42 header(
'Cache-Control: no-store, no-cache, must-revalidate');
43 header(
'Cache-Control: post-check=0, pre-check=0',
false);
45 header(
'Pragma: no-cache');
48 header(
'Content-Type: text/xml; charset=utf-8');
59function CreateXmlHeader($command, $resourceType, $currentFolder)
64 echo
'<?xml version="1.0" encoding="utf-8" ?>';
67 echo
'<Connector command="'.$command.
'" resourceType="'.$resourceType.
'">';
70 echo
'<CurrentFolder path="'.ConvertToXmlAttribute($currentFolder).
'" url="'.ConvertToXmlAttribute(GetUrlFromPath($resourceType, $currentFolder, $command)).
'" />';
72 $GLOBALS[
'HeaderSent'] =
true;
80function CreateXmlFooter()
92function SendError($number, $text)
94 if ($_GET[
'Command'] ==
'FileUpload') {
95 SendUploadResults((
string) $number,
"",
"", $text);
98 if (isset($GLOBALS[
'HeaderSent']) && $GLOBALS[
'HeaderSent']) {
99 SendErrorNode($number, $text);
104 dol_syslog(
'Error: '.$number.
' '.$text, LOG_ERR);
107 echo
'<?xml version="1.0" encoding="utf-8" ?>';
111 SendErrorNode($number, $text);
125function SendErrorNode($number, $text)
128 echo
'<Error number="'.$number.
'" text="'.htmlspecialchars($text).
'" />';
130 echo
'<Error number="'.$number.
'" />';
144function GetFolders($resourceType, $currentFolder)
147 $sServerDir = ServerMapFolder($resourceType, $currentFolder,
'GetFolders');
152 $oCurrentFolder = @opendir($sServerDir);
154 if ($oCurrentFolder !==
false) {
155 while ($sFile = readdir($oCurrentFolder)) {
156 if ($sFile !=
'.' && $sFile !=
'..' && is_dir($sServerDir.$sFile)) {
157 $aFolders[] =
'<Folder name="'.ConvertToXmlAttribute($sFile).
'" />';
160 closedir($oCurrentFolder);
166 natcasesort($aFolders);
167 foreach ($aFolders as $sFolder) {
182function GetFoldersAndFiles($resourceType, $currentFolder)
185 $sServerDir = ServerMapFolder($resourceType, $currentFolder,
'GetFoldersAndFiles');
191 $oCurrentFolder = @opendir($sServerDir);
193 if ($oCurrentFolder !==
false) {
194 while ($sFile = readdir($oCurrentFolder)) {
195 if ($sFile !=
'.' && $sFile !=
'..') {
196 if (is_dir($sServerDir.$sFile)) {
197 $aFolders[] =
'<Folder name="'.ConvertToXmlAttribute($sFile).
'" />';
199 $iFileSize = @filesize($sServerDir.$sFile);
203 if ($iFileSize > 0) {
204 $iFileSize = round($iFileSize / 1024);
205 if ($iFileSize < 1) {
210 $aFiles[] =
'<File name="'.ConvertToXmlAttribute($sFile).
'" size="'.$iFileSize.
'" />';
214 closedir($oCurrentFolder);
218 natcasesort($aFolders);
221 foreach ($aFolders as $sFolder) {
228 natcasesort($aFiles);
231 foreach ($aFiles as $sFiles) {
245function CreateFolder($resourceType, $currentFolder)
250 if (isset($_GET[
'NewFolderName'])) {
251 $sNewFolderName =
GETPOST(
'NewFolderName');
252 $sNewFolderName = SanitizeFolderName($sNewFolderName);
254 if (strpos($sNewFolderName,
'..') !==
false) {
255 $sErrorNumber =
'102';
258 $sServerDir = ServerMapFolder($resourceType, $currentFolder,
'CreateFolder');
260 if (is_writable($sServerDir)) {
261 $sServerDir .= $sNewFolderName;
263 $sErrorMsg = CreateServerFolder($sServerDir);
265 switch ($sErrorMsg) {
269 case 'Invalid argument':
270 case 'No such file or directory':
271 $sErrorNumber =
'102';
274 $sErrorNumber =
'110';
278 $sErrorNumber =
'103';
282 $sErrorNumber =
'102';
286 echo
'<Error number="'.$sErrorNumber.
'" />';
298function FileUpload($resourceType, $currentFolder, $sCommand, $CKEcallback =
'')
302 if (!isset($_FILES)) {
309 if (isset($_FILES[
'NewFile']) && !is_null($_FILES[
'NewFile'][
'tmp_name']) && !is_null($_FILES[
'NewFile'][
'name']) || (isset($_FILES[
'upload']) && !is_null($_FILES[
'upload'][
'tmp_name']) && !is_null($_FILES[
'upload'][
'name']))) {
312 $oFile = isset($_FILES[
'NewFile']) ? $_FILES[
'NewFile'] : $_FILES[
'upload'];
318 $sServerDir = ServerMapFolder($resourceType, $currentFolder, $sCommand);
321 $sFileName = $oFile[
'name'];
326 dol_syslog(
"FileUpload sFileName=".$sFileName);
328 $sOriginalFileName = $sFileName;
331 $sExtension = substr($sFileName, (strrpos($sFileName,
'.') + 1));
332 $sExtension = strtolower($sExtension);
335 $permissiontouploadmediaisok = 1;
336 if (!empty($user->socid)) {
337 $permissiontouploadmediaisok = 0;
342 if (!$permissiontouploadmediaisok) {
343 dol_syslog(
"connector.lib.php Try to upload a file with no permission");
344 $sErrorNumber =
'204';
347 include_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
350 $isImageValid = ($imgsupported >= 0);
351 if (!$isImageValid) {
352 $sErrorNumber =
'202';
357 if (!$sErrorNumber) {
358 if (IsAllowedExt($sExtension, $resourceType)) {
362 $sFilePath = $sServerDir.$sFileName;
364 if (is_file($sFilePath)) {
366 $sFileName = RemoveExtension($sOriginalFileName).
'('.$iCounter.
').'.$sExtension;
367 $sErrorNumber =
'201';
369 include_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
372 if (is_file($sFilePath)) {
373 if (isset($Config[
'ChmodOnUpload']) && !$Config[
'ChmodOnUpload']) {
377 $permissions =
'0777';
378 if (isset($Config[
'ChmodOnUpload']) && $Config[
'ChmodOnUpload']) {
379 $permissions = (string) $Config[
'ChmodOnUpload'];
381 $permissionsdec = octdec($permissions);
382 dol_syslog(
"connector.lib.php permission = ".$permissions.
" ".$permissionsdec.
" ".decoct($permissionsdec));
383 $oldumask = umask(0);
384 chmod($sFilePath, $permissionsdec);
392 if (file_exists($sFilePath)) {
394 if (isset($isImageValid) && $imgsupported === -1 && IsImageValid($sFilePath, $sExtension) ===
false) {
395 dol_syslog(
"connector.lib.php IsImageValid is ko");
397 $sErrorNumber =
'202';
399 $detectHtml = DetectHtml($sFilePath);
400 if ($detectHtml ===
true || $detectHtml == -1) {
402 dol_syslog(
"connector.lib.php DetectHtml is ko detectHtml=".$detectHtml.
", we delete the file.");
404 $sErrorNumber =
'205';
409 $sErrorNumber =
'202';
413 $sErrorNumber =
'203';
417 $sFileUrl = CombinePaths(GetResourceTypePath($resourceType, $sCommand), $currentFolder);
418 $sFileUrl = CombinePaths($sFileUrl, $sFileName);
423 if ($CKEcallback ==
'') {
425 SendUploadResults($sErrorNumber, $sFileUrl, $sFileName);
431 ($sErrorNumber != 0 ?
'Error '.$sErrorNumber.
' upload failed.' :
'Upload Successful')
447function CombinePaths($sBasePath, $sFolder)
449 return RemoveFromEnd($sBasePath,
'/').
'/'.RemoveFromStart($sFolder,
'/');
459function GetResourceTypePath($resourceType, $sCommand)
463 if ($sCommand ==
"QuickUpload") {
464 return $Config[
'QuickUploadPath'][$resourceType];
466 return $Config[
'FileTypesPath'][$resourceType];
477function GetResourceTypeDirectory($resourceType, $sCommand)
480 if ($sCommand ==
"QuickUpload") {
481 if (strlen($Config[
'QuickUploadAbsolutePath'][$resourceType]) > 0) {
482 return $Config[
'QuickUploadAbsolutePath'][$resourceType];
486 return Server_MapPath($Config[
'QuickUploadPath'][$resourceType]);
488 if (strlen($Config[
'FileTypesAbsolutePath'][$resourceType]) > 0) {
489 return $Config[
'FileTypesAbsolutePath'][$resourceType];
493 return Server_MapPath($Config[
'FileTypesPath'][$resourceType]);
505function GetUrlFromPath($resourceType, $folderPath, $sCommand)
507 return CombinePaths(GetResourceTypePath($resourceType, $sCommand), $folderPath);
516function RemoveExtension($fileName)
518 return substr($fileName, 0, strrpos($fileName,
'.'));
529function ServerMapFolder($resourceType, $folderPath, $sCommand)
532 $sResourceTypePath = GetResourceTypeDirectory($resourceType, $sCommand);
535 $sErrorMsg = CreateServerFolder($sResourceTypePath);
536 if ($sErrorMsg !=
'') {
537 SendError(1,
"Error creating folder \"$sResourceTypePath\" ($sErrorMsg)");
541 return CombinePaths($sResourceTypePath, $folderPath);
550function GetParentFolder($folderPath)
552 $sPattern =
"-[/\\\\][^/\\\\]+[/\\\\]?$-";
553 return preg_replace($sPattern,
'', $folderPath);
563function CreateServerFolder($folderPath, $lastFolder =
null)
568 $sParent = GetParentFolder($folderPath);
571 while (strpos($folderPath,
'//') !==
false) {
572 $folderPath = str_replace(
'//',
'/', $folderPath);
575 $permissiontouploadmediaisok = 1;
576 if (!empty($user->socid)) {
577 $permissiontouploadmediaisok = 0;
582 if (!$permissiontouploadmediaisok) {
583 return 'Bad permissions to create a folder in media directory';
587 if (!empty($sParent) && !file_exists($sParent)) {
589 if (!is_null($lastFolder) && $lastFolder === $sParent) {
590 return "Can't create $folderPath directory";
594 $sErrorMsg = CreateServerFolder($sParent, $folderPath);
595 if ($sErrorMsg !=
'') {
600 if (!file_exists($folderPath)) {
606 ini_set(
'track_errors',
'1');
608 if (isset($Config[
'ChmodOnFolderCreate']) && !$Config[
'ChmodOnFolderCreate']) {
611 $permissions =
'0777';
612 if (isset($Config[
'ChmodOnFolderCreate']) && $Config[
'ChmodOnFolderCreate']) {
613 $permissions = (string) $Config[
'ChmodOnFolderCreate'];
615 $permissionsdec = octdec($permissions);
616 $permissionsdec |= octdec(
'0111');
617 dol_syslog(
"connector.lib.php permission = ".$permissions.
" ".$permissionsdec.
" ".decoct($permissionsdec));
619 $oldumask = umask(0);
620 mkdir($folderPath, $permissionsdec);
624 $sErrorMsg = $php_errormsg;
627 ini_restore(
'track_errors');
628 ini_restore(
'error_reporting');
641function GetRootPath()
643 if (!isset($_SERVER)) {
646 $sRealPath = realpath(
'./');
648 $sRealPath = rtrim($sRealPath,
"\\/");
650 $sSelfPath = $_SERVER[
'PHP_SELF'];
651 $sSelfPath = substr($sSelfPath, 0, strrpos($sSelfPath,
'/'));
653 $sSelfPath = str_replace(
'/', DIRECTORY_SEPARATOR, $sSelfPath);
655 $position = strpos($sRealPath, $sSelfPath);
659 if ($position ===
false || $position != strlen($sRealPath) - strlen($sSelfPath)) {
660 SendError(1,
'Sorry, can\'t map "UserFilesPath" to a physical path. You must set the "UserFilesAbsolutePath" value in "editor/filemanager/connectors/php/config.inc.php".');
663 return substr($sRealPath, 0, $position);
671function Server_MapPath($path)
674 if (function_exists(
'apache_lookup_uri')) {
675 $info = apache_lookup_uri($path);
676 return $info->filename.$info->path_info;
681 return GetRootPath().$path;
691function IsAllowedExt($sExtension, $resourceType)
695 $arAllowed = $Config[
'AllowedExtensions'][$resourceType];
696 $arDenied = $Config[
'DeniedExtensions'][$resourceType];
698 if (count($arAllowed) > 0 && !in_array($sExtension, $arAllowed)) {
702 if (count($arDenied) > 0 && in_array($sExtension, $arDenied)) {
715function IsAllowedType($resourceType)
718 if (!in_array($resourceType, $Config[
'ConfigAllowedTypes'])) {
731function IsAllowedCommand($sCommand)
735 if (!in_array($sCommand, $Config[
'ConfigAllowedCommands'])) {
747function GetCurrentFolder()
749 $sCurrentFolder = isset($_GET[
'CurrentFolder']) ?
GETPOST(
'CurrentFolder',
'alphanohtml', 1) :
'/';
752 if (!preg_match(
'|/$|', $sCurrentFolder)) {
753 $sCurrentFolder .=
'/';
755 if (strpos($sCurrentFolder,
'/') !== 0) {
756 $sCurrentFolder =
'/'.$sCurrentFolder;
760 while (strpos($sCurrentFolder,
'//') !==
false) {
761 $sCurrentFolder = str_replace(
'//',
'/', $sCurrentFolder);
765 if (strpos($sCurrentFolder,
'..') || strpos($sCurrentFolder,
"\\")) {
769 if (preg_match(
",(/\.)|[[:cntrl:]]|(//)|(\\\\)|([\:\*\?\"<>\|]),", $sCurrentFolder)) {
773 return $sCurrentFolder;
782function SanitizeFolderName($sNewFolderName)
784 $sNewFolderName = stripslashes($sNewFolderName);
787 $sNewFolderName = preg_replace(
'/\\.|\\\\|\\/|\\||\\:|\\?|\\*|"|<|>|[[:cntrl:]]/',
'_', $sNewFolderName);
789 return $sNewFolderName;
798function SanitizeFileName($sNewFileName)
802 $sNewFileName = stripslashes($sNewFileName);
805 if ($Config[
'ForceSingleExtension']) {
806 $sNewFileName = preg_replace(
'/\\.(?![^.]*$)/',
'_', $sNewFileName);
810 $sNewFileName = preg_replace(
'/\\\\|\\/|\\||\\:|\\?|\\*|"|<|>|[[:cntrl:]]/',
'_', $sNewFileName);
812 return $sNewFileName;
824function SendUploadResults($errorNumber, $fileUrl =
'', $fileName =
'', $customMsg =
'')
829<script
type=
"text/javascript">
830(
function(){var d=document.domain;
while (
true){
try{var A=window.parent.document.domain;
break;}
catch(e) {};d=d.replace(/.*?(?:\.|$)/,
'');
if (d.length==0)
break;
try{document.domain=d;}
catch (e){
break;}}})();
833 if ($errorNumber && $errorNumber !=
'201') {
838 $rpl = array(
'\\' =>
'\\\\',
'"' =>
'\\"');
839 echo
'console.log('.$errorNumber.
');';
840 echo
'window.parent.OnUploadCompleted('.$errorNumber.
', "'.strtr($fileUrl, $rpl).
'", "'.strtr($fileName, $rpl).
'", "'.strtr($customMsg, $rpl).
'");';
857function SendCKEditorResults($callback, $sFileUrl, $customMsg =
'')
859 echo
'<script type="text/javascript">';
861 $rpl = array(
'\\' =>
'\\\\',
'"' =>
'\\"');
863 echo
'window.parent.CKEDITOR.tools.callFunction("'.$callback.
'","'.strtr($sFileUrl, $rpl).
'", "'.strtr($customMsg, $rpl).
'");';
877function RemoveFromStart($sourceString, $charToRemove)
879 $sPattern =
'|^'.$charToRemove.
'+|';
880 return preg_replace($sPattern,
'', $sourceString);
890function RemoveFromEnd($sourceString, $charToRemove)
892 $sPattern =
'|'.$charToRemove.
'+$|';
893 return preg_replace($sPattern,
'', $sourceString);
902function FindBadUtf8($string)
904 $regex =
'([\x00-\x7F]|[\xC2-\xDF][\x80-\xBF]|\xE0[\xA0-\xBF][\x80-\xBF]|[\xE1-\xEC\xEE\xEF][\x80-\xBF]{2}|\xED[\x80-\x9F][\x80-\xBF]';
905 $regex .=
'|\xF0[\x90-\xBF][\x80-\xBF]{2}|[\xF1-\xF3][\x80-\xBF]{3}|\xF4[\x80-\x8F][\x80-\xBF]{2}|(.{1}))';
908 while (preg_match(
'/'.$regex.
'/S', $string, $matches)) {
909 if (isset($matches[2])) {
912 $string = substr($string, strlen($matches[0]));
924function ConvertToXmlAttribute($value)
926 if (defined(
'PHP_OS')) {
932 if (strtoupper(substr($os, 0, 3)) ===
'WIN' || FindBadUtf8($value)) {
933 return (mb_convert_encoding(htmlspecialchars($value),
'UTF-8',
'ISO-8859-1'));
935 return (htmlspecialchars($value));
946function IsHtmlExtension($ext, $formExtensions)
948 if (!$formExtensions || !is_array($formExtensions)) {
951 $lcaseHtmlExtensions = array();
952 foreach ($formExtensions as $key => $val) {
953 $lcaseHtmlExtensions[$key] = strtolower($val);
955 return in_array($ext, $lcaseHtmlExtensions);
965function DetectHtml($filePath)
967 $fp = @fopen($filePath,
'rb');
973 $chunk = fread($fp, 1024);
976 $chunk = strtolower($chunk);
982 $chunk = trim($chunk);
984 if (preg_match(
"/<!DOCTYPE\W*X?HTML/sim", $chunk)) {
988 $tags = array(
'<body',
'<head',
'<html',
'<img',
'<pre',
'<script',
'<table',
'<title');
990 foreach ($tags as $tag) {
991 if (
false !== strpos($chunk, $tag)) {
997 if (preg_match(
'!type\s*=\s*[\'"]?\s*(?:\w*/)?(?:ecma|java)!sim', $chunk)) {
1004 if (preg_match(
'!(?:href|src|data)\s*=\s*[\'"]?\s*(?:ecma|java)script:!sim', $chunk)) {
1009 if (preg_match(
'!url\s*\(\s*[\'"]?\s*(?:ecma|java)script:!sim', $chunk)) {
1024function IsImageValid($filePath, $extension)
1026 if (!@is_readable($filePath)) {
1030 $imageCheckExtensions = array(
1050 if (!in_array($extension, $imageCheckExtensions)) {
1054 if (@getimagesize($filePath) ===
false) {
This class is used to manage file upload using ajax.
dol_move_uploaded_file($src_file, $dest_file, $allowoverwrite, $disablevirusscan=0, $uploaderrorcode=0, $nohook=0, $varfiles='addedfile', $upload_dir='')
Check validity of a file upload from an GUI page, and move it to its final destination.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0)
Clean a string to use it as a file name.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
image_format_supported($file, $acceptsvg=0)
Return if a filename is file name of a supported image format.
if(preg_match('/crypted:/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type