25 require 
'../main.inc.php';
 
   26 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
 
   27 require_once DOL_DOCUMENT_ROOT.
'/ecm/class/ecmdirectory.class.php';
 
   28 require_once DOL_DOCUMENT_ROOT.
'/ecm/class/ecmfiles.class.php';
 
   29 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
 
   30 require_once DOL_DOCUMENT_ROOT.
'/core/lib/ecm.lib.php';
 
   31 require_once DOL_DOCUMENT_ROOT.
'/core/class/extrafields.class.php';
 
   34 $langs->loadLangs(array(
'ecm', 
'companies', 
'other', 
'users', 
'orders', 
'propal', 
'bills', 
'contracts', 
'categories'));
 
   36 $action = 
GETPOST(
'action', 
'aZ09');
 
   37 $cancel = 
GETPOST(
'cancel', 
'alpha');
 
   38 $backtopage = 
GETPOST(
'backtopage', 
'alpha');
 
   41 $socid = 
GETPOST(
"socid", 
"int");
 
   44 if ($user->socid > 0) {
 
   46   $socid = $user->socid;
 
   49 $limit = 
GETPOST(
'limit', 
'int') ? 
GETPOST(
'limit', 
'int') : $conf->liste_limit;
 
   50 $sortfield = 
GETPOST(
'sortfield', 
'aZ09comma');
 
   51 $sortorder = 
GETPOST(
'sortorder', 
'aZ09comma');
 
   53 if (empty($page) || $page == -1) {
 
   56 $offset = $limit * $page;
 
   57 $pageprev = $page - 1;
 
   58 $pagenext = $page + 1;
 
   66 $section = 
GETPOST(
"section", 
'alpha');
 
   79 $result = $ecmdir->fetch(
GETPOST(
"section", 
'alpha'));
 
   84 $relativepath = $ecmdir->getRelativePath();
 
   85 $upload_dir = $conf->ecm->dir_output.
'/'.$relativepath;
 
   87 $fullpath = $conf->ecm->dir_output.
'/'.$relativepath.$urlfile;
 
   89 $relativetodocument = 
'ecm/'.$relativepath; 
 
   90 $filepath = $relativepath.$urlfile;
 
   91 $filepathtodocument = $relativetodocument.$urlfile;
 
   94 $object = 
new ECMFiles($db);
 
   97 $extrafields->fetch_name_optionals_label($object->table_element);
 
   99 $result = $object->fetch(0, 
'', $filepathtodocument);
 
  106 $permissiontoread = $user->rights->ecm->read;
 
  107 $permissiontoadd = $user->rights->ecm->setup;
 
  108 $permissiontoupload = $user->rights->ecm->upload;
 
  110 if (!$permissiontoread) {
 
  122     header(
"Location: ".$backtopage);
 
  125     header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?urlfile='.urlencode($urlfile).
'§ion='.urlencode($section).($module ? 
'&module='.urlencode($module) : 
''));
 
  131 if ($action == 
'update' && $permissiontoadd) {
 
  134   $oldlabel = 
GETPOST(
'urlfile', 
'alpha');
 
  136   $shareenabled = 
GETPOST(
'shareenabled', 
'alpha');
 
  140   $olddir = $ecmdir->getRelativePath(0); 
 
  141   $olddirrelativetodocument = 
'ecm/'.$olddir; 
 
  142   $newdirrelativetodocument = 
'ecm/'.$olddir;
 
  143   $olddir = $conf->ecm->dir_output.
'/'.$olddir;
 
  146   $oldfile = $olddir.$oldlabel;
 
  147   $newfile = $newdir.$newlabel;
 
  148   $newfileformove = $newfile;
 
  150   if (preg_match(
'/\.noexe$/', $oldfile) && !preg_match(
'/\.noexe$/', $newfileformove)) {
 
  151     $newfileformove .= 
'.noexe';
 
  158   if ($newlabel != $oldlabel) {
 
  159     $result = 
dol_move($oldfile, $newfileformove); 
 
  161       $langs->load(
'errors');
 
  162       setEventMessages($langs->trans(
'ErrorFailToRenameFile', $oldfile, $newfile), 
null, 
'errors');
 
  167     $result = $object->fetch(0, 
'', $newdirrelativetodocument.$newlabel);
 
  176       require_once DOL_DOCUMENT_ROOT.
'/core/lib/security2.lib.php';
 
  182     if ($object->id > 0) {
 
  183       $ret = $extrafields->setOptionalsFromPost(
null, $object);
 
  189         $result = $object->insertExtraFields();
 
  196       $result = $object->update($user);
 
  202       $object->entity = $conf->entity;
 
  203       $object->filepath = preg_replace(
'/[\\/]+$/', 
'', $newdirrelativetodocument);
 
  204       $object->filename = $newlabel;
 
  205       $object->label = md5_file(
dol_osencode($newfileformove)); 
 
  206       $object->fullpath_orig = 
'';
 
  207       $object->gen_or_uploaded = 
'unknown';
 
  208       $object->description = 
''; 
 
  209       $object->keywords = 
''; 
 
  210       $result = $object->create($user);
 
  220     $urlfile = $newlabel;
 
  222     if (preg_match(
'/\.noexe$/', $newfileformove)) {
 
  223       $urlfile .= 
'.noexe';
 
  226     header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?urlfile='.urlencode($urlfile).
'§ion='.urlencode($section));
 
  243 $object->section_id = $ecmdir->id;
 
  244 $object->label = $urlfile;
 
  247 if ($action == 
'edit') {
 
  248   print 
'<form name="update" action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
 
  249   print 
'<input type="hidden" name="token" value="'.newToken().
'">';
 
  250   print 
'<input type="hidden" name="section" value="'.$section.
'">';
 
  251   print 
'<input type="hidden" name="urlfile" value="'.$urlfile.
'">';
 
  252   print 
'<input type="hidden" name="module" value="'.$module.
'">';
 
  253   print 
'<input type="hidden" name="action" value="update">';
 
  254   print 
'<input type="hidden" name="id" value="'.$object->id.
'">';
 
  262 $tmpecmdir->fetch($ecmdir->id);
 
  265 while ($tmpecmdir && $result > 0) {
 
  266   $tmpecmdir->ref = $tmpecmdir->label;
 
  267   $s = $tmpecmdir->getNomUrl(1).$s;
 
  268   if ($tmpecmdir->fk_parent) {
 
  270     $result = $tmpecmdir->fetch($tmpecmdir->fk_parent);
 
  277 $urlfiletoshow = preg_replace(
'/\.noexe$/', 
'', $urlfile);
 
  279 $s = 
img_picto(
'', 
'object_dir').
' <a href="'.DOL_URL_ROOT.
'/ecm/index.php">'.$langs->trans(
"ECMRoot").
'</a> -> '.$s.
' -> ';
 
  280 if ($action == 
'edit') {
 
  281   $s .= 
'<input type="text" name="label" class="quatrevingtpercent" value="'.$urlfiletoshow.
'">';
 
  283   $s .= $urlfiletoshow;
 
  288   $linkback = 
'<a href="'.$backtopage.
'">'.$langs->trans(
"BackToTree").
'</a>';
 
  294 print 
'<div class="fichecenter">';
 
  296 print 
'<div class="underbanner clearboth"></div>';
 
  297 print 
'<table class="border centpercent tableforfield">';
 
  298 print 
'<tr><td class="titlefieldcreate">'.$langs->trans(
"ECMCreationDate").
'</td><td>';
 
  313 print 
'<tr><td>'.$langs->trans(
"HashOfFileContent").
'</td><td>';
 
  315 $object->fetch(0, 
'', $filepathtodocument);
 
  316 if (!empty($object->label)) {
 
  317   print $object->label;
 
  319   print 
img_warning().
' '.$langs->trans(
"FileNotYetIndexedInDatabase");
 
  324 $urlwithouturlroot = preg_replace(
'/'.preg_quote(DOL_URL_ROOT, 
'/').
'$/i', 
'', trim($dolibarr_main_url_root));
 
  325 $urlwithroot = $urlwithouturlroot.DOL_URL_ROOT; 
 
  330 print 
$form->textwithpicto($langs->trans(
"DirectDownloadInternalLink"), $langs->trans(
"PrivateDownloadLinkDesc"));
 
  334 $rellink = 
'/document.php?modulepart='.$modulepart;
 
  335 if ($forcedownload) {
 
  336   $rellink .= 
'&attachment=1';
 
  338 if (!empty($object->entity)) {
 
  339   $rellink .= 
'&entity='.$object->entity;
 
  341 $rellink .= 
'&file='.urlencode($filepath);
 
  342 $fulllink = $urlwithroot.$rellink;
 
  344 if ($action != 
'edit') {
 
  345   print 
'<input type="text" class="maxquatrevingtpercent widthcentpercentminusxx" id="downloadinternallink" name="downloadinternellink" value="'.dol_escape_htmltag($fulllink).
'">';
 
  349 if ($action != 
'edit') {
 
  350   print 
' <a href="'.$fulllink.
'">'.
img_picto($langs->trans(
"Download"), 
'download', 
'class="opacitymedium paddingrightonly"').
'</a>'; 
 
  356 if ($action != 
'edit') {
 
  357   print 
$form->textwithpicto($langs->trans(
"DirectDownloadLink"), $langs->trans(
"PublicDownloadLinkDesc"));
 
  359   print 
$form->textwithpicto($langs->trans(
"FileSharedViaALink"), $langs->trans(
"PublicDownloadLinkDesc"));
 
  362 if (!empty($object->share)) {
 
  363   if ($action != 
'edit') {
 
  367     if (!empty($object->share)) {
 
  368       $paramlink .= ($paramlink ? 
'&' : 
'').
'hashp='.$object->share; 
 
  370     if ($forcedownload) {
 
  371       $paramlink .= ($paramlink ? 
'&' : 
'').
'attachment=1';
 
  374     $fulllink = $urlwithroot.
'/document.php'.($paramlink ? 
'?'.$paramlink : 
'');
 
  379     if ($action != 
'edit') {
 
  380       print 
'<input type="text" class="quatrevingtpercent nopadding small" id="downloadlink" name="downloadexternallink" value="'.dol_escape_htmltag($fulllink).
'">';
 
  384     if ($action != 
'edit') {
 
  385       print 
' <a href="'.$fulllink.
'">'.$langs->trans(
"Download").
'</a>'; 
 
  388     print 
'<input type="checkbox" name="shareenabled"'.($object->share ? 
' checked="checked"' : 
'').
' /> ';
 
  391   if ($action != 
'edit') {
 
  392     print 
'<span class="opacitymedium">'.$langs->trans(
"FileNotShared").
'</span>';
 
  394     print 
'<input type="checkbox" name="shareenabled"'.($object->share ? 
' checked="checked"' : 
'').
' /> ';
 
  399 print $object->showOptionals($extrafields, ($action == 
'edit' ? 
'edit' : 
'view'));
 
  408 if ($action == 
'edit') {
 
  409   print 
$form->buttonsSaveCancel();
 
  416 if ($action == 
'deletefile') {
 
  417   print 
$form->formconfirm($_SERVER[
"PHP_SELF"].
'?section='.urlencode($section), $langs->trans(
'DeleteFile'), $langs->trans(
'ConfirmDeleteFile', $urlfile), 
'confirm_deletefile', 
'', 1, 1);
 
  420 if ($action != 
'edit') {
 
  422   print 
'<div class="tabsAction">';
 
  424   if ($user->rights->ecm->setup) {
 
  425     print 
'<a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=edit§ion='.urlencode($section).
'&urlfile='.urlencode($urlfile).
'">'.$langs->trans(
'Edit').
'</a>';
 
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Class to manage ECM directories.
Class to manage ECM files.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
ecm_file_prepare_head($object)
Prepare array with list of tabs.
dol_filemtime($pathoffile)
Return time of a file.
dol_move($srcfile, $destfile, $newmask=0, $overwriteifexists=1, $testvirus=0, $indexdatabase=1)
Move a file into another name.
dol_banner_tab($object, $paramid, $morehtml='', $shownav=1, $fieldid='rowid', $fieldref='ref', $morehtmlref='', $moreparam='', $nodbprefix=0, $morehtmlleft='', $morehtmlstatus='', $onlybanner=0, $morehtmlright='')
Show tab footer of a card.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='')
Show tabs of a record.
img_warning($titlealt='default', $moreatt='', $morecss='pictowarning')
Show warning logo.
dol_osencode($str)
Return a string encoded into OS filesystem encoding.
dol_print_error($db='', $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_get_fiche_end($notab=0)
Return tab footer of a card.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='')
Set event messages in dol_events session object.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs='', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
ajax_autoselect($htmlname, $addlink='', $textonlink='Link')
Make content of an input box selected when we click into input field.
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)
Clean a string to use it as a file name.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form.
dol_sanitizePathName($str, $newstr='_', $unaccent=1)
Clean a string to use it as a path name.
getRandomPassword($generic=false, $replaceambiguouschars=null, $length=32)
Return a generated password using default module.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.