@@ -104,28 +104,28 @@ discard block  | 
                                                    ||
| 104 | 104 | // Action ajout d'une categorie  | 
                                                        
| 105 | 105 |              if ($cancel) {
 | 
                                                        
| 106 | 106 |                  if ($urlfrom) {
 | 
                                                        
| 107 | -                    header("Location: " . $urlfrom);
 | 
                                                        |
| 107 | +                    header("Location: ".$urlfrom);
 | 
                                                        |
| 108 | 108 | exit;  | 
                                                        
| 109 | 109 |                  } else if ($idProdOrigin) {
 | 
                                                        
| 110 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idProdOrigin . '&type=' . $type);
 | 
                                                        |
| 110 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idProdOrigin.'&type='.$type);
 | 
                                                        |
| 111 | 111 | exit;  | 
                                                        
| 112 | 112 |                  } else if ($idCompanyOrigin) {
 | 
                                                        
| 113 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idCompanyOrigin . '&type=' . $type);
 | 
                                                        |
| 113 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idCompanyOrigin.'&type='.$type);
 | 
                                                        |
| 114 | 114 | exit;  | 
                                                        
| 115 | 115 |                  } else if ($idSupplierOrigin) {
 | 
                                                        
| 116 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idSupplierOrigin . '&type=' . $type);
 | 
                                                        |
| 116 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idSupplierOrigin.'&type='.$type);
 | 
                                                        |
| 117 | 117 | exit;  | 
                                                        
| 118 | 118 |                  } else if ($idMemberOrigin) {
 | 
                                                        
| 119 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idMemberOrigin . '&type=' . $type);
 | 
                                                        |
| 119 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idMemberOrigin.'&type='.$type);
 | 
                                                        |
| 120 | 120 | exit;  | 
                                                        
| 121 | 121 |                  } else if ($idContactOrigin) {
 | 
                                                        
| 122 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idContactOrigin . '&type=' . $type);
 | 
                                                        |
| 122 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idContactOrigin.'&type='.$type);
 | 
                                                        |
| 123 | 123 | exit;  | 
                                                        
| 124 | 124 |                  } else if ($idProjectOrigin) {
 | 
                                                        
| 125 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idProjectOrigin . '&type=' . $type);
 | 
                                                        |
| 125 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idProjectOrigin.'&type='.$type);
 | 
                                                        |
| 126 | 126 | exit;  | 
                                                        
| 127 | 127 |                  } else {
 | 
                                                        
| 128 | -                    header("Location: " . DOL_URL_ROOT . '/categories/index.php?leftmenu=cat&type=' . $type);
 | 
                                                        |
| 128 | +                    header("Location: ".DOL_URL_ROOT.'/categories/index.php?leftmenu=cat&type='.$type);
 | 
                                                        |
| 129 | 129 | exit;  | 
                                                        
| 130 | 130 | }  | 
                                                        
| 131 | 131 | }  | 
                                                        
@@ -169,32 +169,32 @@ discard block  | 
                                                    ||
| 169 | 169 | // Action confirmation de creation categorie  | 
                                                        
| 170 | 170 |              if ($action == 'confirmed') {
 | 
                                                        
| 171 | 171 |                  if ($urlfrom) {
 | 
                                                        
| 172 | -                    header("Location: " . $urlfrom);
 | 
                                                        |
| 172 | +                    header("Location: ".$urlfrom);
 | 
                                                        |
| 173 | 173 | exit;  | 
                                                        
| 174 | 174 |                  } elseif ($backtopage) {
 | 
                                                        
| 175 | -                    header("Location: " . $backtopage);
 | 
                                                        |
| 175 | +                    header("Location: ".$backtopage);
 | 
                                                        |
| 176 | 176 | exit;  | 
                                                        
| 177 | 177 |                  } else if ($idProdOrigin) {
 | 
                                                        
| 178 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idProdOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 178 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idProdOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 179 | 179 | exit;  | 
                                                        
| 180 | 180 |                  } else if ($idCompanyOrigin) {
 | 
                                                        
| 181 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idCompanyOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 181 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idCompanyOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 182 | 182 | exit;  | 
                                                        
| 183 | 183 |                  } else if ($idSupplierOrigin) {
 | 
                                                        
| 184 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idSupplierOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 184 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idSupplierOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 185 | 185 | exit;  | 
                                                        
| 186 | 186 |                  } else if ($idMemberOrigin) {
 | 
                                                        
| 187 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idMemberOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 187 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idMemberOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 188 | 188 | exit;  | 
                                                        
| 189 | 189 |                  } else if ($idContactOrigin) {
 | 
                                                        
| 190 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idContactOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 190 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idContactOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 191 | 191 | exit;  | 
                                                        
| 192 | 192 |                  } else if ($idProjectOrigin) {
 | 
                                                        
| 193 | -                    header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $idProjectOrigin . '&type=' . $type . '&mesg=' . urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 193 | +                    header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$idProjectOrigin.'&type='.$type.'&mesg='.urlencode($langs->trans("CatCreated")));
 | 
                                                        |
| 194 | 194 | exit;  | 
                                                        
| 195 | 195 | }  | 
                                                        
| 196 | 196 | |
| 197 | -                header("Location: " . DOL_URL_ROOT . '/categories/viewcat.php?id=' . $result . '&type=' . $type);
 | 
                                                        |
| 197 | +                header("Location: ".DOL_URL_ROOT.'/categories/viewcat.php?id='.$result.'&type='.$type);
 | 
                                                        |
| 198 | 198 | exit;  | 
                                                        
| 199 | 199 | }  | 
                                                        
| 200 | 200 | }  | 
                                                        
@@ -50,8 +50,9 @@ discard block  | 
                                                    ||
| 50 | 50 | |
| 51 | 51 | // Security check  | 
                                                        
| 52 | 52 |          $socid = DolUtils::GETPOST('socid', 'int');
 | 
                                                        
| 53 | - if (!Globals::$user->rights->categorie->lire)  | 
                                                        |
| 54 | - accessforbidden();  | 
                                                        |
| 53 | +        if (!Globals::$user->rights->categorie->lire) { | 
                                                        |
| 54 | + accessforbidden();  | 
                                                        |
| 55 | + }  | 
                                                        |
| 55 | 56 | |
| 56 | 57 |          $action = DolUtils::GETPOST('action', 'alpha');
 | 
                                                        
| 57 | 58 |          $cancel = DolUtils::GETPOST('cancel', 'alpha');
 | 
                                                        
@@ -69,22 +70,29 @@ discard block  | 
                                                    ||
| 69 | 70 |          $parent = DolUtils::GETPOST('parent');
 | 
                                                        
| 70 | 71 | |
| 71 | 72 |          if ($origin) {
 | 
                                                        
| 72 | - if ($type == Categorie::TYPE_PRODUCT)  | 
                                                        |
| 73 | - $idProdOrigin = $origin;  | 
                                                        |
| 74 | - if ($type == Categorie::TYPE_SUPPLIER)  | 
                                                        |
| 75 | - $idSupplierOrigin = $origin;  | 
                                                        |
| 76 | - if ($type == Categorie::TYPE_CUSTOMER)  | 
                                                        |
| 77 | - $idCompanyOrigin = $origin;  | 
                                                        |
| 78 | - if ($type == Categorie::TYPE_MEMBER)  | 
                                                        |
| 79 | - $idMemberOrigin = $origin;  | 
                                                        |
| 80 | - if ($type == Categorie::TYPE_CONTACT)  | 
                                                        |
| 81 | - $idContactOrigin = $origin;  | 
                                                        |
| 82 | - if ($type == Categorie::TYPE_PROJECT)  | 
                                                        |
| 83 | - $idProjectOrigin = $origin;  | 
                                                        |
| 73 | +            if ($type == Categorie::TYPE_PRODUCT) { | 
                                                        |
| 74 | + $idProdOrigin = $origin;  | 
                                                        |
| 75 | + }  | 
                                                        |
| 76 | +            if ($type == Categorie::TYPE_SUPPLIER) { | 
                                                        |
| 77 | + $idSupplierOrigin = $origin;  | 
                                                        |
| 78 | + }  | 
                                                        |
| 79 | +            if ($type == Categorie::TYPE_CUSTOMER) { | 
                                                        |
| 80 | + $idCompanyOrigin = $origin;  | 
                                                        |
| 81 | + }  | 
                                                        |
| 82 | +            if ($type == Categorie::TYPE_MEMBER) { | 
                                                        |
| 83 | + $idMemberOrigin = $origin;  | 
                                                        |
| 84 | + }  | 
                                                        |
| 85 | +            if ($type == Categorie::TYPE_CONTACT) { | 
                                                        |
| 86 | + $idContactOrigin = $origin;  | 
                                                        |
| 87 | + }  | 
                                                        |
| 88 | +            if ($type == Categorie::TYPE_PROJECT) { | 
                                                        |
| 89 | + $idProjectOrigin = $origin;  | 
                                                        |
| 90 | + }  | 
                                                        |
| 84 | 91 | }  | 
                                                        
| 85 | 92 | |
| 86 | - if ($catorigin && $type == Categorie::TYPE_PRODUCT)  | 
                                                        |
| 87 | - $idCatOrigin = $catorigin;  | 
                                                        |
| 93 | +        if ($catorigin && $type == Categorie::TYPE_PRODUCT) { | 
                                                        |
| 94 | + $idCatOrigin = $catorigin;  | 
                                                        |
| 95 | + }  | 
                                                        |
| 88 | 96 | |
| 89 | 97 | $object = new Categorie();  | 
                                                        
| 90 | 98 | |
@@ -139,12 +147,14 @@ discard block  | 
                                                    ||
| 139 | 147 | $object->visible = $visible;  | 
                                                        
| 140 | 148 | $object->type = $type;  | 
                                                        
| 141 | 149 | |
| 142 | - if ($parent != "-1")  | 
                                                        |
| 143 | - $object->fk_parent = $parent;  | 
                                                        |
| 150 | +            if ($parent != "-1") { | 
                                                        |
| 151 | + $object->fk_parent = $parent;  | 
                                                        |
| 152 | + }  | 
                                                        |
| 144 | 153 | |
| 145 | 154 | $ret = $extrafields->setOptionalsFromPost($extralabels, $object);  | 
                                                        
| 146 | - if ($ret < 0)  | 
                                                        |
| 147 | - $error++;  | 
                                                        |
| 155 | +            if ($ret < 0) { | 
                                                        |
| 156 | + $error++;  | 
                                                        |
| 157 | + }  | 
                                                        |
| 148 | 158 | |
| 149 | 159 |              if (!$object->label) {
 | 
                                                        
| 150 | 160 | $error++;  | 
                                                        
@@ -64,21 +64,21 @@ discard block  | 
                                                    ||
| 64 | 64 |              if ($action == 'create' || $_POST["addcat"] == 'addcat') {
 | 
                                                        
| 65 | 65 |                  DolUtils::dol_set_focus('#label');
 | 
                                                        
| 66 | 66 | |
| 67 | - print '<form action="' . $_SERVER['PHP_SELF'] . '?type=' . $type . '" method="POST">';  | 
                                                        |
| 68 | - print '<input type="hidden" name="token" value="' . $_SESSION['newtoken'] . '">';  | 
                                                        |
| 69 | - print '<input type="hidden" name="urlfrom" value="' . $urlfrom . '">';  | 
                                                        |
| 67 | + print '<form action="'.$_SERVER['PHP_SELF'].'?type='.$type.'" method="POST">';  | 
                                                        |
| 68 | + print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">';  | 
                                                        |
| 69 | + print '<input type="hidden" name="urlfrom" value="'.$urlfrom.'">';  | 
                                                        |
| 70 | 70 | print '<input type="hidden" name="action" value="add">';  | 
                                                        
| 71 | 71 | print '<input type="hidden" name="addcat" value="addcat">';  | 
                                                        
| 72 | -                print '<input type="hidden" name="id" value="' . DolUtils::GETPOST('origin', 'alpha') . '">';
 | 
                                                        |
| 73 | - print '<input type="hidden" name="type" value="' . $type . '">';  | 
                                                        |
| 74 | - print '<input type="hidden" name="backtopage" value="' . $backtopage . '">';  | 
                                                        |
| 72 | +                print '<input type="hidden" name="id" value="'.DolUtils::GETPOST('origin', 'alpha').'">';
 | 
                                                        |
| 73 | + print '<input type="hidden" name="type" value="'.$type.'">';  | 
                                                        |
| 74 | + print '<input type="hidden" name="backtopage" value="'.$backtopage.'">';  | 
                                                        |
| 75 | 75 | if ($origin)  | 
                                                        
| 76 | 76 |                  {
 | 
                                                        
| 77 | - print '<input type="hidden" name="origin" value="' . $origin . '">';  | 
                                                        |
| 77 | + print '<input type="hidden" name="origin" value="'.$origin.'">';  | 
                                                        |
| 78 | 78 | }  | 
                                                        
| 79 | 79 | if ($catorigin)  | 
                                                        
| 80 | 80 |                  {
 | 
                                                        
| 81 | - print '<input type="hidden" name="catorigin" value="' . $catorigin . '">';  | 
                                                        |
| 81 | + print '<input type="hidden" name="catorigin" value="'.$catorigin.'">';  | 
                                                        |
| 82 | 82 | }  | 
                                                        
| 83 | 83 | |
| 84 | 84 |                  print load_fiche_titre($langs->trans("CreateCat"));
 | 
                                                        
@@ -89,29 +89,29 @@ discard block  | 
                                                    ||
| 89 | 89 | |
| 90 | 90 | // Ref  | 
                                                        
| 91 | 91 | print '<tr>';  | 
                                                        
| 92 | -                print '<td class="titlefieldcreate fieldrequired">' . $langs->trans("Ref") . '</td><td><input id="label" class="minwidth100" name="label" value="' . $label . '">';
 | 
                                                        |
| 92 | +                print '<td class="titlefieldcreate fieldrequired">'.$langs->trans("Ref").'</td><td><input id="label" class="minwidth100" name="label" value="'.$label.'">';
 | 
                                                        |
| 93 | 93 | print'</td></tr>';  | 
                                                        
| 94 | 94 | |
| 95 | 95 | // Description  | 
                                                        
| 96 | -                print '<tr><td class="tdtop">' . $langs->trans("Description") . '</td><td>';
 | 
                                                        |
| 96 | +                print '<tr><td class="tdtop">'.$langs->trans("Description").'</td><td>';
 | 
                                                        |
| 97 | 97 | //require_once DOL_DOCUMENT_ROOT . '/core/class/doleditor.class.php';  | 
                                                        
| 98 | 98 |                  $doleditor = new DolEditor('description', $description, '', 200, 'dolibarr_notes', '', false, true, $conf->global->FCKEDITOR_ENABLE_PRODUCTDESC, ROWS_6, '90%');
 | 
                                                        
| 99 | 99 | $doleditor->Create();  | 
                                                        
| 100 | 100 | print '</td></tr>';  | 
                                                        
| 101 | 101 | |
| 102 | 102 | // Color  | 
                                                        
| 103 | -                print '<tr><td>' . $langs->trans("Color") . '</td><td>';
 | 
                                                        |
| 103 | +                print '<tr><td>'.$langs->trans("Color").'</td><td>';
 | 
                                                        |
| 104 | 104 | print $formother->selectColor($color, 'color');  | 
                                                        
| 105 | 105 | print '</td></tr>';  | 
                                                        
| 106 | 106 | |
| 107 | 107 | // Parent category  | 
                                                        
| 108 | -                print '<tr><td>' . $langs->trans("AddIn") . '</td><td>';
 | 
                                                        |
| 108 | +                print '<tr><td>'.$langs->trans("AddIn").'</td><td>';
 | 
                                                        |
| 109 | 109 | print $form->select_all_categories($type, $catorigin, 'parent');  | 
                                                        
| 110 | 110 |                  print ajax_combobox('parent');
 | 
                                                        
| 111 | 111 | print '</td></tr>';  | 
                                                        
| 112 | 112 | |
| 113 | 113 | $parameters = array();  | 
                                                        
| 114 | -                $reshook = Globals::$hookManager->executeHooks('formObjectOptions', $parameters, $object, $action);    // Note that $action and $object may have been modified by hook
 | 
                                                        |
| 114 | +                $reshook = Globals::$hookManager->executeHooks('formObjectOptions', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
 | 
                                                        |
| 115 | 115 | print Globals::$hookManager->resPrint;  | 
                                                        
| 116 | 116 |                  if (empty($reshook)) {
 | 
                                                        
| 117 | 117 | print $object->showOptionals($extrafields, 'edit');  | 
                                                        
@@ -122,9 +122,9 @@ discard block  | 
                                                    ||
| 122 | 122 |                  DolUtils::dol_fiche_end('');
 | 
                                                        
| 123 | 123 | |
| 124 | 124 | print '<div class="center">';  | 
                                                        
| 125 | -                print '<input type="submit" class="button" value="' . $langs->trans("CreateThisCat") . '" name="creation" />';
 | 
                                                        |
| 125 | +                print '<input type="submit" class="button" value="'.$langs->trans("CreateThisCat").'" name="creation" />';
 | 
                                                        |
| 126 | 126 | print '     ';  | 
                                                        
| 127 | -                print '<input type="submit" class="button" value="' . $langs->trans("Cancel") . '" name="cancel" />';
 | 
                                                        |
| 127 | +                print '<input type="submit" class="button" value="'.$langs->trans("Cancel").'" name="cancel" />';
 | 
                                                        |
| 128 | 128 | print '</div>';  | 
                                                        
| 129 | 129 | |
| 130 | 130 | print '</form>';  | 
                                                        
@@ -61,7 +61,7 @@ discard block  | 
                                                    ||
| 61 | 61 | public function draw()  | 
                                                        
| 62 | 62 |      {
 | 
                                                        
| 63 | 63 |          header('Cache-Control: Public, must-revalidate');
 | 
                                                        
| 64 | -        header("Content-type: text/html; charset=" . Globals::$conf->file->character_set_client);
 | 
                                                        |
| 64 | +        header("Content-type: text/html; charset=".Globals::$conf->file->character_set_client);
 | 
                                                        |
| 65 | 65 | |
| 66 | 66 | // Need global variable $title to be defined by caller (like dol_loginfunction)  | 
                                                        
| 67 | 67 |  // Caller can also set 	$morelogincontent = array(['options']=>array('js'=>..., 'table'=>...);
 | 
                                                        
@@ -94,9 +94,9 @@ discard block  | 
                                                    ||
| 94 | 94 | }  | 
                                                        
| 95 | 95 | |
| 96 | 96 | $php_self = DolUtils::dol_escape_htmltag($_SERVER['PHP_SELF']);  | 
                                                        
| 97 | - $php_self .= DolUtils::dol_escape_htmltag($_SERVER["QUERY_STRING"]) ? '?' . DolUtils::dol_escape_htmltag($_SERVER["QUERY_STRING"]) : '';  | 
                                                        |
| 97 | + $php_self .= DolUtils::dol_escape_htmltag($_SERVER["QUERY_STRING"]) ? '?'.DolUtils::dol_escape_htmltag($_SERVER["QUERY_STRING"]) : '';  | 
                                                        |
| 98 | 98 |          if (!preg_match('/mainmenu=/', $php_self)) {
 | 
                                                        
| 99 | -            $php_self .= (preg_match('/\?/', $php_self) ? '&' : '?') . 'mainmenu=home';
 | 
                                                        |
| 99 | +            $php_self .= (preg_match('/\?/', $php_self) ? '&' : '?').'mainmenu=home';
 | 
                                                        |
| 100 | 100 | }  | 
                                                        
| 101 | 101 | |
| 102 | 102 | $this->url = $php_self;  | 
                                                        
@@ -110,28 +110,28 @@ discard block  | 
                                                    ||
| 110 | 110 | );  | 
                                                        
| 111 | 111 | */  | 
                                                        
| 112 | 112 | $arrayofjs = array(  | 
                                                        
| 113 | - DOL_BASE_URI . '/includes/jstz/jstz.min.js' . (empty(Globals::$conf->dol_use_jmobile) ? '' : '?version=' . urlencode(DOL_VERSION)),  | 
                                                        |
| 114 | - DOL_BASE_URI . '/core/js/dst.js' . (empty(Globals::$conf->dol_use_jmobile) ? '' : '?version=' . urlencode(DOL_VERSION))  | 
                                                        |
| 113 | + DOL_BASE_URI.'/includes/jstz/jstz.min.js'.(empty(Globals::$conf->dol_use_jmobile) ? '' : '?version='.urlencode(DOL_VERSION)),  | 
                                                        |
| 114 | + DOL_BASE_URI.'/core/js/dst.js'.(empty(Globals::$conf->dol_use_jmobile) ? '' : '?version='.urlencode(DOL_VERSION))  | 
                                                        |
| 115 | 115 | );  | 
                                                        
| 116 | 116 | |
| 117 | 117 | // $titletruedolibarrversion is defined by dol_loginfunction in security2.lib.php.  | 
                                                        
| 118 | 118 | // We must keep the @, some tools use it to know it is login page and find true dolibarr version.  | 
                                                        
| 119 | 119 |          // $titleofloginpage = Globals::$langs->trans('Login') . ' @ ' . $titletruedolibarrversion;
 | 
                                                        
| 120 | -        $titleofloginpage = Globals::$langs->trans('Login') . ' @ ' . DOL_VERSION;
 | 
                                                        |
| 120 | +        $titleofloginpage = Globals::$langs->trans('Login').' @ '.DOL_VERSION;
 | 
                                                        |
| 121 | 121 | |
| 122 | 122 | $disablenofollow = 1;  | 
                                                        
| 123 | -        if (!preg_match('/' . constant('DOL_APPLICATION_TITLE') . '/', $this->title)) {
 | 
                                                        |
| 123 | +        if (!preg_match('/'.constant('DOL_APPLICATION_TITLE').'/', $this->title)) {
 | 
                                                        |
| 124 | 124 | $disablenofollow = 0;  | 
                                                        
| 125 | 125 | }  | 
                                                        
| 126 | 126 | |
| 127 | 127 |          print $this->top_htmlhead('', $titleofloginpage, 0, 0, $arrayofjs, array(), 0, $disablenofollow);
 | 
                                                        
| 128 | 128 | |
| 129 | 129 | |
| 130 | - $colorbackhmenu1 = '60,70,100'; // topmenu  | 
                                                        |
| 130 | + $colorbackhmenu1 = '60,70,100'; // topmenu  | 
                                                        |
| 131 | 131 |          if (!isset(Globals::$conf->global->THEME_ELDY_TOPMENU_BACK1)) {
 | 
                                                        
| 132 | 132 | Globals::$conf->global->THEME_ELDY_TOPMENU_BACK1 = $colorbackhmenu1;  | 
                                                        
| 133 | 133 | }  | 
                                                        
| 134 | 134 | $colorbackhmenu1 = empty($user->conf->THEME_ELDY_ENABLE_PERSONALIZED) ? (empty(Globals::$conf->global->THEME_ELDY_TOPMENU_BACK1) ? $colorbackhmenu1 : Globals::$conf->global->THEME_ELDY_TOPMENU_BACK1) : (empty($user->conf->THEME_ELDY_TOPMENU_BACK1) ? $colorbackhmenu1 : $user->conf->THEME_ELDY_TOPMENU_BACK1);  | 
                                                        
| 135 | -        $colorbackhmenu1 = join(',', DolUtils2::colorStringToArray($colorbackhmenu1));    // Normalize value to 'x,y,z'
 | 
                                                        |
| 135 | +        $colorbackhmenu1 = join(',', DolUtils2::colorStringToArray($colorbackhmenu1)); // Normalize value to 'x,y,z'
 | 
                                                        |
| 136 | 136 | }  | 
                                                        
| 137 | 137 | }  | 
                                                        
@@ -33,12 +33,12 @@ discard block  | 
                                                    ||
| 33 | 33 | // Just to define version DOL_VERSION  | 
                                                        
| 34 | 34 |  if (!defined('DOL_INC_FOR_VERSION_ERROR')) | 
                                                        
| 35 | 35 |      define('DOL_INC_FOR_VERSION_ERROR', '1'); | 
                                                        
| 36 | -require_once DOL_BASE_PATH . '/filefunc.inc.php';  | 
                                                        |
| 36 | +require_once DOL_BASE_PATH.'/filefunc.inc.php';  | 
                                                        |
| 37 | 37 | |
| 38 | -require_once DOL_BASE_PATH . '/core/class/translate.class.php';  | 
                                                        |
| 39 | -require_once DOL_BASE_PATH . '/core/lib/functions.lib.php';  | 
                                                        |
| 40 | -require_once DOL_BASE_PATH . '/core/lib/admin.lib.php';  | 
                                                        |
| 41 | -require_once DOL_BASE_PATH . '/core/lib/files.lib.php';  | 
                                                        |
| 38 | +require_once DOL_BASE_PATH.'/core/class/translate.class.php';  | 
                                                        |
| 39 | +require_once DOL_BASE_PATH.'/core/lib/functions.lib.php';  | 
                                                        |
| 40 | +require_once DOL_BASE_PATH.'/core/lib/admin.lib.php';  | 
                                                        |
| 41 | +require_once DOL_BASE_PATH.'/core/lib/files.lib.php';  | 
                                                        |
| 42 | 42 | |
| 43 | 43 | /*  | 
                                                        
| 44 | 44 | * adobdbtime package  | 
                                                        
@@ -78,7 +78,7 @@ discard block  | 
                                                    ||
| 78 | 78 | // Define vars  | 
                                                        
| 79 | 79 | $conffiletoshowshort = "conf.php";  | 
                                                        
| 80 | 80 | // Define localization of conf file  | 
                                                        
| 81 | -$conffile = DOL_BASE_PATH . "/conf/conf.php";  | 
                                                        |
| 81 | +$conffile = DOL_BASE_PATH."/conf/conf.php";  | 
                                                        |
| 82 | 82 | $conffiletoshow = "htdocs/conf/conf.php";  | 
                                                        
| 83 | 83 | // For debian/redhat like systems  | 
                                                        
| 84 | 84 | //$conffile = "/etc/dolibarr/conf.php";  | 
                                                        
@@ -100,7 +100,7 @@ discard block  | 
                                                    ||
| 100 | 100 | $dolibarr_main_db_port = '3306'; // For backward compatibility  | 
                                                        
| 101 | 101 | }  | 
                                                        
| 102 | 102 | // Clean parameters  | 
                                                        
| 103 | - $dolibarr_main_data_root = isset($dolibarr_main_data_root) ? trim($dolibarr_main_data_root) : DOL_BASE_PATH . '../documents';  | 
                                                        |
| 103 | + $dolibarr_main_data_root = isset($dolibarr_main_data_root) ? trim($dolibarr_main_data_root) : DOL_BASE_PATH.'../documents';  | 
                                                        |
| 104 | 104 | $dolibarr_main_url_root = isset($dolibarr_main_url_root) ? trim($dolibarr_main_url_root) : '';  | 
                                                        
| 105 | 105 | $dolibarr_main_url_root_alt = isset($dolibarr_main_url_root_alt) ? trim($dolibarr_main_url_root_alt) : '';  | 
                                                        
| 106 | 106 | $dolibarr_main_document_root = isset($dolibarr_main_document_root) ? trim($dolibarr_main_document_root) : '';  | 
                                                        
@@ -126,7 +126,7 @@ discard block  | 
                                                    ||
| 126 | 126 | // Load database driver  | 
                                                        
| 127 | 127 |          if ($result) { | 
                                                        
| 128 | 128 |              if (!empty($dolibarr_main_document_root) && !empty($dolibarr_main_db_type)) { | 
                                                        
| 129 | - $result = include_once $dolibarr_main_document_root . "/core/db/" . $dolibarr_main_db_type . '.class.php';  | 
                                                        |
| 129 | + $result = include_once $dolibarr_main_document_root."/core/db/".$dolibarr_main_db_type.'.class.php';  | 
                                                        |
| 130 | 130 |                  if (!$result) { | 
                                                        
| 131 | 131 | $includeconferror = 'ErrorBadValueForDolibarrMainDBType';  | 
                                                        
| 132 | 132 | }  | 
                                                        
@@ -146,14 +146,14 @@ discard block  | 
                                                    ||
| 146 | 146 | }  | 
                                                        
| 147 | 147 |  define('MAIN_DB_PREFIX', (isset($dolibarr_main_db_prefix) ? $dolibarr_main_db_prefix : '')); | 
                                                        
| 148 | 148 | |
| 149 | -define('DOL_CLASS_PATH', 'class/');                             // Filsystem path to class dir | 
                                                        |
| 150 | -define('DOL_DATA_ROOT', (isset($dolibarr_main_data_root) ? $dolibarr_main_data_root : DOL_BASE_PATH . '../documents')); | 
                                                        |
| 151 | -define('DOL_MAIN_URL_ROOT', (isset($dolibarr_main_url_root) ? $dolibarr_main_url_root : ''));           // URL relative root | 
                                                        |
| 152 | -$uri = preg_replace('/^http(s?):\/\//i', '', constant('DOL_MAIN_URL_ROOT'));  // $uri contains url without http* | 
                                                        |
| 153 | -$suburi = strstr($uri, '/'); // $suburi contains url without domain  | 
                                                        |
| 149 | +define('DOL_CLASS_PATH', 'class/'); // Filsystem path to class dir | 
                                                        |
| 150 | +define('DOL_DATA_ROOT', (isset($dolibarr_main_data_root) ? $dolibarr_main_data_root : DOL_BASE_PATH.'../documents')); | 
                                                        |
| 151 | +define('DOL_MAIN_URL_ROOT', (isset($dolibarr_main_url_root) ? $dolibarr_main_url_root : '')); // URL relative root | 
                                                        |
| 152 | +$uri = preg_replace('/^http(s?):\/\//i', '', constant('DOL_MAIN_URL_ROOT')); // $uri contains url without http* | 
                                                        |
| 153 | +$suburi = strstr($uri, '/'); // $suburi contains url without domain  | 
                                                        |
| 154 | 154 | if ($suburi == '/')  | 
                                                        
| 155 | - $suburi = ''; // If $suburi is /, it is now ''  | 
                                                        |
| 156 | -define('DOL_URL_ROOT', $suburi);    // URL relative root ('', '/dolibarr', ...) | 
                                                        |
| 155 | + $suburi = ''; // If $suburi is /, it is now ''  | 
                                                        |
| 156 | +define('DOL_URL_ROOT', $suburi); // URL relative root ('', '/dolibarr', ...) | 
                                                        |
| 157 | 157 | |
| 158 | 158 | |
| 159 | 159 | if (empty($conf->file->character_set_client))  | 
                                                        
@@ -189,14 +189,14 @@ discard block  | 
                                                    ||
| 189 | 189 |      $langs->load("install"); | 
                                                        
| 190 | 190 |      print $langs->trans("YouTryInstallDisabledByDirLock"); | 
                                                        
| 191 | 191 |      if (!empty($dolibarr_main_url_root)) { | 
                                                        
| 192 | - print 'Click on following link, <a href="' . $dolibarr_main_url_root . '/admin/index.php?mainmenu=home&leftmenu=setup' . (isset($_POST["login"]) ? '&username=' . urlencode($_POST["login"]) : '') . '">';  | 
                                                        |
| 192 | + print 'Click on following link, <a href="'.$dolibarr_main_url_root.'/admin/index.php?mainmenu=home&leftmenu=setup'.(isset($_POST["login"]) ? '&username='.urlencode($_POST["login"]) : '').'">';  | 
                                                        |
| 193 | 193 |          print $langs->trans("ClickHereToGoToApp"); | 
                                                        
| 194 | 194 | print '</a>';  | 
                                                        
| 195 | 195 | }  | 
                                                        
| 196 | 196 | exit;  | 
                                                        
| 197 | 197 | }  | 
                                                        
| 198 | 198 | |
| 199 | -$lockfile = DOL_DATA_ROOT . '/install.lock';  | 
                                                        |
| 199 | +$lockfile = DOL_DATA_ROOT.'/install.lock';  | 
                                                        |
| 200 | 200 |  if (constant('DOL_DATA_ROOT') === null) { | 
                                                        
| 201 | 201 | // We don't have a configuration file yet  | 
                                                        
| 202 | 202 | // Try to detect any lockfile in the default documents path  | 
                                                        
@@ -210,8 +210,8 @@ discard block  | 
                                                    ||
| 210 | 210 |      $langs->load("install"); | 
                                                        
| 211 | 211 |      print $langs->trans("YouTryInstallDisabledByFileLock"); | 
                                                        
| 212 | 212 |      if (!empty($dolibarr_main_url_root)) { | 
                                                        
| 213 | -        print $langs->trans("ClickOnLinkOrRemoveManualy") . '<br>'; | 
                                                        |
| 214 | - print '<a href="' . $dolibarr_main_url_root . '/admin/index.php?mainmenu=home&leftmenu=setup' . (isset($_POST["login"]) ? '&username=' . urlencode($_POST["login"]) : '') . '">';  | 
                                                        |
| 213 | +        print $langs->trans("ClickOnLinkOrRemoveManualy").'<br>'; | 
                                                        |
| 214 | + print '<a href="'.$dolibarr_main_url_root.'/admin/index.php?mainmenu=home&leftmenu=setup'.(isset($_POST["login"]) ? '&username='.urlencode($_POST["login"]) : '').'">';  | 
                                                        |
| 215 | 215 |          print $langs->trans("ClickHereToGoToApp"); | 
                                                        
| 216 | 216 | print '</a>';  | 
                                                        
| 217 | 217 |      } else { | 
                                                        
@@ -230,13 +230,13 @@ discard block  | 
                                                    ||
| 230 | 230 |      if (@is_writable('/tmp')) | 
                                                        
| 231 | 231 |          define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        
| 232 | 232 | else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"]))  | 
                                                        
| 233 | -        define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 233 | +        define('SYSLOG_FILE', $_ENV["TMP"].'/dolibarr_install.log'); | 
                                                        |
| 234 | 234 | else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"]))  | 
                                                        
| 235 | -        define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 235 | +        define('SYSLOG_FILE', $_ENV["TEMP"].'/dolibarr_install.log'); | 
                                                        |
| 236 | 236 |      else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) | 
                                                        
| 237 | 237 |          define('SYSLOG_FILE', '../../../../dolibarr_install.log'); // For DoliWamp | 
                                                        
| 238 | 238 |      else if (@is_writable('../../')) | 
                                                        
| 239 | -        define('SYSLOG_FILE', '../../dolibarr_install.log');    // For others | 
                                                        |
| 239 | +        define('SYSLOG_FILE', '../../dolibarr_install.log'); // For others | 
                                                        |
| 240 | 240 | |
| 241 | 241 | |
| 242 | 242 | |
@@ -258,9 +258,9 @@ discard block  | 
                                                    ||
| 258 | 258 | // We init log handler for install  | 
                                                        
| 259 | 259 |  $handlers = array('mod_syslog_file'); | 
                                                        
| 260 | 260 |  foreach ($handlers as $handler) { | 
                                                        
| 261 | - $file = DOL_BASE_PATH . '/core/modules/syslog/' . $handler . '.php';  | 
                                                        |
| 261 | + $file = DOL_BASE_PATH.'/core/modules/syslog/'.$handler.'.php';  | 
                                                        |
| 262 | 262 |      if (!file_exists($file)) { | 
                                                        
| 263 | -        throw new Exception('Missing log handler file ' . $handler . '.php'); | 
                                                        |
| 263 | +        throw new Exception('Missing log handler file '.$handler.'.php'); | 
                                                        |
| 264 | 264 | }  | 
                                                        
| 265 | 265 | |
| 266 | 266 | require_once $file;  | 
                                                        
@@ -320,7 +320,7 @@ discard block  | 
                                                    ||
| 320 | 320 | global $dolibarr_main_db_pass;  | 
                                                        
| 321 | 321 | global $character_set_client;  | 
                                                        
| 322 | 322 | |
| 323 | - $return = include_once $dolibarr_main_document_root . '/core/class/conf.class.php';  | 
                                                        |
| 323 | + $return = include_once $dolibarr_main_document_root.'/core/class/conf.class.php';  | 
                                                        |
| 324 | 324 | if (!$return)  | 
                                                        
| 325 | 325 | return -1;  | 
                                                        
| 326 | 326 | |
@@ -360,13 +360,13 @@ discard block  | 
                                                    ||
| 360 | 360 |          if (@is_writable('/tmp')) | 
                                                        
| 361 | 361 |              define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        
| 362 | 362 | else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"]))  | 
                                                        
| 363 | -            define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 363 | +            define('SYSLOG_FILE', $_ENV["TMP"].'/dolibarr_install.log'); | 
                                                        |
| 364 | 364 | else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"]))  | 
                                                        
| 365 | -            define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 365 | +            define('SYSLOG_FILE', $_ENV["TEMP"].'/dolibarr_install.log'); | 
                                                        |
| 366 | 366 |          else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) | 
                                                        
| 367 | 367 |              define('SYSLOG_FILE', '../../../../dolibarr_install.log'); // For DoliWamp | 
                                                        
| 368 | 368 |          else if (@is_writable('../../')) | 
                                                        
| 369 | -            define('SYSLOG_FILE', '../../dolibarr_install.log');    // For others | 
                                                        |
| 369 | +            define('SYSLOG_FILE', '../../dolibarr_install.log'); // For others | 
                                                        |
| 370 | 370 | |
| 371 | 371 | |
| 372 | 372 | |
@@ -388,9 +388,9 @@ discard block  | 
                                                    ||
| 388 | 388 | // We init log handler for install  | 
                                                        
| 389 | 389 |      $handlers = array('mod_syslog_file'); | 
                                                        
| 390 | 390 |      foreach ($handlers as $handler) { | 
                                                        
| 391 | - $file = DOL_BASE_PATH . '/core/modules/syslog/' . $handler . '.php';  | 
                                                        |
| 391 | + $file = DOL_BASE_PATH.'/core/modules/syslog/'.$handler.'.php';  | 
                                                        |
| 392 | 392 |          if (!file_exists($file)) { | 
                                                        
| 393 | -            throw new Exception('Missing log handler file ' . $handler . '.php'); | 
                                                        |
| 393 | +            throw new Exception('Missing log handler file '.$handler.'.php'); | 
                                                        |
| 394 | 394 | }  | 
                                                        
| 395 | 395 | |
| 396 | 396 | require_once $file;  | 
                                                        
@@ -436,63 +436,63 @@ discard block  | 
                                                    ||
| 436 | 436 | }  | 
                                                        
| 437 | 437 | |
| 438 | 438 | // We force the content charset  | 
                                                        
| 439 | -    header("Content-type: text/html; charset=" . $conf->file->character_set_client); | 
                                                        |
| 439 | +    header("Content-type: text/html; charset=".$conf->file->character_set_client); | 
                                                        |
| 440 | 440 |      header("X-Content-Type-Options: nosniff"); | 
                                                        
| 441 | 441 | |
| 442 | - print '<!DOCTYPE HTML>' . "\n";  | 
                                                        |
| 443 | - print '<html>' . "\n";  | 
                                                        |
| 444 | - print '<head>' . "\n";  | 
                                                        |
| 445 | - print '<meta charset="' . $conf->file->character_set_client . '">' . "\n";  | 
                                                        |
| 446 | - print '<meta name="viewport" content="width=device-width, initial-scale=1.0">' . "\n";  | 
                                                        |
| 447 | - print '<meta name="generator" content="Dolibarr installer">' . "\n";  | 
                                                        |
| 448 | - print '<link rel="stylesheet" type="text/css" href="' . DOL_BASE_URI . '/install/default.css">' . "\n";  | 
                                                        |
| 442 | + print '<!DOCTYPE HTML>'."\n";  | 
                                                        |
| 443 | + print '<html>'."\n";  | 
                                                        |
| 444 | + print '<head>'."\n";  | 
                                                        |
| 445 | + print '<meta charset="'.$conf->file->character_set_client.'">'."\n";  | 
                                                        |
| 446 | + print '<meta name="viewport" content="width=device-width, initial-scale=1.0">'."\n";  | 
                                                        |
| 447 | + print '<meta name="generator" content="Dolibarr installer">'."\n";  | 
                                                        |
| 448 | + print '<link rel="stylesheet" type="text/css" href="'.DOL_BASE_URI.'/install/default.css">'."\n";  | 
                                                        |
| 449 | 449 | |
| 450 | - print '<!-- Includes CSS for JQuery -->' . "\n";  | 
                                                        |
| 450 | + print '<!-- Includes CSS for JQuery -->'."\n";  | 
                                                        |
| 451 | 451 |      if ($jQueryUiCustomPath) { | 
                                                        
| 452 | - print '<link rel="stylesheet" type="text/css" href="' . $jQueryUiCustomPath . 'css/' . $jquerytheme . '/jquery-ui.min.css" />' . "\n"; // JQuery  | 
                                                        |
| 452 | + print '<link rel="stylesheet" type="text/css" href="'.$jQueryUiCustomPath.'css/'.$jquerytheme.'/jquery-ui.min.css" />'."\n"; // JQuery  | 
                                                        |
| 453 | 453 |      } else { | 
                                                        
| 454 | 454 | //print '<link rel="stylesheet" type="text/css" href="' . DOL_BASE_URI . '/includes/jquery/css/' . $jquerytheme . '/jquery-ui.min.css" />' . "\n"; // JQuery  | 
                                                        
| 455 | - print '<link rel="stylesheet" type="text/css" href="' . BASE_URI . '/includes/jquery/css/' . $jquerytheme . '/jquery-ui.min.css" />' . "\n"; // JQuery  | 
                                                        |
| 455 | + print '<link rel="stylesheet" type="text/css" href="'.BASE_URI.'/includes/jquery/css/'.$jquerytheme.'/jquery-ui.min.css" />'."\n"; // JQuery  | 
                                                        |
| 456 | 456 | }  | 
                                                        
| 457 | - print '<!-- Includes JS for JQuery -->' . "\n";  | 
                                                        |
| 457 | + print '<!-- Includes JS for JQuery -->'."\n";  | 
                                                        |
| 458 | 458 |      if ($jQueryCustomPath) { | 
                                                        
| 459 | - print '<script type="text/javascript" src="' . $jQueryCustomPath . 'jquery.min.js"></script>' . "\n";  | 
                                                        |
| 459 | + print '<script type="text/javascript" src="'.$jQueryCustomPath.'jquery.min.js"></script>'."\n";  | 
                                                        |
| 460 | 460 |      } else { | 
                                                        
| 461 | 461 | // print '<script type="text/javascript" src="' . DOL_BASE_URI . '/includes/jquery/js/jquery.min.js"></script>' . "\n";  | 
                                                        
| 462 | - print '<script type="text/javascript" src="' . BASE_URI . '/vendor/components/jquery/jquery.min.js"></script>' . "\n";  | 
                                                        |
| 462 | + print '<script type="text/javascript" src="'.BASE_URI.'/vendor/components/jquery/jquery.min.js"></script>'."\n";  | 
                                                        |
| 463 | 463 | }  | 
                                                        
| 464 | 464 |      if ($jQueryUiCustomPath) { | 
                                                        
| 465 | - print '<script type="text/javascript" src="' . $jQueryUiCustomPath . 'jquery-ui.min.js"></script>' . "\n";  | 
                                                        |
| 465 | + print '<script type="text/javascript" src="'.$jQueryUiCustomPath.'jquery-ui.min.js"></script>'."\n";  | 
                                                        |
| 466 | 466 |      } else { | 
                                                        
| 467 | 467 | // print '<script type="text/javascript" src="' . DOL_BASE_URI . '/includes/jquery/js/jquery-ui.min.js"></script>' . "\n";  | 
                                                        
| 468 | - print '<script type="text/javascript" src="' . BASE_URI . '/vendor/components/jqueryui/jquery-ui.min.js"></script>' . "\n";  | 
                                                        |
| 468 | + print '<script type="text/javascript" src="'.BASE_URI.'/vendor/components/jqueryui/jquery-ui.min.js"></script>'."\n";  | 
                                                        |
| 469 | 469 | }  | 
                                                        
| 470 | -    print '<title>' . $langs->trans("DolibarrSetup") . '</title>' . "\n"; | 
                                                        |
| 470 | +    print '<title>'.$langs->trans("DolibarrSetup").'</title>'."\n"; | 
                                                        |
| 471 | 471 | print "<!-- Alixar debugBar header -->";  | 
                                                        
| 472 | 472 | print Debug::getRenderHeader(); // Includes Alixar debugBar header  | 
                                                        
| 473 | - print '</head>' . "\n";  | 
                                                        |
| 473 | + print '</head>'."\n";  | 
                                                        |
| 474 | 474 | |
| 475 | - print '<body>' . "\n";  | 
                                                        |
| 475 | + print '<body>'."\n";  | 
                                                        |
| 476 | 476 | |
| 477 | 477 | print '<div class="divlogoinstall" style="text-align:center">';  | 
                                                        
| 478 | - print '<img class="imglogoinstall" src="' . DOL_BASE_URI . '/theme/dolibarr_logo.png" alt="Dolibarr logo"><br>';  | 
                                                        |
| 478 | + print '<img class="imglogoinstall" src="'.DOL_BASE_URI.'/theme/dolibarr_logo.png" alt="Dolibarr logo"><br>';  | 
                                                        |
| 479 | 479 | print DOL_VERSION;  | 
                                                        
| 480 | 480 | print '</div><br>';  | 
                                                        
| 481 | 481 | |
| 482 | -    print '<span class="titre">' . $langs->trans("DolibarrSetup"); | 
                                                        |
| 482 | +    print '<span class="titre">'.$langs->trans("DolibarrSetup"); | 
                                                        |
| 483 | 483 |      if ($subtitle) { | 
                                                        
| 484 | - print ' - ' . $subtitle;  | 
                                                        |
| 484 | + print ' - '.$subtitle;  | 
                                                        |
| 485 | 485 | }  | 
                                                        
| 486 | - print '</span>' . "\n";  | 
                                                        |
| 486 | + print '</span>'."\n";  | 
                                                        |
| 487 | 487 | |
| 488 | 488 | //print '<form name="forminstall" style="width: 100%" action="' . $next . '.php' . ($param ? '?' . $param : '') . '" method="POST">' . "\n";  | 
                                                        
| 489 | - print '<form name="forminstall" style="width: 100%" action="' . BASE_URI . '?controller=install&method=' . $next . ($param ? '&' . $param : '') . '" method="POST">' . "\n";  | 
                                                        |
| 490 | - print '<input type="hidden" name="testpost" value="ok">' . "\n";  | 
                                                        |
| 491 | - print '<input type="hidden" name="action" value="' . $action . '">' . "\n";  | 
                                                        |
| 489 | + print '<form name="forminstall" style="width: 100%" action="'.BASE_URI.'?controller=install&method='.$next.($param ? '&'.$param : '').'" method="POST">'."\n";  | 
                                                        |
| 490 | + print '<input type="hidden" name="testpost" value="ok">'."\n";  | 
                                                        |
| 491 | + print '<input type="hidden" name="action" value="'.$action.'">'."\n";  | 
                                                        |
| 492 | 492 | |
| 493 | - print '<table class="main" width="100%"><tr><td>' . "\n";  | 
                                                        |
| 493 | + print '<table class="main" width="100%"><tr><td>'."\n";  | 
                                                        |
| 494 | 494 | |
| 495 | - print '<table class="' . $csstable . '" width="100%"><tr><td>' . "\n";  | 
                                                        |
| 495 | + print '<table class="'.$csstable.'" width="100%"><tr><td>'."\n";  | 
                                                        |
| 496 | 496 | }  | 
                                                        
| 497 | 497 | |
| 498 | 498 | /**  | 
                                                        
@@ -512,27 +512,27 @@ discard block  | 
                                                    ||
| 512 | 512 |      $langs->load("other"); | 
                                                        
| 513 | 513 |      $langs->load("admin"); | 
                                                        
| 514 | 514 | |
| 515 | - print '</td></tr></table>' . "\n";  | 
                                                        |
| 516 | - print '</td></tr></table>' . "\n";  | 
                                                        |
| 515 | + print '</td></tr></table>'."\n";  | 
                                                        |
| 516 | + print '</td></tr></table>'."\n";  | 
                                                        |
| 517 | 517 | |
| 518 | 518 |      if (!$nonext || ($nonext == '2')) { | 
                                                        
| 519 | 519 | print '<div class="nextbutton" id="nextbutton">';  | 
                                                        
| 520 | 520 |          if ($nonext == '2') { | 
                                                        
| 521 | -            print $langs->trans("ErrorFoundDuringMigration", isset($_SERVER["REQUEST_URI"]) ? $_SERVER["REQUEST_URI"] . '&ignoreerrors=1' : '') . '<br><br>'; | 
                                                        |
| 521 | +            print $langs->trans("ErrorFoundDuringMigration", isset($_SERVER["REQUEST_URI"]) ? $_SERVER["REQUEST_URI"].'&ignoreerrors=1' : '').'<br><br>'; | 
                                                        |
| 522 | 522 | }  | 
                                                        
| 523 | 523 | |
| 524 | -        print '<input type="submit" ' . ($nonext == '2' ? 'disabled="disabled" ' : '') . 'value="' . $langs->trans("NextStep") . ' ->"'; | 
                                                        |
| 524 | +        print '<input type="submit" '.($nonext == '2' ? 'disabled="disabled" ' : '').'value="'.$langs->trans("NextStep").' ->"'; | 
                                                        |
| 525 | 525 | if ($jscheckfunction)  | 
                                                        
| 526 | - print ' onClick="return ' . $jscheckfunction . '();"';  | 
                                                        |
| 526 | + print ' onClick="return '.$jscheckfunction.'();"';  | 
                                                        |
| 527 | 527 | print '></div>';  | 
                                                        
| 528 | 528 | if ($withpleasewait)  | 
                                                        
| 529 | -            print '<div style="visibility: hidden;" class="pleasewait" id="pleasewait"><br>' . $langs->trans("NextStepMightLastALongTime") . '<br><br><div class="blinkwait">' . $langs->trans("PleaseBePatient") . '</div></div>'; | 
                                                        |
| 529 | +            print '<div style="visibility: hidden;" class="pleasewait" id="pleasewait"><br>'.$langs->trans("NextStepMightLastALongTime").'<br><br><div class="blinkwait">'.$langs->trans("PleaseBePatient").'</div></div>'; | 
                                                        |
| 530 | 530 | }  | 
                                                        
| 531 | 531 |      if ($setuplang) { | 
                                                        
| 532 | - print '<input type="hidden" name="selectlang" value="' . $setuplang . '">';  | 
                                                        |
| 532 | + print '<input type="hidden" name="selectlang" value="'.$setuplang.'">';  | 
                                                        |
| 533 | 533 | }  | 
                                                        
| 534 | 534 | |
| 535 | - print '</form>' . "\n";  | 
                                                        |
| 535 | + print '</form>'."\n";  | 
                                                        |
| 536 | 536 | |
| 537 | 537 | // If there is some logs in buffer to show  | 
                                                        
| 538 | 538 |      if (isset($conf->logbuffer) && count($conf->logbuffer)) { | 
                                                        
@@ -540,7 +540,7 @@ discard block  | 
                                                    ||
| 540 | 540 | print "<!-- Start of log output\n";  | 
                                                        
| 541 | 541 | //print '<div class="hidden">'."\n";  | 
                                                        
| 542 | 542 |          foreach ($conf->logbuffer as $logline) { | 
                                                        
| 543 | - print $logline . "<br>\n";  | 
                                                        |
| 543 | + print $logline."<br>\n";  | 
                                                        |
| 544 | 544 | }  | 
                                                        
| 545 | 545 | //print '</div>'."\n";  | 
                                                        
| 546 | 546 | print "End of log output -->\n";  | 
                                                        
@@ -549,8 +549,8 @@ discard block  | 
                                                    ||
| 549 | 549 | |
| 550 | 550 | print "<!-- Alixar debugBar footer -->";  | 
                                                        
| 551 | 551 | print Debug::getRenderFooter(); // Includes Alixar debugBar footer  | 
                                                        
| 552 | - print '</body>' . "\n";  | 
                                                        |
| 553 | - print '</html>' . "\n";  | 
                                                        |
| 552 | + print '</body>'."\n";  | 
                                                        |
| 553 | + print '</html>'."\n";  | 
                                                        |
| 554 | 554 | }  | 
                                                        
| 555 | 555 | |
| 556 | 556 | /**  | 
                                                        
@@ -615,16 +615,16 @@ discard block  | 
                                                    ||
| 615 | 615 | $dolibarr_main_url_root = $_SERVER["SCRIPT_URI"];  | 
                                                        
| 616 | 616 | } // If defined (Ie: Apache with Caudium)  | 
                                                        
| 617 | 617 |      elseif (isset($_SERVER["SERVER_URL"]) && isset($_SERVER["DOCUMENT_URI"])) { | 
                                                        
| 618 | - $dolibarr_main_url_root = $_SERVER["SERVER_URL"] . $_SERVER["DOCUMENT_URI"];  | 
                                                        |
| 618 | + $dolibarr_main_url_root = $_SERVER["SERVER_URL"].$_SERVER["DOCUMENT_URI"];  | 
                                                        |
| 619 | 619 | } // If SCRIPT_URI, SERVER_URL, DOCUMENT_URI not defined (Ie: Apache 2.0.44 for Windows)  | 
                                                        
| 620 | 620 |      else { | 
                                                        
| 621 | - $proto = ( (!empty($_SERVER["HTTPS"]) && $_SERVER["HTTPS"] == 'on') || $_SERVER['SERVER_PORT'] == 443) ? 'https' : 'http';  | 
                                                        |
| 621 | + $proto = ((!empty($_SERVER["HTTPS"]) && $_SERVER["HTTPS"] == 'on') || $_SERVER['SERVER_PORT'] == 443) ? 'https' : 'http';  | 
                                                        |
| 622 | 622 |          if (!empty($_SERVER["HTTP_HOST"])) { | 
                                                        
| 623 | 623 | $serverport = $_SERVER["HTTP_HOST"];  | 
                                                        
| 624 | 624 |          } else { | 
                                                        
| 625 | 625 | $serverport = $_SERVER["SERVER_NAME"];  | 
                                                        
| 626 | 626 | }  | 
                                                        
| 627 | - $dolibarr_main_url_root = $proto . "://" . $serverport . $_SERVER["SCRIPT_NAME"];  | 
                                                        |
| 627 | + $dolibarr_main_url_root = $proto."://".$serverport.$_SERVER["SCRIPT_NAME"];  | 
                                                        |
| 628 | 628 | }  | 
                                                        
| 629 | 629 | // Clean proposed URL  | 
                                                        
| 630 | 630 | // We assume /install to be under /htdocs, so we get the parent path of the current URL  | 
                                                        
@@ -31,8 +31,9 @@ discard block  | 
                                                    ||
| 31 | 31 | * \brief File that define environment for support pages  | 
                                                        
| 32 | 32 | */  | 
                                                        
| 33 | 33 | // Just to define version DOL_VERSION  | 
                                                        
| 34 | -if (!defined('DOL_INC_FOR_VERSION_ERROR')) | 
                                                        |
| 34 | +if (!defined('DOL_INC_FOR_VERSION_ERROR')) { | 
                                                        |
| 35 | 35 |      define('DOL_INC_FOR_VERSION_ERROR', '1'); | 
                                                        
| 36 | +}  | 
                                                        |
| 36 | 37 | require_once DOL_BASE_PATH . '/filefunc.inc.php';  | 
                                                        
| 37 | 38 | |
| 38 | 39 | require_once DOL_BASE_PATH . '/core/class/translate.class.php';  | 
                                                        
@@ -151,23 +152,31 @@ discard block  | 
                                                    ||
| 151 | 152 |  define('DOL_MAIN_URL_ROOT', (isset($dolibarr_main_url_root) ? $dolibarr_main_url_root : ''));           // URL relative root | 
                                                        
| 152 | 153 |  $uri = preg_replace('/^http(s?):\/\//i', '', constant('DOL_MAIN_URL_ROOT'));  // $uri contains url without http* | 
                                                        
| 153 | 154 | $suburi = strstr($uri, '/'); // $suburi contains url without domain  | 
                                                        
| 154 | -if ($suburi == '/')  | 
                                                        |
| 155 | - $suburi = ''; // If $suburi is /, it is now ''  | 
                                                        |
| 155 | +if ($suburi == '/') { | 
                                                        |
| 156 | + $suburi = '';  | 
                                                        |
| 157 | +}  | 
                                                        |
| 158 | +// If $suburi is /, it is now ''  | 
                                                        |
| 156 | 159 |  define('DOL_URL_ROOT', $suburi);    // URL relative root ('', '/dolibarr', ...) | 
                                                        
| 157 | 160 | |
| 158 | 161 | |
| 159 | -if (empty($conf->file->character_set_client))  | 
                                                        |
| 162 | +if (empty($conf->file->character_set_client)) { | 
                                                        |
| 160 | 163 | $conf->file->character_set_client = "utf-8";  | 
                                                        
| 161 | -if (empty($conf->db->character_set))  | 
                                                        |
| 164 | +}  | 
                                                        |
| 165 | +if (empty($conf->db->character_set)) { | 
                                                        |
| 162 | 166 | $conf->db->character_set = 'utf8';  | 
                                                        
| 163 | -if (empty($conf->db->dolibarr_main_db_collation))  | 
                                                        |
| 167 | +}  | 
                                                        |
| 168 | +if (empty($conf->db->dolibarr_main_db_collation)) { | 
                                                        |
| 164 | 169 | $conf->db->dolibarr_main_db_collation = 'utf8_unicode_ci';  | 
                                                        
| 165 | -if (empty($conf->db->dolibarr_main_db_encryption))  | 
                                                        |
| 170 | +}  | 
                                                        |
| 171 | +if (empty($conf->db->dolibarr_main_db_encryption)) { | 
                                                        |
| 166 | 172 | $conf->db->dolibarr_main_db_encryption = 0;  | 
                                                        
| 167 | -if (empty($conf->db->dolibarr_main_db_cryptkey))  | 
                                                        |
| 173 | +}  | 
                                                        |
| 174 | +if (empty($conf->db->dolibarr_main_db_cryptkey)) { | 
                                                        |
| 168 | 175 | $conf->db->dolibarr_main_db_cryptkey = '';  | 
                                                        
| 169 | -if (empty($conf->db->user))  | 
                                                        |
| 176 | +}  | 
                                                        |
| 177 | +if (empty($conf->db->user)) { | 
                                                        |
| 170 | 178 | $conf->db->user = '';  | 
                                                        
| 179 | +}  | 
                                                        |
| 171 | 180 | |
| 172 | 181 | // Define array of document root directories  | 
                                                        
| 173 | 182 | $conf->file->dol_document_root = array(DOL_DOCUMENT_ROOT);  | 
                                                        
@@ -224,19 +233,24 @@ discard block  | 
                                                    ||
| 224 | 233 | // Force usage of log file for install and upgrades  | 
                                                        
| 225 | 234 | $conf->syslog->enabled = 1;  | 
                                                        
| 226 | 235 |  $conf->global->SYSLOG_LEVEL = constant('LOG_DEBUG'); | 
                                                        
| 227 | -if (!defined('SYSLOG_HANDLERS')) | 
                                                        |
| 236 | +if (!defined('SYSLOG_HANDLERS')) { | 
                                                        |
| 228 | 237 |      define('SYSLOG_HANDLERS', '["mod_syslog_file"]'); | 
                                                        
| 238 | +}  | 
                                                        |
| 229 | 239 |  if (!defined('SYSLOG_FILE')) { // To avoid warning on systems with constant already defined | 
                                                        
| 230 | -    if (@is_writable('/tmp')) | 
                                                        |
| 231 | -        define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        |
| 232 | - else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"]))  | 
                                                        |
| 233 | -        define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 234 | - else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"]))  | 
                                                        |
| 235 | -        define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 236 | -    else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) | 
                                                        |
| 237 | -        define('SYSLOG_FILE', '../../../../dolibarr_install.log'); // For DoliWamp | 
                                                        |
| 238 | -    else if (@is_writable('../../')) | 
                                                        |
| 239 | -        define('SYSLOG_FILE', '../../dolibarr_install.log');    // For others | 
                                                        |
| 240 | +    if (@is_writable('/tmp')) { | 
                                                        |
| 241 | +            define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        |
| 242 | +    } else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"])) { | 
                                                        |
| 243 | +            define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 244 | +    } else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"])) { | 
                                                        |
| 245 | +            define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 246 | +    } else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) { | 
                                                        |
| 247 | +            define('SYSLOG_FILE', '../../../../dolibarr_install.log'); | 
                                                        |
| 248 | + }  | 
                                                        |
| 249 | + // For DoliWamp  | 
                                                        |
| 250 | +    else if (@is_writable('../../')) { | 
                                                        |
| 251 | +            define('SYSLOG_FILE', '../../dolibarr_install.log'); | 
                                                        |
| 252 | + }  | 
                                                        |
| 253 | + // For others  | 
                                                        |
| 240 | 254 | |
| 241 | 255 | |
| 242 | 256 | |
@@ -251,10 +265,12 @@ discard block  | 
                                                    ||
| 251 | 265 | |
| 252 | 266 | //print 'SYSLOG_FILE='.SYSLOG_FILE;exit;  | 
                                                        
| 253 | 267 | }  | 
                                                        
| 254 | -if (defined('SYSLOG_FILE')) | 
                                                        |
| 268 | +if (defined('SYSLOG_FILE')) { | 
                                                        |
| 255 | 269 |      $conf->global->SYSLOG_FILE = constant('SYSLOG_FILE'); | 
                                                        
| 256 | -if (!defined('SYSLOG_FILE_NO_ERROR')) | 
                                                        |
| 270 | +}  | 
                                                        |
| 271 | +if (!defined('SYSLOG_FILE_NO_ERROR')) { | 
                                                        |
| 257 | 272 |      define('SYSLOG_FILE_NO_ERROR', 1); | 
                                                        
| 273 | +}  | 
                                                        |
| 258 | 274 | // We init log handler for install  | 
                                                        
| 259 | 275 |  $handlers = array('mod_syslog_file'); | 
                                                        
| 260 | 276 |  foreach ($handlers as $handler) { | 
                                                        
@@ -269,9 +285,10 @@ discard block  | 
                                                    ||
| 269 | 285 |          throw new Exception('Log handler does not extend LogHandlerInterface'); | 
                                                        
| 270 | 286 | }  | 
                                                        
| 271 | 287 | |
| 272 | - if (empty($conf->loghandlers[$handler]))  | 
                                                        |
| 273 | - $conf->loghandlers[$handler] = $loghandlerinstance;  | 
                                                        |
| 274 | -}  | 
                                                        |
| 288 | +    if (empty($conf->loghandlers[$handler])) { | 
                                                        |
| 289 | + $conf->loghandlers[$handler] = $loghandlerinstance;  | 
                                                        |
| 290 | + }  | 
                                                        |
| 291 | + }  | 
                                                        |
| 275 | 292 | |
| 276 | 293 | // Removed magic_quotes  | 
                                                        
| 277 | 294 |  if (function_exists('get_magic_quotes_gpc')) { // magic_quotes_* removed in PHP 5.4 | 
                                                        
@@ -295,10 +312,11 @@ discard block  | 
                                                    ||
| 295 | 312 | |
| 296 | 313 | // Defini objet langs  | 
                                                        
| 297 | 314 |  $langs = new Translate('..', $conf); | 
                                                        
| 298 | -if (GETPOST('lang', 'aZ09')) | 
                                                        |
| 315 | +if (GETPOST('lang', 'aZ09')) { | 
                                                        |
| 299 | 316 |      $langs->setDefaultLang(GETPOST('lang', 'aZ09')); | 
                                                        
| 300 | -else  | 
                                                        |
| 317 | +} else { | 
                                                        |
| 301 | 318 |      $langs->setDefaultLang('auto'); | 
                                                        
| 319 | +}  | 
                                                        |
| 302 | 320 | |
| 303 | 321 | $bc[false] = ' class="bg1"';  | 
                                                        
| 304 | 322 | $bc[true] = ' class="bg2"';  | 
                                                        
@@ -321,8 +339,9 @@ discard block  | 
                                                    ||
| 321 | 339 | global $character_set_client;  | 
                                                        
| 322 | 340 | |
| 323 | 341 | $return = include_once $dolibarr_main_document_root . '/core/class/conf.class.php';  | 
                                                        
| 324 | - if (!$return)  | 
                                                        |
| 325 | - return -1;  | 
                                                        |
| 342 | +    if (!$return) { | 
                                                        |
| 343 | + return -1;  | 
                                                        |
| 344 | + }  | 
                                                        |
| 326 | 345 | |
| 327 | 346 | $conf = new Conf();  | 
                                                        
| 328 | 347 | $conf->db->type = trim($dolibarr_main_db_type);  | 
                                                        
@@ -333,40 +352,51 @@ discard block  | 
                                                    ||
| 333 | 352 | $conf->db->pass = trim($dolibarr_main_db_pass);  | 
                                                        
| 334 | 353 | |
| 335 | 354 | // Mysql driver support has been removed in favor of mysqli  | 
                                                        
| 336 | - if ($conf->db->type == 'mysql')  | 
                                                        |
| 337 | - $conf->db->type = 'mysqli';  | 
                                                        |
| 338 | - if (empty($character_set_client))  | 
                                                        |
| 339 | - $character_set_client = "UTF-8";  | 
                                                        |
| 355 | +    if ($conf->db->type == 'mysql') { | 
                                                        |
| 356 | + $conf->db->type = 'mysqli';  | 
                                                        |
| 357 | + }  | 
                                                        |
| 358 | +    if (empty($character_set_client)) { | 
                                                        |
| 359 | + $character_set_client = "UTF-8";  | 
                                                        |
| 360 | + }  | 
                                                        |
| 340 | 361 | $conf->file->character_set_client = strtoupper($character_set_client);  | 
                                                        
| 341 | - if (empty($dolibarr_main_db_character_set))  | 
                                                        |
| 342 | - $dolibarr_main_db_character_set = ($conf->db->type == 'mysqli' ? 'utf8' : '');  | 
                                                        |
| 362 | +    if (empty($dolibarr_main_db_character_set)) { | 
                                                        |
| 363 | + $dolibarr_main_db_character_set = ($conf->db->type == 'mysqli' ? 'utf8' : '');  | 
                                                        |
| 364 | + }  | 
                                                        |
| 343 | 365 | $conf->db->character_set = $dolibarr_main_db_character_set;  | 
                                                        
| 344 | - if (empty($dolibarr_main_db_collation))  | 
                                                        |
| 345 | - $dolibarr_main_db_collation = ($conf->db->type == 'mysqli' ? 'utf8_unicode_ci' : '');  | 
                                                        |
| 366 | +    if (empty($dolibarr_main_db_collation)) { | 
                                                        |
| 367 | + $dolibarr_main_db_collation = ($conf->db->type == 'mysqli' ? 'utf8_unicode_ci' : '');  | 
                                                        |
| 368 | + }  | 
                                                        |
| 346 | 369 | $conf->db->dolibarr_main_db_collation = $dolibarr_main_db_collation;  | 
                                                        
| 347 | - if (empty($dolibarr_main_db_encryption))  | 
                                                        |
| 348 | - $dolibarr_main_db_encryption = 0;  | 
                                                        |
| 370 | +    if (empty($dolibarr_main_db_encryption)) { | 
                                                        |
| 371 | + $dolibarr_main_db_encryption = 0;  | 
                                                        |
| 372 | + }  | 
                                                        |
| 349 | 373 | $conf->db->dolibarr_main_db_encryption = $dolibarr_main_db_encryption;  | 
                                                        
| 350 | - if (empty($dolibarr_main_db_cryptkey))  | 
                                                        |
| 351 | - $dolibarr_main_db_cryptkey = '';  | 
                                                        |
| 374 | +    if (empty($dolibarr_main_db_cryptkey)) { | 
                                                        |
| 375 | + $dolibarr_main_db_cryptkey = '';  | 
                                                        |
| 376 | + }  | 
                                                        |
| 352 | 377 | $conf->db->dolibarr_main_db_cryptkey = $dolibarr_main_db_cryptkey;  | 
                                                        
| 353 | 378 | |
| 354 | 379 | // Force usage of log file for install and upgrades  | 
                                                        
| 355 | 380 | $conf->syslog->enabled = 1;  | 
                                                        
| 356 | 381 |      $conf->global->SYSLOG_LEVEL = constant('LOG_DEBUG'); | 
                                                        
| 357 | -    if (!defined('SYSLOG_HANDLERS')) | 
                                                        |
| 358 | -        define('SYSLOG_HANDLERS', '["mod_syslog_file"]'); | 
                                                        |
| 382 | +    if (!defined('SYSLOG_HANDLERS')) { | 
                                                        |
| 383 | +            define('SYSLOG_HANDLERS', '["mod_syslog_file"]'); | 
                                                        |
| 384 | + }  | 
                                                        |
| 359 | 385 |      if (!defined('SYSLOG_FILE')) { // To avoid warning on systems with constant already defined | 
                                                        
| 360 | -        if (@is_writable('/tmp')) | 
                                                        |
| 361 | -            define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        |
| 362 | - else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"]))  | 
                                                        |
| 363 | -            define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 364 | - else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"]))  | 
                                                        |
| 365 | -            define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 366 | -        else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) | 
                                                        |
| 367 | -            define('SYSLOG_FILE', '../../../../dolibarr_install.log'); // For DoliWamp | 
                                                        |
| 368 | -        else if (@is_writable('../../')) | 
                                                        |
| 369 | -            define('SYSLOG_FILE', '../../dolibarr_install.log');    // For others | 
                                                        |
| 386 | +        if (@is_writable('/tmp')) { | 
                                                        |
| 387 | +                    define('SYSLOG_FILE', '/tmp/dolibarr_install.log'); | 
                                                        |
| 388 | +        } else if (!empty($_ENV["TMP"]) && @is_writable($_ENV["TMP"])) { | 
                                                        |
| 389 | +                    define('SYSLOG_FILE', $_ENV["TMP"] . '/dolibarr_install.log'); | 
                                                        |
| 390 | +        } else if (!empty($_ENV["TEMP"]) && @is_writable($_ENV["TEMP"])) { | 
                                                        |
| 391 | +                    define('SYSLOG_FILE', $_ENV["TEMP"] . '/dolibarr_install.log'); | 
                                                        |
| 392 | +        } else if (@is_writable('../../../../') && @file_exists('../../../../startdoliwamp.bat')) { | 
                                                        |
| 393 | +                    define('SYSLOG_FILE', '../../../../dolibarr_install.log'); | 
                                                        |
| 394 | + }  | 
                                                        |
| 395 | + // For DoliWamp  | 
                                                        |
| 396 | +        else if (@is_writable('../../')) { | 
                                                        |
| 397 | +                    define('SYSLOG_FILE', '../../dolibarr_install.log'); | 
                                                        |
| 398 | + }  | 
                                                        |
| 399 | + // For others  | 
                                                        |
| 370 | 400 | |
| 371 | 401 | |
| 372 | 402 | |
@@ -381,10 +411,12 @@ discard block  | 
                                                    ||
| 381 | 411 | |
| 382 | 412 | //print 'SYSLOG_FILE='.SYSLOG_FILE;exit;  | 
                                                        
| 383 | 413 | }  | 
                                                        
| 384 | -    if (defined('SYSLOG_FILE')) | 
                                                        |
| 385 | -        $conf->global->SYSLOG_FILE = constant('SYSLOG_FILE'); | 
                                                        |
| 386 | -    if (!defined('SYSLOG_FILE_NO_ERROR')) | 
                                                        |
| 387 | -        define('SYSLOG_FILE_NO_ERROR', 1); | 
                                                        |
| 414 | +    if (defined('SYSLOG_FILE')) { | 
                                                        |
| 415 | +            $conf->global->SYSLOG_FILE = constant('SYSLOG_FILE'); | 
                                                        |
| 416 | + }  | 
                                                        |
| 417 | +    if (!defined('SYSLOG_FILE_NO_ERROR')) { | 
                                                        |
| 418 | +            define('SYSLOG_FILE_NO_ERROR', 1); | 
                                                        |
| 419 | + }  | 
                                                        |
| 388 | 420 | // We init log handler for install  | 
                                                        
| 389 | 421 |      $handlers = array('mod_syslog_file'); | 
                                                        
| 390 | 422 |      foreach ($handlers as $handler) { | 
                                                        
@@ -399,8 +431,9 @@ discard block  | 
                                                    ||
| 399 | 431 |              throw new Exception('Log handler does not extend LogHandlerInterface'); | 
                                                        
| 400 | 432 | }  | 
                                                        
| 401 | 433 | |
| 402 | - if (empty($conf->loghandlers[$handler]))  | 
                                                        |
| 403 | - $conf->loghandlers[$handler] = $loghandlerinstance;  | 
                                                        |
| 434 | +        if (empty($conf->loghandlers[$handler])) { | 
                                                        |
| 435 | + $conf->loghandlers[$handler] = $loghandlerinstance;  | 
                                                        |
| 436 | + }  | 
                                                        |
| 404 | 437 | }  | 
                                                        
| 405 | 438 | |
| 406 | 439 | return 1;  | 
                                                        
@@ -522,11 +555,13 @@ discard block  | 
                                                    ||
| 522 | 555 | }  | 
                                                        
| 523 | 556 | |
| 524 | 557 |          print '<input type="submit" ' . ($nonext == '2' ? 'disabled="disabled" ' : '') . 'value="' . $langs->trans("NextStep") . ' ->"'; | 
                                                        
| 525 | - if ($jscheckfunction)  | 
                                                        |
| 526 | - print ' onClick="return ' . $jscheckfunction . '();"';  | 
                                                        |
| 558 | +        if ($jscheckfunction) { | 
                                                        |
| 559 | + print ' onClick="return ' . $jscheckfunction . '();"';  | 
                                                        |
| 560 | + }  | 
                                                        |
| 527 | 561 | print '></div>';  | 
                                                        
| 528 | - if ($withpleasewait)  | 
                                                        |
| 529 | -            print '<div style="visibility: hidden;" class="pleasewait" id="pleasewait"><br>' . $langs->trans("NextStepMightLastALongTime") . '<br><br><div class="blinkwait">' . $langs->trans("PleaseBePatient") . '</div></div>'; | 
                                                        |
| 562 | +        if ($withpleasewait) { | 
                                                        |
| 563 | +                    print '<div style="visibility: hidden;" class="pleasewait" id="pleasewait"><br>' . $langs->trans("NextStepMightLastALongTime") . '<br><br><div class="blinkwait">' . $langs->trans("PleaseBePatient") . '</div></div>'; | 
                                                        |
| 564 | + }  | 
                                                        |
| 530 | 565 | }  | 
                                                        
| 531 | 566 |      if ($setuplang) { | 
                                                        
| 532 | 567 | print '<input type="hidden" name="selectlang" value="' . $setuplang . '">';  | 
                                                        
@@ -562,8 +597,9 @@ discard block  | 
                                                    ||
| 562 | 597 | */  | 
                                                        
| 563 | 598 | function dolibarr_install_syslog($message, $level = LOG_DEBUG)  | 
                                                        
| 564 | 599 |  { | 
                                                        
| 565 | -    if (!defined('LOG_DEBUG')) | 
                                                        |
| 566 | -        define('LOG_DEBUG', 6); | 
                                                        |
| 600 | +    if (!defined('LOG_DEBUG')) { | 
                                                        |
| 601 | +            define('LOG_DEBUG', 6); | 
                                                        |
| 602 | + }  | 
                                                        |
| 567 | 603 | dol_syslog($message, $level);  | 
                                                        
| 568 | 604 | }  | 
                                                        
| 569 | 605 | |
@@ -56,7 +56,7 @@ discard block  | 
                                                    ||
| 56 | 56 | $pos++;  | 
                                                        
| 57 | 57 | $unicodeHexVal = substr($source, $pos, 4);  | 
                                                        
| 58 | 58 | $unicode = hexdec($unicodeHexVal);  | 
                                                        
| 59 | - $entity = "&#". $unicode . ';';  | 
                                                        |
| 59 | + $entity = "&#".$unicode.';';  | 
                                                        |
| 60 | 60 | $decodedStr .= utf8_encode($entity);  | 
                                                        
| 61 | 61 | $pos += 4;  | 
                                                        
| 62 | 62 | }  | 
                                                        
@@ -82,32 +82,32 @@ discard block  | 
                                                    ||
| 82 | 82 | * @param string $subdir Sub directory (Example: '/mailings')  | 
                                                        
| 83 | 83 | * @return array Array of directories that can contains module descriptors  | 
                                                        
| 84 | 84 | */  | 
                                                        
| 85 | -function dolGetModulesDirs($subdir='')  | 
                                                        |
| 85 | +function dolGetModulesDirs($subdir = '')  | 
                                                        |
| 86 | 86 |  {
 | 
                                                        
| 87 | 87 | global $conf;  | 
                                                        
| 88 | 88 | |
| 89 | - $modulesdir=array();  | 
                                                        |
| 89 | + $modulesdir = array();  | 
                                                        |
| 90 | 90 | |
| 91 | 91 | foreach ($conf->file->dol_document_root as $type => $dirroot)  | 
                                                        
| 92 | 92 |      {
 | 
                                                        
| 93 | 93 | // Default core/modules dir  | 
                                                        
| 94 | 94 |          if ($type === 'main') {
 | 
                                                        
| 95 | - $modulesdir[$dirroot . '/core/modules' . $subdir . '/'] = $dirroot . '/core/modules' . $subdir . '/';  | 
                                                        |
| 95 | + $modulesdir[$dirroot.'/core/modules'.$subdir.'/'] = $dirroot.'/core/modules'.$subdir.'/';  | 
                                                        |
| 96 | 96 | }  | 
                                                        
| 97 | 97 | |
| 98 | 98 | // Scan dir from external modules  | 
                                                        
| 99 | - $handle=@opendir($dirroot);  | 
                                                        |
| 99 | + $handle = @opendir($dirroot);  | 
                                                        |
| 100 | 100 | if (is_resource($handle))  | 
                                                        
| 101 | 101 |          {
 | 
                                                        
| 102 | - while (($file = readdir($handle))!==false)  | 
                                                        |
| 102 | + while (($file = readdir($handle)) !== false)  | 
                                                        |
| 103 | 103 |              {
 | 
                                                        
| 104 | -                if (preg_match('/disabled/',$file)) continue;   // We discard module if it contains disabled into name.
 | 
                                                        |
| 104 | +                if (preg_match('/disabled/', $file)) continue; // We discard module if it contains disabled into name.
 | 
                                                        |
| 105 | 105 | |
| 106 | 106 | if (is_dir($dirroot.'/'.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS' && $file != 'includes')  | 
                                                        
| 107 | 107 |                  {
 | 
                                                        
| 108 | - if (is_dir($dirroot . '/' . $file . '/core/modules'.$subdir.'/'))  | 
                                                        |
| 108 | + if (is_dir($dirroot.'/'.$file.'/core/modules'.$subdir.'/'))  | 
                                                        |
| 109 | 109 |                      {
 | 
                                                        
| 110 | - $modulesdir[$dirroot . '/' . $file . '/core/modules'.$subdir.'/'] = $dirroot . '/' . $file . '/core/modules'.$subdir.'/';  | 
                                                        |
| 110 | + $modulesdir[$dirroot.'/'.$file.'/core/modules'.$subdir.'/'] = $dirroot.'/'.$file.'/core/modules'.$subdir.'/';  | 
                                                        |
| 111 | 111 | }  | 
                                                        
| 112 | 112 | }  | 
                                                        
| 113 | 113 | }  | 
                                                        
@@ -128,13 +128,13 @@ discard block  | 
                                                    ||
| 128 | 128 |  {
 | 
                                                        
| 129 | 129 | global $langs;  | 
                                                        
| 130 | 130 | |
| 131 | - $selected='EUA4';  | 
                                                        |
| 131 | + $selected = 'EUA4';  | 
                                                        |
| 132 | 132 |      if (!$outputlangs) {
 | 
                                                        
| 133 | - $outputlangs=$langs;  | 
                                                        |
| 133 | + $outputlangs = $langs;  | 
                                                        |
| 134 | 134 | }  | 
                                                        
| 135 | 135 | |
| 136 | - if ($outputlangs->defaultlang == 'ca_CA') $selected='CAP4'; // Canada  | 
                                                        |
| 137 | - if ($outputlangs->defaultlang == 'en_US') $selected='USLetter'; // US  | 
                                                        |
| 136 | + if ($outputlangs->defaultlang == 'ca_CA') $selected = 'CAP4'; // Canada  | 
                                                        |
| 137 | + if ($outputlangs->defaultlang == 'en_US') $selected = 'USLetter'; // US  | 
                                                        |
| 138 | 138 | return $selected;  | 
                                                        
| 139 | 139 | }  | 
                                                        
| 140 | 140 | |
@@ -146,20 +146,20 @@ discard block  | 
                                                    ||
| 146 | 146 | * @param int $searchalt 1=Search also in alternative languages  | 
                                                        
| 147 | 147 | * @return boolean true if OK, false if KO  | 
                                                        
| 148 | 148 | */  | 
                                                        
| 149 | -function dol_print_file($langs,$filename,$searchalt=0)  | 
                                                        |
| 149 | +function dol_print_file($langs, $filename, $searchalt = 0)  | 
                                                        |
| 150 | 150 |  {
 | 
                                                        
| 151 | 151 | global $conf;  | 
                                                        
| 152 | 152 | |
| 153 | 153 | // Test if file is in lang directory  | 
                                                        
| 154 | - foreach($langs->dir as $searchdir)  | 
                                                        |
| 154 | + foreach ($langs->dir as $searchdir)  | 
                                                        |
| 155 | 155 |      {
 | 
                                                        
| 156 | - $formfile=($searchdir."/langs/".$langs->defaultlang."/".$filename);  | 
                                                        |
| 156 | + $formfile = ($searchdir."/langs/".$langs->defaultlang."/".$filename);  | 
                                                        |
| 157 | 157 |          dol_syslog('functions2::dol_print_file search file '.$formfile, LOG_DEBUG);
 | 
                                                        
| 158 | 158 | if (is_readable($formfile))  | 
                                                        
| 159 | 159 |          {
 | 
                                                        
| 160 | - $content=file_get_contents($formfile);  | 
                                                        |
| 161 | - $isutf8=utf8_check($content);  | 
                                                        |
| 162 | - if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 160 | + $content = file_get_contents($formfile);  | 
                                                        |
| 161 | + $isutf8 = utf8_check($content);  | 
                                                        |
| 162 | + if (!$isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 163 | 163 | elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') print utf8_decode($content);  | 
                                                        
| 164 | 164 | else print $content;  | 
                                                        
| 165 | 165 | return true;  | 
                                                        
@@ -174,9 +174,9 @@ discard block  | 
                                                    ||
| 174 | 174 | //print 'getcwd='.getcwd().' htmlfilealt='.$formfilealt.' X '.file_exists(getcwd().'/'.$formfilealt);  | 
                                                        
| 175 | 175 | if (is_readable($formfilealt))  | 
                                                        
| 176 | 176 |              {
 | 
                                                        
| 177 | - $content=file_get_contents($formfilealt);  | 
                                                        |
| 178 | - $isutf8=utf8_check($content);  | 
                                                        |
| 179 | - if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 177 | + $content = file_get_contents($formfilealt);  | 
                                                        |
| 178 | + $isutf8 = utf8_check($content);  | 
                                                        |
| 179 | + if (!$isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 180 | 180 | elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') print utf8_decode($content);  | 
                                                        
| 181 | 181 | else print $content;  | 
                                                        
| 182 | 182 | return true;  | 
                                                        
@@ -196,7 +196,7 @@ discard block  | 
                                                    ||
| 196 | 196 | * @param int $usetable Output into a table  | 
                                                        
| 197 | 197 | * @return void  | 
                                                        
| 198 | 198 | */  | 
                                                        
| 199 | -function dol_print_object_info($object, $usetable=0)  | 
                                                        |
| 199 | +function dol_print_object_info($object, $usetable = 0)  | 
                                                        |
| 200 | 200 |  {
 | 
                                                        
| 201 | 201 | global $langs, $db;  | 
                                                        
| 202 | 202 | |
@@ -205,16 +205,16 @@ discard block  | 
                                                    ||
| 205 | 205 | |
| 206 | 206 | include_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';  | 
                                                        
| 207 | 207 | |
| 208 | -    $deltadateforserver=getServerTimeZoneInt('now');
 | 
                                                        |
| 209 | - $deltadateforclient=((int) $_SESSION['dol_tz'] + (int) $_SESSION['dol_dst']);  | 
                                                        |
| 208 | +    $deltadateforserver = getServerTimeZoneInt('now');
 | 
                                                        |
| 209 | + $deltadateforclient = ((int) $_SESSION['dol_tz'] + (int) $_SESSION['dol_dst']);  | 
                                                        |
| 210 | 210 | //$deltadateforcompany=((int) $_SESSION['dol_tz'] + (int) $_SESSION['dol_dst']);  | 
                                                        
| 211 | - $deltadateforuser=round($deltadateforclient-$deltadateforserver);  | 
                                                        |
| 211 | + $deltadateforuser = round($deltadateforclient - $deltadateforserver);  | 
                                                        |
| 212 | 212 | //print "x".$deltadateforserver." - ".$deltadateforclient." - ".$deltadateforuser;  | 
                                                        
| 213 | 213 | |
| 214 | 214 | if ($usetable) print '<table class="border centpercent">';  | 
                                                        
| 215 | 215 | |
| 216 | 216 | // Import key  | 
                                                        
| 217 | - if (! empty($object->import_key))  | 
                                                        |
| 217 | + if (!empty($object->import_key))  | 
                                                        |
| 218 | 218 |      {
 | 
                                                        
| 219 | 219 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 220 | 220 |          print $langs->trans("ImportedWithSet");
 | 
                                                        
@@ -226,7 +226,7 @@ discard block  | 
                                                    ||
| 226 | 226 | }  | 
                                                        
| 227 | 227 | |
| 228 | 228 | // User creation (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 229 | - if (! empty($object->user_creation) || ! empty($object->user_creation_id))  | 
                                                        |
| 229 | + if (!empty($object->user_creation) || !empty($object->user_creation_id))  | 
                                                        |
| 230 | 230 |      {
 | 
                                                        
| 231 | 231 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 232 | 232 |          print $langs->trans("CreatedBy");
 | 
                                                        
@@ -239,7 +239,7 @@ discard block  | 
                                                    ||
| 239 | 239 | }  | 
                                                        
| 240 | 240 | else  | 
                                                        
| 241 | 241 |          {
 | 
                                                        
| 242 | - $userstatic=new User($db);  | 
                                                        |
| 242 | + $userstatic = new User($db);  | 
                                                        |
| 243 | 243 | $userstatic->fetch($object->user_creation_id ? $object->user_creation_id : $object->user_creation);  | 
                                                        
| 244 | 244 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 245 | 245 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -249,20 +249,20 @@ discard block  | 
                                                    ||
| 249 | 249 | }  | 
                                                        
| 250 | 250 | |
| 251 | 251 | // Date creation  | 
                                                        
| 252 | - if (! empty($object->date_creation))  | 
                                                        |
| 252 | + if (!empty($object->date_creation))  | 
                                                        |
| 253 | 253 |      {
 | 
                                                        
| 254 | 254 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 255 | 255 |          print $langs->trans("DateCreation");
 | 
                                                        
| 256 | 256 | if ($usetable) print '</td><td>';  | 
                                                        
| 257 | 257 | else print ': ';  | 
                                                        
| 258 | 258 | print dol_print_date($object->date_creation, 'dayhour');  | 
                                                        
| 259 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_creation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 259 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_creation + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 260 | 260 | if ($usetable) print '</td></tr>';  | 
                                                        
| 261 | 261 | else print '<br>';  | 
                                                        
| 262 | 262 | }  | 
                                                        
| 263 | 263 | |
| 264 | 264 | // User change (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 265 | - if (! empty($object->user_modification) || ! empty($object->user_modification_id))  | 
                                                        |
| 265 | + if (!empty($object->user_modification) || !empty($object->user_modification_id))  | 
                                                        |
| 266 | 266 |      {
 | 
                                                        
| 267 | 267 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 268 | 268 |          print $langs->trans("ModifiedBy");
 | 
                                                        
@@ -275,7 +275,7 @@ discard block  | 
                                                    ||
| 275 | 275 | }  | 
                                                        
| 276 | 276 | else  | 
                                                        
| 277 | 277 |          {
 | 
                                                        
| 278 | - $userstatic=new User($db);  | 
                                                        |
| 278 | + $userstatic = new User($db);  | 
                                                        |
| 279 | 279 | $userstatic->fetch($object->user_modification_id ? $object->user_modification_id : $object->user_modification);  | 
                                                        
| 280 | 280 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 281 | 281 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -285,20 +285,20 @@ discard block  | 
                                                    ||
| 285 | 285 | }  | 
                                                        
| 286 | 286 | |
| 287 | 287 | // Date change  | 
                                                        
| 288 | - if (! empty($object->date_modification))  | 
                                                        |
| 288 | + if (!empty($object->date_modification))  | 
                                                        |
| 289 | 289 |      {
 | 
                                                        
| 290 | 290 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 291 | 291 |          print $langs->trans("DateLastModification");
 | 
                                                        
| 292 | 292 | if ($usetable) print '</td><td>';  | 
                                                        
| 293 | 293 | else print ': ';  | 
                                                        
| 294 | 294 | print dol_print_date($object->date_modification, 'dayhour');  | 
                                                        
| 295 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_modification+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 295 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_modification + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 296 | 296 | if ($usetable) print '</td></tr>';  | 
                                                        
| 297 | 297 | else print '<br>';  | 
                                                        
| 298 | 298 | }  | 
                                                        
| 299 | 299 | |
| 300 | 300 | // User validation (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 301 | - if (! empty($object->user_validation) || ! empty($object->user_validation_id))  | 
                                                        |
| 301 | + if (!empty($object->user_validation) || !empty($object->user_validation_id))  | 
                                                        |
| 302 | 302 |      {
 | 
                                                        
| 303 | 303 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 304 | 304 |          print $langs->trans("ValidatedBy");
 | 
                                                        
@@ -311,7 +311,7 @@ discard block  | 
                                                    ||
| 311 | 311 | }  | 
                                                        
| 312 | 312 | else  | 
                                                        
| 313 | 313 |          {
 | 
                                                        
| 314 | - $userstatic=new User($db);  | 
                                                        |
| 314 | + $userstatic = new User($db);  | 
                                                        |
| 315 | 315 | $userstatic->fetch($object->user_validation_id ? $object->user_validation_id : $object->user_validation);  | 
                                                        
| 316 | 316 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 317 | 317 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -321,20 +321,20 @@ discard block  | 
                                                    ||
| 321 | 321 | }  | 
                                                        
| 322 | 322 | |
| 323 | 323 | // Date validation  | 
                                                        
| 324 | - if (! empty($object->date_validation))  | 
                                                        |
| 324 | + if (!empty($object->date_validation))  | 
                                                        |
| 325 | 325 |      {
 | 
                                                        
| 326 | 326 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 327 | 327 |          print $langs->trans("DateValidation");
 | 
                                                        
| 328 | 328 | if ($usetable) print '</td><td>';  | 
                                                        
| 329 | 329 | else print ': ';  | 
                                                        
| 330 | 330 | print dol_print_date($object->date_validation, 'dayhour');  | 
                                                        
| 331 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_validation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 331 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_validation + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 332 | 332 | if ($usetable) print '</td></tr>';  | 
                                                        
| 333 | 333 | else print '<br>';  | 
                                                        
| 334 | 334 | }  | 
                                                        
| 335 | 335 | |
| 336 | 336 | // User approve (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 337 | - if (! empty($object->user_approve) || ! empty($object->user_approve_id))  | 
                                                        |
| 337 | + if (!empty($object->user_approve) || !empty($object->user_approve_id))  | 
                                                        |
| 338 | 338 |      {
 | 
                                                        
| 339 | 339 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 340 | 340 |          print $langs->trans("ApprovedBy");
 | 
                                                        
@@ -347,7 +347,7 @@ discard block  | 
                                                    ||
| 347 | 347 | }  | 
                                                        
| 348 | 348 | else  | 
                                                        
| 349 | 349 |          {
 | 
                                                        
| 350 | - $userstatic=new User($db);  | 
                                                        |
| 350 | + $userstatic = new User($db);  | 
                                                        |
| 351 | 351 | $userstatic->fetch($object->user_approve_id ? $object->user_approve_id : $object->user_approve);  | 
                                                        
| 352 | 352 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 353 | 353 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -357,26 +357,26 @@ discard block  | 
                                                    ||
| 357 | 357 | }  | 
                                                        
| 358 | 358 | |
| 359 | 359 | // Date approve  | 
                                                        
| 360 | - if (! empty($object->date_approve))  | 
                                                        |
| 360 | + if (!empty($object->date_approve))  | 
                                                        |
| 361 | 361 |      {
 | 
                                                        
| 362 | 362 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 363 | 363 |          print $langs->trans("DateApprove");
 | 
                                                        
| 364 | 364 | if ($usetable) print '</td><td>';  | 
                                                        
| 365 | 365 | else print ': ';  | 
                                                        
| 366 | 366 | print dol_print_date($object->date_approve, 'dayhour');  | 
                                                        
| 367 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 367 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 368 | 368 | if ($usetable) print '</td></tr>';  | 
                                                        
| 369 | 369 | else print '<br>';  | 
                                                        
| 370 | 370 | }  | 
                                                        
| 371 | 371 | |
| 372 | 372 | // User approve  | 
                                                        
| 373 | - if (! empty($object->user_approve_id2))  | 
                                                        |
| 373 | + if (!empty($object->user_approve_id2))  | 
                                                        |
| 374 | 374 |      {
 | 
                                                        
| 375 | 375 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 376 | 376 |          print $langs->trans("ApprovedBy");
 | 
                                                        
| 377 | 377 | if ($usetable) print '</td><td>';  | 
                                                        
| 378 | 378 | else print ': ';  | 
                                                        
| 379 | - $userstatic=new User($db);  | 
                                                        |
| 379 | + $userstatic = new User($db);  | 
                                                        |
| 380 | 380 | $userstatic->fetch($object->user_approve_id2);  | 
                                                        
| 381 | 381 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 382 | 382 |          else print $langs->trans("Unknown");
 | 
                                                        
@@ -385,20 +385,20 @@ discard block  | 
                                                    ||
| 385 | 385 | }  | 
                                                        
| 386 | 386 | |
| 387 | 387 | // Date approve  | 
                                                        
| 388 | - if (! empty($object->date_approve2))  | 
                                                        |
| 388 | + if (!empty($object->date_approve2))  | 
                                                        |
| 389 | 389 |      {
 | 
                                                        
| 390 | 390 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 391 | 391 |          print $langs->trans("DateApprove2");
 | 
                                                        
| 392 | 392 | if ($usetable) print '</td><td>';  | 
                                                        
| 393 | 393 | else print ': ';  | 
                                                        
| 394 | 394 | print dol_print_date($object->date_approve2, 'dayhour');  | 
                                                        
| 395 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve2+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 395 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve2 + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 396 | 396 | if ($usetable) print '</td></tr>';  | 
                                                        
| 397 | 397 | else print '<br>';  | 
                                                        
| 398 | 398 | }  | 
                                                        
| 399 | 399 | |
| 400 | 400 | // User close  | 
                                                        
| 401 | - if (! empty($object->user_cloture))  | 
                                                        |
| 401 | + if (!empty($object->user_cloture))  | 
                                                        |
| 402 | 402 |      {
 | 
                                                        
| 403 | 403 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 404 | 404 |          print $langs->trans("ClosedBy");
 | 
                                                        
@@ -411,7 +411,7 @@ discard block  | 
                                                    ||
| 411 | 411 | }  | 
                                                        
| 412 | 412 | else  | 
                                                        
| 413 | 413 |          {
 | 
                                                        
| 414 | - $userstatic=new User($db);  | 
                                                        |
| 414 | + $userstatic = new User($db);  | 
                                                        |
| 415 | 415 | $userstatic->fetch($object->user_cloture);  | 
                                                        
| 416 | 416 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 417 | 417 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -421,20 +421,20 @@ discard block  | 
                                                    ||
| 421 | 421 | }  | 
                                                        
| 422 | 422 | |
| 423 | 423 | // Date close  | 
                                                        
| 424 | - if (! empty($object->date_cloture))  | 
                                                        |
| 424 | + if (!empty($object->date_cloture))  | 
                                                        |
| 425 | 425 |      {
 | 
                                                        
| 426 | 426 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 427 | 427 |          print $langs->trans("DateClosing");
 | 
                                                        
| 428 | 428 | if ($usetable) print '</td><td>';  | 
                                                        
| 429 | 429 | else print ': ';  | 
                                                        
| 430 | 430 | print dol_print_date($object->date_cloture, 'dayhour');  | 
                                                        
| 431 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_cloture+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 431 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_cloture + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 432 | 432 | if ($usetable) print '</td></tr>';  | 
                                                        
| 433 | 433 | else print '<br>';  | 
                                                        
| 434 | 434 | }  | 
                                                        
| 435 | 435 | |
| 436 | 436 | // User conciliate  | 
                                                        
| 437 | - if (! empty($object->user_rappro))  | 
                                                        |
| 437 | + if (!empty($object->user_rappro))  | 
                                                        |
| 438 | 438 |      {
 | 
                                                        
| 439 | 439 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 440 | 440 |          print $langs->trans("ConciliatedBy");
 | 
                                                        
@@ -447,7 +447,7 @@ discard block  | 
                                                    ||
| 447 | 447 | }  | 
                                                        
| 448 | 448 | else  | 
                                                        
| 449 | 449 |          {
 | 
                                                        
| 450 | - $userstatic=new User($db);  | 
                                                        |
| 450 | + $userstatic = new User($db);  | 
                                                        |
| 451 | 451 | $userstatic->fetch($object->user_rappro);  | 
                                                        
| 452 | 452 | if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        
| 453 | 453 |          	else print $langs->trans("Unknown");
 | 
                                                        
@@ -457,27 +457,27 @@ discard block  | 
                                                    ||
| 457 | 457 | }  | 
                                                        
| 458 | 458 | |
| 459 | 459 | // Date conciliate  | 
                                                        
| 460 | - if (! empty($object->date_rappro))  | 
                                                        |
| 460 | + if (!empty($object->date_rappro))  | 
                                                        |
| 461 | 461 |      {
 | 
                                                        
| 462 | 462 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 463 | 463 |          print $langs->trans("DateConciliating");
 | 
                                                        
| 464 | 464 | if ($usetable) print '</td><td>';  | 
                                                        
| 465 | 465 | else print ': ';  | 
                                                        
| 466 | 466 | print dol_print_date($object->date_rappro, 'dayhour');  | 
                                                        
| 467 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_rappro+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 467 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_rappro + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 468 | 468 | if ($usetable) print '</td></tr>';  | 
                                                        
| 469 | 469 | else print '<br>';  | 
                                                        
| 470 | 470 | }  | 
                                                        
| 471 | 471 | |
| 472 | 472 | // Date send  | 
                                                        
| 473 | - if (! empty($object->date_envoi))  | 
                                                        |
| 473 | + if (!empty($object->date_envoi))  | 
                                                        |
| 474 | 474 |      {
 | 
                                                        
| 475 | 475 | if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        
| 476 | 476 |          print $langs->trans("DateLastSend");
 | 
                                                        
| 477 | 477 | if ($usetable) print '</td><td>';  | 
                                                        
| 478 | 478 | else print ': ';  | 
                                                        
| 479 | 479 | print dol_print_date($object->date_envoi, 'dayhour');  | 
                                                        
| 480 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_envoi+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 480 | +        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_envoi + ($deltadateforuser * 3600), "dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 481 | 481 | if ($usetable) print '</td></tr>';  | 
                                                        
| 482 | 482 | else print '<br>';  | 
                                                        
| 483 | 483 | }  | 
                                                        
@@ -496,8 +496,8 @@ discard block  | 
                                                    ||
| 496 | 496 | */  | 
                                                        
| 497 | 497 | function dolAddEmailTrackId($email, $trackingid)  | 
                                                        
| 498 | 498 |  {
 | 
                                                        
| 499 | -	$tmp=explode('@',$email);
 | 
                                                        |
| 500 | - return $tmp[0].'+'.$trackingid.'@'.(isset($tmp[1])?$tmp[1]:'');  | 
                                                        |
| 499 | +	$tmp = explode('@', $email);
 | 
                                                        |
| 500 | + return $tmp[0].'+'.$trackingid.'@'.(isset($tmp[1]) ? $tmp[1] : '');  | 
                                                        |
| 501 | 501 | }  | 
                                                        
| 502 | 502 | |
| 503 | 503 | /**  | 
                                                        
@@ -532,7 +532,7 @@ discard block  | 
                                                    ||
| 532 | 532 | * @param int $anchor 1: verify anchor is provided, 0: not verify anchor  | 
                                                        
| 533 | 533 | * @return int 1=Check is OK, 0=Check is KO  | 
                                                        
| 534 | 534 | */  | 
                                                        
| 535 | -function isValidUrl($url,$http=0,$pass=0,$port=0,$path=0,$query=0,$anchor=0)  | 
                                                        |
| 535 | +function isValidUrl($url, $http = 0, $pass = 0, $port = 0, $path = 0, $query = 0, $anchor = 0)  | 
                                                        |
| 536 | 536 |  {
 | 
                                                        
| 537 | 537 | $ValidUrl = 0;  | 
                                                        
| 538 | 538 | $urlregex = '';  | 
                                                        
@@ -546,7 +546,7 @@ discard block  | 
                                                    ||
| 546 | 546 | // HOSTNAME OR IP  | 
                                                        
| 547 | 547 | //$urlregex .= "[a-z0-9+\$_-]+(\.[a-z0-9+\$_-]+)*"; // x allowed (ex. http://localhost, http://routerlogin)  | 
                                                        
| 548 | 548 | //$urlregex .= "[a-z0-9+\$_-]+(\.[a-z0-9+\$_-]+)+"; // x.x  | 
                                                        
| 549 | - $urlregex .= "([a-z0-9+\$_\\\:-])+(\.[a-z0-9+\$_-][a-z0-9+\$_-]+)*"; // x ou x.xx (2 x ou plus)  | 
                                                        |
| 549 | + $urlregex .= "([a-z0-9+\$_\\\:-])+(\.[a-z0-9+\$_-][a-z0-9+\$_-]+)*"; // x ou x.xx (2 x ou plus)  | 
                                                        |
| 550 | 550 | //use only one of the above  | 
                                                        
| 551 | 551 | |
| 552 | 552 | // PORT  | 
                                                        
@@ -575,33 +575,33 @@ discard block  | 
                                                    ||
| 575 | 575 | * @param integer $http 1 = keep both http:// and https://, 0: remove http:// but not https://  | 
                                                        
| 576 | 576 | * @return string Cleaned url  | 
                                                        
| 577 | 577 | */  | 
                                                        
| 578 | -function clean_url($url,$http=1)  | 
                                                        |
| 578 | +function clean_url($url, $http = 1)  | 
                                                        |
| 579 | 579 |  {
 | 
                                                        
| 580 | 580 | // Fixed by Matelli (see http://matelli.fr/showcases/patchs-dolibarr/fix-cleaning-url.html)  | 
                                                        
| 581 | 581 | // To include the minus sign in a char class, we must not escape it but put it at the end of the class  | 
                                                        
| 582 | 582 | // Also, there's no need of escape a dot sign in a class  | 
                                                        
| 583 | -    if (preg_match('/^(https?:[\\/]+)?([0-9A-Z.-]+\.[A-Z]{2,4})(:[0-9]+)?/i',$url,$regs))
 | 
                                                        |
| 583 | +    if (preg_match('/^(https?:[\\/]+)?([0-9A-Z.-]+\.[A-Z]{2,4})(:[0-9]+)?/i', $url, $regs))
 | 
                                                        |
| 584 | 584 |      {
 | 
                                                        
| 585 | - $proto=$regs[1];  | 
                                                        |
| 586 | - $domain=$regs[2];  | 
                                                        |
| 587 | - $port=isset($regs[3])?$regs[3]:'';  | 
                                                        |
| 585 | + $proto = $regs[1];  | 
                                                        |
| 586 | + $domain = $regs[2];  | 
                                                        |
| 587 | + $port = isset($regs[3]) ? $regs[3] : '';  | 
                                                        |
| 588 | 588 | //print $url." -> ".$proto." - ".$domain." - ".$port;  | 
                                                        
| 589 | 589 | //$url = dol_string_nospecial(trim($url));  | 
                                                        
| 590 | 590 | $url = trim($url);  | 
                                                        
| 591 | 591 | |
| 592 | 592 | // Si http: defini on supprime le http (Si https on ne supprime pas)  | 
                                                        
| 593 | - $newproto=$proto;  | 
                                                        |
| 594 | - if ($http==0)  | 
                                                        |
| 593 | + $newproto = $proto;  | 
                                                        |
| 594 | + if ($http == 0)  | 
                                                        |
| 595 | 595 |          {
 | 
                                                        
| 596 | -            if (preg_match('/^http:[\\/]+/i',$url))
 | 
                                                        |
| 596 | +            if (preg_match('/^http:[\\/]+/i', $url))
 | 
                                                        |
| 597 | 597 |              {
 | 
                                                        
| 598 | -                $url = preg_replace('/^http:[\\/]+/i','',$url);
 | 
                                                        |
| 598 | +                $url = preg_replace('/^http:[\\/]+/i', '', $url);
 | 
                                                        |
| 599 | 599 | $newproto = '';  | 
                                                        
| 600 | 600 | }  | 
                                                        
| 601 | 601 | }  | 
                                                        
| 602 | 602 | |
| 603 | 603 | // On passe le nom de domaine en minuscule  | 
                                                        
| 604 | -        $CleanUrl = preg_replace('/^'.preg_quote($proto.$domain,'/').'/i', $newproto.strtolower($domain), $url);
 | 
                                                        |
| 604 | +        $CleanUrl = preg_replace('/^'.preg_quote($proto.$domain, '/').'/i', $newproto.strtolower($domain), $url);
 | 
                                                        |
| 605 | 605 | |
| 606 | 606 | return $CleanUrl;  | 
                                                        
| 607 | 607 | }  | 
                                                        
@@ -621,35 +621,35 @@ discard block  | 
                                                    ||
| 621 | 621 | * @param bool $displaytld Display tld (default: true)  | 
                                                        
| 622 | 622 | * @return string Return email with hidden parts or '';  | 
                                                        
| 623 | 623 | */  | 
                                                        
| 624 | -function dolObfuscateEmail($mail, $replace="*", $nbreplace=8, $nbdisplaymail=4, $nbdisplaydomain=3, $displaytld=true)  | 
                                                        |
| 624 | +function dolObfuscateEmail($mail, $replace = "*", $nbreplace = 8, $nbdisplaymail = 4, $nbdisplaydomain = 3, $displaytld = true)  | 
                                                        |
| 625 | 625 |  {
 | 
                                                        
| 626 | - if(!isValidEmail($mail))return '';  | 
                                                        |
| 626 | + if (!isValidEmail($mail))return '';  | 
                                                        |
| 627 | 627 |  	$tab = explode('@', $mail);
 | 
                                                        
| 628 | -	$tab2 = explode('.',$tab[1]);
 | 
                                                        |
| 628 | +	$tab2 = explode('.', $tab[1]);
 | 
                                                        |
| 629 | 629 | $string_replace = '';  | 
                                                        
| 630 | 630 | $mail_name = $tab[0];  | 
                                                        
| 631 | 631 | $mail_domaine = $tab2[0];  | 
                                                        
| 632 | 632 | $mail_tld = '';  | 
                                                        
| 633 | 633 | |
| 634 | 634 | $nbofelem = count($tab2);  | 
                                                        
| 635 | - for($i=1; $i < $nbofelem && $displaytld; $i++)  | 
                                                        |
| 635 | + for ($i = 1; $i < $nbofelem && $displaytld; $i++)  | 
                                                        |
| 636 | 636 |  	{
 | 
                                                        
| 637 | 637 | $mail_tld .= '.'.$tab2[$i];  | 
                                                        
| 638 | 638 | }  | 
                                                        
| 639 | 639 | |
| 640 | -	for($i=0; $i < $nbreplace; $i++){
 | 
                                                        |
| 640 | +	for ($i = 0; $i < $nbreplace; $i++) {
 | 
                                                        |
| 641 | 641 | $string_replace .= $replace;  | 
                                                        
| 642 | 642 | }  | 
                                                        
| 643 | 643 | |
| 644 | -	if(strlen($mail_name) > $nbdisplaymail){
 | 
                                                        |
| 644 | +	if (strlen($mail_name) > $nbdisplaymail) {
 | 
                                                        |
| 645 | 645 | $mail_name = substr($mail_name, 0, $nbdisplaymail);  | 
                                                        
| 646 | 646 | }  | 
                                                        
| 647 | 647 | |
| 648 | -	if(strlen($mail_domaine) > $nbdisplaydomain){
 | 
                                                        |
| 649 | - $mail_domaine = substr($mail_domaine, strlen($mail_domaine)-$nbdisplaydomain);  | 
                                                        |
| 648 | +	if (strlen($mail_domaine) > $nbdisplaydomain) {
 | 
                                                        |
| 649 | + $mail_domaine = substr($mail_domaine, strlen($mail_domaine) - $nbdisplaydomain);  | 
                                                        |
| 650 | 650 | }  | 
                                                        
| 651 | 651 | |
| 652 | - return $mail_name . $string_replace . $mail_domaine . $mail_tld;  | 
                                                        |
| 652 | + return $mail_name.$string_replace.$mail_domaine.$mail_tld;  | 
                                                        |
| 653 | 653 | }  | 
                                                        
| 654 | 654 | |
| 655 | 655 | |
@@ -662,14 +662,14 @@ discard block  | 
                                                    ||
| 662 | 662 | * @param string $tdoptions Options for td  | 
                                                        
| 663 | 663 | * @return string  | 
                                                        
| 664 | 664 | */  | 
                                                        
| 665 | -function array2tr($data,$troptions='',$tdoptions='')  | 
                                                        |
| 665 | +function array2tr($data, $troptions = '', $tdoptions = '')  | 
                                                        |
| 666 | 666 |  {
 | 
                                                        
| 667 | - $text = '<tr '.$troptions.'>' ;  | 
                                                        |
| 668 | -    foreach($data as $key => $item){
 | 
                                                        |
| 669 | - $text.= '<td '.$tdoptions.'>'.$item.'</td>' ;  | 
                                                        |
| 667 | + $text = '<tr '.$troptions.'>';  | 
                                                        |
| 668 | +    foreach ($data as $key => $item) {
 | 
                                                        |
| 669 | + $text .= '<td '.$tdoptions.'>'.$item.'</td>';  | 
                                                        |
| 670 | 670 | }  | 
                                                        
| 671 | - $text.= '</tr>' ;  | 
                                                        |
| 672 | - return $text ;  | 
                                                        |
| 671 | + $text .= '</tr>';  | 
                                                        |
| 672 | + return $text;  | 
                                                        |
| 673 | 673 | }  | 
                                                        
| 674 | 674 | |
| 675 | 675 | /**  | 
                                                        
@@ -682,22 +682,22 @@ discard block  | 
                                                    ||
| 682 | 682 | * @param string $tdoptions Options for td  | 
                                                        
| 683 | 683 | * @return string  | 
                                                        
| 684 | 684 | */  | 
                                                        
| 685 | -function array2table($data,$tableMarkup=1,$tableoptions='',$troptions='',$tdoptions='')  | 
                                                        |
| 685 | +function array2table($data, $tableMarkup = 1, $tableoptions = '', $troptions = '', $tdoptions = '')  | 
                                                        |
| 686 | 686 |  {
 | 
                                                        
| 687 | - $text='' ;  | 
                                                        |
| 688 | - if($tableMarkup) $text = '<table '.$tableoptions.'>' ;  | 
                                                        |
| 689 | -    foreach($data as $key => $item){
 | 
                                                        |
| 690 | -        if(is_array($item)){
 | 
                                                        |
| 691 | - $text.=array2tr($item,$troptions,$tdoptions);  | 
                                                        |
| 687 | + $text = '';  | 
                                                        |
| 688 | + if ($tableMarkup) $text = '<table '.$tableoptions.'>';  | 
                                                        |
| 689 | +    foreach ($data as $key => $item) {
 | 
                                                        |
| 690 | +        if (is_array($item)) {
 | 
                                                        |
| 691 | + $text .= array2tr($item, $troptions, $tdoptions);  | 
                                                        |
| 692 | 692 |          } else {
 | 
                                                        
| 693 | - $text.= '<tr '.$troptions.'>' ;  | 
                                                        |
| 694 | - $text.= '<td '.$tdoptions.'>'.$key.'</td>' ;  | 
                                                        |
| 695 | - $text.= '<td '.$tdoptions.'>'.$item.'</td>' ;  | 
                                                        |
| 696 | - $text.= '</tr>' ;  | 
                                                        |
| 693 | + $text .= '<tr '.$troptions.'>';  | 
                                                        |
| 694 | + $text .= '<td '.$tdoptions.'>'.$key.'</td>';  | 
                                                        |
| 695 | + $text .= '<td '.$tdoptions.'>'.$item.'</td>';  | 
                                                        |
| 696 | + $text .= '</tr>';  | 
                                                        |
| 697 | 697 | }  | 
                                                        
| 698 | 698 | }  | 
                                                        
| 699 | - if($tableMarkup) $text.= '</table>' ;  | 
                                                        |
| 700 | - return $text ;  | 
                                                        |
| 699 | + if ($tableMarkup) $text .= '</table>';  | 
                                                        |
| 700 | + return $text;  | 
                                                        |
| 701 | 701 | }  | 
                                                        
| 702 | 702 | |
| 703 | 703 | /**  | 
                                                        
@@ -716,19 +716,19 @@ discard block  | 
                                                    ||
| 716 | 716 | * @param int $forceentity Entity id to force  | 
                                                        
| 717 | 717 | * @return string New value (numeric) or error message  | 
                                                        
| 718 | 718 | */  | 
                                                        
| 719 | -function get_next_value($db,$mask,$table,$field,$where='',$objsoc='',$date='',$mode='next', $bentityon=true, $objuser=null, $forceentity=null)  | 
                                                        |
| 719 | +function get_next_value($db, $mask, $table, $field, $where = '', $objsoc = '', $date = '', $mode = 'next', $bentityon = true, $objuser = null, $forceentity = null)  | 
                                                        |
| 720 | 720 |  {
 | 
                                                        
| 721 | - global $conf,$user;  | 
                                                        |
| 721 | + global $conf, $user;  | 
                                                        |
| 722 | 722 | |
| 723 | - if (! is_object($objsoc)) $valueforccc=$objsoc;  | 
                                                        |
| 724 | - else if ($table == "commande_fournisseur" || $table == "facture_fourn" ) $valueforccc=$objsoc->code_fournisseur;  | 
                                                        |
| 725 | - else $valueforccc=$objsoc->code_client;  | 
                                                        |
| 723 | + if (!is_object($objsoc)) $valueforccc = $objsoc;  | 
                                                        |
| 724 | + else if ($table == "commande_fournisseur" || $table == "facture_fourn") $valueforccc = $objsoc->code_fournisseur;  | 
                                                        |
| 725 | + else $valueforccc = $objsoc->code_client;  | 
                                                        |
| 726 | 726 | |
| 727 | 727 | $sharetable = $table;  | 
                                                        
| 728 | 728 | if ($table == 'facture' || $table == 'invoice') $sharetable = 'invoicenumber'; // for getEntity function  | 
                                                        
| 729 | 729 | |
| 730 | 730 | // Clean parameters  | 
                                                        
| 731 | - if ($date == '') $date=dol_now(); // We use local year and month of PHP server to search numbers  | 
                                                        |
| 731 | + if ($date == '') $date = dol_now(); // We use local year and month of PHP server to search numbers  | 
                                                        |
| 732 | 732 | // but we should use local year and month of user  | 
                                                        
| 733 | 733 | |
| 734 | 734 | // For debugging  | 
                                                        
@@ -738,132 +738,132 @@ discard block  | 
                                                    ||
| 738 | 738 | //$date=dol_mktime(12, 0, 0, 1, 1, 1900);  | 
                                                        
| 739 | 739 |      //$date=dol_stringtotime('20130101');
 | 
                                                        
| 740 | 740 | |
| 741 | - $hasglobalcounter=false;  | 
                                                        |
| 741 | + $hasglobalcounter = false;  | 
                                                        |
| 742 | 742 | // Extract value for mask counter, mask raz and mask offset  | 
                                                        
| 743 | -    if (preg_match('/\{(0+)([@\+][0-9\-\+\=]+)?([@\+][0-9\-\+\=]+)?\}/i',$mask,$reg))
 | 
                                                        |
| 743 | +    if (preg_match('/\{(0+)([@\+][0-9\-\+\=]+)?([@\+][0-9\-\+\=]+)?\}/i', $mask, $reg))
 | 
                                                        |
| 744 | 744 |      {
 | 
                                                        
| 745 | - $masktri=$reg[1].(! empty($reg[2])?$reg[2]:'').(! empty($reg[3])?$reg[3]:'');  | 
                                                        |
| 746 | - $maskcounter=$reg[1];  | 
                                                        |
| 747 | - $hasglobalcounter=true;  | 
                                                        |
| 745 | + $masktri = $reg[1].(!empty($reg[2]) ? $reg[2] : '').(!empty($reg[3]) ? $reg[3] : '');  | 
                                                        |
| 746 | + $maskcounter = $reg[1];  | 
                                                        |
| 747 | + $hasglobalcounter = true;  | 
                                                        |
| 748 | 748 | }  | 
                                                        
| 749 | 749 | else  | 
                                                        
| 750 | 750 |      {
 | 
                                                        
| 751 | 751 | // setting some defaults so the rest of the code won't fail if there is a third party counter  | 
                                                        
| 752 | - $masktri='00000';  | 
                                                        |
| 753 | - $maskcounter='00000';  | 
                                                        |
| 752 | + $masktri = '00000';  | 
                                                        |
| 753 | + $maskcounter = '00000';  | 
                                                        |
| 754 | 754 | }  | 
                                                        
| 755 | 755 | |
| 756 | - $maskraz=-1;  | 
                                                        |
| 757 | - $maskoffset=0;  | 
                                                        |
| 758 | - $resetEveryMonth=false;  | 
                                                        |
| 756 | + $maskraz = -1;  | 
                                                        |
| 757 | + $maskoffset = 0;  | 
                                                        |
| 758 | + $resetEveryMonth = false;  | 
                                                        |
| 759 | 759 | if (dol_strlen($maskcounter) < 3 && empty($conf->global->MAIN_COUNTER_WITH_LESS_3_DIGITS)) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        
| 760 | 760 | |
| 761 | 761 | // Extract value for third party mask counter  | 
                                                        
| 762 | -    if (preg_match('/\{(c+)(0*)\}/i',$mask,$regClientRef))
 | 
                                                        |
| 763 | -    {
 | 
                                                        |
| 764 | - $maskrefclient=$regClientRef[1].$regClientRef[2];  | 
                                                        |
| 765 | - $maskrefclient_maskclientcode=$regClientRef[1];  | 
                                                        |
| 766 | - $maskrefclient_maskcounter=$regClientRef[2];  | 
                                                        |
| 767 | - $maskrefclient_maskoffset=0; //default value of maskrefclient_counter offset  | 
                                                        |
| 768 | - $maskrefclient_clientcode=substr($valueforccc,0,dol_strlen($maskrefclient_maskclientcode));//get n first characters of client code where n is length in mask  | 
                                                        |
| 769 | - $maskrefclient_clientcode=str_pad($maskrefclient_clientcode,dol_strlen($maskrefclient_maskclientcode),"#",STR_PAD_RIGHT);//padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        |
| 770 | - $maskrefclient_clientcode=dol_string_nospecial($maskrefclient_clientcode);//sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        |
| 762 | +    if (preg_match('/\{(c+)(0*)\}/i', $mask, $regClientRef))
 | 
                                                        |
| 763 | +    {
 | 
                                                        |
| 764 | + $maskrefclient = $regClientRef[1].$regClientRef[2];  | 
                                                        |
| 765 | + $maskrefclient_maskclientcode = $regClientRef[1];  | 
                                                        |
| 766 | + $maskrefclient_maskcounter = $regClientRef[2];  | 
                                                        |
| 767 | + $maskrefclient_maskoffset = 0; //default value of maskrefclient_counter offset  | 
                                                        |
| 768 | + $maskrefclient_clientcode = substr($valueforccc, 0, dol_strlen($maskrefclient_maskclientcode)); //get n first characters of client code where n is length in mask  | 
                                                        |
| 769 | + $maskrefclient_clientcode = str_pad($maskrefclient_clientcode, dol_strlen($maskrefclient_maskclientcode), "#", STR_PAD_RIGHT); //padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        |
| 770 | + $maskrefclient_clientcode = dol_string_nospecial($maskrefclient_clientcode); //sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        |
| 771 | 771 | if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        
| 772 | 772 | }  | 
                                                        
| 773 | - else $maskrefclient='';  | 
                                                        |
| 773 | + else $maskrefclient = '';  | 
                                                        |
| 774 | 774 | |
| 775 | 775 | // fail if there is neither a global nor a third party counter  | 
                                                        
| 776 | - if (! $hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        |
| 776 | + if (!$hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        |
| 777 | 777 |      {
 | 
                                                        
| 778 | 778 | return 'ErrorBadMask';  | 
                                                        
| 779 | 779 | }  | 
                                                        
| 780 | 780 | |
| 781 | 781 | // Extract value for third party type  | 
                                                        
| 782 | -    if (preg_match('/\{(t+)\}/i',$mask,$regType))
 | 
                                                        |
| 782 | +    if (preg_match('/\{(t+)\}/i', $mask, $regType))
 | 
                                                        |
| 783 | 783 |      {
 | 
                                                        
| 784 | - $masktype=$regType[1];  | 
                                                        |
| 785 | -        $masktype_value=substr(preg_replace('/^TE_/','',$objsoc->typent_code),0,dol_strlen($regType[1]));// get n first characters of thirdpaty typent_code (where n is length in mask)
 | 
                                                        |
| 786 | - $masktype_value=str_pad($masktype_value,dol_strlen($regType[1]),"#",STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        |
| 784 | + $masktype = $regType[1];  | 
                                                        |
| 785 | +        $masktype_value = substr(preg_replace('/^TE_/', '', $objsoc->typent_code), 0, dol_strlen($regType[1])); // get n first characters of thirdpaty typent_code (where n is length in mask)
 | 
                                                        |
| 786 | + $masktype_value = str_pad($masktype_value, dol_strlen($regType[1]), "#", STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        |
| 787 | 787 | }  | 
                                                        
| 788 | 788 | else  | 
                                                        
| 789 | 789 |      {
 | 
                                                        
| 790 | - $masktype='';  | 
                                                        |
| 791 | - $masktype_value='';  | 
                                                        |
| 790 | + $masktype = '';  | 
                                                        |
| 791 | + $masktype_value = '';  | 
                                                        |
| 792 | 792 | }  | 
                                                        
| 793 | 793 | |
| 794 | 794 | // Extract value for user  | 
                                                        
| 795 | -    if (preg_match('/\{(u+)\}/i',$mask,$regType))
 | 
                                                        |
| 795 | +    if (preg_match('/\{(u+)\}/i', $mask, $regType))
 | 
                                                        |
| 796 | 796 |      {
 | 
                                                        
| 797 | 797 | $lastname = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';  | 
                                                        
| 798 | 798 | if (is_object($objuser)) $lastname = $objuser->lastname;  | 
                                                        
| 799 | 799 | |
| 800 | - $maskuser=$regType[1];  | 
                                                        |
| 801 | - $maskuser_value=substr($lastname,0,dol_strlen($regType[1]));// get n first characters of user firstname (where n is length in mask)  | 
                                                        |
| 802 | - $maskuser_value=str_pad($maskuser_value,dol_strlen($regType[1]),"#",STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        |
| 800 | + $maskuser = $regType[1];  | 
                                                        |
| 801 | + $maskuser_value = substr($lastname, 0, dol_strlen($regType[1])); // get n first characters of user firstname (where n is length in mask)  | 
                                                        |
| 802 | + $maskuser_value = str_pad($maskuser_value, dol_strlen($regType[1]), "#", STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        |
| 803 | 803 | }  | 
                                                        
| 804 | 804 | else  | 
                                                        
| 805 | 805 |      {
 | 
                                                        
| 806 | - $maskuser='';  | 
                                                        |
| 807 | - $maskuser_value='';  | 
                                                        |
| 806 | + $maskuser = '';  | 
                                                        |
| 807 | + $maskuser_value = '';  | 
                                                        |
| 808 | 808 | }  | 
                                                        
| 809 | 809 | |
| 810 | 810 |      // Personalized field {XXX-1} à {XXX-9}
 | 
                                                        
| 811 | - $maskperso=array();  | 
                                                        |
| 812 | - $maskpersonew=array();  | 
                                                        |
| 813 | - $tmpmask=$mask;  | 
                                                        |
| 814 | -    while (preg_match('/\{([A-Z]+)\-([1-9])\}/',$tmpmask,$regKey))
 | 
                                                        |
| 811 | + $maskperso = array();  | 
                                                        |
| 812 | + $maskpersonew = array();  | 
                                                        |
| 813 | + $tmpmask = $mask;  | 
                                                        |
| 814 | +    while (preg_match('/\{([A-Z]+)\-([1-9])\}/', $tmpmask, $regKey))
 | 
                                                        |
| 815 | 815 |      {
 | 
                                                        
| 816 | -        $maskperso[$regKey[1]]='{'.$regKey[1].'-'.$regKey[2].'}';
 | 
                                                        |
| 817 | -        $maskpersonew[$regKey[1]]=str_pad('', $regKey[2], '_', STR_PAD_RIGHT);
 | 
                                                        |
| 818 | -        $tmpmask=preg_replace('/\{'.$regKey[1].'\-'.$regKey[2].'\}/i', $maskpersonew[$regKey[1]], $tmpmask);
 | 
                                                        |
| 816 | +        $maskperso[$regKey[1]] = '{'.$regKey[1].'-'.$regKey[2].'}';
 | 
                                                        |
| 817 | +        $maskpersonew[$regKey[1]] = str_pad('', $regKey[2], '_', STR_PAD_RIGHT);
 | 
                                                        |
| 818 | +        $tmpmask = preg_replace('/\{'.$regKey[1].'\-'.$regKey[2].'\}/i', $maskpersonew[$regKey[1]], $tmpmask);
 | 
                                                        |
| 819 | 819 | }  | 
                                                        
| 820 | 820 | |
| 821 | - if (strstr($mask,'user_extra_'))  | 
                                                        |
| 821 | + if (strstr($mask, 'user_extra_'))  | 
                                                        |
| 822 | 822 |      {
 | 
                                                        
| 823 | 823 |  			$start = "{user_extra_";
 | 
                                                        
| 824 | 824 | $end = "\}";  | 
                                                        
| 825 | - $extra= get_string_between($mask, "user_extra_", "}");  | 
                                                        |
| 826 | -			if(!empty($user->array_options['options_'.$extra])){
 | 
                                                        |
| 827 | -				$mask =  preg_replace('#('.$start.')(.*?)('.$end.')#si', $user->array_options['options_'.$extra], $mask);
 | 
                                                        |
| 825 | + $extra = get_string_between($mask, "user_extra_", "}");  | 
                                                        |
| 826 | +			if (!empty($user->array_options['options_'.$extra])) {
 | 
                                                        |
| 827 | +				$mask = preg_replace('#('.$start.')(.*?)('.$end.')#si', $user->array_options['options_'.$extra], $mask);
 | 
                                                        |
| 828 | 828 | }  | 
                                                        
| 829 | 829 | }  | 
                                                        
| 830 | - $maskwithonlyymcode=$mask;  | 
                                                        |
| 831 | -    $maskwithonlyymcode=preg_replace('/\{(0+)([@\+][0-9\-\+\=]+)?([@\+][0-9\-\+\=]+)?\}/i',$maskcounter,$maskwithonlyymcode);
 | 
                                                        |
| 832 | -    $maskwithonlyymcode=preg_replace('/\{dd\}/i','dd',$maskwithonlyymcode);
 | 
                                                        |
| 833 | -    $maskwithonlyymcode=preg_replace('/\{(c+)(0*)\}/i',$maskrefclient,$maskwithonlyymcode);
 | 
                                                        |
| 834 | -    $maskwithonlyymcode=preg_replace('/\{(t+)\}/i',$masktype_value,$maskwithonlyymcode);
 | 
                                                        |
| 835 | -    $maskwithonlyymcode=preg_replace('/\{(u+)\}/i',$maskuser_value,$maskwithonlyymcode);
 | 
                                                        |
| 836 | - foreach($maskperso as $key => $val)  | 
                                                        |
| 837 | -    {
 | 
                                                        |
| 838 | -        $maskwithonlyymcode=preg_replace('/'.preg_quote($val,'/').'/i', $maskpersonew[$key], $maskwithonlyymcode);
 | 
                                                        |
| 839 | - }  | 
                                                        |
| 840 | - $maskwithnocode=$maskwithonlyymcode;  | 
                                                        |
| 841 | -    $maskwithnocode=preg_replace('/\{yyyy\}/i','yyyy',$maskwithnocode);
 | 
                                                        |
| 842 | -    $maskwithnocode=preg_replace('/\{yy\}/i','yy',$maskwithnocode);
 | 
                                                        |
| 843 | -    $maskwithnocode=preg_replace('/\{y\}/i','y',$maskwithnocode);
 | 
                                                        |
| 844 | -    $maskwithnocode=preg_replace('/\{mm\}/i','mm',$maskwithnocode);
 | 
                                                        |
| 830 | + $maskwithonlyymcode = $mask;  | 
                                                        |
| 831 | +    $maskwithonlyymcode = preg_replace('/\{(0+)([@\+][0-9\-\+\=]+)?([@\+][0-9\-\+\=]+)?\}/i', $maskcounter, $maskwithonlyymcode);
 | 
                                                        |
| 832 | +    $maskwithonlyymcode = preg_replace('/\{dd\}/i', 'dd', $maskwithonlyymcode);
 | 
                                                        |
| 833 | +    $maskwithonlyymcode = preg_replace('/\{(c+)(0*)\}/i', $maskrefclient, $maskwithonlyymcode);
 | 
                                                        |
| 834 | +    $maskwithonlyymcode = preg_replace('/\{(t+)\}/i', $masktype_value, $maskwithonlyymcode);
 | 
                                                        |
| 835 | +    $maskwithonlyymcode = preg_replace('/\{(u+)\}/i', $maskuser_value, $maskwithonlyymcode);
 | 
                                                        |
| 836 | + foreach ($maskperso as $key => $val)  | 
                                                        |
| 837 | +    {
 | 
                                                        |
| 838 | +        $maskwithonlyymcode = preg_replace('/'.preg_quote($val, '/').'/i', $maskpersonew[$key], $maskwithonlyymcode);
 | 
                                                        |
| 839 | + }  | 
                                                        |
| 840 | + $maskwithnocode = $maskwithonlyymcode;  | 
                                                        |
| 841 | +    $maskwithnocode = preg_replace('/\{yyyy\}/i', 'yyyy', $maskwithnocode);
 | 
                                                        |
| 842 | +    $maskwithnocode = preg_replace('/\{yy\}/i', 'yy', $maskwithnocode);
 | 
                                                        |
| 843 | +    $maskwithnocode = preg_replace('/\{y\}/i', 'y', $maskwithnocode);
 | 
                                                        |
| 844 | +    $maskwithnocode = preg_replace('/\{mm\}/i', 'mm', $maskwithnocode);
 | 
                                                        |
| 845 | 845 | // Now maskwithnocode = 0000ddmmyyyyccc for example  | 
                                                        
| 846 | 846 | // and maskcounter = 0000 for example  | 
                                                        
| 847 | 847 | //print "maskwithonlyymcode=".$maskwithonlyymcode." maskwithnocode=".$maskwithnocode."\n<br>";  | 
                                                        
| 848 | 848 | //var_dump($reg);  | 
                                                        
| 849 | 849 | |
| 850 | 850 | // If an offset is asked  | 
                                                        
| 851 | -    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) $maskoffset=preg_replace('/^\+/','',$reg[2]);
 | 
                                                        |
| 852 | -    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) $maskoffset=preg_replace('/^\+/','',$reg[3]);
 | 
                                                        |
| 851 | +    if (!empty($reg[2]) && preg_match('/^\+/', $reg[2])) $maskoffset = preg_replace('/^\+/', '', $reg[2]);
 | 
                                                        |
| 852 | +    if (!empty($reg[3]) && preg_match('/^\+/', $reg[3])) $maskoffset = preg_replace('/^\+/', '', $reg[3]);
 | 
                                                        |
| 853 | 853 | |
| 854 | 854 | // Define $sqlwhere  | 
                                                        
| 855 | - $sqlwhere='';  | 
                                                        |
| 856 | - $yearoffset=0; // Use year of current $date by default  | 
                                                        |
| 857 | - $yearoffsettype=false; // false: no reset, 0,-,=,+: reset at offset SOCIETE_FISCAL_MONTH_START, x=reset at offset x  | 
                                                        |
| 855 | + $sqlwhere = '';  | 
                                                        |
| 856 | + $yearoffset = 0; // Use year of current $date by default  | 
                                                        |
| 857 | + $yearoffsettype = false; // false: no reset, 0,-,=,+: reset at offset SOCIETE_FISCAL_MONTH_START, x=reset at offset x  | 
                                                        |
| 858 | 858 | |
| 859 | 859 | // If a restore to zero after a month is asked we check if there is already a value for this year.  | 
                                                        
| 860 | -    if (! empty($reg[2]) && preg_match('/^@/',$reg[2]))	$yearoffsettype = preg_replace('/^@/','',$reg[2]);
 | 
                                                        |
| 861 | -    if (! empty($reg[3]) && preg_match('/^@/',$reg[3]))	$yearoffsettype = preg_replace('/^@/','',$reg[3]);
 | 
                                                        |
| 860 | +    if (!empty($reg[2]) && preg_match('/^@/', $reg[2]))	$yearoffsettype = preg_replace('/^@/', '', $reg[2]);
 | 
                                                        |
| 861 | +    if (!empty($reg[3]) && preg_match('/^@/', $reg[3]))	$yearoffsettype = preg_replace('/^@/', '', $reg[3]);
 | 
                                                        |
| 862 | 862 | |
| 863 | 863 | //print "yearoffset=".$yearoffset." yearoffsettype=".$yearoffsettype;  | 
                                                        
| 864 | 864 | if (is_numeric($yearoffsettype) && $yearoffsettype >= 1)  | 
                                                        
| 865 | - $maskraz=$yearoffsettype; // For backward compatibility  | 
                                                        |
| 866 | - else if ($yearoffsettype === '0' || (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $conf->global->SOCIETE_FISCAL_MONTH_START > 1))  | 
                                                        |
| 865 | + $maskraz = $yearoffsettype; // For backward compatibility  | 
                                                        |
| 866 | + else if ($yearoffsettype === '0' || (!empty($yearoffsettype) && !is_numeric($yearoffsettype) && $conf->global->SOCIETE_FISCAL_MONTH_START > 1))  | 
                                                        |
| 867 | 867 | $maskraz = $conf->global->SOCIETE_FISCAL_MONTH_START;  | 
                                                        
| 868 | 868 | //print "maskraz=".$maskraz; // -1=no reset  | 
                                                        
| 869 | 869 | |
@@ -877,79 +877,79 @@ discard block  | 
                                                    ||
| 877 | 877 | // Define posy, posm and reg  | 
                                                        
| 878 | 878 | if ($maskraz > 1) // if reset is not first month, we need month and year into mask  | 
                                                        
| 879 | 879 |          {
 | 
                                                        
| 880 | -            if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=3; }
 | 
                                                        |
| 881 | -            elseif (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; }
 | 
                                                        |
| 880 | +            if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i', $maskwithonlyymcode, $reg)) { $posy = 2; $posm = 3; }
 | 
                                                        |
| 881 | +            elseif (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i', $maskwithonlyymcode, $reg)) { $posy = 3; $posm = 2; }
 | 
                                                        |
| 882 | 882 | else return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';  | 
                                                        
| 883 | 883 | |
| 884 | 884 | if (dol_strlen($reg[$posy]) < 2) return 'ErrorCantUseRazWithYearOnOneDigit';  | 
                                                        
| 885 | 885 | }  | 
                                                        
| 886 | 886 | else // if reset is for a specific month in year, we need year  | 
                                                        
| 887 | 887 |          {
 | 
                                                        
| 888 | -            if (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; }
 | 
                                                        |
| 889 | -        	else if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=3; }
 | 
                                                        |
| 890 | -            else if (preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=0; }
 | 
                                                        |
| 888 | +            if (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i', $maskwithonlyymcode, $reg)) { $posy = 3; $posm = 2; }
 | 
                                                        |
| 889 | +        	else if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i', $maskwithonlyymcode, $reg)) { $posy = 2; $posm = 3; }
 | 
                                                        |
| 890 | +            else if (preg_match('/^(.*)\{(y+)\}/i', $maskwithonlyymcode, $reg)) { $posy = 2; $posm = 0; }
 | 
                                                        |
| 891 | 891 | else return 'ErrorCantUseRazIfNoYearInMask';  | 
                                                        
| 892 | 892 | }  | 
                                                        
| 893 | 893 | // Define length  | 
                                                        
| 894 | - $yearlen = $posy?dol_strlen($reg[$posy]):0;  | 
                                                        |
| 895 | - $monthlen = $posm?dol_strlen($reg[$posm]):0;  | 
                                                        |
| 894 | + $yearlen = $posy ?dol_strlen($reg[$posy]) : 0;  | 
                                                        |
| 895 | + $monthlen = $posm ?dol_strlen($reg[$posm]) : 0;  | 
                                                        |
| 896 | 896 | // Define pos  | 
                                                        
| 897 | - $yearpos = (dol_strlen($reg[1])+1);  | 
                                                        |
| 898 | - $monthpos = ($yearpos+$yearlen);  | 
                                                        |
| 897 | + $yearpos = (dol_strlen($reg[1]) + 1);  | 
                                                        |
| 898 | + $monthpos = ($yearpos + $yearlen);  | 
                                                        |
| 899 | 899 |          if ($posy == 3 && $posm == 2) {		// if month is before year
 | 
                                                        
| 900 | - $monthpos = (dol_strlen($reg[1])+1);  | 
                                                        |
| 901 | - $yearpos = ($monthpos+$monthlen);  | 
                                                        |
| 900 | + $monthpos = (dol_strlen($reg[1]) + 1);  | 
                                                        |
| 901 | + $yearpos = ($monthpos + $monthlen);  | 
                                                        |
| 902 | 902 | }  | 
                                                        
| 903 | 903 | //print "xxx ".$maskwithonlyymcode." maskraz=".$maskraz." posy=".$posy." yearlen=".$yearlen." yearpos=".$yearpos." posm=".$posm." monthlen=".$monthlen." monthpos=".$monthpos." yearoffsettype=".$yearoffsettype." resetEveryMonth=".$resetEveryMonth."\n";  | 
                                                        
| 904 | 904 | |
| 905 | 905 | // Define $yearcomp and $monthcomp (that will be use in the select where to search max number)  | 
                                                        
| 906 | - $monthcomp=$maskraz;  | 
                                                        |
| 907 | - $yearcomp=0;  | 
                                                        |
| 906 | + $monthcomp = $maskraz;  | 
                                                        |
| 907 | + $yearcomp = 0;  | 
                                                        |
| 908 | 908 | |
| 909 | - if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') // $yearoffsettype is - or +  | 
                                                        |
| 909 | + if (!empty($yearoffsettype) && !is_numeric($yearoffsettype) && $yearoffsettype != '=') // $yearoffsettype is - or +  | 
                                                        |
| 910 | 910 |          {
 | 
                                                        
| 911 | -        	$currentyear=date("Y", $date);
 | 
                                                        |
| 912 | -        	$fiscaldate=dol_mktime('0','0','0',$maskraz,'1',$currentyear);
 | 
                                                        |
| 913 | -        	$newyeardate=dol_mktime('0','0','0','1','1',$currentyear);
 | 
                                                        |
| 914 | -        	$nextnewyeardate=dol_mktime('0','0','0','1','1',$currentyear+1);
 | 
                                                        |
| 911 | +        	$currentyear = date("Y", $date);
 | 
                                                        |
| 912 | +        	$fiscaldate = dol_mktime('0', '0', '0', $maskraz, '1', $currentyear);
 | 
                                                        |
| 913 | +        	$newyeardate = dol_mktime('0', '0', '0', '1', '1', $currentyear);
 | 
                                                        |
| 914 | +        	$nextnewyeardate = dol_mktime('0', '0', '0', '1', '1', $currentyear + 1);
 | 
                                                        |
| 915 | 915 | //echo 'currentyear='.$currentyear.' date='.dol_print_date($date, 'day').' fiscaldate='.dol_print_date($fiscaldate, 'day').'<br>';  | 
                                                        
| 916 | 916 | |
| 917 | 917 | // If after or equal of current fiscal date  | 
                                                        
| 918 | 918 | if ($date >= $fiscaldate)  | 
                                                        
| 919 | 919 |          	{
 | 
                                                        
| 920 | 920 | // If before of next new year date  | 
                                                        
| 921 | - if ($date < $nextnewyeardate && $yearoffsettype == '+') $yearoffset=1;  | 
                                                        |
| 921 | + if ($date < $nextnewyeardate && $yearoffsettype == '+') $yearoffset = 1;  | 
                                                        |
| 922 | 922 | }  | 
                                                        
| 923 | 923 | // If after or equal of current new year date  | 
                                                        
| 924 | - else if ($date >= $newyeardate && $yearoffsettype == '-') $yearoffset=-1;  | 
                                                        |
| 924 | + else if ($date >= $newyeardate && $yearoffsettype == '-') $yearoffset = -1;  | 
                                                        |
| 925 | 925 | }  | 
                                                        
| 926 | 926 | // For backward compatibility  | 
                                                        
| 927 | -        else if (date("m",$date) < $maskraz && empty($resetEveryMonth)) { $yearoffset=-1; }	// If current month lower that month of return to zero, year is previous year
 | 
                                                        |
| 927 | +        else if (date("m", $date) < $maskraz && empty($resetEveryMonth)) { $yearoffset = -1; }	// If current month lower that month of return to zero, year is previous year
 | 
                                                        |
| 928 | 928 | |
| 929 | -        if ($yearlen == 4) $yearcomp=sprintf("%04d",date("Y",$date)+$yearoffset);
 | 
                                                        |
| 930 | -        elseif ($yearlen == 2) $yearcomp=sprintf("%02d",date("y",$date)+$yearoffset);
 | 
                                                        |
| 931 | -        elseif ($yearlen == 1) $yearcomp=substr(date("y",$date),2,1)+$yearoffset;
 | 
                                                        |
| 929 | +        if ($yearlen == 4) $yearcomp = sprintf("%04d", date("Y", $date) + $yearoffset);
 | 
                                                        |
| 930 | +        elseif ($yearlen == 2) $yearcomp = sprintf("%02d", date("y", $date) + $yearoffset);
 | 
                                                        |
| 931 | +        elseif ($yearlen == 1) $yearcomp = substr(date("y", $date), 2, 1) + $yearoffset;
 | 
                                                        |
| 932 | 932 | if ($monthcomp > 1 && empty($resetEveryMonth)) // Test with month is useless if monthcomp = 0 or 1 (0 is same as 1) (regis: $monthcomp can't equal 0)  | 
                                                        
| 933 | 933 |          {
 | 
                                                        
| 934 | -            if ($yearlen == 4) $yearcomp1=sprintf("%04d",date("Y",$date)+$yearoffset+1);
 | 
                                                        |
| 935 | -            elseif ($yearlen == 2) $yearcomp1=sprintf("%02d",date("y",$date)+$yearoffset+1);
 | 
                                                        |
| 936 | -  | 
                                                        |
| 937 | -            $sqlwhere.="(";
 | 
                                                        |
| 938 | -            $sqlwhere.=" (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        |
| 939 | -            $sqlwhere.=" AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") >= '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."')";
 | 
                                                        |
| 940 | - $sqlwhere.=" OR";  | 
                                                        |
| 941 | -            $sqlwhere.=" (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp1."'";
 | 
                                                        |
| 942 | -            $sqlwhere.=" AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") < '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."') ";
 | 
                                                        |
| 943 | - $sqlwhere.=')';  | 
                                                        |
| 934 | +            if ($yearlen == 4) $yearcomp1 = sprintf("%04d", date("Y", $date) + $yearoffset + 1);
 | 
                                                        |
| 935 | +            elseif ($yearlen == 2) $yearcomp1 = sprintf("%02d", date("y", $date) + $yearoffset + 1);
 | 
                                                        |
| 936 | +  | 
                                                        |
| 937 | +            $sqlwhere .= "(";
 | 
                                                        |
| 938 | +            $sqlwhere .= " (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        |
| 939 | +            $sqlwhere .= " AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") >= '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."')";
 | 
                                                        |
| 940 | + $sqlwhere .= " OR";  | 
                                                        |
| 941 | +            $sqlwhere .= " (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp1."'";
 | 
                                                        |
| 942 | +            $sqlwhere .= " AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") < '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."') ";
 | 
                                                        |
| 943 | + $sqlwhere .= ')';  | 
                                                        |
| 944 | 944 | }  | 
                                                        
| 945 | 945 | else if ($resetEveryMonth)  | 
                                                        
| 946 | 946 |  		{
 | 
                                                        
| 947 | -			$sqlwhere.="(SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        |
| 948 | -            $sqlwhere.=" AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") = '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."')";
 | 
                                                        |
| 947 | +			$sqlwhere .= "(SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        |
| 948 | +            $sqlwhere .= " AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") = '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."')";
 | 
                                                        |
| 949 | 949 | }  | 
                                                        
| 950 | 950 | else // reset is done on january  | 
                                                        
| 951 | 951 |          {
 | 
                                                        
| 952 | -            $sqlwhere.='(SUBSTRING('.$field.', '.$yearpos.', '.$yearlen.") = '".$yearcomp."')";
 | 
                                                        |
| 952 | +            $sqlwhere .= '(SUBSTRING('.$field.', '.$yearpos.', '.$yearlen.") = '".$yearcomp."')";
 | 
                                                        |
| 953 | 953 | }  | 
                                                        
| 954 | 954 | }  | 
                                                        
| 955 | 955 | //print "sqlwhere=".$sqlwhere." yearcomp=".$yearcomp."<br>\n"; // sqlwhere and yearcomp defined only if we ask a reset  | 
                                                        
@@ -958,49 +958,49 @@ discard block  | 
                                                    ||
| 958 | 958 | // Define $sqlstring  | 
                                                        
| 959 | 959 |      if (function_exists('mb_strrpos'))
 | 
                                                        
| 960 | 960 |      	{
 | 
                                                        
| 961 | - $posnumstart=mb_strrpos($maskwithnocode,$maskcounter, 'UTF-8');  | 
                                                        |
| 961 | + $posnumstart = mb_strrpos($maskwithnocode, $maskcounter, 'UTF-8');  | 
                                                        |
| 962 | 962 | }  | 
                                                        
| 963 | 963 | else  | 
                                                        
| 964 | 964 |  	{
 | 
                                                        
| 965 | - $posnumstart=strrpos($maskwithnocode,$maskcounter);  | 
                                                        |
| 965 | + $posnumstart = strrpos($maskwithnocode, $maskcounter);  | 
                                                        |
| 966 | 966 | } // Pos of counter in final string (from 0 to ...)  | 
                                                        
| 967 | 967 | if ($posnumstart < 0) return 'ErrorBadMaskFailedToLocatePosOfSequence';  | 
                                                        
| 968 | -    $sqlstring='SUBSTRING('.$field.', '.($posnumstart+1).', '.dol_strlen($maskcounter).')';
 | 
                                                        |
| 968 | +    $sqlstring = 'SUBSTRING('.$field.', '.($posnumstart + 1).', '.dol_strlen($maskcounter).')';
 | 
                                                        |
| 969 | 969 | |
| 970 | 970 | // Define $maskLike  | 
                                                        
| 971 | 971 | $maskLike = dol_string_nospecial($mask);  | 
                                                        
| 972 | -    $maskLike = str_replace("%","_",$maskLike);
 | 
                                                        |
| 972 | +    $maskLike = str_replace("%", "_", $maskLike);
 | 
                                                        |
| 973 | 973 | // Replace protected special codes with matching number of _ as wild card caracter  | 
                                                        
| 974 | -    $maskLike = preg_replace('/\{yyyy\}/i','____',$maskLike);
 | 
                                                        |
| 975 | -    $maskLike = preg_replace('/\{yy\}/i','__',$maskLike);
 | 
                                                        |
| 976 | -    $maskLike = preg_replace('/\{y\}/i','_',$maskLike);
 | 
                                                        |
| 977 | -    $maskLike = preg_replace('/\{mm\}/i','__',$maskLike);
 | 
                                                        |
| 978 | -    $maskLike = preg_replace('/\{dd\}/i','__',$maskLike);
 | 
                                                        |
| 979 | -    $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'),str_pad("",dol_strlen($maskcounter),"_"),$maskLike);
 | 
                                                        |
| 980 | -    if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike);
 | 
                                                        |
| 981 | -    if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike);
 | 
                                                        |
| 982 | -    if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike);
 | 
                                                        |
| 983 | - foreach($maskperso as $key => $val)  | 
                                                        |
| 974 | +    $maskLike = preg_replace('/\{yyyy\}/i', '____', $maskLike);
 | 
                                                        |
| 975 | +    $maskLike = preg_replace('/\{yy\}/i', '__', $maskLike);
 | 
                                                        |
| 976 | +    $maskLike = preg_replace('/\{y\}/i', '_', $maskLike);
 | 
                                                        |
| 977 | +    $maskLike = preg_replace('/\{mm\}/i', '__', $maskLike);
 | 
                                                        |
| 978 | +    $maskLike = preg_replace('/\{dd\}/i', '__', $maskLike);
 | 
                                                        |
| 979 | +    $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'), str_pad("", dol_strlen($maskcounter), "_"), $maskLike);
 | 
                                                        |
| 980 | +    if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'), str_pad("", dol_strlen($maskrefclient), "_"), $maskLike);
 | 
                                                        |
| 981 | +    if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'), $masktype_value, $maskLike);
 | 
                                                        |
| 982 | +    if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'), $maskuser_value, $maskLike);
 | 
                                                        |
| 983 | + foreach ($maskperso as $key => $val)  | 
                                                        |
| 984 | 984 |      {
 | 
                                                        
| 985 | - $maskLike = str_replace(dol_string_nospecial($maskperso[$key]),$maskpersonew[$key],$maskLike);  | 
                                                        |
| 985 | + $maskLike = str_replace(dol_string_nospecial($maskperso[$key]), $maskpersonew[$key], $maskLike);  | 
                                                        |
| 986 | 986 | }  | 
                                                        
| 987 | 987 | |
| 988 | 988 | // Get counter in database  | 
                                                        
| 989 | - $counter=0;  | 
                                                        |
| 989 | + $counter = 0;  | 
                                                        |
| 990 | 990 |      $sql = "SELECT MAX(".$sqlstring.") as val";
 | 
                                                        
| 991 | - $sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 992 | - $sql.= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        |
| 993 | - $sql.= " AND ".$field." NOT LIKE '(PROV%)'";  | 
                                                        |
| 991 | + $sql .= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 992 | + $sql .= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        |
| 993 | + $sql .= " AND ".$field." NOT LIKE '(PROV%)'";  | 
                                                        |
| 994 | 994 | if ($bentityon) // only if entity enable  | 
                                                        
| 995 | -    	$sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 996 | - else if (! empty($forceentity))  | 
                                                        |
| 997 | -    	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 998 | - if ($where) $sql.=$where;  | 
                                                        |
| 999 | - if ($sqlwhere) $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 995 | +    	$sql .= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 996 | + else if (!empty($forceentity))  | 
                                                        |
| 997 | +    	$sql .= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 998 | + if ($where) $sql .= $where;  | 
                                                        |
| 999 | + if ($sqlwhere) $sql .= ' AND '.$sqlwhere;  | 
                                                        |
| 1000 | 1000 | |
| 1001 | 1001 | //print $sql.'<br>';  | 
                                                        
| 1002 | 1002 |      dol_syslog("functions2::get_next_value mode=".$mode."", LOG_DEBUG);
 | 
                                                        
| 1003 | - $resql=$db->query($sql);  | 
                                                        |
| 1003 | + $resql = $db->query($sql);  | 
                                                        |
| 1004 | 1004 | if ($resql)  | 
                                                        
| 1005 | 1005 |      {
 | 
                                                        
| 1006 | 1006 | $obj = $db->fetch_object($resql);  | 
                                                        
@@ -1009,46 +1009,46 @@ discard block  | 
                                                    ||
| 1009 | 1009 | else dol_print_error($db);  | 
                                                        
| 1010 | 1010 | |
| 1011 | 1011 | // Check if we must force counter to maskoffset  | 
                                                        
| 1012 | - if (empty($counter)) $counter=$maskoffset;  | 
                                                        |
| 1013 | -    else if (preg_match('/[^0-9]/i',$counter))
 | 
                                                        |
| 1012 | + if (empty($counter)) $counter = $maskoffset;  | 
                                                        |
| 1013 | +    else if (preg_match('/[^0-9]/i', $counter))
 | 
                                                        |
| 1014 | 1014 |      {
 | 
                                                        
| 1015 | - $counter=0;  | 
                                                        |
| 1015 | + $counter = 0;  | 
                                                        |
| 1016 | 1016 |      	dol_syslog("Error, the last counter found is '".$counter."' so is not a numeric value. We will restart to 1.", LOG_ERR);
 | 
                                                        
| 1017 | 1017 | }  | 
                                                        
| 1018 | - else if ($counter < $maskoffset && empty($conf->global->MAIN_NUMBERING_OFFSET_ONLY_FOR_FIRST)) $counter=$maskoffset;  | 
                                                        |
| 1018 | + else if ($counter < $maskoffset && empty($conf->global->MAIN_NUMBERING_OFFSET_ONLY_FOR_FIRST)) $counter = $maskoffset;  | 
                                                        |
| 1019 | 1019 | |
| 1020 | 1020 | if ($mode == 'last') // We found value for counter = last counter value. Now need to get corresponding ref of invoice.  | 
                                                        
| 1021 | 1021 |      {
 | 
                                                        
| 1022 | - $counterpadded=str_pad($counter,dol_strlen($maskcounter),"0",STR_PAD_LEFT);  | 
                                                        |
| 1022 | + $counterpadded = str_pad($counter, dol_strlen($maskcounter), "0", STR_PAD_LEFT);  | 
                                                        |
| 1023 | 1023 | |
| 1024 | 1024 | // Define $maskLike  | 
                                                        
| 1025 | 1025 | $maskLike = dol_string_nospecial($mask);  | 
                                                        
| 1026 | -        $maskLike = str_replace("%","_",$maskLike);
 | 
                                                        |
| 1026 | +        $maskLike = str_replace("%", "_", $maskLike);
 | 
                                                        |
| 1027 | 1027 | // Replace protected special codes with matching number of _ as wild card caracter  | 
                                                        
| 1028 | -        $maskLike = preg_replace('/\{yyyy\}/i','____',$maskLike);
 | 
                                                        |
| 1029 | -        $maskLike = preg_replace('/\{yy\}/i','__',$maskLike);
 | 
                                                        |
| 1030 | -        $maskLike = preg_replace('/\{y\}/i','_',$maskLike);
 | 
                                                        |
| 1031 | -        $maskLike = preg_replace('/\{mm\}/i','__',$maskLike);
 | 
                                                        |
| 1032 | -        $maskLike = preg_replace('/\{dd\}/i','__',$maskLike);
 | 
                                                        |
| 1033 | -        $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'),$counterpadded,$maskLike);
 | 
                                                        |
| 1034 | -        if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike);
 | 
                                                        |
| 1035 | -        if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike);
 | 
                                                        |
| 1036 | -        if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike);
 | 
                                                        |
| 1037 | -  | 
                                                        |
| 1038 | - $ref='';  | 
                                                        |
| 1028 | +        $maskLike = preg_replace('/\{yyyy\}/i', '____', $maskLike);
 | 
                                                        |
| 1029 | +        $maskLike = preg_replace('/\{yy\}/i', '__', $maskLike);
 | 
                                                        |
| 1030 | +        $maskLike = preg_replace('/\{y\}/i', '_', $maskLike);
 | 
                                                        |
| 1031 | +        $maskLike = preg_replace('/\{mm\}/i', '__', $maskLike);
 | 
                                                        |
| 1032 | +        $maskLike = preg_replace('/\{dd\}/i', '__', $maskLike);
 | 
                                                        |
| 1033 | +        $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'), $counterpadded, $maskLike);
 | 
                                                        |
| 1034 | +        if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'), str_pad("", dol_strlen($maskrefclient), "_"), $maskLike);
 | 
                                                        |
| 1035 | +        if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'), $masktype_value, $maskLike);
 | 
                                                        |
| 1036 | +        if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'), $maskuser_value, $maskLike);
 | 
                                                        |
| 1037 | +  | 
                                                        |
| 1038 | + $ref = '';  | 
                                                        |
| 1039 | 1039 | $sql = "SELECT ".$field." as ref";  | 
                                                        
| 1040 | - $sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 1041 | - $sql.= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        |
| 1042 | - $sql.= " AND ".$field." NOT LIKE '%PROV%'";  | 
                                                        |
| 1040 | + $sql .= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 1041 | + $sql .= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        |
| 1042 | + $sql .= " AND ".$field." NOT LIKE '%PROV%'";  | 
                                                        |
| 1043 | 1043 | if ($bentityon) // only if entity enable  | 
                                                        
| 1044 | -        	$sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1045 | - else if (! empty($forceentity))  | 
                                                        |
| 1046 | -        	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1047 | - if ($where) $sql.=$where;  | 
                                                        |
| 1048 | - if ($sqlwhere) $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1044 | +        	$sql .= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1045 | + else if (!empty($forceentity))  | 
                                                        |
| 1046 | +        	$sql .= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1047 | + if ($where) $sql .= $where;  | 
                                                        |
| 1048 | + if ($sqlwhere) $sql .= ' AND '.$sqlwhere;  | 
                                                        |
| 1049 | 1049 | |
| 1050 | 1050 |          dol_syslog("functions2::get_next_value mode=".$mode."", LOG_DEBUG);
 | 
                                                        
| 1051 | - $resql=$db->query($sql);  | 
                                                        |
| 1051 | + $resql = $db->query($sql);  | 
                                                        |
| 1052 | 1052 | if ($resql)  | 
                                                        
| 1053 | 1053 |          {
 | 
                                                        
| 1054 | 1054 | $obj = $db->fetch_object($resql);  | 
                                                        
@@ -1056,7 +1056,7 @@ discard block  | 
                                                    ||
| 1056 | 1056 | }  | 
                                                        
| 1057 | 1057 | else dol_print_error($db);  | 
                                                        
| 1058 | 1058 | |
| 1059 | - $numFinal=$ref;  | 
                                                        |
| 1059 | + $numFinal = $ref;  | 
                                                        |
| 1060 | 1060 | }  | 
                                                        
| 1061 | 1061 | else if ($mode == 'next')  | 
                                                        
| 1062 | 1062 |      {
 | 
                                                        
@@ -1065,47 +1065,47 @@ discard block  | 
                                                    ||
| 1065 | 1065 | // If value for $counter has a length higher than $maskcounter chars  | 
                                                        
| 1066 | 1066 | if ($counter >= pow(10, dol_strlen($maskcounter)))  | 
                                                        
| 1067 | 1067 |          {
 | 
                                                        
| 1068 | - $counter='ErrorMaxNumberReachForThisMask';  | 
                                                        |
| 1068 | + $counter = 'ErrorMaxNumberReachForThisMask';  | 
                                                        |
| 1069 | 1069 | }  | 
                                                        
| 1070 | 1070 | |
| 1071 | - if (! empty($maskrefclient_maskcounter))  | 
                                                        |
| 1071 | + if (!empty($maskrefclient_maskcounter))  | 
                                                        |
| 1072 | 1072 |          {
 | 
                                                        
| 1073 | 1073 | //print "maskrefclient_maskcounter=".$maskrefclient_maskcounter." maskwithnocode=".$maskwithnocode." maskrefclient=".$maskrefclient."\n<br>";  | 
                                                        
| 1074 | 1074 | |
| 1075 | 1075 | // Define $sqlstring  | 
                                                        
| 1076 | - $maskrefclient_posnumstart=strpos($maskwithnocode,$maskrefclient_maskcounter,strpos($maskwithnocode,$maskrefclient)); // Pos of counter in final string (from 0 to ...)  | 
                                                        |
| 1076 | + $maskrefclient_posnumstart = strpos($maskwithnocode, $maskrefclient_maskcounter, strpos($maskwithnocode, $maskrefclient)); // Pos of counter in final string (from 0 to ...)  | 
                                                        |
| 1077 | 1077 | if ($maskrefclient_posnumstart <= 0) return 'ErrorBadMask';  | 
                                                        
| 1078 | -            $maskrefclient_sqlstring='SUBSTRING('.$field.', '.($maskrefclient_posnumstart+1).', '.dol_strlen($maskrefclient_maskcounter).')';
 | 
                                                        |
| 1078 | +            $maskrefclient_sqlstring = 'SUBSTRING('.$field.', '.($maskrefclient_posnumstart + 1).', '.dol_strlen($maskrefclient_maskcounter).')';
 | 
                                                        |
| 1079 | 1079 | //print "x".$sqlstring;  | 
                                                        
| 1080 | 1080 | |
| 1081 | 1081 | // Define $maskrefclient_maskLike  | 
                                                        
| 1082 | 1082 | $maskrefclient_maskLike = dol_string_nospecial($mask);  | 
                                                        
| 1083 | -            $maskrefclient_maskLike = str_replace("%","_",$maskrefclient_maskLike);
 | 
                                                        |
| 1083 | +            $maskrefclient_maskLike = str_replace("%", "_", $maskrefclient_maskLike);
 | 
                                                        |
| 1084 | 1084 | // Replace protected special codes with matching number of _ as wild card caracter  | 
                                                        
| 1085 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{yyyy}'),'____',$maskrefclient_maskLike);
 | 
                                                        |
| 1086 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{yy}'),'__',$maskrefclient_maskLike);
 | 
                                                        |
| 1087 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{y}'),'_',$maskrefclient_maskLike);
 | 
                                                        |
| 1088 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{mm}'),'__',$maskrefclient_maskLike);
 | 
                                                        |
| 1089 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{dd}'),'__',$maskrefclient_maskLike);
 | 
                                                        |
| 1090 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'),str_pad("",dol_strlen($maskcounter),"_"),$maskrefclient_maskLike);
 | 
                                                        |
| 1091 | -            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),$maskrefclient_clientcode.str_pad("",dol_strlen($maskrefclient_maskcounter),"_"),$maskrefclient_maskLike);
 | 
                                                        |
| 1085 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{yyyy}'), '____', $maskrefclient_maskLike);
 | 
                                                        |
| 1086 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{yy}'), '__', $maskrefclient_maskLike);
 | 
                                                        |
| 1087 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{y}'), '_', $maskrefclient_maskLike);
 | 
                                                        |
| 1088 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{mm}'), '__', $maskrefclient_maskLike);
 | 
                                                        |
| 1089 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{dd}'), '__', $maskrefclient_maskLike);
 | 
                                                        |
| 1090 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'), str_pad("", dol_strlen($maskcounter), "_"), $maskrefclient_maskLike);
 | 
                                                        |
| 1091 | +            $maskrefclient_maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'), $maskrefclient_clientcode.str_pad("", dol_strlen($maskrefclient_maskcounter), "_"), $maskrefclient_maskLike);
 | 
                                                        |
| 1092 | 1092 | |
| 1093 | 1093 | // Get counter in database  | 
                                                        
| 1094 | - $maskrefclient_counter=0;  | 
                                                        |
| 1094 | + $maskrefclient_counter = 0;  | 
                                                        |
| 1095 | 1095 |              $maskrefclient_sql = "SELECT MAX(".$maskrefclient_sqlstring.") as val";
 | 
                                                        
| 1096 | - $maskrefclient_sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 1096 | + $maskrefclient_sql .= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        |
| 1097 | 1097 | //$sql.= " WHERE ".$field." not like '(%'";  | 
                                                        
| 1098 | - $maskrefclient_sql.= " WHERE ".$field." LIKE '".$maskrefclient_maskLike."'";  | 
                                                        |
| 1098 | + $maskrefclient_sql .= " WHERE ".$field." LIKE '".$maskrefclient_maskLike."'";  | 
                                                        |
| 1099 | 1099 | if ($bentityon) // only if entity enable  | 
                                                        
| 1100 | -            	$maskrefclient_sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1101 | - else if (! empty($forceentity))  | 
                                                        |
| 1102 | -            	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1103 | - if ($where) $maskrefclient_sql.=$where; //use the same optional where as general mask  | 
                                                        |
| 1104 | - if ($sqlwhere) $maskrefclient_sql.=' AND '.$sqlwhere; //use the same sqlwhere as general mask  | 
                                                        |
| 1105 | -            $maskrefclient_sql.=' AND (SUBSTRING('.$field.', '.(strpos($maskwithnocode,$maskrefclient)+1).', '.dol_strlen($maskrefclient_maskclientcode).")='".$maskrefclient_clientcode."')";
 | 
                                                        |
| 1100 | +            	$maskrefclient_sql .= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1101 | + else if (!empty($forceentity))  | 
                                                        |
| 1102 | +            	$sql .= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1103 | + if ($where) $maskrefclient_sql .= $where; //use the same optional where as general mask  | 
                                                        |
| 1104 | + if ($sqlwhere) $maskrefclient_sql .= ' AND '.$sqlwhere; //use the same sqlwhere as general mask  | 
                                                        |
| 1105 | +            $maskrefclient_sql .= ' AND (SUBSTRING('.$field.', '.(strpos($maskwithnocode, $maskrefclient) + 1).', '.dol_strlen($maskrefclient_maskclientcode).")='".$maskrefclient_clientcode."')";
 | 
                                                        |
| 1106 | 1106 | |
| 1107 | 1107 |              dol_syslog("functions2::get_next_value maskrefclient", LOG_DEBUG);
 | 
                                                        
| 1108 | - $maskrefclient_resql=$db->query($maskrefclient_sql);  | 
                                                        |
| 1108 | + $maskrefclient_resql = $db->query($maskrefclient_sql);  | 
                                                        |
| 1109 | 1109 | if ($maskrefclient_resql)  | 
                                                        
| 1110 | 1110 |              {
 | 
                                                        
| 1111 | 1111 | $maskrefclient_obj = $db->fetch_object($maskrefclient_resql);  | 
                                                        
@@ -1113,7 +1113,7 @@ discard block  | 
                                                    ||
| 1113 | 1113 | }  | 
                                                        
| 1114 | 1114 | else dol_print_error($db);  | 
                                                        
| 1115 | 1115 | |
| 1116 | -            if (empty($maskrefclient_counter) || preg_match('/[^0-9]/i',$maskrefclient_counter)) $maskrefclient_counter=$maskrefclient_maskoffset;
 | 
                                                        |
| 1116 | +            if (empty($maskrefclient_counter) || preg_match('/[^0-9]/i', $maskrefclient_counter)) $maskrefclient_counter = $maskrefclient_maskoffset;
 | 
                                                        |
| 1117 | 1117 | $maskrefclient_counter++;  | 
                                                        
| 1118 | 1118 | }  | 
                                                        
| 1119 | 1119 | |
@@ -1121,54 +1121,54 @@ discard block  | 
                                                    ||
| 1121 | 1121 | $numFinal = $mask;  | 
                                                        
| 1122 | 1122 | |
| 1123 | 1123 | // We replace special codes except refclient  | 
                                                        
| 1124 | - if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') // yearoffsettype is - or +, so we don't want current year  | 
                                                        |
| 1124 | + if (!empty($yearoffsettype) && !is_numeric($yearoffsettype) && $yearoffsettype != '=') // yearoffsettype is - or +, so we don't want current year  | 
                                                        |
| 1125 | 1125 |  		{
 | 
                                                        
| 1126 | -	        $numFinal = preg_replace('/\{yyyy\}/i',date("Y",$date)+$yearoffset, $numFinal);
 | 
                                                        |
| 1127 | -        	$numFinal = preg_replace('/\{yy\}/i',  date("y",$date)+$yearoffset, $numFinal);
 | 
                                                        |
| 1128 | -        	$numFinal = preg_replace('/\{y\}/i',   substr(date("y",$date),1,1)+$yearoffset, $numFinal);
 | 
                                                        |
| 1126 | +	        $numFinal = preg_replace('/\{yyyy\}/i', date("Y", $date) + $yearoffset, $numFinal);
 | 
                                                        |
| 1127 | +        	$numFinal = preg_replace('/\{yy\}/i', date("y", $date) + $yearoffset, $numFinal);
 | 
                                                        |
| 1128 | +        	$numFinal = preg_replace('/\{y\}/i', substr(date("y", $date), 1, 1) + $yearoffset, $numFinal);
 | 
                                                        |
| 1129 | 1129 | }  | 
                                                        
| 1130 | 1130 | else // we want yyyy to be current year  | 
                                                        
| 1131 | 1131 |  		{
 | 
                                                        
| 1132 | -        	$numFinal = preg_replace('/\{yyyy\}/i',date("Y",$date), $numFinal);
 | 
                                                        |
| 1133 | -        	$numFinal = preg_replace('/\{yy\}/i',  date("y",$date), $numFinal);
 | 
                                                        |
| 1134 | -        	$numFinal = preg_replace('/\{y\}/i',   substr(date("y",$date),1,1), $numFinal);
 | 
                                                        |
| 1132 | +        	$numFinal = preg_replace('/\{yyyy\}/i', date("Y", $date), $numFinal);
 | 
                                                        |
| 1133 | +        	$numFinal = preg_replace('/\{yy\}/i', date("y", $date), $numFinal);
 | 
                                                        |
| 1134 | +        	$numFinal = preg_replace('/\{y\}/i', substr(date("y", $date), 1, 1), $numFinal);
 | 
                                                        |
| 1135 | 1135 | }  | 
                                                        
| 1136 | -        $numFinal = preg_replace('/\{mm\}/i',  date("m",$date), $numFinal);
 | 
                                                        |
| 1137 | -        $numFinal = preg_replace('/\{dd\}/i',  date("d",$date), $numFinal);
 | 
                                                        |
| 1136 | +        $numFinal = preg_replace('/\{mm\}/i', date("m", $date), $numFinal);
 | 
                                                        |
| 1137 | +        $numFinal = preg_replace('/\{dd\}/i', date("d", $date), $numFinal);
 | 
                                                        |
| 1138 | 1138 | |
| 1139 | 1139 | // Now we replace the counter  | 
                                                        
| 1140 | -        $maskbefore='{'.$masktri.'}';
 | 
                                                        |
| 1141 | - $maskafter=str_pad($counter,dol_strlen($maskcounter),"0",STR_PAD_LEFT);  | 
                                                        |
| 1140 | +        $maskbefore = '{'.$masktri.'}';
 | 
                                                        |
| 1141 | + $maskafter = str_pad($counter, dol_strlen($maskcounter), "0", STR_PAD_LEFT);  | 
                                                        |
| 1142 | 1142 | //print 'x'.$maskbefore.'-'.$maskafter.'y';  | 
                                                        
| 1143 | - $numFinal = str_replace($maskbefore,$maskafter,$numFinal);  | 
                                                        |
| 1143 | + $numFinal = str_replace($maskbefore, $maskafter, $numFinal);  | 
                                                        |
| 1144 | 1144 | |
| 1145 | 1145 | // Now we replace the refclient  | 
                                                        
| 1146 | 1146 | if ($maskrefclient)  | 
                                                        
| 1147 | 1147 |          {
 | 
                                                        
| 1148 | 1148 | //print "maskrefclient=".$maskrefclient." maskwithonlyymcode=".$maskwithonlyymcode." maskwithnocode=".$maskwithnocode."\n<br>";  | 
                                                        
| 1149 | -            $maskrefclient_maskbefore='{'.$maskrefclient.'}';
 | 
                                                        |
| 1150 | - $maskrefclient_maskafter=$maskrefclient_clientcode.str_pad($maskrefclient_counter,dol_strlen($maskrefclient_maskcounter),"0",STR_PAD_LEFT);  | 
                                                        |
| 1151 | - $numFinal = str_replace($maskrefclient_maskbefore,$maskrefclient_maskafter,$numFinal);  | 
                                                        |
| 1149 | +            $maskrefclient_maskbefore = '{'.$maskrefclient.'}';
 | 
                                                        |
| 1150 | + $maskrefclient_maskafter = $maskrefclient_clientcode.str_pad($maskrefclient_counter, dol_strlen($maskrefclient_maskcounter), "0", STR_PAD_LEFT);  | 
                                                        |
| 1151 | + $numFinal = str_replace($maskrefclient_maskbefore, $maskrefclient_maskafter, $numFinal);  | 
                                                        |
| 1152 | 1152 | }  | 
                                                        
| 1153 | 1153 | |
| 1154 | 1154 | // Now we replace the type  | 
                                                        
| 1155 | 1155 | if ($masktype)  | 
                                                        
| 1156 | 1156 |          {
 | 
                                                        
| 1157 | -            $masktype_maskbefore='{'.$masktype.'}';
 | 
                                                        |
| 1158 | - $masktype_maskafter=$masktype_value;  | 
                                                        |
| 1159 | - $numFinal = str_replace($masktype_maskbefore,$masktype_maskafter,$numFinal);  | 
                                                        |
| 1157 | +            $masktype_maskbefore = '{'.$masktype.'}';
 | 
                                                        |
| 1158 | + $masktype_maskafter = $masktype_value;  | 
                                                        |
| 1159 | + $numFinal = str_replace($masktype_maskbefore, $masktype_maskafter, $numFinal);  | 
                                                        |
| 1160 | 1160 | }  | 
                                                        
| 1161 | 1161 | |
| 1162 | 1162 | // Now we replace the user  | 
                                                        
| 1163 | 1163 | if ($maskuser)  | 
                                                        
| 1164 | 1164 |          {
 | 
                                                        
| 1165 | -        	$maskuser_maskbefore='{'.$maskuser.'}';
 | 
                                                        |
| 1166 | - $maskuser_maskafter=$maskuser_value;  | 
                                                        |
| 1167 | - $numFinal = str_replace($maskuser_maskbefore,$maskuser_maskafter,$numFinal);  | 
                                                        |
| 1165 | +        	$maskuser_maskbefore = '{'.$maskuser.'}';
 | 
                                                        |
| 1166 | + $maskuser_maskafter = $maskuser_value;  | 
                                                        |
| 1167 | + $numFinal = str_replace($maskuser_maskbefore, $maskuser_maskafter, $numFinal);  | 
                                                        |
| 1168 | 1168 | }  | 
                                                        
| 1169 | 1169 | }  | 
                                                        
| 1170 | 1170 | |
| 1171 | -    dol_syslog("functions2::get_next_value return ".$numFinal,LOG_DEBUG);
 | 
                                                        |
| 1171 | +    dol_syslog("functions2::get_next_value return ".$numFinal, LOG_DEBUG);
 | 
                                                        |
| 1172 | 1172 | return $numFinal;  | 
                                                        
| 1173 | 1173 | }  | 
                                                        
| 1174 | 1174 | |
@@ -1183,11 +1183,11 @@ discard block  | 
                                                    ||
| 1183 | 1183 | function get_string_between($string, $start, $end)  | 
                                                        
| 1184 | 1184 |  {
 | 
                                                        
| 1185 | 1185 | $string = " ".$string;  | 
                                                        
| 1186 | - $ini = strpos($string,$start);  | 
                                                        |
| 1186 | + $ini = strpos($string, $start);  | 
                                                        |
| 1187 | 1187 | if ($ini == 0) return "";  | 
                                                        
| 1188 | 1188 | $ini += strlen($start);  | 
                                                        
| 1189 | - $len = strpos($string,$end,$ini) - $ini;  | 
                                                        |
| 1190 | - return substr($string,$ini,$len);  | 
                                                        |
| 1189 | + $len = strpos($string, $end, $ini) - $ini;  | 
                                                        |
| 1190 | + return substr($string, $ini, $len);  | 
                                                        |
| 1191 | 1191 | }  | 
                                                        
| 1192 | 1192 | |
| 1193 | 1193 | /**  | 
                                                        
@@ -1197,78 +1197,78 @@ discard block  | 
                                                    ||
| 1197 | 1197 | * @param string $value Value  | 
                                                        
| 1198 | 1198 | * @return int|string <0 or error string if KO, 0 if OK  | 
                                                        
| 1199 | 1199 | */  | 
                                                        
| 1200 | -function check_value($mask,$value)  | 
                                                        |
| 1200 | +function check_value($mask, $value)  | 
                                                        |
| 1201 | 1201 |  {
 | 
                                                        
| 1202 | - $result=0;  | 
                                                        |
| 1202 | + $result = 0;  | 
                                                        |
| 1203 | 1203 | |
| 1204 | - $hasglobalcounter=false;  | 
                                                        |
| 1204 | + $hasglobalcounter = false;  | 
                                                        |
| 1205 | 1205 | // Extract value for mask counter, mask raz and mask offset  | 
                                                        
| 1206 | -    if (preg_match('/\{(0+)([@\+][0-9]+)?([@\+][0-9]+)?\}/i',$mask,$reg))
 | 
                                                        |
| 1206 | +    if (preg_match('/\{(0+)([@\+][0-9]+)?([@\+][0-9]+)?\}/i', $mask, $reg))
 | 
                                                        |
| 1207 | 1207 |      {
 | 
                                                        
| 1208 | - $masktri=$reg[1].(isset($reg[2])?$reg[2]:'').(isset($reg[3])?$reg[3]:'');  | 
                                                        |
| 1209 | - $maskcounter=$reg[1];  | 
                                                        |
| 1210 | - $hasglobalcounter=true;  | 
                                                        |
| 1208 | + $masktri = $reg[1].(isset($reg[2]) ? $reg[2] : '').(isset($reg[3]) ? $reg[3] : '');  | 
                                                        |
| 1209 | + $maskcounter = $reg[1];  | 
                                                        |
| 1210 | + $hasglobalcounter = true;  | 
                                                        |
| 1211 | 1211 | }  | 
                                                        
| 1212 | 1212 | else  | 
                                                        
| 1213 | 1213 |      {
 | 
                                                        
| 1214 | 1214 | // setting some defaults so the rest of the code won't fail if there is a third party counter  | 
                                                        
| 1215 | - $masktri='00000';  | 
                                                        |
| 1216 | - $maskcounter='00000';  | 
                                                        |
| 1215 | + $masktri = '00000';  | 
                                                        |
| 1216 | + $maskcounter = '00000';  | 
                                                        |
| 1217 | 1217 | }  | 
                                                        
| 1218 | 1218 | |
| 1219 | - $maskraz=-1;  | 
                                                        |
| 1220 | - $maskoffset=0;  | 
                                                        |
| 1219 | + $maskraz = -1;  | 
                                                        |
| 1220 | + $maskoffset = 0;  | 
                                                        |
| 1221 | 1221 | if (dol_strlen($maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        
| 1222 | 1222 | |
| 1223 | 1223 | // Extract value for third party mask counter  | 
                                                        
| 1224 | -    if (preg_match('/\{(c+)(0*)\}/i',$mask,$regClientRef))
 | 
                                                        |
| 1225 | -    {
 | 
                                                        |
| 1226 | - $maskrefclient=$regClientRef[1].$regClientRef[2];  | 
                                                        |
| 1227 | - $maskrefclient_maskclientcode=$regClientRef[1];  | 
                                                        |
| 1228 | - $maskrefclient_maskcounter=$regClientRef[2];  | 
                                                        |
| 1229 | - $maskrefclient_maskoffset=0; //default value of maskrefclient_counter offset  | 
                                                        |
| 1230 | -        $maskrefclient_clientcode=substr('',0,dol_strlen($maskrefclient_maskclientcode));//get n first characters of client code to form maskrefclient_clientcode
 | 
                                                        |
| 1231 | - $maskrefclient_clientcode=str_pad($maskrefclient_clientcode,dol_strlen($maskrefclient_maskclientcode),"#",STR_PAD_RIGHT);//padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        |
| 1232 | - $maskrefclient_clientcode=dol_string_nospecial($maskrefclient_clientcode);//sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        |
| 1224 | +    if (preg_match('/\{(c+)(0*)\}/i', $mask, $regClientRef))
 | 
                                                        |
| 1225 | +    {
 | 
                                                        |
| 1226 | + $maskrefclient = $regClientRef[1].$regClientRef[2];  | 
                                                        |
| 1227 | + $maskrefclient_maskclientcode = $regClientRef[1];  | 
                                                        |
| 1228 | + $maskrefclient_maskcounter = $regClientRef[2];  | 
                                                        |
| 1229 | + $maskrefclient_maskoffset = 0; //default value of maskrefclient_counter offset  | 
                                                        |
| 1230 | +        $maskrefclient_clientcode = substr('', 0, dol_strlen($maskrefclient_maskclientcode)); //get n first characters of client code to form maskrefclient_clientcode
 | 
                                                        |
| 1231 | + $maskrefclient_clientcode = str_pad($maskrefclient_clientcode, dol_strlen($maskrefclient_maskclientcode), "#", STR_PAD_RIGHT); //padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        |
| 1232 | + $maskrefclient_clientcode = dol_string_nospecial($maskrefclient_clientcode); //sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        |
| 1233 | 1233 | if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        
| 1234 | 1234 | }  | 
                                                        
| 1235 | - else $maskrefclient='';  | 
                                                        |
| 1235 | + else $maskrefclient = '';  | 
                                                        |
| 1236 | 1236 | |
| 1237 | 1237 | // fail if there is neither a global nor a third party counter  | 
                                                        
| 1238 | - if (! $hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        |
| 1238 | + if (!$hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        |
| 1239 | 1239 |      {
 | 
                                                        
| 1240 | 1240 | return 'ErrorBadMask';  | 
                                                        
| 1241 | 1241 | }  | 
                                                        
| 1242 | 1242 | |
| 1243 | - $maskwithonlyymcode=$mask;  | 
                                                        |
| 1244 | -    $maskwithonlyymcode=preg_replace('/\{(0+)([@\+][0-9]+)?([@\+][0-9]+)?\}/i',$maskcounter,$maskwithonlyymcode);
 | 
                                                        |
| 1245 | -    $maskwithonlyymcode=preg_replace('/\{dd\}/i','dd',$maskwithonlyymcode);
 | 
                                                        |
| 1246 | -    $maskwithonlyymcode=preg_replace('/\{(c+)(0*)\}/i',$maskrefclient,$maskwithonlyymcode);
 | 
                                                        |
| 1247 | - $maskwithnocode=$maskwithonlyymcode;  | 
                                                        |
| 1248 | -    $maskwithnocode=preg_replace('/\{yyyy\}/i','yyyy',$maskwithnocode);
 | 
                                                        |
| 1249 | -    $maskwithnocode=preg_replace('/\{yy\}/i','yy',$maskwithnocode);
 | 
                                                        |
| 1250 | -    $maskwithnocode=preg_replace('/\{y\}/i','y',$maskwithnocode);
 | 
                                                        |
| 1251 | -    $maskwithnocode=preg_replace('/\{mm\}/i','mm',$maskwithnocode);
 | 
                                                        |
| 1243 | + $maskwithonlyymcode = $mask;  | 
                                                        |
| 1244 | +    $maskwithonlyymcode = preg_replace('/\{(0+)([@\+][0-9]+)?([@\+][0-9]+)?\}/i', $maskcounter, $maskwithonlyymcode);
 | 
                                                        |
| 1245 | +    $maskwithonlyymcode = preg_replace('/\{dd\}/i', 'dd', $maskwithonlyymcode);
 | 
                                                        |
| 1246 | +    $maskwithonlyymcode = preg_replace('/\{(c+)(0*)\}/i', $maskrefclient, $maskwithonlyymcode);
 | 
                                                        |
| 1247 | + $maskwithnocode = $maskwithonlyymcode;  | 
                                                        |
| 1248 | +    $maskwithnocode = preg_replace('/\{yyyy\}/i', 'yyyy', $maskwithnocode);
 | 
                                                        |
| 1249 | +    $maskwithnocode = preg_replace('/\{yy\}/i', 'yy', $maskwithnocode);
 | 
                                                        |
| 1250 | +    $maskwithnocode = preg_replace('/\{y\}/i', 'y', $maskwithnocode);
 | 
                                                        |
| 1251 | +    $maskwithnocode = preg_replace('/\{mm\}/i', 'mm', $maskwithnocode);
 | 
                                                        |
| 1252 | 1252 | // Now maskwithnocode = 0000ddmmyyyyccc for example  | 
                                                        
| 1253 | 1253 | // and maskcounter = 0000 for example  | 
                                                        
| 1254 | 1254 | //print "maskwithonlyymcode=".$maskwithonlyymcode." maskwithnocode=".$maskwithnocode."\n<br>";  | 
                                                        
| 1255 | 1255 | |
| 1256 | 1256 | // If an offset is asked  | 
                                                        
| 1257 | -    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) $maskoffset=preg_replace('/^\+/','',$reg[2]);
 | 
                                                        |
| 1258 | -    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) $maskoffset=preg_replace('/^\+/','',$reg[3]);
 | 
                                                        |
| 1257 | +    if (!empty($reg[2]) && preg_match('/^\+/', $reg[2])) $maskoffset = preg_replace('/^\+/', '', $reg[2]);
 | 
                                                        |
| 1258 | +    if (!empty($reg[3]) && preg_match('/^\+/', $reg[3])) $maskoffset = preg_replace('/^\+/', '', $reg[3]);
 | 
                                                        |
| 1259 | 1259 | |
| 1260 | 1260 | // Define $sqlwhere  | 
                                                        
| 1261 | 1261 | |
| 1262 | 1262 | // If a restore to zero after a month is asked we check if there is already a value for this year.  | 
                                                        
| 1263 | -    if (! empty($reg[2]) && preg_match('/^@/',$reg[2]))  $maskraz=preg_replace('/^@/','',$reg[2]);
 | 
                                                        |
| 1264 | -    if (! empty($reg[3]) && preg_match('/^@/',$reg[3]))  $maskraz=preg_replace('/^@/','',$reg[3]);
 | 
                                                        |
| 1263 | +    if (!empty($reg[2]) && preg_match('/^@/', $reg[2]))  $maskraz = preg_replace('/^@/', '', $reg[2]);
 | 
                                                        |
| 1264 | +    if (!empty($reg[3]) && preg_match('/^@/', $reg[3]))  $maskraz = preg_replace('/^@/', '', $reg[3]);
 | 
                                                        |
| 1265 | 1265 | if ($maskraz >= 0)  | 
                                                        
| 1266 | 1266 |      {
 | 
                                                        
| 1267 | 1267 | if ($maskraz > 12) return 'ErrorBadMaskBadRazMonth';  | 
                                                        
| 1268 | 1268 | |
| 1269 | 1269 | // Define reg  | 
                                                        
| 1270 | -        if ($maskraz > 1 && ! preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';
 | 
                                                        |
| 1271 | -        if ($maskraz <= 1 && ! preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) return 'ErrorCantUseRazIfNoYearInMask';
 | 
                                                        |
| 1270 | +        if ($maskraz > 1 && !preg_match('/^(.*)\{(y+)\}\{(m+)\}/i', $maskwithonlyymcode, $reg)) return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';
 | 
                                                        |
| 1271 | +        if ($maskraz <= 1 && !preg_match('/^(.*)\{(y+)\}/i', $maskwithonlyymcode, $reg)) return 'ErrorCantUseRazIfNoYearInMask';
 | 
                                                        |
| 1272 | 1272 | //print "x".$maskwithonlyymcode." ".$maskraz;  | 
                                                        
| 1273 | 1273 | }  | 
                                                        
| 1274 | 1274 | //print "masktri=".$masktri." maskcounter=".$maskcounter." maskraz=".$maskraz." maskoffset=".$maskoffset."<br>\n";  | 
                                                        
@@ -1277,8 +1277,8 @@ discard block  | 
                                                    ||
| 1277 | 1277 | //  | 
                                                        
| 1278 | 1278 | |
| 1279 | 1279 | // Check length  | 
                                                        
| 1280 | - $len=dol_strlen($maskwithnocode);  | 
                                                        |
| 1281 | - if (dol_strlen($value) != $len) $result=-1;  | 
                                                        |
| 1280 | + $len = dol_strlen($maskwithnocode);  | 
                                                        |
| 1281 | + if (dol_strlen($value) != $len) $result = -1;  | 
                                                        |
| 1282 | 1282 | |
| 1283 | 1283 | // Define $maskLike  | 
                                                        
| 1284 | 1284 | /* seems not used  | 
                                                        
@@ -1294,7 +1294,7 @@ discard block  | 
                                                    ||
| 1294 | 1294 |      if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",strlen($maskrefclient),"_"),$maskLike);
 | 
                                                        
| 1295 | 1295 | */  | 
                                                        
| 1296 | 1296 | |
| 1297 | -    dol_syslog("functions2::check_value result=".$result,LOG_DEBUG);
 | 
                                                        |
| 1297 | +    dol_syslog("functions2::check_value result=".$result, LOG_DEBUG);
 | 
                                                        |
| 1298 | 1298 | return $result;  | 
                                                        
| 1299 | 1299 | }  | 
                                                        
| 1300 | 1300 | |
@@ -1306,13 +1306,13 @@ discard block  | 
                                                    ||
| 1306 | 1306 | * @param boolean $upper Convert to tupper  | 
                                                        
| 1307 | 1307 | * @return string x  | 
                                                        
| 1308 | 1308 | */  | 
                                                        
| 1309 | -function binhex($bin, $pad=false, $upper=false)  | 
                                                        |
| 1309 | +function binhex($bin, $pad = false, $upper = false)  | 
                                                        |
| 1310 | 1310 |  {
 | 
                                                        
| 1311 | - $last = dol_strlen($bin)-1;  | 
                                                        |
| 1312 | -    for($i=0; $i<=$last; $i++){ $x += $bin[$last-$i] * pow(2,$i); }
 | 
                                                        |
| 1311 | + $last = dol_strlen($bin) - 1;  | 
                                                        |
| 1312 | +    for ($i = 0; $i <= $last; $i++) { $x += $bin[$last - $i] * pow(2, $i); }
 | 
                                                        |
| 1313 | 1313 | $x = dechex($x);  | 
                                                        
| 1314 | -    if($pad){ while(dol_strlen($x) < intval(dol_strlen($bin))/4){ $x = "0$x"; } }
 | 
                                                        |
| 1315 | -    if($upper){ $x = strtoupper($x); }
 | 
                                                        |
| 1314 | +    if ($pad) { while (dol_strlen($x) < intval(dol_strlen($bin)) / 4) { $x = "0$x"; } }
 | 
                                                        |
| 1315 | +    if ($upper) { $x = strtoupper($x); }
 | 
                                                        |
| 1316 | 1316 | return $x;  | 
                                                        
| 1317 | 1317 | }  | 
                                                        
| 1318 | 1318 | |
@@ -1324,11 +1324,11 @@ discard block  | 
                                                    ||
| 1324 | 1324 | */  | 
                                                        
| 1325 | 1325 | function hexbin($hexa)  | 
                                                        
| 1326 | 1326 |  {
 | 
                                                        
| 1327 | - $bin='';  | 
                                                        |
| 1327 | + $bin = '';  | 
                                                        |
| 1328 | 1328 | $strLength = dol_strlen($hexa);  | 
                                                        
| 1329 | - for($i=0;$i<$strLength;$i++)  | 
                                                        |
| 1329 | + for ($i = 0; $i < $strLength; $i++)  | 
                                                        |
| 1330 | 1330 |      {
 | 
                                                        
| 1331 | -        $bin.=str_pad(decbin(hexdec($hexa{$i})),4,'0',STR_PAD_LEFT);
 | 
                                                        |
| 1331 | +        $bin .= str_pad(decbin(hexdec($hexa{$i})), 4, '0', STR_PAD_LEFT);
 | 
                                                        |
| 1332 | 1332 | }  | 
                                                        
| 1333 | 1333 | return $bin;  | 
                                                        
| 1334 | 1334 | }  | 
                                                        
@@ -1341,9 +1341,9 @@ discard block  | 
                                                    ||
| 1341 | 1341 | */  | 
                                                        
| 1342 | 1342 | function numero_semaine($time)  | 
                                                        
| 1343 | 1343 |  {
 | 
                                                        
| 1344 | -    $stime = strftime('%Y-%m-%d',$time);
 | 
                                                        |
| 1344 | +    $stime = strftime('%Y-%m-%d', $time);
 | 
                                                        |
| 1345 | 1345 | |
| 1346 | -    if (preg_match('/^([0-9]+)\-([0-9]+)\-([0-9]+)\s?([0-9]+)?:?([0-9]+)?/i',$stime,$reg))
 | 
                                                        |
| 1346 | +    if (preg_match('/^([0-9]+)\-([0-9]+)\-([0-9]+)\s?([0-9]+)?:?([0-9]+)?/i', $stime, $reg))
 | 
                                                        |
| 1347 | 1347 |      {
 | 
                                                        
| 1348 | 1348 | // Date est au format 'YYYY-MM-DD' ou 'YYYY-MM-DD HH:MM:SS'  | 
                                                        
| 1349 | 1349 | $annee = $reg[1];  | 
                                                        
@@ -1359,47 +1359,47 @@ discard block  | 
                                                    ||
| 1359 | 1359 | */  | 
                                                        
| 1360 | 1360 | |
| 1361 | 1361 | // Definition du Jeudi de la semaine  | 
                                                        
| 1362 | -    if (date("w",mktime(12,0,0,$mois,$jour,$annee))==0) // Dimanche
 | 
                                                        |
| 1363 | - $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-3*24*60*60;  | 
                                                        |
| 1364 | -    else if (date("w",mktime(12,0,0,$mois,$jour,$annee))<4) // du Lundi au Mercredi
 | 
                                                        |
| 1365 | -    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)+(4-date("w",mktime(12,0,0,$mois,$jour,$annee)))*24*60*60;
 | 
                                                        |
| 1366 | -    else if (date("w",mktime(12,0,0,$mois,$jour,$annee))>4) // du Vendredi au Samedi
 | 
                                                        |
| 1367 | -    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-(date("w",mktime(12,0,0,$mois,$jour,$annee))-4)*24*60*60;
 | 
                                                        |
| 1362 | +    if (date("w", mktime(12, 0, 0, $mois, $jour, $annee)) == 0) // Dimanche
 | 
                                                        |
| 1363 | + $jeudiSemaine = mktime(12, 0, 0, $mois, $jour, $annee) - 3 * 24 * 60 * 60;  | 
                                                        |
| 1364 | +    else if (date("w", mktime(12, 0, 0, $mois, $jour, $annee)) < 4) // du Lundi au Mercredi
 | 
                                                        |
| 1365 | +    $jeudiSemaine = mktime(12, 0, 0, $mois, $jour, $annee) + (4 - date("w", mktime(12, 0, 0, $mois, $jour, $annee))) * 24 * 60 * 60;
 | 
                                                        |
| 1366 | +    else if (date("w", mktime(12, 0, 0, $mois, $jour, $annee)) > 4) // du Vendredi au Samedi
 | 
                                                        |
| 1367 | +    $jeudiSemaine = mktime(12, 0, 0, $mois, $jour, $annee) - (date("w", mktime(12, 0, 0, $mois, $jour, $annee)) - 4) * 24 * 60 * 60;
 | 
                                                        |
| 1368 | 1368 | else // Jeudi  | 
                                                        
| 1369 | - $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee);  | 
                                                        |
| 1369 | + $jeudiSemaine = mktime(12, 0, 0, $mois, $jour, $annee);  | 
                                                        |
| 1370 | 1370 | |
| 1371 | 1371 | // Definition du premier Jeudi de l'annee  | 
                                                        
| 1372 | -    if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==0) // Dimanche
 | 
                                                        |
| 1372 | +    if (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) == 0) // Dimanche
 | 
                                                        |
| 1373 | 1373 |      {
 | 
                                                        
| 1374 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+4*24*60*60;
 | 
                                                        |
| 1374 | +        $premierJeudiAnnee = mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine)) + 4 * 24 * 60 * 60;
 | 
                                                        |
| 1375 | 1375 | }  | 
                                                        
| 1376 | -    else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))<4) // du Lundi au Mercredi
 | 
                                                        |
| 1376 | +    else if (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) < 4) // du Lundi au Mercredi
 | 
                                                        |
| 1377 | 1377 |      {
 | 
                                                        
| 1378 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(4-date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine))))*24*60*60;
 | 
                                                        |
| 1378 | +        $premierJeudiAnnee = mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine)) + (4 - date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine)))) * 24 * 60 * 60;
 | 
                                                        |
| 1379 | 1379 | }  | 
                                                        
| 1380 | -    else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))>4) // du Vendredi au Samedi
 | 
                                                        |
| 1380 | +    else if (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) > 4) // du Vendredi au Samedi
 | 
                                                        |
| 1381 | 1381 |      {
 | 
                                                        
| 1382 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(7-(date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))-4))*24*60*60;
 | 
                                                        |
| 1382 | +        $premierJeudiAnnee = mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine)) + (7 - (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) - 4)) * 24 * 60 * 60;
 | 
                                                        |
| 1383 | 1383 | }  | 
                                                        
| 1384 | 1384 | else // Jeudi  | 
                                                        
| 1385 | 1385 |      {
 | 
                                                        
| 1386 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine));
 | 
                                                        |
| 1386 | +        $premierJeudiAnnee = mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine));
 | 
                                                        |
| 1387 | 1387 | }  | 
                                                        
| 1388 | 1388 | |
| 1389 | 1389 | // Definition du numero de semaine: nb de jours entre "premier Jeudi de l'annee" et "Jeudi de la semaine";  | 
                                                        
| 1390 | - $numeroSemaine = (  | 
                                                        |
| 1390 | + $numeroSemaine = (  | 
                                                        |
| 1391 | 1391 | (  | 
                                                        
| 1392 | -    date("z",mktime(12,0,0,date("m",$jeudiSemaine),date("d",$jeudiSemaine),date("Y",$jeudiSemaine)))
 | 
                                                        |
| 1392 | +    date("z", mktime(12, 0, 0, date("m", $jeudiSemaine), date("d", $jeudiSemaine), date("Y", $jeudiSemaine)))
 | 
                                                        |
| 1393 | 1393 | -  | 
                                                        
| 1394 | -    date("z",mktime(12,0,0,date("m",$premierJeudiAnnee),date("d",$premierJeudiAnnee),date("Y",$premierJeudiAnnee)))
 | 
                                                        |
| 1394 | +    date("z", mktime(12, 0, 0, date("m", $premierJeudiAnnee), date("d", $premierJeudiAnnee), date("Y", $premierJeudiAnnee)))
 | 
                                                        |
| 1395 | 1395 | ) / 7  | 
                                                        
| 1396 | 1396 | ) + 1;  | 
                                                        
| 1397 | 1397 | |
| 1398 | 1398 | // Cas particulier de la semaine 53  | 
                                                        
| 1399 | - if ($numeroSemaine==53)  | 
                                                        |
| 1399 | + if ($numeroSemaine == 53)  | 
                                                        |
| 1400 | 1400 |      {
 | 
                                                        
| 1401 | 1401 | // Les annees qui commence un Jeudi et les annees bissextiles commencant un Mercredi en possede 53  | 
                                                        
| 1402 | -        if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==4 || (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==3 && date("z",mktime(12,0,0,12,31,date("Y",$jeudiSemaine)))==365))
 | 
                                                        |
| 1402 | +        if (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) == 4 || (date("w", mktime(12, 0, 0, 1, 1, date("Y", $jeudiSemaine))) == 3 && date("z", mktime(12, 0, 0, 12, 31, date("Y", $jeudiSemaine))) == 365))
 | 
                                                        |
| 1403 | 1403 |          {
 | 
                                                        
| 1404 | 1404 | $numeroSemaine = 53;  | 
                                                        
| 1405 | 1405 | }  | 
                                                        
@@ -1411,7 +1411,7 @@ discard block  | 
                                                    ||
| 1411 | 1411 | |
| 1412 | 1412 |      //echo $jour."-".$mois."-".$annee." (".date("d-m-Y",$premierJeudiAnnee)." - ".date("d-m-Y",$jeudiSemaine).") -> ".$numeroSemaine."<BR>";
 | 
                                                        
| 1413 | 1413 | |
| 1414 | -    return sprintf("%02d",$numeroSemaine);
 | 
                                                        |
| 1414 | +    return sprintf("%02d", $numeroSemaine);
 | 
                                                        |
| 1415 | 1415 | }  | 
                                                        
| 1416 | 1416 | |
| 1417 | 1417 | /**  | 
                                                        
@@ -1422,26 +1422,26 @@ discard block  | 
                                                    ||
| 1422 | 1422 | * @param int $to_unit Nouvelle unite en puissance de 10  | 
                                                        
| 1423 | 1423 | * @return float Masse convertie  | 
                                                        
| 1424 | 1424 | */  | 
                                                        
| 1425 | -function weight_convert($weight,&$from_unit,$to_unit)  | 
                                                        |
| 1425 | +function weight_convert($weight, &$from_unit, $to_unit)  | 
                                                        |
| 1426 | 1426 |  {
 | 
                                                        
| 1427 | 1427 | /* Pour convertire 320 gr en Kg appeler  | 
                                                        
| 1428 | 1428 | * $f = -3  | 
                                                        
| 1429 | 1429 | * weigh_convert(320, $f, 0) retournera 0.32  | 
                                                        
| 1430 | 1430 | *  | 
                                                        
| 1431 | 1431 | */  | 
                                                        
| 1432 | - while ($from_unit <> $to_unit)  | 
                                                        |
| 1432 | + while ($from_unit <> $to_unit)  | 
                                                        |
| 1433 | 1433 |      {
 | 
                                                        
| 1434 | 1434 | if ($from_unit > $to_unit)  | 
                                                        
| 1435 | 1435 |          {
 | 
                                                        
| 1436 | 1436 | $weight = $weight * 10;  | 
                                                        
| 1437 | 1437 | $from_unit = $from_unit - 1;  | 
                                                        
| 1438 | - $weight = weight_convert($weight,$from_unit, $to_unit);  | 
                                                        |
| 1438 | + $weight = weight_convert($weight, $from_unit, $to_unit);  | 
                                                        |
| 1439 | 1439 | }  | 
                                                        
| 1440 | 1440 | if ($from_unit < $to_unit)  | 
                                                        
| 1441 | 1441 |          {
 | 
                                                        
| 1442 | 1442 | $weight = $weight / 10;  | 
                                                        
| 1443 | 1443 | $from_unit = $from_unit + 1;  | 
                                                        
| 1444 | - $weight = weight_convert($weight,$from_unit, $to_unit);  | 
                                                        |
| 1444 | + $weight = weight_convert($weight, $from_unit, $to_unit);  | 
                                                        |
| 1445 | 1445 | }  | 
                                                        
| 1446 | 1446 | }  | 
                                                        
| 1447 | 1447 | |
@@ -1468,21 +1468,21 @@ discard block  | 
                                                    ||
| 1468 | 1468 | |
| 1469 | 1469 | // We remove old parameters for all keys in $tab  | 
                                                        
| 1470 | 1470 | $sql = "DELETE FROM ".MAIN_DB_PREFIX."user_param";  | 
                                                        
| 1471 | - $sql.= " WHERE fk_user = ".$user->id;  | 
                                                        |
| 1472 | - $sql.= " AND entity = ".$conf->entity;  | 
                                                        |
| 1473 | -    $sql.= " AND param in (";
 | 
                                                        |
| 1474 | - $i=0;  | 
                                                        |
| 1471 | + $sql .= " WHERE fk_user = ".$user->id;  | 
                                                        |
| 1472 | + $sql .= " AND entity = ".$conf->entity;  | 
                                                        |
| 1473 | +    $sql .= " AND param in (";
 | 
                                                        |
| 1474 | + $i = 0;  | 
                                                        |
| 1475 | 1475 | foreach ($tab as $key => $value)  | 
                                                        
| 1476 | 1476 |      {
 | 
                                                        
| 1477 | - if ($i > 0) $sql.=',';  | 
                                                        |
| 1478 | - $sql.="'".$db->escape($key)."'";  | 
                                                        |
| 1477 | + if ($i > 0) $sql .= ',';  | 
                                                        |
| 1478 | + $sql .= "'".$db->escape($key)."'";  | 
                                                        |
| 1479 | 1479 | $i++;  | 
                                                        
| 1480 | 1480 | }  | 
                                                        
| 1481 | - $sql.= ")";  | 
                                                        |
| 1481 | + $sql .= ")";  | 
                                                        |
| 1482 | 1482 |      dol_syslog("functions2.lib::dol_set_user_param", LOG_DEBUG);
 | 
                                                        
| 1483 | 1483 | |
| 1484 | - $resql=$db->query($sql);  | 
                                                        |
| 1485 | - if (! $resql)  | 
                                                        |
| 1484 | + $resql = $db->query($sql);  | 
                                                        |
| 1485 | + if (!$resql)  | 
                                                        |
| 1486 | 1486 |      {
 | 
                                                        
| 1487 | 1487 | dol_print_error($db);  | 
                                                        
| 1488 | 1488 | $db->rollback();  | 
                                                        
@@ -1495,12 +1495,12 @@ discard block  | 
                                                    ||
| 1495 | 1495 | if ($value)  | 
                                                        
| 1496 | 1496 |          {
 | 
                                                        
| 1497 | 1497 | $sql = "INSERT INTO ".MAIN_DB_PREFIX."user_param(fk_user,entity,param,value)";  | 
                                                        
| 1498 | -            $sql.= " VALUES (".$user->id.",".$conf->entity.",";
 | 
                                                        |
| 1499 | - $sql.= " '".$db->escape($key)."','".$db->escape($value)."')";  | 
                                                        |
| 1498 | +            $sql .= " VALUES (".$user->id.",".$conf->entity.",";
 | 
                                                        |
| 1499 | + $sql .= " '".$db->escape($key)."','".$db->escape($value)."')";  | 
                                                        |
| 1500 | 1500 | |
| 1501 | 1501 |              dol_syslog("functions2.lib::dol_set_user_param", LOG_DEBUG);
 | 
                                                        
| 1502 | - $result=$db->query($sql);  | 
                                                        |
| 1503 | - if (! $result)  | 
                                                        |
| 1502 | + $result = $db->query($sql);  | 
                                                        |
| 1503 | + if (!$result)  | 
                                                        |
| 1504 | 1504 |              {
 | 
                                                        
| 1505 | 1505 | dol_print_error($db);  | 
                                                        
| 1506 | 1506 | $db->rollback();  | 
                                                        
@@ -1526,7 +1526,7 @@ discard block  | 
                                                    ||
| 1526 | 1526 | * @param Translate $langs Output language  | 
                                                        
| 1527 | 1527 | * @return string Formated reduction  | 
                                                        
| 1528 | 1528 | */  | 
                                                        
| 1529 | -function dol_print_reduction($reduction,$langs)  | 
                                                        |
| 1529 | +function dol_print_reduction($reduction, $langs)  | 
                                                        |
| 1530 | 1530 |  {
 | 
                                                        
| 1531 | 1531 | $string = '';  | 
                                                        
| 1532 | 1532 | if ($reduction == 100)  | 
                                                        
@@ -1535,7 +1535,7 @@ discard block  | 
                                                    ||
| 1535 | 1535 | }  | 
                                                        
| 1536 | 1536 | else  | 
                                                        
| 1537 | 1537 |      {
 | 
                                                        
| 1538 | - $string = vatrate($reduction,true);  | 
                                                        |
| 1538 | + $string = vatrate($reduction, true);  | 
                                                        |
| 1539 | 1539 | }  | 
                                                        
| 1540 | 1540 | |
| 1541 | 1541 | return $string;  | 
                                                        
@@ -1549,7 +1549,7 @@ discard block  | 
                                                    ||
| 1549 | 1549 | */  | 
                                                        
| 1550 | 1550 | function version_os()  | 
                                                        
| 1551 | 1551 |  {
 | 
                                                        
| 1552 | - $osversion=php_uname();  | 
                                                        |
| 1552 | + $osversion = php_uname();  | 
                                                        |
| 1553 | 1553 | return $osversion;  | 
                                                        
| 1554 | 1554 | }  | 
                                                        
| 1555 | 1555 | |
@@ -1593,18 +1593,18 @@ discard block  | 
                                                    ||
| 1593 | 1593 | * @param int $maxfilenamelength Max length of value to show  | 
                                                        
| 1594 | 1594 | * @return mixed 0 if no module is activated, or array(key=>label). For modules that need directory scan, key is completed with ":filename".  | 
                                                        
| 1595 | 1595 | */  | 
                                                        
| 1596 | -function getListOfModels($db,$type,$maxfilenamelength=0)  | 
                                                        |
| 1596 | +function getListOfModels($db, $type, $maxfilenamelength = 0)  | 
                                                        |
| 1597 | 1597 |  {
 | 
                                                        
| 1598 | - global $conf,$langs;  | 
                                                        |
| 1599 | - $liste=array();  | 
                                                        |
| 1600 | - $found=0;  | 
                                                        |
| 1601 | - $dirtoscan='';  | 
                                                        |
| 1598 | + global $conf, $langs;  | 
                                                        |
| 1599 | + $liste = array();  | 
                                                        |
| 1600 | + $found = 0;  | 
                                                        |
| 1601 | + $dirtoscan = '';  | 
                                                        |
| 1602 | 1602 | |
| 1603 | 1603 | $sql = "SELECT nom as id, nom as lib, libelle as label, description as description";  | 
                                                        
| 1604 | - $sql.= " FROM ".MAIN_DB_PREFIX."document_model";  | 
                                                        |
| 1605 | - $sql.= " WHERE type = '".$type."'";  | 
                                                        |
| 1606 | - $sql.= " AND entity IN (0,".$conf->entity.")";  | 
                                                        |
| 1607 | - $sql.= " ORDER BY description DESC";  | 
                                                        |
| 1604 | + $sql .= " FROM ".MAIN_DB_PREFIX."document_model";  | 
                                                        |
| 1605 | + $sql .= " WHERE type = '".$type."'";  | 
                                                        |
| 1606 | + $sql .= " AND entity IN (0,".$conf->entity.")";  | 
                                                        |
| 1607 | + $sql .= " ORDER BY description DESC";  | 
                                                        |
| 1608 | 1608 | |
| 1609 | 1609 |      dol_syslog('/core/lib/function2.lib.php::getListOfModels', LOG_DEBUG);
 | 
                                                        
| 1610 | 1610 | $resql = $db->query($sql);  | 
                                                        
@@ -1614,48 +1614,48 @@ discard block  | 
                                                    ||
| 1614 | 1614 | $i = 0;  | 
                                                        
| 1615 | 1615 | while ($i < $num)  | 
                                                        
| 1616 | 1616 |          {
 | 
                                                        
| 1617 | - $found=1;  | 
                                                        |
| 1617 | + $found = 1;  | 
                                                        |
| 1618 | 1618 | |
| 1619 | 1619 | $obj = $db->fetch_object($resql);  | 
                                                        
| 1620 | 1620 | |
| 1621 | 1621 | // If this generation module needs to scan a directory, then description field is filled  | 
                                                        
| 1622 | 1622 | // with the constant that contains list of directories to scan (COMPANY_ADDON_PDF_ODT_PATH, ...).  | 
                                                        
| 1623 | - if (! empty($obj->description)) // A list of directories to scan is defined  | 
                                                        |
| 1623 | + if (!empty($obj->description)) // A list of directories to scan is defined  | 
                                                        |
| 1624 | 1624 |              {
 | 
                                                        
| 1625 | 1625 | include_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';  | 
                                                        
| 1626 | 1626 | |
| 1627 | - $const=$obj->description;  | 
                                                        |
| 1627 | + $const = $obj->description;  | 
                                                        |
| 1628 | 1628 |                  //irtoscan.=($dirtoscan?',':'').preg_replace('/[\r\n]+/',',',trim($conf->global->$const));
 | 
                                                        
| 1629 | -                $dirtoscan= preg_replace('/[\r\n]+/',',',trim($conf->global->$const));
 | 
                                                        |
| 1629 | +                $dirtoscan = preg_replace('/[\r\n]+/', ',', trim($conf->global->$const));
 | 
                                                        |
| 1630 | 1630 | |
| 1631 | - $listoffiles=array();  | 
                                                        |
| 1631 | + $listoffiles = array();  | 
                                                        |
| 1632 | 1632 | |
| 1633 | 1633 | // Now we add models found in directories scanned  | 
                                                        
| 1634 | -                $listofdir=explode(',',$dirtoscan);
 | 
                                                        |
| 1635 | - foreach($listofdir as $key=>$tmpdir)  | 
                                                        |
| 1634 | +                $listofdir = explode(',', $dirtoscan);
 | 
                                                        |
| 1635 | + foreach ($listofdir as $key=>$tmpdir)  | 
                                                        |
| 1636 | 1636 |                  {
 | 
                                                        
| 1637 | - $tmpdir=trim($tmpdir);  | 
                                                        |
| 1638 | -                    $tmpdir=preg_replace('/DOL_DATA_ROOT/',DOL_DATA_ROOT,$tmpdir);
 | 
                                                        |
| 1639 | -                    if (! $tmpdir) { unset($listofdir[$key]); continue; }
 | 
                                                        |
| 1637 | + $tmpdir = trim($tmpdir);  | 
                                                        |
| 1638 | +                    $tmpdir = preg_replace('/DOL_DATA_ROOT/', DOL_DATA_ROOT, $tmpdir);
 | 
                                                        |
| 1639 | +                    if (!$tmpdir) { unset($listofdir[$key]); continue; }
 | 
                                                        |
| 1640 | 1640 | if (is_dir($tmpdir))  | 
                                                        
| 1641 | 1641 |                      {
 | 
                                                        
| 1642 | 1642 | // all type of template is allowed  | 
                                                        
| 1643 | - $tmpfiles=dol_dir_list($tmpdir, 'files', 0, '', '', 'name', SORT_ASC, 0);  | 
                                                        |
| 1644 | - if (count($tmpfiles)) $listoffiles=array_merge($listoffiles,$tmpfiles);  | 
                                                        |
| 1643 | + $tmpfiles = dol_dir_list($tmpdir, 'files', 0, '', '', 'name', SORT_ASC, 0);  | 
                                                        |
| 1644 | + if (count($tmpfiles)) $listoffiles = array_merge($listoffiles, $tmpfiles);  | 
                                                        |
| 1645 | 1645 | }  | 
                                                        
| 1646 | 1646 | }  | 
                                                        
| 1647 | 1647 | |
| 1648 | 1648 | if (count($listoffiles))  | 
                                                        
| 1649 | 1649 |                  {
 | 
                                                        
| 1650 | - foreach($listoffiles as $record)  | 
                                                        |
| 1650 | + foreach ($listoffiles as $record)  | 
                                                        |
| 1651 | 1651 |                      {
 | 
                                                        
| 1652 | - $max=($maxfilenamelength?$maxfilenamelength:28);  | 
                                                        |
| 1653 | - $liste[$obj->id.':'.$record['fullname']]=dol_trunc($record['name'],$max,'middle');  | 
                                                        |
| 1652 | + $max = ($maxfilenamelength ? $maxfilenamelength : 28);  | 
                                                        |
| 1653 | + $liste[$obj->id.':'.$record['fullname']] = dol_trunc($record['name'], $max, 'middle');  | 
                                                        |
| 1654 | 1654 | }  | 
                                                        
| 1655 | 1655 | }  | 
                                                        
| 1656 | 1656 | else  | 
                                                        
| 1657 | 1657 |                  {
 | 
                                                        
| 1658 | -                    $liste[0]=$obj->label.': '.$langs->trans("None");
 | 
                                                        |
| 1658 | +                    $liste[0] = $obj->label.': '.$langs->trans("None");
 | 
                                                        |
| 1659 | 1659 | }  | 
                                                        
| 1660 | 1660 | }  | 
                                                        
| 1661 | 1661 | else  | 
                                                        
@@ -1664,14 +1664,14 @@ discard block  | 
                                                    ||
| 1664 | 1664 |                  {
 | 
                                                        
| 1665 | 1665 | global $_Avery_Labels;  | 
                                                        
| 1666 | 1666 | include_once DOL_DOCUMENT_ROOT.'/core/lib/format_cards.lib.php';  | 
                                                        
| 1667 | - foreach($_Avery_Labels as $key => $val)  | 
                                                        |
| 1667 | + foreach ($_Avery_Labels as $key => $val)  | 
                                                        |
| 1668 | 1668 |                      {
 | 
                                                        
| 1669 | - $liste[$obj->id.':'.$key]=($obj->label?$obj->label:$obj->lib).' '.$val['name'];  | 
                                                        |
| 1669 | + $liste[$obj->id.':'.$key] = ($obj->label ? $obj->label : $obj->lib).' '.$val['name'];  | 
                                                        |
| 1670 | 1670 | }  | 
                                                        
| 1671 | 1671 | }  | 
                                                        
| 1672 | 1672 | else // Common usage  | 
                                                        
| 1673 | 1673 |                  {
 | 
                                                        
| 1674 | - $liste[$obj->id]=$obj->label?$obj->label:$obj->lib;  | 
                                                        |
| 1674 | + $liste[$obj->id] = $obj->label ? $obj->label : $obj->lib;  | 
                                                        |
| 1675 | 1675 | }  | 
                                                        
| 1676 | 1676 | }  | 
                                                        
| 1677 | 1677 | $i++;  | 
                                                        
@@ -1700,10 +1700,10 @@ discard block  | 
                                                    ||
| 1700 | 1700 |  	if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
 | 
                                                        
| 1701 | 1701 | |
| 1702 | 1702 | // Then we test if it is a private range  | 
                                                        
| 1703 | - if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE)) return 2;  | 
                                                        |
| 1703 | + if (!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE)) return 2;  | 
                                                        |
| 1704 | 1704 | |
| 1705 | 1705 | // Then we test if it is a reserved range  | 
                                                        
| 1706 | - if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) return 0;  | 
                                                        |
| 1706 | + if (!filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) return 0;  | 
                                                        |
| 1707 | 1707 | |
| 1708 | 1708 | return 1;  | 
                                                        
| 1709 | 1709 | }  | 
                                                        
@@ -1718,12 +1718,12 @@ discard block  | 
                                                    ||
| 1718 | 1718 | * @param string $firstname Firstname  | 
                                                        
| 1719 | 1719 | * @return string Login  | 
                                                        
| 1720 | 1720 | */  | 
                                                        
| 1721 | -function dol_buildlogin($lastname,$firstname)  | 
                                                        |
| 1721 | +function dol_buildlogin($lastname, $firstname)  | 
                                                        |
| 1722 | 1722 |  {
 | 
                                                        
| 1723 | - $login=strtolower(dol_string_unaccent($firstname));  | 
                                                        |
| 1724 | - $login.=($login?'.':'');  | 
                                                        |
| 1725 | - $login.=strtolower(dol_string_unaccent($lastname));  | 
                                                        |
| 1726 | - $login=dol_string_nospecial($login,''); // For special names  | 
                                                        |
| 1723 | + $login = strtolower(dol_string_unaccent($firstname));  | 
                                                        |
| 1724 | + $login .= ($login ? '.' : '');  | 
                                                        |
| 1725 | + $login .= strtolower(dol_string_unaccent($lastname));  | 
                                                        |
| 1726 | + $login = dol_string_nospecial($login, ''); // For special names  | 
                                                        |
| 1727 | 1727 | return $login;  | 
                                                        
| 1728 | 1728 | }  | 
                                                        
| 1729 | 1729 | |
@@ -1736,18 +1736,18 @@ discard block  | 
                                                    ||
| 1736 | 1736 |  {
 | 
                                                        
| 1737 | 1737 | global $conf;  | 
                                                        
| 1738 | 1738 | |
| 1739 | - $params=array();  | 
                                                        |
| 1740 | - $proxyuse =(empty($conf->global->MAIN_PROXY_USE)?false:true);  | 
                                                        |
| 1741 | - $proxyhost=(empty($conf->global->MAIN_PROXY_USE)?false:$conf->global->MAIN_PROXY_HOST);  | 
                                                        |
| 1742 | - $proxyport=(empty($conf->global->MAIN_PROXY_USE)?false:$conf->global->MAIN_PROXY_PORT);  | 
                                                        |
| 1743 | - $proxyuser=(empty($conf->global->MAIN_PROXY_USE)?false:$conf->global->MAIN_PROXY_USER);  | 
                                                        |
| 1744 | - $proxypass=(empty($conf->global->MAIN_PROXY_USE)?false:$conf->global->MAIN_PROXY_PASS);  | 
                                                        |
| 1745 | - $timeout =(empty($conf->global->MAIN_USE_CONNECT_TIMEOUT)?10:$conf->global->MAIN_USE_CONNECT_TIMEOUT); // Connection timeout  | 
                                                        |
| 1746 | - $response_timeout=(empty($conf->global->MAIN_USE_RESPONSE_TIMEOUT)?30:$conf->global->MAIN_USE_RESPONSE_TIMEOUT); // Response timeout  | 
                                                        |
| 1739 | + $params = array();  | 
                                                        |
| 1740 | + $proxyuse = (empty($conf->global->MAIN_PROXY_USE) ?false:true);  | 
                                                        |
| 1741 | + $proxyhost = (empty($conf->global->MAIN_PROXY_USE) ?false:$conf->global->MAIN_PROXY_HOST);  | 
                                                        |
| 1742 | + $proxyport = (empty($conf->global->MAIN_PROXY_USE) ?false:$conf->global->MAIN_PROXY_PORT);  | 
                                                        |
| 1743 | + $proxyuser = (empty($conf->global->MAIN_PROXY_USE) ?false:$conf->global->MAIN_PROXY_USER);  | 
                                                        |
| 1744 | + $proxypass = (empty($conf->global->MAIN_PROXY_USE) ?false:$conf->global->MAIN_PROXY_PASS);  | 
                                                        |
| 1745 | + $timeout = (empty($conf->global->MAIN_USE_CONNECT_TIMEOUT) ? 10 : $conf->global->MAIN_USE_CONNECT_TIMEOUT); // Connection timeout  | 
                                                        |
| 1746 | + $response_timeout = (empty($conf->global->MAIN_USE_RESPONSE_TIMEOUT) ? 30 : $conf->global->MAIN_USE_RESPONSE_TIMEOUT); // Response timeout  | 
                                                        |
| 1747 | 1747 |      //print extension_loaded('soap');
 | 
                                                        
| 1748 | 1748 | if ($proxyuse)  | 
                                                        
| 1749 | 1749 |      {
 | 
                                                        
| 1750 | -        $params=array('connection_timeout'=>$timeout,
 | 
                                                        |
| 1750 | +        $params = array('connection_timeout'=>$timeout,
 | 
                                                        |
| 1751 | 1751 | 'response_timeout'=>$response_timeout,  | 
                                                        
| 1752 | 1752 | 'proxy_use' => 1,  | 
                                                        
| 1753 | 1753 | 'proxy_host' => $proxyhost,  | 
                                                        
@@ -1759,7 +1759,7 @@ discard block  | 
                                                    ||
| 1759 | 1759 | }  | 
                                                        
| 1760 | 1760 | else  | 
                                                        
| 1761 | 1761 |      {
 | 
                                                        
| 1762 | -        $params=array('connection_timeout'=>$timeout,
 | 
                                                        |
| 1762 | +        $params = array('connection_timeout'=>$timeout,
 | 
                                                        |
| 1763 | 1763 | 'response_timeout'=>$response_timeout,  | 
                                                        
| 1764 | 1764 | 'proxy_use' => 0,  | 
                                                        
| 1765 | 1765 | 'proxy_host' => false,  | 
                                                        
@@ -1782,15 +1782,15 @@ discard block  | 
                                                    ||
| 1782 | 1782 | * @param string $option More options  | 
                                                        
| 1783 | 1783 | * @return string URL of link to object id/type  | 
                                                        
| 1784 | 1784 | */  | 
                                                        
| 1785 | -function dolGetElementUrl($objectid,$objecttype,$withpicto=0,$option='')  | 
                                                        |
| 1785 | +function dolGetElementUrl($objectid, $objecttype, $withpicto = 0, $option = '')  | 
                                                        |
| 1786 | 1786 |  {
 | 
                                                        
| 1787 | 1787 | global $db, $conf, $langs;  | 
                                                        
| 1788 | 1788 | |
| 1789 | - $ret='';  | 
                                                        |
| 1789 | + $ret = '';  | 
                                                        |
| 1790 | 1790 | |
| 1791 | 1791 | // Parse element/subelement (ex: project_task)  | 
                                                        
| 1792 | 1792 | $module = $element = $subelement = $objecttype;  | 
                                                        
| 1793 | -	if (preg_match('/^([^_]+)_([^_]+)/i',$objecttype,$regs))
 | 
                                                        |
| 1793 | +	if (preg_match('/^([^_]+)_([^_]+)/i', $objecttype, $regs))
 | 
                                                        |
| 1794 | 1794 |  	{
 | 
                                                        
| 1795 | 1795 | $module = $element = $regs[1];  | 
                                                        
| 1796 | 1796 | $subelement = $regs[2];  | 
                                                        
@@ -1801,18 +1801,18 @@ discard block  | 
                                                    ||
| 1801 | 1801 | // To work with non standard path  | 
                                                        
| 1802 | 1802 |  	if ($objecttype == 'facture' || $objecttype == 'invoice') {
 | 
                                                        
| 1803 | 1803 | $classpath = 'compta/facture/class';  | 
                                                        
| 1804 | - $module='facture';  | 
                                                        |
| 1805 | - $subelement='facture';  | 
                                                        |
| 1804 | + $module = 'facture';  | 
                                                        |
| 1805 | + $subelement = 'facture';  | 
                                                        |
| 1806 | 1806 | }  | 
                                                        
| 1807 | 1807 |  	if ($objecttype == 'commande' || $objecttype == 'order') {
 | 
                                                        
| 1808 | 1808 | $classpath = 'commande/class';  | 
                                                        
| 1809 | - $module='commande';  | 
                                                        |
| 1810 | - $subelement='commande';  | 
                                                        |
| 1809 | + $module = 'commande';  | 
                                                        |
| 1810 | + $subelement = 'commande';  | 
                                                        |
| 1811 | 1811 | }  | 
                                                        
| 1812 | -	if ($objecttype == 'propal')  {
 | 
                                                        |
| 1812 | +	if ($objecttype == 'propal') {
 | 
                                                        |
| 1813 | 1813 | $classpath = 'comm/propal/class';  | 
                                                        
| 1814 | 1814 | }  | 
                                                        
| 1815 | -	if ($objecttype == 'supplier_proposal')  {
 | 
                                                        |
| 1815 | +	if ($objecttype == 'supplier_proposal') {
 | 
                                                        |
| 1816 | 1816 | $classpath = 'supplier_proposal/class';  | 
                                                        
| 1817 | 1817 | }  | 
                                                        
| 1818 | 1818 |  	if ($objecttype == 'shipping') {
 | 
                                                        
@@ -1827,33 +1827,33 @@ discard block  | 
                                                    ||
| 1827 | 1827 | }  | 
                                                        
| 1828 | 1828 |  	if ($objecttype == 'contract') {
 | 
                                                        
| 1829 | 1829 | $classpath = 'contrat/class';  | 
                                                        
| 1830 | - $module='contrat';  | 
                                                        |
| 1831 | - $subelement='contrat';  | 
                                                        |
| 1830 | + $module = 'contrat';  | 
                                                        |
| 1831 | + $subelement = 'contrat';  | 
                                                        |
| 1832 | 1832 | }  | 
                                                        
| 1833 | 1833 |  	if ($objecttype == 'member') {
 | 
                                                        
| 1834 | 1834 | $classpath = 'adherents/class';  | 
                                                        
| 1835 | - $module='adherent';  | 
                                                        |
| 1836 | - $subelement='adherent';  | 
                                                        |
| 1835 | + $module = 'adherent';  | 
                                                        |
| 1836 | + $subelement = 'adherent';  | 
                                                        |
| 1837 | 1837 | }  | 
                                                        
| 1838 | 1838 |  	if ($objecttype == 'cabinetmed_cons') {
 | 
                                                        
| 1839 | 1839 | $classpath = 'cabinetmed/class';  | 
                                                        
| 1840 | - $module='cabinetmed';  | 
                                                        |
| 1841 | - $subelement='cabinetmedcons';  | 
                                                        |
| 1840 | + $module = 'cabinetmed';  | 
                                                        |
| 1841 | + $subelement = 'cabinetmedcons';  | 
                                                        |
| 1842 | 1842 | }  | 
                                                        
| 1843 | 1843 |  	if ($objecttype == 'fichinter') {
 | 
                                                        
| 1844 | 1844 | $classpath = 'fichinter/class';  | 
                                                        
| 1845 | - $module='ficheinter';  | 
                                                        |
| 1846 | - $subelement='fichinter';  | 
                                                        |
| 1845 | + $module = 'ficheinter';  | 
                                                        |
| 1846 | + $subelement = 'fichinter';  | 
                                                        |
| 1847 | 1847 | }  | 
                                                        
| 1848 | 1848 |  	if ($objecttype == 'task') {
 | 
                                                        
| 1849 | 1849 | $classpath = 'projet/class';  | 
                                                        
| 1850 | - $module='projet';  | 
                                                        |
| 1851 | - $subelement='task';  | 
                                                        |
| 1850 | + $module = 'projet';  | 
                                                        |
| 1851 | + $subelement = 'task';  | 
                                                        |
| 1852 | 1852 | }  | 
                                                        
| 1853 | 1853 |  	if ($objecttype == 'stock') {
 | 
                                                        
| 1854 | 1854 | $classpath = 'product/stock/class';  | 
                                                        
| 1855 | - $module='stock';  | 
                                                        |
| 1856 | - $subelement='stock';  | 
                                                        |
| 1855 | + $module = 'stock';  | 
                                                        |
| 1856 | + $subelement = 'stock';  | 
                                                        |
| 1857 | 1857 | }  | 
                                                        
| 1858 | 1858 | |
| 1859 | 1859 | //print "objecttype=".$objecttype." module=".$module." subelement=".$subelement;  | 
                                                        
@@ -1861,34 +1861,34 @@ discard block  | 
                                                    ||
| 1861 | 1861 | $classfile = strtolower($subelement); $classname = ucfirst($subelement);  | 
                                                        
| 1862 | 1862 |  	if ($objecttype == 'invoice_supplier') {
 | 
                                                        
| 1863 | 1863 | $classfile = 'fournisseur.facture';  | 
                                                        
| 1864 | - $classname='FactureFournisseur';  | 
                                                        |
| 1864 | + $classname = 'FactureFournisseur';  | 
                                                        |
| 1865 | 1865 | $classpath = 'fourn/class';  | 
                                                        
| 1866 | - $module='fournisseur';  | 
                                                        |
| 1866 | + $module = 'fournisseur';  | 
                                                        |
| 1867 | 1867 | }  | 
                                                        
| 1868 | -	elseif ($objecttype == 'order_supplier')   {
 | 
                                                        |
| 1868 | +	elseif ($objecttype == 'order_supplier') {
 | 
                                                        |
| 1869 | 1869 | $classfile = 'fournisseur.commande';  | 
                                                        
| 1870 | - $classname='CommandeFournisseur';  | 
                                                        |
| 1870 | + $classname = 'CommandeFournisseur';  | 
                                                        |
| 1871 | 1871 | $classpath = 'fourn/class';  | 
                                                        
| 1872 | - $module='fournisseur';  | 
                                                        |
| 1872 | + $module = 'fournisseur';  | 
                                                        |
| 1873 | 1873 | }  | 
                                                        
| 1874 | -	elseif ($objecttype == 'stock')   {
 | 
                                                        |
| 1874 | +	elseif ($objecttype == 'stock') {
 | 
                                                        |
| 1875 | 1875 | $classpath = 'product/stock/class';  | 
                                                        
| 1876 | - $classfile='entrepot';  | 
                                                        |
| 1877 | - $classname='Entrepot';  | 
                                                        |
| 1876 | + $classfile = 'entrepot';  | 
                                                        |
| 1877 | + $classname = 'Entrepot';  | 
                                                        |
| 1878 | 1878 | }  | 
                                                        
| 1879 | - if (! empty($conf->$module->enabled))  | 
                                                        |
| 1879 | + if (!empty($conf->$module->enabled))  | 
                                                        |
| 1880 | 1880 |  	{
 | 
                                                        
| 1881 | -		$res=dol_include_once('/'.$classpath.'/'.$classfile.'.class.php');
 | 
                                                        |
| 1881 | +		$res = dol_include_once('/'.$classpath.'/'.$classfile.'.class.php');
 | 
                                                        |
| 1882 | 1882 | if ($res)  | 
                                                        
| 1883 | 1883 |  		{
 | 
                                                        
| 1884 | 1884 | if (class_exists($classname))  | 
                                                        
| 1885 | 1885 |  			{
 | 
                                                        
| 1886 | 1886 | $object = new $classname($db);  | 
                                                        
| 1887 | - $res=$object->fetch($objectid);  | 
                                                        |
| 1887 | + $res = $object->fetch($objectid);  | 
                                                        |
| 1888 | 1888 |  				if ($res > 0) {
 | 
                                                        
| 1889 | - $ret=$object->getNomUrl($withpicto,$option);  | 
                                                        |
| 1890 | -				} elseif($res==0) {
 | 
                                                        |
| 1891 | -					$ret=$langs->trans('Deleted');
 | 
                                                        |
| 1889 | + $ret = $object->getNomUrl($withpicto, $option);  | 
                                                        |
| 1890 | +				} elseif ($res == 0) {
 | 
                                                        |
| 1891 | +					$ret = $langs->trans('Deleted');
 | 
                                                        |
| 1892 | 1892 | }  | 
                                                        
| 1893 | 1893 | unset($object);  | 
                                                        
| 1894 | 1894 | }  | 
                                                        
@@ -1909,12 +1909,12 @@ discard block  | 
                                                    ||
| 1909 | 1909 | */  | 
                                                        
| 1910 | 1910 | function cleanCorruptedTree($db, $tabletocleantree, $fieldfkparent)  | 
                                                        
| 1911 | 1911 |  {
 | 
                                                        
| 1912 | - $totalnb=0;  | 
                                                        |
| 1913 | - $listofid=array();  | 
                                                        |
| 1914 | - $listofparentid=array();  | 
                                                        |
| 1912 | + $totalnb = 0;  | 
                                                        |
| 1913 | + $listofid = array();  | 
                                                        |
| 1914 | + $listofparentid = array();  | 
                                                        |
| 1915 | 1915 | |
| 1916 | 1916 | // Get list of all id in array listofid and all parents in array listofparentid  | 
                                                        
| 1917 | - $sql='SELECT rowid, '.$fieldfkparent.' as parent_id FROM '.MAIN_DB_PREFIX.$tabletocleantree;  | 
                                                        |
| 1917 | + $sql = 'SELECT rowid, '.$fieldfkparent.' as parent_id FROM '.MAIN_DB_PREFIX.$tabletocleantree;  | 
                                                        |
| 1918 | 1918 | $resql = $db->query($sql);  | 
                                                        
| 1919 | 1919 | if ($resql)  | 
                                                        
| 1920 | 1920 |  	{
 | 
                                                        
@@ -1923,8 +1923,8 @@ discard block  | 
                                                    ||
| 1923 | 1923 | while ($i < $num)  | 
                                                        
| 1924 | 1924 |  		{
 | 
                                                        
| 1925 | 1925 | $obj = $db->fetch_object($resql);  | 
                                                        
| 1926 | - $listofid[]=$obj->rowid;  | 
                                                        |
| 1927 | - if ($obj->parent_id > 0) $listofparentid[$obj->rowid]=$obj->parent_id;  | 
                                                        |
| 1926 | + $listofid[] = $obj->rowid;  | 
                                                        |
| 1927 | + if ($obj->parent_id > 0) $listofparentid[$obj->rowid] = $obj->parent_id;  | 
                                                        |
| 1928 | 1928 | $i++;  | 
                                                        
| 1929 | 1929 | }  | 
                                                        
| 1930 | 1930 | }  | 
                                                        
@@ -1938,78 +1938,78 @@ discard block  | 
                                                    ||
| 1938 | 1938 | print 'Code requested to clean tree (may be to solve data corruption), so we check/clean orphelins and loops.'."<br>\n";  | 
                                                        
| 1939 | 1939 | |
| 1940 | 1940 | // Check loops on each other  | 
                                                        
| 1941 | - $sql = "UPDATE ".MAIN_DB_PREFIX.$tabletocleantree." SET ".$fieldfkparent." = 0 WHERE ".$fieldfkparent." = rowid"; // So we update only records linked to themself  | 
                                                        |
| 1941 | + $sql = "UPDATE ".MAIN_DB_PREFIX.$tabletocleantree." SET ".$fieldfkparent." = 0 WHERE ".$fieldfkparent." = rowid"; // So we update only records linked to themself  | 
                                                        |
| 1942 | 1942 | $resql = $db->query($sql);  | 
                                                        
| 1943 | 1943 | if ($resql)  | 
                                                        
| 1944 | 1944 |  		{
 | 
                                                        
| 1945 | - $nb=$db->affected_rows($sql);  | 
                                                        |
| 1945 | + $nb = $db->affected_rows($sql);  | 
                                                        |
| 1946 | 1946 | if ($nb > 0)  | 
                                                        
| 1947 | 1947 |  			{
 | 
                                                        
| 1948 | 1948 | print '<br>Some record that were parent of themself were cleaned.';  | 
                                                        
| 1949 | 1949 | }  | 
                                                        
| 1950 | 1950 | |
| 1951 | - $totalnb+=$nb;  | 
                                                        |
| 1951 | + $totalnb += $nb;  | 
                                                        |
| 1952 | 1952 | }  | 
                                                        
| 1953 | 1953 | //else dol_print_error($db);  | 
                                                        
| 1954 | 1954 | |
| 1955 | 1955 | // Check other loops  | 
                                                        
| 1956 | - $listofidtoclean=array();  | 
                                                        |
| 1957 | - foreach($listofparentid as $id => $pid)  | 
                                                        |
| 1956 | + $listofidtoclean = array();  | 
                                                        |
| 1957 | + foreach ($listofparentid as $id => $pid)  | 
                                                        |
| 1958 | 1958 |  		{
 | 
                                                        
| 1959 | 1959 | // Check depth  | 
                                                        
| 1960 | 1960 | //print 'Analyse record id='.$id.' with parent '.$pid.'<br>';  | 
                                                        
| 1961 | 1961 | |
| 1962 | - $cursor=$id; $arrayidparsed=array(); // We start from child $id  | 
                                                        |
| 1962 | + $cursor = $id; $arrayidparsed = array(); // We start from child $id  | 
                                                        |
| 1963 | 1963 | while ($cursor > 0)  | 
                                                        
| 1964 | 1964 |  			{
 | 
                                                        
| 1965 | - $arrayidparsed[$cursor]=1;  | 
                                                        |
| 1965 | + $arrayidparsed[$cursor] = 1;  | 
                                                        |
| 1966 | 1966 | if ($arrayidparsed[$listofparentid[$cursor]]) // We detect a loop. A record with a parent that was already into child  | 
                                                        
| 1967 | 1967 |  				{
 | 
                                                        
| 1968 | 1968 | print 'Found a loop between id '.$id.' - '.$cursor.'<br>';  | 
                                                        
| 1969 | 1969 | unset($arrayidparsed);  | 
                                                        
| 1970 | - $listofidtoclean[$cursor]=$id;  | 
                                                        |
| 1970 | + $listofidtoclean[$cursor] = $id;  | 
                                                        |
| 1971 | 1971 | break;  | 
                                                        
| 1972 | 1972 | }  | 
                                                        
| 1973 | - $cursor=$listofparentid[$cursor];  | 
                                                        |
| 1973 | + $cursor = $listofparentid[$cursor];  | 
                                                        |
| 1974 | 1974 | }  | 
                                                        
| 1975 | 1975 | |
| 1976 | 1976 | if (count($listofidtoclean)) break;  | 
                                                        
| 1977 | 1977 | }  | 
                                                        
| 1978 | 1978 | |
| 1979 | 1979 | $sql = "UPDATE ".MAIN_DB_PREFIX.$tabletocleantree;  | 
                                                        
| 1980 | - $sql.= " SET ".$fieldfkparent." = 0";  | 
                                                        |
| 1981 | -		$sql.= " WHERE rowid IN (".join(',',$listofidtoclean).")";	// So we update only records detected wrong
 | 
                                                        |
| 1980 | + $sql .= " SET ".$fieldfkparent." = 0";  | 
                                                        |
| 1981 | +		$sql .= " WHERE rowid IN (".join(',', $listofidtoclean).")"; // So we update only records detected wrong
 | 
                                                        |
| 1982 | 1982 | $resql = $db->query($sql);  | 
                                                        
| 1983 | 1983 | if ($resql)  | 
                                                        
| 1984 | 1984 |  		{
 | 
                                                        
| 1985 | - $nb=$db->affected_rows($sql);  | 
                                                        |
| 1985 | + $nb = $db->affected_rows($sql);  | 
                                                        |
| 1986 | 1986 | if ($nb > 0)  | 
                                                        
| 1987 | 1987 |  			{
 | 
                                                        
| 1988 | 1988 | // Removed orphelins records  | 
                                                        
| 1989 | 1989 | print '<br>Some records were detected to have parent that is a child, we set them as root record for id: ';  | 
                                                        
| 1990 | -				print join(',',$listofidtoclean);
 | 
                                                        |
| 1990 | +				print join(',', $listofidtoclean);
 | 
                                                        |
| 1991 | 1991 | }  | 
                                                        
| 1992 | 1992 | |
| 1993 | - $totalnb+=$nb;  | 
                                                        |
| 1993 | + $totalnb += $nb;  | 
                                                        |
| 1994 | 1994 | }  | 
                                                        
| 1995 | 1995 | //else dol_print_error($db);  | 
                                                        
| 1996 | 1996 | |
| 1997 | 1997 | // Check and clean orphelins  | 
                                                        
| 1998 | 1998 | $sql = "UPDATE ".MAIN_DB_PREFIX.$tabletocleantree;  | 
                                                        
| 1999 | - $sql.= " SET ".$fieldfkparent." = 0";  | 
                                                        |
| 2000 | -		$sql.= " WHERE ".$fieldfkparent." NOT IN (".join(',',$listofid).")";	// So we update only records linked to a non existing parent
 | 
                                                        |
| 1999 | + $sql .= " SET ".$fieldfkparent." = 0";  | 
                                                        |
| 2000 | +		$sql .= " WHERE ".$fieldfkparent." NOT IN (".join(',', $listofid).")"; // So we update only records linked to a non existing parent
 | 
                                                        |
| 2001 | 2001 | $resql = $db->query($sql);  | 
                                                        
| 2002 | 2002 | if ($resql)  | 
                                                        
| 2003 | 2003 |  		{
 | 
                                                        
| 2004 | - $nb=$db->affected_rows($sql);  | 
                                                        |
| 2004 | + $nb = $db->affected_rows($sql);  | 
                                                        |
| 2005 | 2005 | if ($nb > 0)  | 
                                                        
| 2006 | 2006 |  			{
 | 
                                                        
| 2007 | 2007 | // Removed orphelins records  | 
                                                        
| 2008 | 2008 | print '<br>Some orphelins were found and modified to be parent so records are visible again for id: ';  | 
                                                        
| 2009 | -				print join(',',$listofid);
 | 
                                                        |
| 2009 | +				print join(',', $listofid);
 | 
                                                        |
| 2010 | 2010 | }  | 
                                                        
| 2011 | 2011 | |
| 2012 | - $totalnb+=$nb;  | 
                                                        |
| 2012 | + $totalnb += $nb;  | 
                                                        |
| 2013 | 2013 | }  | 
                                                        
| 2014 | 2014 | //else dol_print_error($db);  | 
                                                        
| 2015 | 2015 | |
@@ -2030,21 +2030,21 @@ discard block  | 
                                                    ||
| 2030 | 2030 | $module = $element = $subelement = $element_type;  | 
                                                        
| 2031 | 2031 | |
| 2032 | 2032 | // If we ask an resource form external module (instead of default path)  | 
                                                        
| 2033 | -    if (preg_match('/^([^@]+)@([^@]+)$/i',$element_type,$regs))
 | 
                                                        |
| 2033 | +    if (preg_match('/^([^@]+)@([^@]+)$/i', $element_type, $regs))
 | 
                                                        |
| 2034 | 2034 |      {
 | 
                                                        
| 2035 | 2035 | $element = $subelement = $regs[1];  | 
                                                        
| 2036 | 2036 | $module = $regs[2];  | 
                                                        
| 2037 | 2037 | }  | 
                                                        
| 2038 | 2038 | |
| 2039 | 2039 | //print '<br>1. element : '.$element.' - module : '.$module .'<br>';  | 
                                                        
| 2040 | -    if ( preg_match('/^([^_]+)_([^_]+)/i',$element,$regs))
 | 
                                                        |
| 2040 | +    if (preg_match('/^([^_]+)_([^_]+)/i', $element, $regs))
 | 
                                                        |
| 2041 | 2041 |      {
 | 
                                                        
| 2042 | 2042 | $module = $element = $regs[1];  | 
                                                        
| 2043 | 2043 | $subelement = $regs[2];  | 
                                                        
| 2044 | 2044 | }  | 
                                                        
| 2045 | 2045 | |
| 2046 | 2046 | // For compat  | 
                                                        
| 2047 | -    if($element_type == "action") {
 | 
                                                        |
| 2047 | +    if ($element_type == "action") {
 | 
                                                        |
| 2048 | 2048 | $classpath = 'comm/action/class';  | 
                                                        
| 2049 | 2049 | $subelement = 'Actioncomm';  | 
                                                        
| 2050 | 2050 | $module = 'agenda';  | 
                                                        
@@ -2053,18 +2053,18 @@ discard block  | 
                                                    ||
| 2053 | 2053 | // To work with non standard path  | 
                                                        
| 2054 | 2054 |      if ($element_type == 'facture' || $element_type == 'invoice') {
 | 
                                                        
| 2055 | 2055 | $classpath = 'compta/facture/class';  | 
                                                        
| 2056 | - $module='facture';  | 
                                                        |
| 2057 | - $subelement='facture';  | 
                                                        |
| 2056 | + $module = 'facture';  | 
                                                        |
| 2057 | + $subelement = 'facture';  | 
                                                        |
| 2058 | 2058 | }  | 
                                                        
| 2059 | 2059 |      if ($element_type == 'commande' || $element_type == 'order') {
 | 
                                                        
| 2060 | 2060 | $classpath = 'commande/class';  | 
                                                        
| 2061 | - $module='commande';  | 
                                                        |
| 2062 | - $subelement='commande';  | 
                                                        |
| 2061 | + $module = 'commande';  | 
                                                        |
| 2062 | + $subelement = 'commande';  | 
                                                        |
| 2063 | 2063 | }  | 
                                                        
| 2064 | -    if ($element_type == 'propal')  {
 | 
                                                        |
| 2064 | +    if ($element_type == 'propal') {
 | 
                                                        |
| 2065 | 2065 | $classpath = 'comm/propal/class';  | 
                                                        
| 2066 | 2066 | }  | 
                                                        
| 2067 | -    if ($element_type == 'supplier_proposal')  {
 | 
                                                        |
| 2067 | +    if ($element_type == 'supplier_proposal') {
 | 
                                                        |
| 2068 | 2068 | $classpath = 'supplier_proposal/class';  | 
                                                        
| 2069 | 2069 | }  | 
                                                        
| 2070 | 2070 |      if ($element_type == 'shipping') {
 | 
                                                        
@@ -2079,45 +2079,45 @@ discard block  | 
                                                    ||
| 2079 | 2079 | }  | 
                                                        
| 2080 | 2080 |      if ($element_type == 'contract') {
 | 
                                                        
| 2081 | 2081 | $classpath = 'contrat/class';  | 
                                                        
| 2082 | - $module='contrat';  | 
                                                        |
| 2083 | - $subelement='contrat';  | 
                                                        |
| 2082 | + $module = 'contrat';  | 
                                                        |
| 2083 | + $subelement = 'contrat';  | 
                                                        |
| 2084 | 2084 | }  | 
                                                        
| 2085 | 2085 |      if ($element_type == 'member') {
 | 
                                                        
| 2086 | 2086 | $classpath = 'adherents/class';  | 
                                                        
| 2087 | - $module='adherent';  | 
                                                        |
| 2088 | - $subelement='adherent';  | 
                                                        |
| 2087 | + $module = 'adherent';  | 
                                                        |
| 2088 | + $subelement = 'adherent';  | 
                                                        |
| 2089 | 2089 | }  | 
                                                        
| 2090 | 2090 |      if ($element_type == 'cabinetmed_cons') {
 | 
                                                        
| 2091 | 2091 | $classpath = 'cabinetmed/class';  | 
                                                        
| 2092 | - $module='cabinetmed';  | 
                                                        |
| 2093 | - $subelement='cabinetmedcons';  | 
                                                        |
| 2092 | + $module = 'cabinetmed';  | 
                                                        |
| 2093 | + $subelement = 'cabinetmedcons';  | 
                                                        |
| 2094 | 2094 | }  | 
                                                        
| 2095 | 2095 |      if ($element_type == 'fichinter') {
 | 
                                                        
| 2096 | 2096 | $classpath = 'fichinter/class';  | 
                                                        
| 2097 | - $module='ficheinter';  | 
                                                        |
| 2098 | - $subelement='fichinter';  | 
                                                        |
| 2097 | + $module = 'ficheinter';  | 
                                                        |
| 2098 | + $subelement = 'fichinter';  | 
                                                        |
| 2099 | 2099 | }  | 
                                                        
| 2100 | 2100 |      if ($element_type == 'dolresource' || $element_type == 'resource') {
 | 
                                                        
| 2101 | 2101 | $classpath = 'resource/class';  | 
                                                        
| 2102 | - $module='resource';  | 
                                                        |
| 2103 | - $subelement='dolresource';  | 
                                                        |
| 2102 | + $module = 'resource';  | 
                                                        |
| 2103 | + $subelement = 'dolresource';  | 
                                                        |
| 2104 | 2104 | }  | 
                                                        
| 2105 | 2105 |      if ($element_type == 'propaldet') {
 | 
                                                        
| 2106 | 2106 | $classpath = 'comm/propal/class';  | 
                                                        
| 2107 | - $module='propal';  | 
                                                        |
| 2108 | - $subelement='propaleligne';  | 
                                                        |
| 2107 | + $module = 'propal';  | 
                                                        |
| 2108 | + $subelement = 'propaleligne';  | 
                                                        |
| 2109 | 2109 | }  | 
                                                        
| 2110 | -    if ($element_type == 'order_supplier')  {
 | 
                                                        |
| 2110 | +    if ($element_type == 'order_supplier') {
 | 
                                                        |
| 2111 | 2111 | $classpath = 'fourn/class';  | 
                                                        
| 2112 | - $module='fournisseur';  | 
                                                        |
| 2113 | - $subelement='commandefournisseur';  | 
                                                        |
| 2114 | - $classfile='fournisseur.commande';  | 
                                                        |
| 2112 | + $module = 'fournisseur';  | 
                                                        |
| 2113 | + $subelement = 'commandefournisseur';  | 
                                                        |
| 2114 | + $classfile = 'fournisseur.commande';  | 
                                                        |
| 2115 | 2115 | }  | 
                                                        
| 2116 | -    if ($element_type == 'invoice_supplier')  {
 | 
                                                        |
| 2116 | +    if ($element_type == 'invoice_supplier') {
 | 
                                                        |
| 2117 | 2117 | $classpath = 'fourn/class';  | 
                                                        
| 2118 | - $module='fournisseur';  | 
                                                        |
| 2119 | - $subelement='facturefournisseur';  | 
                                                        |
| 2120 | - $classfile='fournisseur.facture';  | 
                                                        |
| 2118 | + $module = 'fournisseur';  | 
                                                        |
| 2119 | + $subelement = 'facturefournisseur';  | 
                                                        |
| 2120 | + $classfile = 'fournisseur.facture';  | 
                                                        |
| 2121 | 2121 | }  | 
                                                        
| 2122 | 2122 | |
| 2123 | 2123 | if (!isset($classfile)) $classfile = strtolower($subelement);  | 
                                                        
@@ -2144,10 +2144,10 @@ discard block  | 
                                                    ||
| 2144 | 2144 | * @param ref $element_ref Element ref (Use this if element_id but not both)  | 
                                                        
| 2145 | 2145 | * @return int|object object || 0 || -1 if error  | 
                                                        
| 2146 | 2146 | */  | 
                                                        
| 2147 | -function fetchObjectByElement($element_id, $element_type, $element_ref='')  | 
                                                        |
| 2147 | +function fetchObjectByElement($element_id, $element_type, $element_ref = '')  | 
                                                        |
| 2148 | 2148 |  {
 | 
                                                        
| 2149 | 2149 | global $conf;  | 
                                                        
| 2150 | - global $db,$conf;  | 
                                                        |
| 2150 | + global $db, $conf;  | 
                                                        |
| 2151 | 2151 | |
| 2152 | 2152 | $element_prop = getElementProperties($element_type);  | 
                                                        
| 2153 | 2153 |      if (is_array($element_prop) && $conf->{$element_prop['module']}->enabled)
 | 
                                                        
@@ -2174,11 +2174,11 @@ discard block  | 
                                                    ||
| 2174 | 2174 | * @return string RGB hex value (without # before). For example: 'FF00FF', '01FF02'  | 
                                                        
| 2175 | 2175 | * @see colorStringToArray  | 
                                                        
| 2176 | 2176 | */  | 
                                                        
| 2177 | -function colorArrayToHex($arraycolor,$colorifnotfound='888888')  | 
                                                        |
| 2177 | +function colorArrayToHex($arraycolor, $colorifnotfound = '888888')  | 
                                                        |
| 2178 | 2178 |  {
 | 
                                                        
| 2179 | - if (! is_array($arraycolor)) return $colorifnotfound;  | 
                                                        |
| 2179 | + if (!is_array($arraycolor)) return $colorifnotfound;  | 
                                                        |
| 2180 | 2180 | if (empty($arraycolor)) return $colorifnotfound;  | 
                                                        
| 2181 | -	return sprintf("%02s",dechex($arraycolor[0])).sprintf("%02s",dechex($arraycolor[1])).sprintf("%02s",dechex($arraycolor[2]));
 | 
                                                        |
| 2181 | +	return sprintf("%02s", dechex($arraycolor[0])).sprintf("%02s", dechex($arraycolor[1])).sprintf("%02s", dechex($arraycolor[2]));
 | 
                                                        |
| 2182 | 2182 | }  | 
                                                        
| 2183 | 2183 | |
| 2184 | 2184 | /**  | 
                                                        
@@ -2193,15 +2193,15 @@ discard block  | 
                                                    ||
| 2193 | 2193 | */  | 
                                                        
| 2194 | 2194 | static function colorStringToArray($stringcolor, $colorifnotfound = array(88, 88, 88))  | 
                                                        
| 2195 | 2195 |      {
 | 
                                                        
| 2196 | - if (is_array($stringcolor)) return $stringcolor; // If already into correct output format, we return as is  | 
                                                        |
| 2197 | -	$tmp=preg_match('/^#?([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])$/',$stringcolor,$reg);
 | 
                                                        |
| 2198 | - if (! $tmp)  | 
                                                        |
| 2196 | + if (is_array($stringcolor)) return $stringcolor; // If already into correct output format, we return as is  | 
                                                        |
| 2197 | +	$tmp = preg_match('/^#?([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])$/', $stringcolor, $reg);
 | 
                                                        |
| 2198 | + if (!$tmp)  | 
                                                        |
| 2199 | 2199 |  	{
 | 
                                                        
| 2200 | -		$tmp=explode(',',$stringcolor);
 | 
                                                        |
| 2200 | +		$tmp = explode(',', $stringcolor);
 | 
                                                        |
| 2201 | 2201 | if (count($tmp) < 3) return $colorifnotfound;  | 
                                                        
| 2202 | 2202 | return $tmp;  | 
                                                        
| 2203 | 2203 | }  | 
                                                        
| 2204 | - return array(hexdec($reg[1]),hexdec($reg[2]),hexdec($reg[3]));  | 
                                                        |
| 2204 | + return array(hexdec($reg[1]), hexdec($reg[2]), hexdec($reg[3]));  | 
                                                        |
| 2205 | 2205 | }  | 
                                                        
| 2206 | 2206 | |
| 2207 | 2207 | /**  | 
                                                        
@@ -2221,8 +2221,8 @@ discard block  | 
                                                    ||
| 2221 | 2221 |      foreach ($input as $key => $values) {
 | 
                                                        
| 2222 | 2222 | $append = array();  | 
                                                        
| 2223 | 2223 | |
| 2224 | -        foreach($result as $product) {
 | 
                                                        |
| 2225 | -            foreach($values as $item) {
 | 
                                                        |
| 2224 | +        foreach ($result as $product) {
 | 
                                                        |
| 2225 | +            foreach ($values as $item) {
 | 
                                                        |
| 2226 | 2226 | $product[$key] = $item;  | 
                                                        
| 2227 | 2227 | $append[] = $product;  | 
                                                        
| 2228 | 2228 | }  | 
                                                        
@@ -2243,8 +2243,8 @@ discard block  | 
                                                    ||
| 2243 | 2243 | */  | 
                                                        
| 2244 | 2244 | function getModuleDirForApiClass($module)  | 
                                                        
| 2245 | 2245 |  {
 | 
                                                        
| 2246 | - $moduledirforclass=$module;  | 
                                                        |
| 2247 | -    if ($moduledirforclass != 'api') $moduledirforclass = preg_replace('/api$/i','',$moduledirforclass);
 | 
                                                        |
| 2246 | + $moduledirforclass = $module;  | 
                                                        |
| 2247 | +    if ($moduledirforclass != 'api') $moduledirforclass = preg_replace('/api$/i', '', $moduledirforclass);
 | 
                                                        |
| 2248 | 2248 | |
| 2249 | 2249 |      if ($module == 'contracts') {
 | 
                                                        
| 2250 | 2250 | $moduledirforclass = 'contrat';  | 
                                                        
@@ -2320,9 +2320,9 @@ discard block  | 
                                                    ||
| 2320 | 2320 | * @param $max int Between 0 and 255  | 
                                                        
| 2321 | 2321 | * @return String  | 
                                                        
| 2322 | 2322 | */  | 
                                                        
| 2323 | -function random_color_part($min=0,$max=255)  | 
                                                        |
| 2323 | +function random_color_part($min = 0, $max = 255)  | 
                                                        |
| 2324 | 2324 |  {
 | 
                                                        
| 2325 | - return str_pad( dechex( mt_rand( $min, $max) ), 2, '0', STR_PAD_LEFT);  | 
                                                        |
| 2325 | + return str_pad(dechex(mt_rand($min, $max)), 2, '0', STR_PAD_LEFT);  | 
                                                        |
| 2326 | 2326 | }  | 
                                                        
| 2327 | 2327 | |
| 2328 | 2328 | /*  | 
                                                        
@@ -2332,8 +2332,8 @@ discard block  | 
                                                    ||
| 2332 | 2332 | * @param $max int Between 0 and 255  | 
                                                        
| 2333 | 2333 | * @return String  | 
                                                        
| 2334 | 2334 | */  | 
                                                        
| 2335 | -function random_color($min=0, $max=255)  | 
                                                        |
| 2335 | +function random_color($min = 0, $max = 255)  | 
                                                        |
| 2336 | 2336 |  {
 | 
                                                        
| 2337 | - return random_color_part($min, $max) . random_color_part($min, $max) . random_color_part($min, $max);  | 
                                                        |
| 2337 | + return random_color_part($min, $max).random_color_part($min, $max).random_color_part($min, $max);  | 
                                                        |
| 2338 | 2338 | }  | 
                                                        
| 2339 | 2339 | }  | 
                                                        
@@ -59,8 +59,7 @@ discard block  | 
                                                    ||
| 59 | 59 | $entity = "&#". $unicode . ';';  | 
                                                        
| 60 | 60 | $decodedStr .= utf8_encode($entity);  | 
                                                        
| 61 | 61 | $pos += 4;  | 
                                                        
| 62 | - }  | 
                                                        |
| 63 | -            else {
 | 
                                                        |
| 62 | +            } else {
 | 
                                                        |
| 64 | 63 | // we have an escaped ascii character  | 
                                                        
| 65 | 64 | $hexVal = substr($source, $pos, 2);  | 
                                                        
| 66 | 65 | $decodedStr .= chr(hexdec($hexVal));  | 
                                                        
@@ -101,7 +100,10 @@ discard block  | 
                                                    ||
| 101 | 100 |          {
 | 
                                                        
| 102 | 101 | while (($file = readdir($handle))!==false)  | 
                                                        
| 103 | 102 |              {
 | 
                                                        
| 104 | -                if (preg_match('/disabled/',$file)) continue;   // We discard module if it contains disabled into name.
 | 
                                                        |
| 103 | +                if (preg_match('/disabled/',$file)) { | 
                                                        |
| 104 | + continue;  | 
                                                        |
| 105 | + }  | 
                                                        |
| 106 | + // We discard module if it contains disabled into name.  | 
                                                        |
| 105 | 107 | |
| 106 | 108 | if (is_dir($dirroot.'/'.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS' && $file != 'includes')  | 
                                                        
| 107 | 109 |                  {
 | 
                                                        
@@ -133,8 +135,14 @@ discard block  | 
                                                    ||
| 133 | 135 | $outputlangs=$langs;  | 
                                                        
| 134 | 136 | }  | 
                                                        
| 135 | 137 | |
| 136 | - if ($outputlangs->defaultlang == 'ca_CA') $selected='CAP4'; // Canada  | 
                                                        |
| 137 | - if ($outputlangs->defaultlang == 'en_US') $selected='USLetter'; // US  | 
                                                        |
| 138 | +    if ($outputlangs->defaultlang == 'ca_CA') { | 
                                                        |
| 139 | + $selected='CAP4';  | 
                                                        |
| 140 | + }  | 
                                                        |
| 141 | + // Canada  | 
                                                        |
| 142 | +    if ($outputlangs->defaultlang == 'en_US') { | 
                                                        |
| 143 | + $selected='USLetter';  | 
                                                        |
| 144 | + }  | 
                                                        |
| 145 | + // US  | 
                                                        |
| 138 | 146 | return $selected;  | 
                                                        
| 139 | 147 | }  | 
                                                        
| 140 | 148 | |
@@ -159,29 +167,42 @@ discard block  | 
                                                    ||
| 159 | 167 |          {
 | 
                                                        
| 160 | 168 | $content=file_get_contents($formfile);  | 
                                                        
| 161 | 169 | $isutf8=utf8_check($content);  | 
                                                        
| 162 | - if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 163 | - elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') print utf8_decode($content);  | 
                                                        |
| 164 | - else print $content;  | 
                                                        |
| 170 | +            if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') { | 
                                                        |
| 171 | + print utf8_encode($content);  | 
                                                        |
| 172 | +            } elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') { | 
                                                        |
| 173 | + print utf8_decode($content);  | 
                                                        |
| 174 | +            } else { | 
                                                        |
| 175 | + print $content;  | 
                                                        |
| 176 | + }  | 
                                                        |
| 165 | 177 | return true;  | 
                                                        
| 166 | - }  | 
                                                        |
| 167 | -        else dol_syslog('functions2::dol_print_file not found', LOG_DEBUG);
 | 
                                                        |
| 178 | +        } else { | 
                                                        |
| 179 | +            dol_syslog('functions2::dol_print_file not found', LOG_DEBUG); | 
                                                        |
| 180 | + }  | 
                                                        |
| 168 | 181 | |
| 169 | 182 |          if ($searchalt) {
 | 
                                                        
| 170 | 183 | // Test si fichier dans repertoire de la langue alternative  | 
                                                        
| 171 | - if ($langs->defaultlang != "en_US") $formfilealt = $searchdir."/langs/en_US/".$filename;  | 
                                                        |
| 172 | - else $formfilealt = $searchdir."/langs/fr_FR/".$filename;  | 
                                                        |
| 184 | +            if ($langs->defaultlang != "en_US") { | 
                                                        |
| 185 | + $formfilealt = $searchdir."/langs/en_US/".$filename;  | 
                                                        |
| 186 | +            } else { | 
                                                        |
| 187 | + $formfilealt = $searchdir."/langs/fr_FR/".$filename;  | 
                                                        |
| 188 | + }  | 
                                                        |
| 173 | 189 |              dol_syslog('functions2::dol_print_file search alt file '.$formfilealt, LOG_DEBUG);
 | 
                                                        
| 174 | 190 | //print 'getcwd='.getcwd().' htmlfilealt='.$formfilealt.' X '.file_exists(getcwd().'/'.$formfilealt);  | 
                                                        
| 175 | 191 | if (is_readable($formfilealt))  | 
                                                        
| 176 | 192 |              {
 | 
                                                        
| 177 | 193 | $content=file_get_contents($formfilealt);  | 
                                                        
| 178 | 194 | $isutf8=utf8_check($content);  | 
                                                        
| 179 | - if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') print utf8_encode($content);  | 
                                                        |
| 180 | - elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') print utf8_decode($content);  | 
                                                        |
| 181 | - else print $content;  | 
                                                        |
| 195 | +                if (! $isutf8 && $conf->file->character_set_client == 'UTF-8') { | 
                                                        |
| 196 | + print utf8_encode($content);  | 
                                                        |
| 197 | +                } elseif ($isutf8 && $conf->file->character_set_client == 'ISO-8859-1') { | 
                                                        |
| 198 | + print utf8_decode($content);  | 
                                                        |
| 199 | +                } else { | 
                                                        |
| 200 | + print $content;  | 
                                                        |
| 201 | + }  | 
                                                        |
| 182 | 202 | return true;  | 
                                                        
| 183 | - }  | 
                                                        |
| 184 | -            else dol_syslog('functions2::dol_print_file not found', LOG_DEBUG);
 | 
                                                        |
| 203 | +            } else { | 
                                                        |
| 204 | +                dol_syslog('functions2::dol_print_file not found', LOG_DEBUG); | 
                                                        |
| 205 | + }  | 
                                                        |
| 185 | 206 | }  | 
                                                        
| 186 | 207 | }  | 
                                                        
| 187 | 208 | |
@@ -211,279 +232,460 @@ discard block  | 
                                                    ||
| 211 | 232 | $deltadateforuser=round($deltadateforclient-$deltadateforserver);  | 
                                                        
| 212 | 233 | //print "x".$deltadateforserver." - ".$deltadateforclient." - ".$deltadateforuser;  | 
                                                        
| 213 | 234 | |
| 214 | - if ($usetable) print '<table class="border centpercent">';  | 
                                                        |
| 235 | +    if ($usetable) { | 
                                                        |
| 236 | + print '<table class="border centpercent">';  | 
                                                        |
| 237 | + }  | 
                                                        |
| 215 | 238 | |
| 216 | 239 | // Import key  | 
                                                        
| 217 | 240 | if (! empty($object->import_key))  | 
                                                        
| 218 | 241 |      {
 | 
                                                        
| 219 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 242 | +        if ($usetable) { | 
                                                        |
| 243 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 244 | + }  | 
                                                        |
| 220 | 245 |          print $langs->trans("ImportedWithSet");
 | 
                                                        
| 221 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 222 | - else print ': ';  | 
                                                        |
| 246 | +        if ($usetable) { | 
                                                        |
| 247 | + print '</td><td>';  | 
                                                        |
| 248 | +        } else { | 
                                                        |
| 249 | + print ': ';  | 
                                                        |
| 250 | + }  | 
                                                        |
| 223 | 251 | print $object->import_key;  | 
                                                        
| 224 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 225 | - else print '<br>';  | 
                                                        |
| 252 | +        if ($usetable) { | 
                                                        |
| 253 | + print '</td></tr>';  | 
                                                        |
| 254 | +        } else { | 
                                                        |
| 255 | + print '<br>';  | 
                                                        |
| 256 | + }  | 
                                                        |
| 226 | 257 | }  | 
                                                        
| 227 | 258 | |
| 228 | 259 | // User creation (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 229 | 260 | if (! empty($object->user_creation) || ! empty($object->user_creation_id))  | 
                                                        
| 230 | 261 |      {
 | 
                                                        
| 231 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 262 | +        if ($usetable) { | 
                                                        |
| 263 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 264 | + }  | 
                                                        |
| 232 | 265 |          print $langs->trans("CreatedBy");
 | 
                                                        
| 233 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 234 | - else print ': ';  | 
                                                        |
| 266 | +        if ($usetable) { | 
                                                        |
| 267 | + print '</td><td>';  | 
                                                        |
| 268 | +        } else { | 
                                                        |
| 269 | + print ': ';  | 
                                                        |
| 270 | + }  | 
                                                        |
| 235 | 271 | if (is_object($object->user_creation))  | 
                                                        
| 236 | 272 |          {
 | 
                                                        
| 237 | - if ($object->user_creation->id) print $object->user_creation->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 238 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 239 | - }  | 
                                                        |
| 240 | - else  | 
                                                        |
| 273 | +        	if ($object->user_creation->id) { | 
                                                        |
| 274 | + print $object->user_creation->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 275 | +        	} else { | 
                                                        |
| 276 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 277 | + }  | 
                                                        |
| 278 | + } else  | 
                                                        |
| 241 | 279 |          {
 | 
                                                        
| 242 | 280 | $userstatic=new User($db);  | 
                                                        
| 243 | 281 | $userstatic->fetch($object->user_creation_id ? $object->user_creation_id : $object->user_creation);  | 
                                                        
| 244 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 245 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 282 | +            if ($userstatic->id) { | 
                                                        |
| 283 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 284 | +            } else { | 
                                                        |
| 285 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 286 | + }  | 
                                                        |
| 246 | 287 | }  | 
                                                        
| 247 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 248 | - else print '<br>';  | 
                                                        |
| 288 | +        if ($usetable) { | 
                                                        |
| 289 | + print '</td></tr>';  | 
                                                        |
| 290 | +        } else { | 
                                                        |
| 291 | + print '<br>';  | 
                                                        |
| 292 | + }  | 
                                                        |
| 249 | 293 | }  | 
                                                        
| 250 | 294 | |
| 251 | 295 | // Date creation  | 
                                                        
| 252 | 296 | if (! empty($object->date_creation))  | 
                                                        
| 253 | 297 |      {
 | 
                                                        
| 254 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 298 | +        if ($usetable) { | 
                                                        |
| 299 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 300 | + }  | 
                                                        |
| 255 | 301 |          print $langs->trans("DateCreation");
 | 
                                                        
| 256 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 257 | - else print ': ';  | 
                                                        |
| 302 | +        if ($usetable) { | 
                                                        |
| 303 | + print '</td><td>';  | 
                                                        |
| 304 | +        } else { | 
                                                        |
| 305 | + print ': ';  | 
                                                        |
| 306 | + }  | 
                                                        |
| 258 | 307 | print dol_print_date($object->date_creation, 'dayhour');  | 
                                                        
| 259 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_creation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 260 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 261 | - else print '<br>';  | 
                                                        |
| 308 | +        if ($deltadateforuser) { | 
                                                        |
| 309 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_creation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 310 | + }  | 
                                                        |
| 311 | +        if ($usetable) { | 
                                                        |
| 312 | + print '</td></tr>';  | 
                                                        |
| 313 | +        } else { | 
                                                        |
| 314 | + print '<br>';  | 
                                                        |
| 315 | + }  | 
                                                        |
| 262 | 316 | }  | 
                                                        
| 263 | 317 | |
| 264 | 318 | // User change (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 265 | 319 | if (! empty($object->user_modification) || ! empty($object->user_modification_id))  | 
                                                        
| 266 | 320 |      {
 | 
                                                        
| 267 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 321 | +        if ($usetable) { | 
                                                        |
| 322 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 323 | + }  | 
                                                        |
| 268 | 324 |          print $langs->trans("ModifiedBy");
 | 
                                                        
| 269 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 270 | - else print ': ';  | 
                                                        |
| 325 | +        if ($usetable) { | 
                                                        |
| 326 | + print '</td><td>';  | 
                                                        |
| 327 | +        } else { | 
                                                        |
| 328 | + print ': ';  | 
                                                        |
| 329 | + }  | 
                                                        |
| 271 | 330 | if (is_object($object->user_modification))  | 
                                                        
| 272 | 331 |          {
 | 
                                                        
| 273 | - if ($object->user_modification->id) print $object->user_modification->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 274 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 275 | - }  | 
                                                        |
| 276 | - else  | 
                                                        |
| 332 | +        	if ($object->user_modification->id) { | 
                                                        |
| 333 | + print $object->user_modification->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 334 | +        	} else { | 
                                                        |
| 335 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 336 | + }  | 
                                                        |
| 337 | + } else  | 
                                                        |
| 277 | 338 |          {
 | 
                                                        
| 278 | 339 | $userstatic=new User($db);  | 
                                                        
| 279 | 340 | $userstatic->fetch($object->user_modification_id ? $object->user_modification_id : $object->user_modification);  | 
                                                        
| 280 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 281 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 341 | +            if ($userstatic->id) { | 
                                                        |
| 342 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 343 | +            } else { | 
                                                        |
| 344 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 345 | + }  | 
                                                        |
| 282 | 346 | }  | 
                                                        
| 283 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 284 | - else print '<br>';  | 
                                                        |
| 347 | +        if ($usetable) { | 
                                                        |
| 348 | + print '</td></tr>';  | 
                                                        |
| 349 | +        } else { | 
                                                        |
| 350 | + print '<br>';  | 
                                                        |
| 351 | + }  | 
                                                        |
| 285 | 352 | }  | 
                                                        
| 286 | 353 | |
| 287 | 354 | // Date change  | 
                                                        
| 288 | 355 | if (! empty($object->date_modification))  | 
                                                        
| 289 | 356 |      {
 | 
                                                        
| 290 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 357 | +        if ($usetable) { | 
                                                        |
| 358 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 359 | + }  | 
                                                        |
| 291 | 360 |          print $langs->trans("DateLastModification");
 | 
                                                        
| 292 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 293 | - else print ': ';  | 
                                                        |
| 361 | +        if ($usetable) { | 
                                                        |
| 362 | + print '</td><td>';  | 
                                                        |
| 363 | +        } else { | 
                                                        |
| 364 | + print ': ';  | 
                                                        |
| 365 | + }  | 
                                                        |
| 294 | 366 | print dol_print_date($object->date_modification, 'dayhour');  | 
                                                        
| 295 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_modification+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 296 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 297 | - else print '<br>';  | 
                                                        |
| 367 | +        if ($deltadateforuser) { | 
                                                        |
| 368 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_modification+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 369 | + }  | 
                                                        |
| 370 | +        if ($usetable) { | 
                                                        |
| 371 | + print '</td></tr>';  | 
                                                        |
| 372 | +        } else { | 
                                                        |
| 373 | + print '<br>';  | 
                                                        |
| 374 | + }  | 
                                                        |
| 298 | 375 | }  | 
                                                        
| 299 | 376 | |
| 300 | 377 | // User validation (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 301 | 378 | if (! empty($object->user_validation) || ! empty($object->user_validation_id))  | 
                                                        
| 302 | 379 |      {
 | 
                                                        
| 303 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 380 | +        if ($usetable) { | 
                                                        |
| 381 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 382 | + }  | 
                                                        |
| 304 | 383 |          print $langs->trans("ValidatedBy");
 | 
                                                        
| 305 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 306 | - else print ': ';  | 
                                                        |
| 384 | +        if ($usetable) { | 
                                                        |
| 385 | + print '</td><td>';  | 
                                                        |
| 386 | +        } else { | 
                                                        |
| 387 | + print ': ';  | 
                                                        |
| 388 | + }  | 
                                                        |
| 307 | 389 | if (is_object($object->user_validation))  | 
                                                        
| 308 | 390 |          {
 | 
                                                        
| 309 | - if ($object->user_validation->id) print $object->user_validation->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 310 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 311 | - }  | 
                                                        |
| 312 | - else  | 
                                                        |
| 391 | +            if ($object->user_validation->id) { | 
                                                        |
| 392 | + print $object->user_validation->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 393 | +            } else { | 
                                                        |
| 394 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 395 | + }  | 
                                                        |
| 396 | + } else  | 
                                                        |
| 313 | 397 |          {
 | 
                                                        
| 314 | 398 | $userstatic=new User($db);  | 
                                                        
| 315 | 399 | $userstatic->fetch($object->user_validation_id ? $object->user_validation_id : $object->user_validation);  | 
                                                        
| 316 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 317 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 400 | +			if ($userstatic->id) { | 
                                                        |
| 401 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 402 | +			} else { | 
                                                        |
| 403 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 404 | + }  | 
                                                        |
| 318 | 405 | }  | 
                                                        
| 319 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 320 | - else print '<br>';  | 
                                                        |
| 406 | +        if ($usetable) { | 
                                                        |
| 407 | + print '</td></tr>';  | 
                                                        |
| 408 | +        } else { | 
                                                        |
| 409 | + print '<br>';  | 
                                                        |
| 410 | + }  | 
                                                        |
| 321 | 411 | }  | 
                                                        
| 322 | 412 | |
| 323 | 413 | // Date validation  | 
                                                        
| 324 | 414 | if (! empty($object->date_validation))  | 
                                                        
| 325 | 415 |      {
 | 
                                                        
| 326 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 416 | +        if ($usetable) { | 
                                                        |
| 417 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 418 | + }  | 
                                                        |
| 327 | 419 |          print $langs->trans("DateValidation");
 | 
                                                        
| 328 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 329 | - else print ': ';  | 
                                                        |
| 420 | +        if ($usetable) { | 
                                                        |
| 421 | + print '</td><td>';  | 
                                                        |
| 422 | +        } else { | 
                                                        |
| 423 | + print ': ';  | 
                                                        |
| 424 | + }  | 
                                                        |
| 330 | 425 | print dol_print_date($object->date_validation, 'dayhour');  | 
                                                        
| 331 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_validation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 332 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 333 | - else print '<br>';  | 
                                                        |
| 426 | +        if ($deltadateforuser) { | 
                                                        |
| 427 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_validation+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 428 | + }  | 
                                                        |
| 429 | +        if ($usetable) { | 
                                                        |
| 430 | + print '</td></tr>';  | 
                                                        |
| 431 | +        } else { | 
                                                        |
| 432 | + print '<br>';  | 
                                                        |
| 433 | + }  | 
                                                        |
| 334 | 434 | }  | 
                                                        
| 335 | 435 | |
| 336 | 436 | // User approve (old method using already loaded object and not id is kept for backward compatibility)  | 
                                                        
| 337 | 437 | if (! empty($object->user_approve) || ! empty($object->user_approve_id))  | 
                                                        
| 338 | 438 |      {
 | 
                                                        
| 339 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 439 | +        if ($usetable) { | 
                                                        |
| 440 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 441 | + }  | 
                                                        |
| 340 | 442 |          print $langs->trans("ApprovedBy");
 | 
                                                        
| 341 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 342 | - else print ': ';  | 
                                                        |
| 443 | +        if ($usetable) { | 
                                                        |
| 444 | + print '</td><td>';  | 
                                                        |
| 445 | +        } else { | 
                                                        |
| 446 | + print ': ';  | 
                                                        |
| 447 | + }  | 
                                                        |
| 343 | 448 | if (is_object($object->user_approve))  | 
                                                        
| 344 | 449 |          {
 | 
                                                        
| 345 | - if ($object->user_approve->id) print $object->user_approve->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 346 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 347 | - }  | 
                                                        |
| 348 | - else  | 
                                                        |
| 450 | +            if ($object->user_approve->id) { | 
                                                        |
| 451 | + print $object->user_approve->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 452 | +            } else { | 
                                                        |
| 453 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 454 | + }  | 
                                                        |
| 455 | + } else  | 
                                                        |
| 349 | 456 |          {
 | 
                                                        
| 350 | 457 | $userstatic=new User($db);  | 
                                                        
| 351 | 458 | $userstatic->fetch($object->user_approve_id ? $object->user_approve_id : $object->user_approve);  | 
                                                        
| 352 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 353 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 459 | +			if ($userstatic->id) { | 
                                                        |
| 460 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 461 | +			} else { | 
                                                        |
| 462 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 463 | + }  | 
                                                        |
| 354 | 464 | }  | 
                                                        
| 355 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 356 | - else print '<br>';  | 
                                                        |
| 465 | +        if ($usetable) { | 
                                                        |
| 466 | + print '</td></tr>';  | 
                                                        |
| 467 | +        } else { | 
                                                        |
| 468 | + print '<br>';  | 
                                                        |
| 469 | + }  | 
                                                        |
| 357 | 470 | }  | 
                                                        
| 358 | 471 | |
| 359 | 472 | // Date approve  | 
                                                        
| 360 | 473 | if (! empty($object->date_approve))  | 
                                                        
| 361 | 474 |      {
 | 
                                                        
| 362 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 475 | +        if ($usetable) { | 
                                                        |
| 476 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 477 | + }  | 
                                                        |
| 363 | 478 |          print $langs->trans("DateApprove");
 | 
                                                        
| 364 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 365 | - else print ': ';  | 
                                                        |
| 479 | +        if ($usetable) { | 
                                                        |
| 480 | + print '</td><td>';  | 
                                                        |
| 481 | +        } else { | 
                                                        |
| 482 | + print ': ';  | 
                                                        |
| 483 | + }  | 
                                                        |
| 366 | 484 | print dol_print_date($object->date_approve, 'dayhour');  | 
                                                        
| 367 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 368 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 369 | - else print '<br>';  | 
                                                        |
| 485 | +        if ($deltadateforuser) { | 
                                                        |
| 486 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 487 | + }  | 
                                                        |
| 488 | +        if ($usetable) { | 
                                                        |
| 489 | + print '</td></tr>';  | 
                                                        |
| 490 | +        } else { | 
                                                        |
| 491 | + print '<br>';  | 
                                                        |
| 492 | + }  | 
                                                        |
| 370 | 493 | }  | 
                                                        
| 371 | 494 | |
| 372 | 495 | // User approve  | 
                                                        
| 373 | 496 | if (! empty($object->user_approve_id2))  | 
                                                        
| 374 | 497 |      {
 | 
                                                        
| 375 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 498 | +        if ($usetable) { | 
                                                        |
| 499 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 500 | + }  | 
                                                        |
| 376 | 501 |          print $langs->trans("ApprovedBy");
 | 
                                                        
| 377 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 378 | - else print ': ';  | 
                                                        |
| 502 | +        if ($usetable) { | 
                                                        |
| 503 | + print '</td><td>';  | 
                                                        |
| 504 | +        } else { | 
                                                        |
| 505 | + print ': ';  | 
                                                        |
| 506 | + }  | 
                                                        |
| 379 | 507 | $userstatic=new User($db);  | 
                                                        
| 380 | 508 | $userstatic->fetch($object->user_approve_id2);  | 
                                                        
| 381 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 382 | -        else print $langs->trans("Unknown");
 | 
                                                        |
| 383 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 384 | - else print '<br>';  | 
                                                        |
| 509 | +        if ($userstatic->id) { | 
                                                        |
| 510 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 511 | +        } else { | 
                                                        |
| 512 | +            print $langs->trans("Unknown"); | 
                                                        |
| 513 | + }  | 
                                                        |
| 514 | +        if ($usetable) { | 
                                                        |
| 515 | + print '</td></tr>';  | 
                                                        |
| 516 | +        } else { | 
                                                        |
| 517 | + print '<br>';  | 
                                                        |
| 518 | + }  | 
                                                        |
| 385 | 519 | }  | 
                                                        
| 386 | 520 | |
| 387 | 521 | // Date approve  | 
                                                        
| 388 | 522 | if (! empty($object->date_approve2))  | 
                                                        
| 389 | 523 |      {
 | 
                                                        
| 390 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 524 | +        if ($usetable) { | 
                                                        |
| 525 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 526 | + }  | 
                                                        |
| 391 | 527 |          print $langs->trans("DateApprove2");
 | 
                                                        
| 392 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 393 | - else print ': ';  | 
                                                        |
| 528 | +        if ($usetable) { | 
                                                        |
| 529 | + print '</td><td>';  | 
                                                        |
| 530 | +        } else { | 
                                                        |
| 531 | + print ': ';  | 
                                                        |
| 532 | + }  | 
                                                        |
| 394 | 533 | print dol_print_date($object->date_approve2, 'dayhour');  | 
                                                        
| 395 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve2+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 396 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 397 | - else print '<br>';  | 
                                                        |
| 534 | +        if ($deltadateforuser) { | 
                                                        |
| 535 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_approve2+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 536 | + }  | 
                                                        |
| 537 | +        if ($usetable) { | 
                                                        |
| 538 | + print '</td></tr>';  | 
                                                        |
| 539 | +        } else { | 
                                                        |
| 540 | + print '<br>';  | 
                                                        |
| 541 | + }  | 
                                                        |
| 398 | 542 | }  | 
                                                        
| 399 | 543 | |
| 400 | 544 | // User close  | 
                                                        
| 401 | 545 | if (! empty($object->user_cloture))  | 
                                                        
| 402 | 546 |      {
 | 
                                                        
| 403 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 547 | +        if ($usetable) { | 
                                                        |
| 548 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 549 | + }  | 
                                                        |
| 404 | 550 |          print $langs->trans("ClosedBy");
 | 
                                                        
| 405 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 406 | - else print ': ';  | 
                                                        |
| 551 | +        if ($usetable) { | 
                                                        |
| 552 | + print '</td><td>';  | 
                                                        |
| 553 | +        } else { | 
                                                        |
| 554 | + print ': ';  | 
                                                        |
| 555 | + }  | 
                                                        |
| 407 | 556 | if (is_object($object->user_cloture))  | 
                                                        
| 408 | 557 |          {
 | 
                                                        
| 409 | - if ($object->user_cloture->id) print $object->user_cloture->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 410 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 411 | - }  | 
                                                        |
| 412 | - else  | 
                                                        |
| 558 | +			if ($object->user_cloture->id) { | 
                                                        |
| 559 | + print $object->user_cloture->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 560 | +			} else { | 
                                                        |
| 561 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 562 | + }  | 
                                                        |
| 563 | + } else  | 
                                                        |
| 413 | 564 |          {
 | 
                                                        
| 414 | 565 | $userstatic=new User($db);  | 
                                                        
| 415 | 566 | $userstatic->fetch($object->user_cloture);  | 
                                                        
| 416 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 417 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 567 | +			if ($userstatic->id) { | 
                                                        |
| 568 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 569 | +			} else { | 
                                                        |
| 570 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 571 | + }  | 
                                                        |
| 418 | 572 | }  | 
                                                        
| 419 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 420 | - else print '<br>';  | 
                                                        |
| 573 | +        if ($usetable) { | 
                                                        |
| 574 | + print '</td></tr>';  | 
                                                        |
| 575 | +        } else { | 
                                                        |
| 576 | + print '<br>';  | 
                                                        |
| 577 | + }  | 
                                                        |
| 421 | 578 | }  | 
                                                        
| 422 | 579 | |
| 423 | 580 | // Date close  | 
                                                        
| 424 | 581 | if (! empty($object->date_cloture))  | 
                                                        
| 425 | 582 |      {
 | 
                                                        
| 426 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 583 | +        if ($usetable) { | 
                                                        |
| 584 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 585 | + }  | 
                                                        |
| 427 | 586 |          print $langs->trans("DateClosing");
 | 
                                                        
| 428 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 429 | - else print ': ';  | 
                                                        |
| 587 | +        if ($usetable) { | 
                                                        |
| 588 | + print '</td><td>';  | 
                                                        |
| 589 | +        } else { | 
                                                        |
| 590 | + print ': ';  | 
                                                        |
| 591 | + }  | 
                                                        |
| 430 | 592 | print dol_print_date($object->date_cloture, 'dayhour');  | 
                                                        
| 431 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_cloture+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 432 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 433 | - else print '<br>';  | 
                                                        |
| 593 | +        if ($deltadateforuser) { | 
                                                        |
| 594 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_cloture+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 595 | + }  | 
                                                        |
| 596 | +        if ($usetable) { | 
                                                        |
| 597 | + print '</td></tr>';  | 
                                                        |
| 598 | +        } else { | 
                                                        |
| 599 | + print '<br>';  | 
                                                        |
| 600 | + }  | 
                                                        |
| 434 | 601 | }  | 
                                                        
| 435 | 602 | |
| 436 | 603 | // User conciliate  | 
                                                        
| 437 | 604 | if (! empty($object->user_rappro))  | 
                                                        
| 438 | 605 |      {
 | 
                                                        
| 439 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 606 | +        if ($usetable) { | 
                                                        |
| 607 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 608 | + }  | 
                                                        |
| 440 | 609 |          print $langs->trans("ConciliatedBy");
 | 
                                                        
| 441 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 442 | - else print ': ';  | 
                                                        |
| 610 | +        if ($usetable) { | 
                                                        |
| 611 | + print '</td><td>';  | 
                                                        |
| 612 | +        } else { | 
                                                        |
| 613 | + print ': ';  | 
                                                        |
| 614 | + }  | 
                                                        |
| 443 | 615 | if (is_object($object->user_rappro))  | 
                                                        
| 444 | 616 |          {
 | 
                                                        
| 445 | - if ($object->user_rappro->id) print $object->user_rappro->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 446 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 447 | - }  | 
                                                        |
| 448 | - else  | 
                                                        |
| 617 | +			if ($object->user_rappro->id) { | 
                                                        |
| 618 | + print $object->user_rappro->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 619 | +			} else { | 
                                                        |
| 620 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 621 | + }  | 
                                                        |
| 622 | + } else  | 
                                                        |
| 449 | 623 |          {
 | 
                                                        
| 450 | 624 | $userstatic=new User($db);  | 
                                                        
| 451 | 625 | $userstatic->fetch($object->user_rappro);  | 
                                                        
| 452 | - if ($userstatic->id) print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 453 | -        	else print $langs->trans("Unknown");
 | 
                                                        |
| 626 | +			if ($userstatic->id) { | 
                                                        |
| 627 | + print $userstatic->getNomUrl(1, '', 0, 0, 0);  | 
                                                        |
| 628 | +			} else { | 
                                                        |
| 629 | +        	    print $langs->trans("Unknown"); | 
                                                        |
| 630 | + }  | 
                                                        |
| 454 | 631 | }  | 
                                                        
| 455 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 456 | - else print '<br>';  | 
                                                        |
| 632 | +        if ($usetable) { | 
                                                        |
| 633 | + print '</td></tr>';  | 
                                                        |
| 634 | +        } else { | 
                                                        |
| 635 | + print '<br>';  | 
                                                        |
| 636 | + }  | 
                                                        |
| 457 | 637 | }  | 
                                                        
| 458 | 638 | |
| 459 | 639 | // Date conciliate  | 
                                                        
| 460 | 640 | if (! empty($object->date_rappro))  | 
                                                        
| 461 | 641 |      {
 | 
                                                        
| 462 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 642 | +        if ($usetable) { | 
                                                        |
| 643 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 644 | + }  | 
                                                        |
| 463 | 645 |          print $langs->trans("DateConciliating");
 | 
                                                        
| 464 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 465 | - else print ': ';  | 
                                                        |
| 646 | +        if ($usetable) { | 
                                                        |
| 647 | + print '</td><td>';  | 
                                                        |
| 648 | +        } else { | 
                                                        |
| 649 | + print ': ';  | 
                                                        |
| 650 | + }  | 
                                                        |
| 466 | 651 | print dol_print_date($object->date_rappro, 'dayhour');  | 
                                                        
| 467 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_rappro+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 468 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 469 | - else print '<br>';  | 
                                                        |
| 652 | +        if ($deltadateforuser) { | 
                                                        |
| 653 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_rappro+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 654 | + }  | 
                                                        |
| 655 | +        if ($usetable) { | 
                                                        |
| 656 | + print '</td></tr>';  | 
                                                        |
| 657 | +        } else { | 
                                                        |
| 658 | + print '<br>';  | 
                                                        |
| 659 | + }  | 
                                                        |
| 470 | 660 | }  | 
                                                        
| 471 | 661 | |
| 472 | 662 | // Date send  | 
                                                        
| 473 | 663 | if (! empty($object->date_envoi))  | 
                                                        
| 474 | 664 |      {
 | 
                                                        
| 475 | - if ($usetable) print '<tr><td class="titlefield">';  | 
                                                        |
| 665 | +        if ($usetable) { | 
                                                        |
| 666 | + print '<tr><td class="titlefield">';  | 
                                                        |
| 667 | + }  | 
                                                        |
| 476 | 668 |          print $langs->trans("DateLastSend");
 | 
                                                        
| 477 | - if ($usetable) print '</td><td>';  | 
                                                        |
| 478 | - else print ': ';  | 
                                                        |
| 669 | +        if ($usetable) { | 
                                                        |
| 670 | + print '</td><td>';  | 
                                                        |
| 671 | +        } else { | 
                                                        |
| 672 | + print ': ';  | 
                                                        |
| 673 | + }  | 
                                                        |
| 479 | 674 | print dol_print_date($object->date_envoi, 'dayhour');  | 
                                                        
| 480 | -        if ($deltadateforuser) print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_envoi+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour");
 | 
                                                        |
| 481 | - if ($usetable) print '</td></tr>';  | 
                                                        |
| 482 | - else print '<br>';  | 
                                                        |
| 675 | +        if ($deltadateforuser) { | 
                                                        |
| 676 | +            print ' '.$langs->trans("CurrentHour").'   /   '.dol_print_date($object->date_envoi+($deltadateforuser*3600),"dayhour").'  '.$langs->trans("ClientHour"); | 
                                                        |
| 677 | + }  | 
                                                        |
| 678 | +        if ($usetable) { | 
                                                        |
| 679 | + print '</td></tr>';  | 
                                                        |
| 680 | +        } else { | 
                                                        |
| 681 | + print '<br>';  | 
                                                        |
| 682 | + }  | 
                                                        |
| 483 | 683 | }  | 
                                                        
| 484 | 684 | |
| 485 | - if ($usetable) print '</table>';  | 
                                                        |
| 486 | -}  | 
                                                        |
| 685 | +    if ($usetable) { | 
                                                        |
| 686 | + print '</table>';  | 
                                                        |
| 687 | + }  | 
                                                        |
| 688 | + }  | 
                                                        |
| 487 | 689 | |
| 488 | 690 | |
| 489 | 691 | /**  | 
                                                        
@@ -512,8 +714,7 @@ discard block  | 
                                                    ||
| 512 | 714 | if (checkdnsrr($domain, "MX"))  | 
                                                        
| 513 | 715 |      {
 | 
                                                        
| 514 | 716 | return true;  | 
                                                        
| 515 | - }  | 
                                                        |
| 516 | - else  | 
                                                        |
| 717 | + } else  | 
                                                        |
| 517 | 718 |      {
 | 
                                                        
| 518 | 719 | return false;  | 
                                                        
| 519 | 720 | }  | 
                                                        
@@ -538,10 +739,14 @@ discard block  | 
                                                    ||
| 538 | 739 | $urlregex = '';  | 
                                                        
| 539 | 740 | |
| 540 | 741 | // SCHEME  | 
                                                        
| 541 | - if ($http) $urlregex .= "^(http:\/\/|https:\/\/)";  | 
                                                        |
| 742 | +    if ($http) { | 
                                                        |
| 743 | + $urlregex .= "^(http:\/\/|https:\/\/)";  | 
                                                        |
| 744 | + }  | 
                                                        |
| 542 | 745 | |
| 543 | 746 | // USER AND PASS  | 
                                                        
| 544 | - if ($pass) $urlregex .= "([a-z0-9+!*(),;?&=\$_.-]+(\:[a-z0-9+!*(),;?&=\$_.-]+)?@)";  | 
                                                        |
| 747 | +    if ($pass) { | 
                                                        |
| 748 | + $urlregex .= "([a-z0-9+!*(),;?&=\$_.-]+(\:[a-z0-9+!*(),;?&=\$_.-]+)?@)";  | 
                                                        |
| 749 | + }  | 
                                                        |
| 545 | 750 | |
| 546 | 751 | // HOSTNAME OR IP  | 
                                                        
| 547 | 752 | //$urlregex .= "[a-z0-9+\$_-]+(\.[a-z0-9+\$_-]+)*"; // x allowed (ex. http://localhost, http://routerlogin)  | 
                                                        
@@ -550,13 +755,21 @@ discard block  | 
                                                    ||
| 550 | 755 | //use only one of the above  | 
                                                        
| 551 | 756 | |
| 552 | 757 | // PORT  | 
                                                        
| 553 | -    if ($port) $urlregex .= "(\:[0-9]{2,5})";
 | 
                                                        |
| 758 | +    if ($port) { | 
                                                        |
| 759 | +        $urlregex .= "(\:[0-9]{2,5})"; | 
                                                        |
| 760 | + }  | 
                                                        |
| 554 | 761 | // PATH  | 
                                                        
| 555 | - if ($path) $urlregex .= "(\/([a-z0-9+\$_-]\.?)+)*\/";  | 
                                                        |
| 762 | +    if ($path) { | 
                                                        |
| 763 | + $urlregex .= "(\/([a-z0-9+\$_-]\.?)+)*\/";  | 
                                                        |
| 764 | + }  | 
                                                        |
| 556 | 765 | // GET Query  | 
                                                        
| 557 | - if ($query) $urlregex .= "(\?[a-z+&\$_.-][a-z0-9;:@\/&%=+\$_.-]*)";  | 
                                                        |
| 766 | +    if ($query) { | 
                                                        |
| 767 | + $urlregex .= "(\?[a-z+&\$_.-][a-z0-9;:@\/&%=+\$_.-]*)";  | 
                                                        |
| 768 | + }  | 
                                                        |
| 558 | 769 | // ANCHOR  | 
                                                        
| 559 | - if ($anchor) $urlregex .= "(#[a-z_.-][a-z0-9+\$_.-]*)$";  | 
                                                        |
| 770 | +    if ($anchor) { | 
                                                        |
| 771 | + $urlregex .= "(#[a-z_.-][a-z0-9+\$_.-]*)$";  | 
                                                        |
| 772 | + }  | 
                                                        |
| 560 | 773 | |
| 561 | 774 | // check  | 
                                                        
| 562 | 775 |      if (preg_match('/'.$urlregex.'/i', $url))
 | 
                                                        
@@ -604,9 +817,10 @@ discard block  | 
                                                    ||
| 604 | 817 |          $CleanUrl = preg_replace('/^'.preg_quote($proto.$domain,'/').'/i', $newproto.strtolower($domain), $url);
 | 
                                                        
| 605 | 818 | |
| 606 | 819 | return $CleanUrl;  | 
                                                        
| 820 | +    } else { | 
                                                        |
| 821 | + return $url;  | 
                                                        |
| 822 | + }  | 
                                                        |
| 607 | 823 | }  | 
                                                        
| 608 | - else return $url;  | 
                                                        |
| 609 | -}  | 
                                                        |
| 610 | 824 | |
| 611 | 825 | |
| 612 | 826 | |
@@ -623,7 +837,9 @@ discard block  | 
                                                    ||
| 623 | 837 | */  | 
                                                        
| 624 | 838 | function dolObfuscateEmail($mail, $replace="*", $nbreplace=8, $nbdisplaymail=4, $nbdisplaydomain=3, $displaytld=true)  | 
                                                        
| 625 | 839 |  {
 | 
                                                        
| 626 | - if(!isValidEmail($mail))return '';  | 
                                                        |
| 840 | +	if(!isValidEmail($mail)) { | 
                                                        |
| 841 | + return '';  | 
                                                        |
| 842 | + }  | 
                                                        |
| 627 | 843 |  	$tab = explode('@', $mail);
 | 
                                                        
| 628 | 844 |  	$tab2 = explode('.',$tab[1]);
 | 
                                                        
| 629 | 845 | $string_replace = '';  | 
                                                        
@@ -685,7 +901,9 @@ discard block  | 
                                                    ||
| 685 | 901 | function array2table($data,$tableMarkup=1,$tableoptions='',$troptions='',$tdoptions='')  | 
                                                        
| 686 | 902 |  {
 | 
                                                        
| 687 | 903 | $text='' ;  | 
                                                        
| 688 | - if($tableMarkup) $text = '<table '.$tableoptions.'>' ;  | 
                                                        |
| 904 | +    if($tableMarkup) { | 
                                                        |
| 905 | + $text = '<table '.$tableoptions.'>' ;  | 
                                                        |
| 906 | + }  | 
                                                        |
| 689 | 907 |      foreach($data as $key => $item){
 | 
                                                        
| 690 | 908 |          if(is_array($item)){
 | 
                                                        
| 691 | 909 | $text.=array2tr($item,$troptions,$tdoptions);  | 
                                                        
@@ -696,7 +914,9 @@ discard block  | 
                                                    ||
| 696 | 914 | $text.= '</tr>' ;  | 
                                                        
| 697 | 915 | }  | 
                                                        
| 698 | 916 | }  | 
                                                        
| 699 | - if($tableMarkup) $text.= '</table>' ;  | 
                                                        |
| 917 | +    if($tableMarkup) { | 
                                                        |
| 918 | + $text.= '</table>' ;  | 
                                                        |
| 919 | + }  | 
                                                        |
| 700 | 920 | return $text ;  | 
                                                        
| 701 | 921 | }  | 
                                                        
| 702 | 922 | |
@@ -720,15 +940,25 @@ discard block  | 
                                                    ||
| 720 | 940 |  {
 | 
                                                        
| 721 | 941 | global $conf,$user;  | 
                                                        
| 722 | 942 | |
| 723 | - if (! is_object($objsoc)) $valueforccc=$objsoc;  | 
                                                        |
| 724 | - else if ($table == "commande_fournisseur" || $table == "facture_fourn" ) $valueforccc=$objsoc->code_fournisseur;  | 
                                                        |
| 725 | - else $valueforccc=$objsoc->code_client;  | 
                                                        |
| 943 | +    if (! is_object($objsoc)) { | 
                                                        |
| 944 | + $valueforccc=$objsoc;  | 
                                                        |
| 945 | +    } else if ($table == "commande_fournisseur" || $table == "facture_fourn" ) { | 
                                                        |
| 946 | + $valueforccc=$objsoc->code_fournisseur;  | 
                                                        |
| 947 | +    } else { | 
                                                        |
| 948 | + $valueforccc=$objsoc->code_client;  | 
                                                        |
| 949 | + }  | 
                                                        |
| 726 | 950 | |
| 727 | 951 | $sharetable = $table;  | 
                                                        
| 728 | - if ($table == 'facture' || $table == 'invoice') $sharetable = 'invoicenumber'; // for getEntity function  | 
                                                        |
| 952 | +    if ($table == 'facture' || $table == 'invoice') { | 
                                                        |
| 953 | + $sharetable = 'invoicenumber';  | 
                                                        |
| 954 | + }  | 
                                                        |
| 955 | + // for getEntity function  | 
                                                        |
| 729 | 956 | |
| 730 | 957 | // Clean parameters  | 
                                                        
| 731 | - if ($date == '') $date=dol_now(); // We use local year and month of PHP server to search numbers  | 
                                                        |
| 958 | +    if ($date == '') { | 
                                                        |
| 959 | + $date=dol_now();  | 
                                                        |
| 960 | + }  | 
                                                        |
| 961 | + // We use local year and month of PHP server to search numbers  | 
                                                        |
| 732 | 962 | // but we should use local year and month of user  | 
                                                        
| 733 | 963 | |
| 734 | 964 | // For debugging  | 
                                                        
@@ -745,8 +975,7 @@ discard block  | 
                                                    ||
| 745 | 975 | $masktri=$reg[1].(! empty($reg[2])?$reg[2]:'').(! empty($reg[3])?$reg[3]:'');  | 
                                                        
| 746 | 976 | $maskcounter=$reg[1];  | 
                                                        
| 747 | 977 | $hasglobalcounter=true;  | 
                                                        
| 748 | - }  | 
                                                        |
| 749 | - else  | 
                                                        |
| 978 | + } else  | 
                                                        |
| 750 | 979 |      {
 | 
                                                        
| 751 | 980 | // setting some defaults so the rest of the code won't fail if there is a third party counter  | 
                                                        
| 752 | 981 | $masktri='00000';  | 
                                                        
@@ -756,7 +985,9 @@ discard block  | 
                                                    ||
| 756 | 985 | $maskraz=-1;  | 
                                                        
| 757 | 986 | $maskoffset=0;  | 
                                                        
| 758 | 987 | $resetEveryMonth=false;  | 
                                                        
| 759 | - if (dol_strlen($maskcounter) < 3 && empty($conf->global->MAIN_COUNTER_WITH_LESS_3_DIGITS)) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 988 | +    if (dol_strlen($maskcounter) < 3 && empty($conf->global->MAIN_COUNTER_WITH_LESS_3_DIGITS)) { | 
                                                        |
| 989 | + return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 990 | + }  | 
                                                        |
| 760 | 991 | |
| 761 | 992 | // Extract value for third party mask counter  | 
                                                        
| 762 | 993 |      if (preg_match('/\{(c+)(0*)\}/i',$mask,$regClientRef))
 | 
                                                        
@@ -768,9 +999,12 @@ discard block  | 
                                                    ||
| 768 | 999 | $maskrefclient_clientcode=substr($valueforccc,0,dol_strlen($maskrefclient_maskclientcode));//get n first characters of client code where n is length in mask  | 
                                                        
| 769 | 1000 | $maskrefclient_clientcode=str_pad($maskrefclient_clientcode,dol_strlen($maskrefclient_maskclientcode),"#",STR_PAD_RIGHT);//padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        
| 770 | 1001 | $maskrefclient_clientcode=dol_string_nospecial($maskrefclient_clientcode);//sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        
| 771 | - if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 772 | - }  | 
                                                        |
| 773 | - else $maskrefclient='';  | 
                                                        |
| 1002 | +        if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) { | 
                                                        |
| 1003 | + return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 1004 | + }  | 
                                                        |
| 1005 | +    } else { | 
                                                        |
| 1006 | + $maskrefclient='';  | 
                                                        |
| 1007 | + }  | 
                                                        |
| 774 | 1008 | |
| 775 | 1009 | // fail if there is neither a global nor a third party counter  | 
                                                        
| 776 | 1010 | if (! $hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        
@@ -784,8 +1018,7 @@ discard block  | 
                                                    ||
| 784 | 1018 | $masktype=$regType[1];  | 
                                                        
| 785 | 1019 |          $masktype_value=substr(preg_replace('/^TE_/','',$objsoc->typent_code),0,dol_strlen($regType[1]));// get n first characters of thirdpaty typent_code (where n is length in mask)
 | 
                                                        
| 786 | 1020 | $masktype_value=str_pad($masktype_value,dol_strlen($regType[1]),"#",STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        
| 787 | - }  | 
                                                        |
| 788 | - else  | 
                                                        |
| 1021 | + } else  | 
                                                        |
| 789 | 1022 |      {
 | 
                                                        
| 790 | 1023 | $masktype='';  | 
                                                        
| 791 | 1024 | $masktype_value='';  | 
                                                        
@@ -795,13 +1028,14 @@ discard block  | 
                                                    ||
| 795 | 1028 |      if (preg_match('/\{(u+)\}/i',$mask,$regType))
 | 
                                                        
| 796 | 1029 |      {
 | 
                                                        
| 797 | 1030 | $lastname = 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';  | 
                                                        
| 798 | - if (is_object($objuser)) $lastname = $objuser->lastname;  | 
                                                        |
| 1031 | +    	if (is_object($objuser)) { | 
                                                        |
| 1032 | + $lastname = $objuser->lastname;  | 
                                                        |
| 1033 | + }  | 
                                                        |
| 799 | 1034 | |
| 800 | 1035 | $maskuser=$regType[1];  | 
                                                        
| 801 | 1036 | $maskuser_value=substr($lastname,0,dol_strlen($regType[1]));// get n first characters of user firstname (where n is length in mask)  | 
                                                        
| 802 | 1037 | $maskuser_value=str_pad($maskuser_value,dol_strlen($regType[1]),"#",STR_PAD_RIGHT); // we fill on right with # to have same number of char than into mask  | 
                                                        
| 803 | - }  | 
                                                        |
| 804 | - else  | 
                                                        |
| 1038 | + } else  | 
                                                        |
| 805 | 1039 |      {
 | 
                                                        
| 806 | 1040 | $maskuser='';  | 
                                                        
| 807 | 1041 | $maskuser_value='';  | 
                                                        
@@ -848,8 +1082,12 @@ discard block  | 
                                                    ||
| 848 | 1082 | //var_dump($reg);  | 
                                                        
| 849 | 1083 | |
| 850 | 1084 | // If an offset is asked  | 
                                                        
| 851 | -    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) $maskoffset=preg_replace('/^\+/','',$reg[2]);
 | 
                                                        |
| 852 | -    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) $maskoffset=preg_replace('/^\+/','',$reg[3]);
 | 
                                                        |
| 1085 | +    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) { | 
                                                        |
| 1086 | +        $maskoffset=preg_replace('/^\+/','',$reg[2]); | 
                                                        |
| 1087 | + }  | 
                                                        |
| 1088 | +    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) { | 
                                                        |
| 1089 | +        $maskoffset=preg_replace('/^\+/','',$reg[3]); | 
                                                        |
| 1090 | + }  | 
                                                        |
| 853 | 1091 | |
| 854 | 1092 | // Define $sqlwhere  | 
                                                        
| 855 | 1093 | $sqlwhere='';  | 
                                                        
@@ -857,14 +1095,21 @@ discard block  | 
                                                    ||
| 857 | 1095 | $yearoffsettype=false; // false: no reset, 0,-,=,+: reset at offset SOCIETE_FISCAL_MONTH_START, x=reset at offset x  | 
                                                        
| 858 | 1096 | |
| 859 | 1097 | // If a restore to zero after a month is asked we check if there is already a value for this year.  | 
                                                        
| 860 | -    if (! empty($reg[2]) && preg_match('/^@/',$reg[2]))	$yearoffsettype = preg_replace('/^@/','',$reg[2]);
 | 
                                                        |
| 861 | -    if (! empty($reg[3]) && preg_match('/^@/',$reg[3]))	$yearoffsettype = preg_replace('/^@/','',$reg[3]);
 | 
                                                        |
| 1098 | +    if (! empty($reg[2]) && preg_match('/^@/',$reg[2])) { | 
                                                        |
| 1099 | +        $yearoffsettype = preg_replace('/^@/','',$reg[2]); | 
                                                        |
| 1100 | + }  | 
                                                        |
| 1101 | +    if (! empty($reg[3]) && preg_match('/^@/',$reg[3])) { | 
                                                        |
| 1102 | +        $yearoffsettype = preg_replace('/^@/','',$reg[3]); | 
                                                        |
| 1103 | + }  | 
                                                        |
| 862 | 1104 | |
| 863 | 1105 | //print "yearoffset=".$yearoffset." yearoffsettype=".$yearoffsettype;  | 
                                                        
| 864 | - if (is_numeric($yearoffsettype) && $yearoffsettype >= 1)  | 
                                                        |
| 865 | - $maskraz=$yearoffsettype; // For backward compatibility  | 
                                                        |
| 866 | - else if ($yearoffsettype === '0' || (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $conf->global->SOCIETE_FISCAL_MONTH_START > 1))  | 
                                                        |
| 867 | - $maskraz = $conf->global->SOCIETE_FISCAL_MONTH_START;  | 
                                                        |
| 1106 | +    if (is_numeric($yearoffsettype) && $yearoffsettype >= 1) { | 
                                                        |
| 1107 | + $maskraz=$yearoffsettype;  | 
                                                        |
| 1108 | + }  | 
                                                        |
| 1109 | + // For backward compatibility  | 
                                                        |
| 1110 | +    else if ($yearoffsettype === '0' || (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $conf->global->SOCIETE_FISCAL_MONTH_START > 1)) { | 
                                                        |
| 1111 | + $maskraz = $conf->global->SOCIETE_FISCAL_MONTH_START;  | 
                                                        |
| 1112 | + }  | 
                                                        |
| 868 | 1113 | //print "maskraz=".$maskraz; // -1=no reset  | 
                                                        
| 869 | 1114 | |
| 870 | 1115 |      if ($maskraz > 0) {   // A reset is required
 | 
                                                        
@@ -872,23 +1117,28 @@ discard block  | 
                                                    ||
| 872 | 1117 |              $maskraz = date('m', $date);
 | 
                                                        
| 873 | 1118 | $resetEveryMonth = true;  | 
                                                        
| 874 | 1119 | }  | 
                                                        
| 875 | - if ($maskraz > 12) return 'ErrorBadMaskBadRazMonth';  | 
                                                        |
| 1120 | +        if ($maskraz > 12) { | 
                                                        |
| 1121 | + return 'ErrorBadMaskBadRazMonth';  | 
                                                        |
| 1122 | + }  | 
                                                        |
| 876 | 1123 | |
| 877 | 1124 | // Define posy, posm and reg  | 
                                                        
| 878 | - if ($maskraz > 1) // if reset is not first month, we need month and year into mask  | 
                                                        |
| 1125 | +        if ($maskraz > 1) { | 
                                                        |
| 1126 | + // if reset is not first month, we need month and year into mask  | 
                                                        |
| 879 | 1127 |          {
 | 
                                                        
| 880 | -            if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=3; }
 | 
                                                        |
| 881 | -            elseif (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; }
 | 
                                                        |
| 882 | - else return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';  | 
                                                        |
| 883 | -  | 
                                                        |
| 884 | - if (dol_strlen($reg[$posy]) < 2) return 'ErrorCantUseRazWithYearOnOneDigit';  | 
                                                        |
| 885 | - }  | 
                                                        |
| 886 | - else // if reset is for a specific month in year, we need year  | 
                                                        |
| 1128 | +            if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; | 
                                                        |
| 1129 | + }  | 
                                                        |
| 1130 | +        $posm=3; } elseif (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; } else { | 
                                                        |
| 1131 | + return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';  | 
                                                        |
| 1132 | + }  | 
                                                        |
| 1133 | +  | 
                                                        |
| 1134 | +            if (dol_strlen($reg[$posy]) < 2) { | 
                                                        |
| 1135 | + return 'ErrorCantUseRazWithYearOnOneDigit';  | 
                                                        |
| 1136 | + }  | 
                                                        |
| 1137 | + } else // if reset is for a specific month in year, we need year  | 
                                                        |
| 887 | 1138 |          {
 | 
                                                        
| 888 | -            if (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; }
 | 
                                                        |
| 889 | -        	else if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=3; }
 | 
                                                        |
| 890 | -            else if (preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=0; }
 | 
                                                        |
| 891 | - else return 'ErrorCantUseRazIfNoYearInMask';  | 
                                                        |
| 1139 | +            if (preg_match('/^(.*)\{(m+)\}\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=3; $posm=2; } else if (preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=3; } else if (preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) { $posy=2; $posm=0; } else { | 
                                                        |
| 1140 | + return 'ErrorCantUseRazIfNoYearInMask';  | 
                                                        |
| 1141 | + }  | 
                                                        |
| 892 | 1142 | }  | 
                                                        
| 893 | 1143 | // Define length  | 
                                                        
| 894 | 1144 | $yearlen = $posy?dol_strlen($reg[$posy]):0;  | 
                                                        
@@ -906,9 +1156,11 @@ discard block  | 
                                                    ||
| 906 | 1156 | $monthcomp=$maskraz;  | 
                                                        
| 907 | 1157 | $yearcomp=0;  | 
                                                        
| 908 | 1158 | |
| 909 | - if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') // $yearoffsettype is - or +  | 
                                                        |
| 1159 | +        if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') { | 
                                                        |
| 1160 | + // $yearoffsettype is - or +  | 
                                                        |
| 910 | 1161 |          {
 | 
                                                        
| 911 | -        	$currentyear=date("Y", $date);
 | 
                                                        |
| 1162 | +        	$currentyear=date("Y", $date); | 
                                                        |
| 1163 | + }  | 
                                                        |
| 912 | 1164 |          	$fiscaldate=dol_mktime('0','0','0',$maskraz,'1',$currentyear);
 | 
                                                        
| 913 | 1165 |          	$newyeardate=dol_mktime('0','0','0','1','1',$currentyear);
 | 
                                                        
| 914 | 1166 |          	$nextnewyeardate=dol_mktime('0','0','0','1','1',$currentyear+1);
 | 
                                                        
@@ -918,21 +1170,32 @@ discard block  | 
                                                    ||
| 918 | 1170 | if ($date >= $fiscaldate)  | 
                                                        
| 919 | 1171 |          	{
 | 
                                                        
| 920 | 1172 | // If before of next new year date  | 
                                                        
| 921 | - if ($date < $nextnewyeardate && $yearoffsettype == '+') $yearoffset=1;  | 
                                                        |
| 1173 | +        		if ($date < $nextnewyeardate && $yearoffsettype == '+') { | 
                                                        |
| 1174 | + $yearoffset=1;  | 
                                                        |
| 1175 | + }  | 
                                                        |
| 922 | 1176 | }  | 
                                                        
| 923 | 1177 | // If after or equal of current new year date  | 
                                                        
| 924 | - else if ($date >= $newyeardate && $yearoffsettype == '-') $yearoffset=-1;  | 
                                                        |
| 1178 | +        	else if ($date >= $newyeardate && $yearoffsettype == '-') { | 
                                                        |
| 1179 | + $yearoffset=-1;  | 
                                                        |
| 1180 | + }  | 
                                                        |
| 925 | 1181 | }  | 
                                                        
| 926 | 1182 | // For backward compatibility  | 
                                                        
| 927 | 1183 |          else if (date("m",$date) < $maskraz && empty($resetEveryMonth)) { $yearoffset=-1; }	// If current month lower that month of return to zero, year is previous year
 | 
                                                        
| 928 | 1184 | |
| 929 | -        if ($yearlen == 4) $yearcomp=sprintf("%04d",date("Y",$date)+$yearoffset);
 | 
                                                        |
| 930 | -        elseif ($yearlen == 2) $yearcomp=sprintf("%02d",date("y",$date)+$yearoffset);
 | 
                                                        |
| 931 | -        elseif ($yearlen == 1) $yearcomp=substr(date("y",$date),2,1)+$yearoffset;
 | 
                                                        |
| 932 | - if ($monthcomp > 1 && empty($resetEveryMonth)) // Test with month is useless if monthcomp = 0 or 1 (0 is same as 1) (regis: $monthcomp can't equal 0)  | 
                                                        |
| 1185 | +        if ($yearlen == 4) { | 
                                                        |
| 1186 | +            $yearcomp=sprintf("%04d",date("Y",$date)+$yearoffset); | 
                                                        |
| 1187 | +        } elseif ($yearlen == 2) { | 
                                                        |
| 1188 | +            $yearcomp=sprintf("%02d",date("y",$date)+$yearoffset); | 
                                                        |
| 1189 | +        } elseif ($yearlen == 1) { | 
                                                        |
| 1190 | +            $yearcomp=substr(date("y",$date),2,1)+$yearoffset; | 
                                                        |
| 1191 | + }  | 
                                                        |
| 1192 | +        if ($monthcomp > 1 && empty($resetEveryMonth)) { | 
                                                        |
| 1193 | + // Test with month is useless if monthcomp = 0 or 1 (0 is same as 1) (regis: $monthcomp can't equal 0)  | 
                                                        |
| 933 | 1194 |          {
 | 
                                                        
| 934 | -            if ($yearlen == 4) $yearcomp1=sprintf("%04d",date("Y",$date)+$yearoffset+1);
 | 
                                                        |
| 935 | -            elseif ($yearlen == 2) $yearcomp1=sprintf("%02d",date("y",$date)+$yearoffset+1);
 | 
                                                        |
| 1195 | +            if ($yearlen == 4) $yearcomp1=sprintf("%04d",date("Y",$date)+$yearoffset+1); | 
                                                        |
| 1196 | +        } elseif ($yearlen == 2) { | 
                                                        |
| 1197 | +                $yearcomp1=sprintf("%02d",date("y",$date)+$yearoffset+1); | 
                                                        |
| 1198 | + }  | 
                                                        |
| 936 | 1199 | |
| 937 | 1200 |              $sqlwhere.="(";
 | 
                                                        
| 938 | 1201 |              $sqlwhere.=" (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        
@@ -941,13 +1204,11 @@ discard block  | 
                                                    ||
| 941 | 1204 |              $sqlwhere.=" (SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp1."'";
 | 
                                                        
| 942 | 1205 |              $sqlwhere.=" AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") < '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."') ";
 | 
                                                        
| 943 | 1206 | $sqlwhere.=')';  | 
                                                        
| 944 | - }  | 
                                                        |
| 945 | - else if ($resetEveryMonth)  | 
                                                        |
| 1207 | + } else if ($resetEveryMonth)  | 
                                                        |
| 946 | 1208 |  		{
 | 
                                                        
| 947 | 1209 |  			$sqlwhere.="(SUBSTRING(".$field.", ".$yearpos.", ".$yearlen.") = '".$yearcomp."'";
 | 
                                                        
| 948 | 1210 |              $sqlwhere.=" AND SUBSTRING(".$field.", ".$monthpos.", ".$monthlen.") = '".str_pad($monthcomp, $monthlen, '0', STR_PAD_LEFT)."')";
 | 
                                                        
| 949 | - }  | 
                                                        |
| 950 | - else // reset is done on january  | 
                                                        |
| 1211 | + } else // reset is done on january  | 
                                                        |
| 951 | 1212 |          {
 | 
                                                        
| 952 | 1213 |              $sqlwhere.='(SUBSTRING('.$field.', '.$yearpos.', '.$yearlen.") = '".$yearcomp."')";
 | 
                                                        
| 953 | 1214 | }  | 
                                                        
@@ -959,12 +1220,13 @@ discard block  | 
                                                    ||
| 959 | 1220 |      if (function_exists('mb_strrpos'))
 | 
                                                        
| 960 | 1221 |      	{
 | 
                                                        
| 961 | 1222 | $posnumstart=mb_strrpos($maskwithnocode,$maskcounter, 'UTF-8');  | 
                                                        
| 962 | - }  | 
                                                        |
| 963 | - else  | 
                                                        |
| 1223 | + } else  | 
                                                        |
| 964 | 1224 |  	{
 | 
                                                        
| 965 | 1225 | $posnumstart=strrpos($maskwithnocode,$maskcounter);  | 
                                                        
| 966 | 1226 | } // Pos of counter in final string (from 0 to ...)  | 
                                                        
| 967 | - if ($posnumstart < 0) return 'ErrorBadMaskFailedToLocatePosOfSequence';  | 
                                                        |
| 1227 | +    if ($posnumstart < 0) { | 
                                                        |
| 1228 | + return 'ErrorBadMaskFailedToLocatePosOfSequence';  | 
                                                        |
| 1229 | + }  | 
                                                        |
| 968 | 1230 |      $sqlstring='SUBSTRING('.$field.', '.($posnumstart+1).', '.dol_strlen($maskcounter).')';
 | 
                                                        
| 969 | 1231 | |
| 970 | 1232 | // Define $maskLike  | 
                                                        
@@ -977,9 +1239,15 @@ discard block  | 
                                                    ||
| 977 | 1239 |      $maskLike = preg_replace('/\{mm\}/i','__',$maskLike);
 | 
                                                        
| 978 | 1240 |      $maskLike = preg_replace('/\{dd\}/i','__',$maskLike);
 | 
                                                        
| 979 | 1241 |      $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'),str_pad("",dol_strlen($maskcounter),"_"),$maskLike);
 | 
                                                        
| 980 | -    if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike);
 | 
                                                        |
| 981 | -    if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike);
 | 
                                                        |
| 982 | -    if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike);
 | 
                                                        |
| 1242 | +    if ($maskrefclient) { | 
                                                        |
| 1243 | +        $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike); | 
                                                        |
| 1244 | + }  | 
                                                        |
| 1245 | +    if ($masktype) { | 
                                                        |
| 1246 | +        $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike); | 
                                                        |
| 1247 | + }  | 
                                                        |
| 1248 | +    if ($maskuser) { | 
                                                        |
| 1249 | +        $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike); | 
                                                        |
| 1250 | + }  | 
                                                        |
| 983 | 1251 | foreach($maskperso as $key => $val)  | 
                                                        
| 984 | 1252 |      {
 | 
                                                        
| 985 | 1253 | $maskLike = str_replace(dol_string_nospecial($maskperso[$key]),$maskpersonew[$key],$maskLike);  | 
                                                        
@@ -991,12 +1259,18 @@ discard block  | 
                                                    ||
| 991 | 1259 | $sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        
| 992 | 1260 | $sql.= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        
| 993 | 1261 | $sql.= " AND ".$field." NOT LIKE '(PROV%)'";  | 
                                                        
| 994 | - if ($bentityon) // only if entity enable  | 
                                                        |
| 995 | -    	$sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 996 | - else if (! empty($forceentity))  | 
                                                        |
| 997 | -    	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 998 | - if ($where) $sql.=$where;  | 
                                                        |
| 999 | - if ($sqlwhere) $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1262 | +    if ($bentityon) { | 
                                                        |
| 1263 | + // only if entity enable  | 
                                                        |
| 1264 | +    	$sql.= " AND entity IN (".getEntity($sharetable).")"; | 
                                                        |
| 1265 | +    } else if (! empty($forceentity)) { | 
                                                        |
| 1266 | +        	$sql.= " AND entity IN (".$forceentity.")"; | 
                                                        |
| 1267 | + }  | 
                                                        |
| 1268 | +    if ($where) { | 
                                                        |
| 1269 | + $sql.=$where;  | 
                                                        |
| 1270 | + }  | 
                                                        |
| 1271 | +    if ($sqlwhere) { | 
                                                        |
| 1272 | + $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1273 | + }  | 
                                                        |
| 1000 | 1274 | |
| 1001 | 1275 | //print $sql.'<br>';  | 
                                                        
| 1002 | 1276 |      dol_syslog("functions2::get_next_value mode=".$mode."", LOG_DEBUG);
 | 
                                                        
@@ -1005,21 +1279,26 @@ discard block  | 
                                                    ||
| 1005 | 1279 |      {
 | 
                                                        
| 1006 | 1280 | $obj = $db->fetch_object($resql);  | 
                                                        
| 1007 | 1281 | $counter = $obj->val;  | 
                                                        
| 1008 | - }  | 
                                                        |
| 1009 | - else dol_print_error($db);  | 
                                                        |
| 1282 | +    } else { | 
                                                        |
| 1283 | + dol_print_error($db);  | 
                                                        |
| 1284 | + }  | 
                                                        |
| 1010 | 1285 | |
| 1011 | 1286 | // Check if we must force counter to maskoffset  | 
                                                        
| 1012 | - if (empty($counter)) $counter=$maskoffset;  | 
                                                        |
| 1013 | -    else if (preg_match('/[^0-9]/i',$counter))
 | 
                                                        |
| 1287 | +    if (empty($counter)) { | 
                                                        |
| 1288 | + $counter=$maskoffset;  | 
                                                        |
| 1289 | +    } else if (preg_match('/[^0-9]/i',$counter))
 | 
                                                        |
| 1014 | 1290 |      {
 | 
                                                        
| 1015 | 1291 | $counter=0;  | 
                                                        
| 1016 | 1292 |      	dol_syslog("Error, the last counter found is '".$counter."' so is not a numeric value. We will restart to 1.", LOG_ERR);
 | 
                                                        
| 1017 | - }  | 
                                                        |
| 1018 | - else if ($counter < $maskoffset && empty($conf->global->MAIN_NUMBERING_OFFSET_ONLY_FOR_FIRST)) $counter=$maskoffset;  | 
                                                        |
| 1293 | +    } else if ($counter < $maskoffset && empty($conf->global->MAIN_NUMBERING_OFFSET_ONLY_FOR_FIRST)) { | 
                                                        |
| 1294 | + $counter=$maskoffset;  | 
                                                        |
| 1295 | + }  | 
                                                        |
| 1019 | 1296 | |
| 1020 | - if ($mode == 'last') // We found value for counter = last counter value. Now need to get corresponding ref of invoice.  | 
                                                        |
| 1297 | +    if ($mode == 'last') { | 
                                                        |
| 1298 | + // We found value for counter = last counter value. Now need to get corresponding ref of invoice.  | 
                                                        |
| 1021 | 1299 |      {
 | 
                                                        
| 1022 | - $counterpadded=str_pad($counter,dol_strlen($maskcounter),"0",STR_PAD_LEFT);  | 
                                                        |
| 1300 | + $counterpadded=str_pad($counter,dol_strlen($maskcounter),"0",STR_PAD_LEFT);  | 
                                                        |
| 1301 | + }  | 
                                                        |
| 1023 | 1302 | |
| 1024 | 1303 | // Define $maskLike  | 
                                                        
| 1025 | 1304 | $maskLike = dol_string_nospecial($mask);  | 
                                                        
@@ -1031,34 +1310,48 @@ discard block  | 
                                                    ||
| 1031 | 1310 |          $maskLike = preg_replace('/\{mm\}/i','__',$maskLike);
 | 
                                                        
| 1032 | 1311 |          $maskLike = preg_replace('/\{dd\}/i','__',$maskLike);
 | 
                                                        
| 1033 | 1312 |          $maskLike = str_replace(dol_string_nospecial('{'.$masktri.'}'),$counterpadded,$maskLike);
 | 
                                                        
| 1034 | -        if ($maskrefclient) $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike);
 | 
                                                        |
| 1035 | -        if ($masktype) $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike);
 | 
                                                        |
| 1036 | -        if ($maskuser) $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike);
 | 
                                                        |
| 1313 | +        if ($maskrefclient) { | 
                                                        |
| 1314 | +            $maskLike = str_replace(dol_string_nospecial('{'.$maskrefclient.'}'),str_pad("",dol_strlen($maskrefclient),"_"),$maskLike); | 
                                                        |
| 1315 | + }  | 
                                                        |
| 1316 | +        if ($masktype) { | 
                                                        |
| 1317 | +            $maskLike = str_replace(dol_string_nospecial('{'.$masktype.'}'),$masktype_value,$maskLike); | 
                                                        |
| 1318 | + }  | 
                                                        |
| 1319 | +        if ($maskuser) { | 
                                                        |
| 1320 | +            $maskLike = str_replace(dol_string_nospecial('{'.$maskuser.'}'),$maskuser_value,$maskLike); | 
                                                        |
| 1321 | + }  | 
                                                        |
| 1037 | 1322 | |
| 1038 | 1323 | $ref='';  | 
                                                        
| 1039 | 1324 | $sql = "SELECT ".$field." as ref";  | 
                                                        
| 1040 | 1325 | $sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        
| 1041 | 1326 | $sql.= " WHERE ".$field." LIKE '".$maskLike."'";  | 
                                                        
| 1042 | 1327 | $sql.= " AND ".$field." NOT LIKE '%PROV%'";  | 
                                                        
| 1043 | - if ($bentityon) // only if entity enable  | 
                                                        |
| 1044 | -        	$sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1045 | - else if (! empty($forceentity))  | 
                                                        |
| 1046 | -        	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1047 | - if ($where) $sql.=$where;  | 
                                                        |
| 1048 | - if ($sqlwhere) $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1328 | +    	if ($bentityon) { | 
                                                        |
| 1329 | + // only if entity enable  | 
                                                        |
| 1330 | +        	$sql.= " AND entity IN (".getEntity($sharetable).")"; | 
                                                        |
| 1331 | +    	} else if (! empty($forceentity)) { | 
                                                        |
| 1332 | +                	$sql.= " AND entity IN (".$forceentity.")"; | 
                                                        |
| 1333 | + }  | 
                                                        |
| 1334 | +        if ($where) { | 
                                                        |
| 1335 | + $sql.=$where;  | 
                                                        |
| 1336 | + }  | 
                                                        |
| 1337 | +        if ($sqlwhere) { | 
                                                        |
| 1338 | + $sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1339 | + }  | 
                                                        |
| 1049 | 1340 | |
| 1050 | 1341 |          dol_syslog("functions2::get_next_value mode=".$mode."", LOG_DEBUG);
 | 
                                                        
| 1051 | 1342 | $resql=$db->query($sql);  | 
                                                        
| 1052 | 1343 | if ($resql)  | 
                                                        
| 1053 | 1344 |          {
 | 
                                                        
| 1054 | 1345 | $obj = $db->fetch_object($resql);  | 
                                                        
| 1055 | - if ($obj) $ref = $obj->ref;  | 
                                                        |
| 1056 | - }  | 
                                                        |
| 1057 | - else dol_print_error($db);  | 
                                                        |
| 1346 | +            if ($obj) { | 
                                                        |
| 1347 | + $ref = $obj->ref;  | 
                                                        |
| 1348 | + }  | 
                                                        |
| 1349 | +        } else { | 
                                                        |
| 1350 | + dol_print_error($db);  | 
                                                        |
| 1351 | + }  | 
                                                        |
| 1058 | 1352 | |
| 1059 | 1353 | $numFinal=$ref;  | 
                                                        
| 1060 | - }  | 
                                                        |
| 1061 | - else if ($mode == 'next')  | 
                                                        |
| 1354 | + } else if ($mode == 'next')  | 
                                                        |
| 1062 | 1355 |      {
 | 
                                                        
| 1063 | 1356 | $counter++;  | 
                                                        
| 1064 | 1357 | |
@@ -1074,7 +1367,9 @@ discard block  | 
                                                    ||
| 1074 | 1367 | |
| 1075 | 1368 | // Define $sqlstring  | 
                                                        
| 1076 | 1369 | $maskrefclient_posnumstart=strpos($maskwithnocode,$maskrefclient_maskcounter,strpos($maskwithnocode,$maskrefclient)); // Pos of counter in final string (from 0 to ...)  | 
                                                        
| 1077 | - if ($maskrefclient_posnumstart <= 0) return 'ErrorBadMask';  | 
                                                        |
| 1370 | +            if ($maskrefclient_posnumstart <= 0) { | 
                                                        |
| 1371 | + return 'ErrorBadMask';  | 
                                                        |
| 1372 | + }  | 
                                                        |
| 1078 | 1373 |              $maskrefclient_sqlstring='SUBSTRING('.$field.', '.($maskrefclient_posnumstart+1).', '.dol_strlen($maskrefclient_maskcounter).')';
 | 
                                                        
| 1079 | 1374 | //print "x".$sqlstring;  | 
                                                        
| 1080 | 1375 | |
@@ -1096,12 +1391,20 @@ discard block  | 
                                                    ||
| 1096 | 1391 | $maskrefclient_sql.= " FROM ".MAIN_DB_PREFIX.$table;  | 
                                                        
| 1097 | 1392 | //$sql.= " WHERE ".$field." not like '(%'";  | 
                                                        
| 1098 | 1393 | $maskrefclient_sql.= " WHERE ".$field." LIKE '".$maskrefclient_maskLike."'";  | 
                                                        
| 1099 | - if ($bentityon) // only if entity enable  | 
                                                        |
| 1100 | -            	$maskrefclient_sql.= " AND entity IN (".getEntity($sharetable).")";
 | 
                                                        |
| 1101 | - else if (! empty($forceentity))  | 
                                                        |
| 1102 | -            	$sql.= " AND entity IN (".$forceentity.")";
 | 
                                                        |
| 1103 | - if ($where) $maskrefclient_sql.=$where; //use the same optional where as general mask  | 
                                                        |
| 1104 | - if ($sqlwhere) $maskrefclient_sql.=' AND '.$sqlwhere; //use the same sqlwhere as general mask  | 
                                                        |
| 1394 | +            if ($bentityon) { | 
                                                        |
| 1395 | + // only if entity enable  | 
                                                        |
| 1396 | +            	$maskrefclient_sql.= " AND entity IN (".getEntity($sharetable).")"; | 
                                                        |
| 1397 | +            } else if (! empty($forceentity)) { | 
                                                        |
| 1398 | +                        	$sql.= " AND entity IN (".$forceentity.")"; | 
                                                        |
| 1399 | + }  | 
                                                        |
| 1400 | +            if ($where) { | 
                                                        |
| 1401 | + $maskrefclient_sql.=$where;  | 
                                                        |
| 1402 | + }  | 
                                                        |
| 1403 | + //use the same optional where as general mask  | 
                                                        |
| 1404 | +            if ($sqlwhere) { | 
                                                        |
| 1405 | + $maskrefclient_sql.=' AND '.$sqlwhere;  | 
                                                        |
| 1406 | + }  | 
                                                        |
| 1407 | + //use the same sqlwhere as general mask  | 
                                                        |
| 1105 | 1408 |              $maskrefclient_sql.=' AND (SUBSTRING('.$field.', '.(strpos($maskwithnocode,$maskrefclient)+1).', '.dol_strlen($maskrefclient_maskclientcode).")='".$maskrefclient_clientcode."')";
 | 
                                                        
| 1106 | 1409 | |
| 1107 | 1410 |              dol_syslog("functions2::get_next_value maskrefclient", LOG_DEBUG);
 | 
                                                        
@@ -1110,10 +1413,13 @@ discard block  | 
                                                    ||
| 1110 | 1413 |              {
 | 
                                                        
| 1111 | 1414 | $maskrefclient_obj = $db->fetch_object($maskrefclient_resql);  | 
                                                        
| 1112 | 1415 | $maskrefclient_counter = $maskrefclient_obj->val;  | 
                                                        
| 1113 | - }  | 
                                                        |
| 1114 | - else dol_print_error($db);  | 
                                                        |
| 1416 | +            } else { | 
                                                        |
| 1417 | + dol_print_error($db);  | 
                                                        |
| 1418 | + }  | 
                                                        |
| 1115 | 1419 | |
| 1116 | -            if (empty($maskrefclient_counter) || preg_match('/[^0-9]/i',$maskrefclient_counter)) $maskrefclient_counter=$maskrefclient_maskoffset;
 | 
                                                        |
| 1420 | +            if (empty($maskrefclient_counter) || preg_match('/[^0-9]/i',$maskrefclient_counter)) { | 
                                                        |
| 1421 | + $maskrefclient_counter=$maskrefclient_maskoffset;  | 
                                                        |
| 1422 | + }  | 
                                                        |
| 1117 | 1423 | $maskrefclient_counter++;  | 
                                                        
| 1118 | 1424 | }  | 
                                                        
| 1119 | 1425 | |
@@ -1121,13 +1427,14 @@ discard block  | 
                                                    ||
| 1121 | 1427 | $numFinal = $mask;  | 
                                                        
| 1122 | 1428 | |
| 1123 | 1429 | // We replace special codes except refclient  | 
                                                        
| 1124 | - if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') // yearoffsettype is - or +, so we don't want current year  | 
                                                        |
| 1430 | +		if (! empty($yearoffsettype) && ! is_numeric($yearoffsettype) && $yearoffsettype != '=') { | 
                                                        |
| 1431 | + // yearoffsettype is - or +, so we don't want current year  | 
                                                        |
| 1125 | 1432 |  		{
 | 
                                                        
| 1126 | -	        $numFinal = preg_replace('/\{yyyy\}/i',date("Y",$date)+$yearoffset, $numFinal);
 | 
                                                        |
| 1433 | +	        $numFinal = preg_replace('/\{yyyy\}/i',date("Y",$date)+$yearoffset, $numFinal); | 
                                                        |
| 1434 | + }  | 
                                                        |
| 1127 | 1435 |          	$numFinal = preg_replace('/\{yy\}/i',  date("y",$date)+$yearoffset, $numFinal);
 | 
                                                        
| 1128 | 1436 |          	$numFinal = preg_replace('/\{y\}/i',   substr(date("y",$date),1,1)+$yearoffset, $numFinal);
 | 
                                                        
| 1129 | - }  | 
                                                        |
| 1130 | - else // we want yyyy to be current year  | 
                                                        |
| 1437 | + } else // we want yyyy to be current year  | 
                                                        |
| 1131 | 1438 |  		{
 | 
                                                        
| 1132 | 1439 |          	$numFinal = preg_replace('/\{yyyy\}/i',date("Y",$date), $numFinal);
 | 
                                                        
| 1133 | 1440 |          	$numFinal = preg_replace('/\{yy\}/i',  date("y",$date), $numFinal);
 | 
                                                        
@@ -1184,7 +1491,9 @@ discard block  | 
                                                    ||
| 1184 | 1491 |  {
 | 
                                                        
| 1185 | 1492 | $string = " ".$string;  | 
                                                        
| 1186 | 1493 | $ini = strpos($string,$start);  | 
                                                        
| 1187 | - if ($ini == 0) return "";  | 
                                                        |
| 1494 | +     if ($ini == 0) { | 
                                                        |
| 1495 | + return "";  | 
                                                        |
| 1496 | + }  | 
                                                        |
| 1188 | 1497 | $ini += strlen($start);  | 
                                                        
| 1189 | 1498 | $len = strpos($string,$end,$ini) - $ini;  | 
                                                        
| 1190 | 1499 | return substr($string,$ini,$len);  | 
                                                        
@@ -1208,8 +1517,7 @@ discard block  | 
                                                    ||
| 1208 | 1517 | $masktri=$reg[1].(isset($reg[2])?$reg[2]:'').(isset($reg[3])?$reg[3]:'');  | 
                                                        
| 1209 | 1518 | $maskcounter=$reg[1];  | 
                                                        
| 1210 | 1519 | $hasglobalcounter=true;  | 
                                                        
| 1211 | - }  | 
                                                        |
| 1212 | - else  | 
                                                        |
| 1520 | + } else  | 
                                                        |
| 1213 | 1521 |      {
 | 
                                                        
| 1214 | 1522 | // setting some defaults so the rest of the code won't fail if there is a third party counter  | 
                                                        
| 1215 | 1523 | $masktri='00000';  | 
                                                        
@@ -1218,7 +1526,9 @@ discard block  | 
                                                    ||
| 1218 | 1526 | |
| 1219 | 1527 | $maskraz=-1;  | 
                                                        
| 1220 | 1528 | $maskoffset=0;  | 
                                                        
| 1221 | - if (dol_strlen($maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 1529 | +    if (dol_strlen($maskcounter) < 3) { | 
                                                        |
| 1530 | + return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 1531 | + }  | 
                                                        |
| 1222 | 1532 | |
| 1223 | 1533 | // Extract value for third party mask counter  | 
                                                        
| 1224 | 1534 |      if (preg_match('/\{(c+)(0*)\}/i',$mask,$regClientRef))
 | 
                                                        
@@ -1230,9 +1540,12 @@ discard block  | 
                                                    ||
| 1230 | 1540 |          $maskrefclient_clientcode=substr('',0,dol_strlen($maskrefclient_maskclientcode));//get n first characters of client code to form maskrefclient_clientcode
 | 
                                                        
| 1231 | 1541 | $maskrefclient_clientcode=str_pad($maskrefclient_clientcode,dol_strlen($maskrefclient_maskclientcode),"#",STR_PAD_RIGHT);//padding maskrefclient_clientcode for having exactly n characters in maskrefclient_clientcode  | 
                                                        
| 1232 | 1542 | $maskrefclient_clientcode=dol_string_nospecial($maskrefclient_clientcode);//sanitize maskrefclient_clientcode for sql insert and sql select like  | 
                                                        
| 1233 | - if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 1234 | - }  | 
                                                        |
| 1235 | - else $maskrefclient='';  | 
                                                        |
| 1543 | +        if (dol_strlen($maskrefclient_maskcounter) > 0 && dol_strlen($maskrefclient_maskcounter) < 3) { | 
                                                        |
| 1544 | + return 'ErrorCounterMustHaveMoreThan3Digits';  | 
                                                        |
| 1545 | + }  | 
                                                        |
| 1546 | +    } else { | 
                                                        |
| 1547 | + $maskrefclient='';  | 
                                                        |
| 1548 | + }  | 
                                                        |
| 1236 | 1549 | |
| 1237 | 1550 | // fail if there is neither a global nor a third party counter  | 
                                                        
| 1238 | 1551 | if (! $hasglobalcounter && ($maskrefclient_maskcounter == ''))  | 
                                                        
@@ -1254,21 +1567,35 @@ discard block  | 
                                                    ||
| 1254 | 1567 | //print "maskwithonlyymcode=".$maskwithonlyymcode." maskwithnocode=".$maskwithnocode."\n<br>";  | 
                                                        
| 1255 | 1568 | |
| 1256 | 1569 | // If an offset is asked  | 
                                                        
| 1257 | -    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) $maskoffset=preg_replace('/^\+/','',$reg[2]);
 | 
                                                        |
| 1258 | -    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) $maskoffset=preg_replace('/^\+/','',$reg[3]);
 | 
                                                        |
| 1570 | +    if (! empty($reg[2]) && preg_match('/^\+/',$reg[2])) { | 
                                                        |
| 1571 | +        $maskoffset=preg_replace('/^\+/','',$reg[2]); | 
                                                        |
| 1572 | + }  | 
                                                        |
| 1573 | +    if (! empty($reg[3]) && preg_match('/^\+/',$reg[3])) { | 
                                                        |
| 1574 | +        $maskoffset=preg_replace('/^\+/','',$reg[3]); | 
                                                        |
| 1575 | + }  | 
                                                        |
| 1259 | 1576 | |
| 1260 | 1577 | // Define $sqlwhere  | 
                                                        
| 1261 | 1578 | |
| 1262 | 1579 | // If a restore to zero after a month is asked we check if there is already a value for this year.  | 
                                                        
| 1263 | -    if (! empty($reg[2]) && preg_match('/^@/',$reg[2]))  $maskraz=preg_replace('/^@/','',$reg[2]);
 | 
                                                        |
| 1264 | -    if (! empty($reg[3]) && preg_match('/^@/',$reg[3]))  $maskraz=preg_replace('/^@/','',$reg[3]);
 | 
                                                        |
| 1580 | +    if (! empty($reg[2]) && preg_match('/^@/',$reg[2])) { | 
                                                        |
| 1581 | +        $maskraz=preg_replace('/^@/','',$reg[2]); | 
                                                        |
| 1582 | + }  | 
                                                        |
| 1583 | +    if (! empty($reg[3]) && preg_match('/^@/',$reg[3])) { | 
                                                        |
| 1584 | +        $maskraz=preg_replace('/^@/','',$reg[3]); | 
                                                        |
| 1585 | + }  | 
                                                        |
| 1265 | 1586 | if ($maskraz >= 0)  | 
                                                        
| 1266 | 1587 |      {
 | 
                                                        
| 1267 | - if ($maskraz > 12) return 'ErrorBadMaskBadRazMonth';  | 
                                                        |
| 1588 | +        if ($maskraz > 12) { | 
                                                        |
| 1589 | + return 'ErrorBadMaskBadRazMonth';  | 
                                                        |
| 1590 | + }  | 
                                                        |
| 1268 | 1591 | |
| 1269 | 1592 | // Define reg  | 
                                                        
| 1270 | -        if ($maskraz > 1 && ! preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';
 | 
                                                        |
| 1271 | -        if ($maskraz <= 1 && ! preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) return 'ErrorCantUseRazIfNoYearInMask';
 | 
                                                        |
| 1593 | +        if ($maskraz > 1 && ! preg_match('/^(.*)\{(y+)\}\{(m+)\}/i',$maskwithonlyymcode,$reg)) { | 
                                                        |
| 1594 | + return 'ErrorCantUseRazInStartedYearIfNoYearMonthInMask';  | 
                                                        |
| 1595 | + }  | 
                                                        |
| 1596 | +        if ($maskraz <= 1 && ! preg_match('/^(.*)\{(y+)\}/i',$maskwithonlyymcode,$reg)) { | 
                                                        |
| 1597 | + return 'ErrorCantUseRazIfNoYearInMask';  | 
                                                        |
| 1598 | + }  | 
                                                        |
| 1272 | 1599 | //print "x".$maskwithonlyymcode." ".$maskraz;  | 
                                                        
| 1273 | 1600 | }  | 
                                                        
| 1274 | 1601 | //print "masktri=".$masktri." maskcounter=".$maskcounter." maskraz=".$maskraz." maskoffset=".$maskoffset."<br>\n";  | 
                                                        
@@ -1278,7 +1605,9 @@ discard block  | 
                                                    ||
| 1278 | 1605 | |
| 1279 | 1606 | // Check length  | 
                                                        
| 1280 | 1607 | $len=dol_strlen($maskwithnocode);  | 
                                                        
| 1281 | - if (dol_strlen($value) != $len) $result=-1;  | 
                                                        |
| 1608 | +    if (dol_strlen($value) != $len) { | 
                                                        |
| 1609 | + $result=-1;  | 
                                                        |
| 1610 | + }  | 
                                                        |
| 1282 | 1611 | |
| 1283 | 1612 | // Define $maskLike  | 
                                                        
| 1284 | 1613 | /* seems not used  | 
                                                        
@@ -1359,29 +1688,37 @@ discard block  | 
                                                    ||
| 1359 | 1688 | */  | 
                                                        
| 1360 | 1689 | |
| 1361 | 1690 | // Definition du Jeudi de la semaine  | 
                                                        
| 1362 | -    if (date("w",mktime(12,0,0,$mois,$jour,$annee))==0) // Dimanche
 | 
                                                        |
| 1363 | - $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-3*24*60*60;  | 
                                                        |
| 1364 | -    else if (date("w",mktime(12,0,0,$mois,$jour,$annee))<4) // du Lundi au Mercredi
 | 
                                                        |
| 1365 | -    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)+(4-date("w",mktime(12,0,0,$mois,$jour,$annee)))*24*60*60;
 | 
                                                        |
| 1366 | -    else if (date("w",mktime(12,0,0,$mois,$jour,$annee))>4) // du Vendredi au Samedi
 | 
                                                        |
| 1367 | -    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-(date("w",mktime(12,0,0,$mois,$jour,$annee))-4)*24*60*60;
 | 
                                                        |
| 1368 | - else // Jeudi  | 
                                                        |
| 1369 | - $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee);  | 
                                                        |
| 1691 | +    if (date("w",mktime(12,0,0,$mois,$jour,$annee))==0) { | 
                                                        |
| 1692 | + // Dimanche  | 
                                                        |
| 1693 | + $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-3*24*60*60;  | 
                                                        |
| 1694 | +    } else if (date("w",mktime(12,0,0,$mois,$jour,$annee))<4) { | 
                                                        |
| 1695 | + // du Lundi au Mercredi  | 
                                                        |
| 1696 | +    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)+(4-date("w",mktime(12,0,0,$mois,$jour,$annee)))*24*60*60; | 
                                                        |
| 1697 | +    } else if (date("w",mktime(12,0,0,$mois,$jour,$annee))>4) { | 
                                                        |
| 1698 | + // du Vendredi au Samedi  | 
                                                        |
| 1699 | +    $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-(date("w",mktime(12,0,0,$mois,$jour,$annee))-4)*24*60*60; | 
                                                        |
| 1700 | +    } else { | 
                                                        |
| 1701 | + // Jeudi  | 
                                                        |
| 1702 | + $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee);  | 
                                                        |
| 1703 | + }  | 
                                                        |
| 1370 | 1704 | |
| 1371 | 1705 | // Definition du premier Jeudi de l'annee  | 
                                                        
| 1372 | -    if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==0) // Dimanche
 | 
                                                        |
| 1706 | +    if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==0) { | 
                                                        |
| 1707 | + // Dimanche  | 
                                                        |
| 1373 | 1708 |      {
 | 
                                                        
| 1374 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+4*24*60*60;
 | 
                                                        |
| 1375 | - }  | 
                                                        |
| 1376 | -    else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))<4) // du Lundi au Mercredi
 | 
                                                        |
| 1709 | +        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+4*24*60*60; | 
                                                        |
| 1710 | + }  | 
                                                        |
| 1711 | +    } else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))<4) { | 
                                                        |
| 1712 | + // du Lundi au Mercredi  | 
                                                        |
| 1377 | 1713 |      {
 | 
                                                        
| 1378 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(4-date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine))))*24*60*60;
 | 
                                                        |
| 1379 | - }  | 
                                                        |
| 1380 | -    else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))>4) // du Vendredi au Samedi
 | 
                                                        |
| 1714 | +        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(4-date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine))))*24*60*60; | 
                                                        |
| 1715 | + }  | 
                                                        |
| 1716 | +    } else if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))>4) { | 
                                                        |
| 1717 | + // du Vendredi au Samedi  | 
                                                        |
| 1381 | 1718 |      {
 | 
                                                        
| 1382 | -        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(7-(date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))-4))*24*60*60;
 | 
                                                        |
| 1383 | - }  | 
                                                        |
| 1384 | - else // Jeudi  | 
                                                        |
| 1719 | +        $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+(7-(date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))-4))*24*60*60; | 
                                                        |
| 1720 | + }  | 
                                                        |
| 1721 | + } else // Jeudi  | 
                                                        |
| 1385 | 1722 |      {
 | 
                                                        
| 1386 | 1723 |          $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine));
 | 
                                                        
| 1387 | 1724 | }  | 
                                                        
@@ -1402,8 +1739,7 @@ discard block  | 
                                                    ||
| 1402 | 1739 |          if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==4 || (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==3 && date("z",mktime(12,0,0,12,31,date("Y",$jeudiSemaine)))==365))
 | 
                                                        
| 1403 | 1740 |          {
 | 
                                                        
| 1404 | 1741 | $numeroSemaine = 53;  | 
                                                        
| 1405 | - }  | 
                                                        |
| 1406 | - else  | 
                                                        |
| 1742 | + } else  | 
                                                        |
| 1407 | 1743 |          {
 | 
                                                        
| 1408 | 1744 | $numeroSemaine = 1;  | 
                                                        
| 1409 | 1745 | }  | 
                                                        
@@ -1462,7 +1798,9 @@ discard block  | 
                                                    ||
| 1462 | 1798 | function dol_set_user_param($db, $conf, &$user, $tab)  | 
                                                        
| 1463 | 1799 |  {
 | 
                                                        
| 1464 | 1800 | // Verification parametres  | 
                                                        
| 1465 | - if (count($tab) < 1) return -1;  | 
                                                        |
| 1801 | +    if (count($tab) < 1) { | 
                                                        |
| 1802 | + return -1;  | 
                                                        |
| 1803 | + }  | 
                                                        |
| 1466 | 1804 | |
| 1467 | 1805 | $db->begin();  | 
                                                        
| 1468 | 1806 | |
@@ -1474,7 +1812,9 @@ discard block  | 
                                                    ||
| 1474 | 1812 | $i=0;  | 
                                                        
| 1475 | 1813 | foreach ($tab as $key => $value)  | 
                                                        
| 1476 | 1814 |      {
 | 
                                                        
| 1477 | - if ($i > 0) $sql.=',';  | 
                                                        |
| 1815 | +        if ($i > 0) { | 
                                                        |
| 1816 | + $sql.=',';  | 
                                                        |
| 1817 | + }  | 
                                                        |
| 1478 | 1818 | $sql.="'".$db->escape($key)."'";  | 
                                                        
| 1479 | 1819 | $i++;  | 
                                                        
| 1480 | 1820 | }  | 
                                                        
@@ -1508,8 +1848,7 @@ discard block  | 
                                                    ||
| 1508 | 1848 | }  | 
                                                        
| 1509 | 1849 | $user->conf->$key = $value;  | 
                                                        
| 1510 | 1850 | //print "key=".$key." user->conf->key=".$user->conf->$key;  | 
                                                        
| 1511 | - }  | 
                                                        |
| 1512 | - else  | 
                                                        |
| 1851 | + } else  | 
                                                        |
| 1513 | 1852 |          {
 | 
                                                        
| 1514 | 1853 | unset($user->conf->$key);  | 
                                                        
| 1515 | 1854 | }  | 
                                                        
@@ -1532,8 +1871,7 @@ discard block  | 
                                                    ||
| 1532 | 1871 | if ($reduction == 100)  | 
                                                        
| 1533 | 1872 |      {
 | 
                                                        
| 1534 | 1873 |          $string = $langs->transnoentities("Offered");
 | 
                                                        
| 1535 | - }  | 
                                                        |
| 1536 | - else  | 
                                                        |
| 1874 | + } else  | 
                                                        |
| 1537 | 1875 |      {
 | 
                                                        
| 1538 | 1876 | $string = vatrate($reduction,true);  | 
                                                        
| 1539 | 1877 | }  | 
                                                        
@@ -1620,9 +1958,11 @@ discard block  | 
                                                    ||
| 1620 | 1958 | |
| 1621 | 1959 | // If this generation module needs to scan a directory, then description field is filled  | 
                                                        
| 1622 | 1960 | // with the constant that contains list of directories to scan (COMPANY_ADDON_PDF_ODT_PATH, ...).  | 
                                                        
| 1623 | - if (! empty($obj->description)) // A list of directories to scan is defined  | 
                                                        |
| 1961 | +            if (! empty($obj->description)) { | 
                                                        |
| 1962 | + // A list of directories to scan is defined  | 
                                                        |
| 1624 | 1963 |              {
 | 
                                                        
| 1625 | - include_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';  | 
                                                        |
| 1964 | + include_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';  | 
                                                        |
| 1965 | + }  | 
                                                        |
| 1626 | 1966 | |
| 1627 | 1967 | $const=$obj->description;  | 
                                                        
| 1628 | 1968 |                  //irtoscan.=($dirtoscan?',':'').preg_replace('/[\r\n]+/',',',trim($conf->global->$const));
 | 
                                                        
@@ -1641,7 +1981,9 @@ discard block  | 
                                                    ||
| 1641 | 1981 |                      {
 | 
                                                        
| 1642 | 1982 | // all type of template is allowed  | 
                                                        
| 1643 | 1983 | $tmpfiles=dol_dir_list($tmpdir, 'files', 0, '', '', 'name', SORT_ASC, 0);  | 
                                                        
| 1644 | - if (count($tmpfiles)) $listoffiles=array_merge($listoffiles,$tmpfiles);  | 
                                                        |
| 1984 | +                        if (count($tmpfiles)) { | 
                                                        |
| 1985 | + $listoffiles=array_merge($listoffiles,$tmpfiles);  | 
                                                        |
| 1986 | + }  | 
                                                        |
| 1645 | 1987 | }  | 
                                                        
| 1646 | 1988 | }  | 
                                                        
| 1647 | 1989 | |
@@ -1652,40 +1994,41 @@ discard block  | 
                                                    ||
| 1652 | 1994 | $max=($maxfilenamelength?$maxfilenamelength:28);  | 
                                                        
| 1653 | 1995 | $liste[$obj->id.':'.$record['fullname']]=dol_trunc($record['name'],$max,'middle');  | 
                                                        
| 1654 | 1996 | }  | 
                                                        
| 1655 | - }  | 
                                                        |
| 1656 | - else  | 
                                                        |
| 1997 | + } else  | 
                                                        |
| 1657 | 1998 |                  {
 | 
                                                        
| 1658 | 1999 |                      $liste[0]=$obj->label.': '.$langs->trans("None");
 | 
                                                        
| 1659 | 2000 | }  | 
                                                        
| 1660 | - }  | 
                                                        |
| 1661 | - else  | 
                                                        |
| 2001 | + } else  | 
                                                        |
| 1662 | 2002 |              {
 | 
                                                        
| 1663 | - if ($type == 'member' && $obj->lib == 'standard') // Special case, if member template, we add variant per format  | 
                                                        |
| 2003 | +                if ($type == 'member' && $obj->lib == 'standard') { | 
                                                        |
| 2004 | + // Special case, if member template, we add variant per format  | 
                                                        |
| 1664 | 2005 |                  {
 | 
                                                        
| 1665 | - global $_Avery_Labels;  | 
                                                        |
| 2006 | + global $_Avery_Labels;  | 
                                                        |
| 2007 | + }  | 
                                                        |
| 1666 | 2008 | include_once DOL_DOCUMENT_ROOT.'/core/lib/format_cards.lib.php';  | 
                                                        
| 1667 | 2009 | foreach($_Avery_Labels as $key => $val)  | 
                                                        
| 1668 | 2010 |                      {
 | 
                                                        
| 1669 | 2011 | $liste[$obj->id.':'.$key]=($obj->label?$obj->label:$obj->lib).' '.$val['name'];  | 
                                                        
| 1670 | 2012 | }  | 
                                                        
| 1671 | - }  | 
                                                        |
| 1672 | - else // Common usage  | 
                                                        |
| 2013 | + } else // Common usage  | 
                                                        |
| 1673 | 2014 |                  {
 | 
                                                        
| 1674 | 2015 | $liste[$obj->id]=$obj->label?$obj->label:$obj->lib;  | 
                                                        
| 1675 | 2016 | }  | 
                                                        
| 1676 | 2017 | }  | 
                                                        
| 1677 | 2018 | $i++;  | 
                                                        
| 1678 | 2019 | }  | 
                                                        
| 1679 | - }  | 
                                                        |
| 1680 | - else  | 
                                                        |
| 2020 | + } else  | 
                                                        |
| 1681 | 2021 |      {
 | 
                                                        
| 1682 | 2022 | dol_print_error($db);  | 
                                                        
| 1683 | 2023 | return -1;  | 
                                                        
| 1684 | 2024 | }  | 
                                                        
| 1685 | 2025 | |
| 1686 | - if ($found) return $liste;  | 
                                                        |
| 1687 | - else return 0;  | 
                                                        |
| 1688 | -}  | 
                                                        |
| 2026 | +    if ($found) { | 
                                                        |
| 2027 | + return $liste;  | 
                                                        |
| 2028 | +    } else { | 
                                                        |
| 2029 | + return 0;  | 
                                                        |
| 2030 | + }  | 
                                                        |
| 2031 | + }  | 
                                                        |
| 1689 | 2032 | |
| 1690 | 2033 | /**  | 
                                                        
| 1691 | 2034 | * This function evaluates a string that should be a valid IPv4  | 
                                                        
@@ -1700,10 +2043,14 @@ discard block  | 
                                                    ||
| 1700 | 2043 |  	if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
 | 
                                                        
| 1701 | 2044 | |
| 1702 | 2045 | // Then we test if it is a private range  | 
                                                        
| 1703 | - if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE)) return 2;  | 
                                                        |
| 2046 | +		if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE)) { | 
                                                        |
| 2047 | + return 2;  | 
                                                        |
| 2048 | + }  | 
                                                        |
| 1704 | 2049 | |
| 1705 | 2050 | // Then we test if it is a reserved range  | 
                                                        
| 1706 | - if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) return 0;  | 
                                                        |
| 2051 | +		if (! filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) { | 
                                                        |
| 2052 | + return 0;  | 
                                                        |
| 2053 | + }  | 
                                                        |
| 1707 | 2054 | |
| 1708 | 2055 | return 1;  | 
                                                        
| 1709 | 2056 | }  | 
                                                        
@@ -1756,8 +2103,7 @@ discard block  | 
                                                    ||
| 1756 | 2103 | 'proxy_password' => $proxypass,  | 
                                                        
| 1757 | 2104 | 'trace' => 1  | 
                                                        
| 1758 | 2105 | );  | 
                                                        
| 1759 | - }  | 
                                                        |
| 1760 | - else  | 
                                                        |
| 2106 | + } else  | 
                                                        |
| 1761 | 2107 |      {
 | 
                                                        
| 1762 | 2108 |          $params=array('connection_timeout'=>$timeout,
 | 
                                                        
| 1763 | 2109 | 'response_timeout'=>$response_timeout,  | 
                                                        
@@ -1864,14 +2210,12 @@ discard block  | 
                                                    ||
| 1864 | 2210 | $classname='FactureFournisseur';  | 
                                                        
| 1865 | 2211 | $classpath = 'fourn/class';  | 
                                                        
| 1866 | 2212 | $module='fournisseur';  | 
                                                        
| 1867 | - }  | 
                                                        |
| 1868 | -	elseif ($objecttype == 'order_supplier')   {
 | 
                                                        |
| 2213 | +	} elseif ($objecttype == 'order_supplier')   {
 | 
                                                        |
| 1869 | 2214 | $classfile = 'fournisseur.commande';  | 
                                                        
| 1870 | 2215 | $classname='CommandeFournisseur';  | 
                                                        
| 1871 | 2216 | $classpath = 'fourn/class';  | 
                                                        
| 1872 | 2217 | $module='fournisseur';  | 
                                                        
| 1873 | - }  | 
                                                        |
| 1874 | -	elseif ($objecttype == 'stock')   {
 | 
                                                        |
| 2218 | +	} elseif ($objecttype == 'stock')   {
 | 
                                                        |
| 1875 | 2219 | $classpath = 'product/stock/class';  | 
                                                        
| 1876 | 2220 | $classfile='entrepot';  | 
                                                        
| 1877 | 2221 | $classname='Entrepot';  | 
                                                        
@@ -1891,8 +2235,9 @@ discard block  | 
                                                    ||
| 1891 | 2235 |  					$ret=$langs->trans('Deleted');
 | 
                                                        
| 1892 | 2236 | }  | 
                                                        
| 1893 | 2237 | unset($object);  | 
                                                        
| 1894 | - }  | 
                                                        |
| 1895 | -			else dol_syslog("Class with classname ".$classname." is unknown even after the include", LOG_ERR);
 | 
                                                        |
| 2238 | +			} else { | 
                                                        |
| 2239 | +			    dol_syslog("Class with classname ".$classname." is unknown even after the include", LOG_ERR); | 
                                                        |
| 2240 | + }  | 
                                                        |
| 1896 | 2241 | }  | 
                                                        
| 1897 | 2242 | }  | 
                                                        
| 1898 | 2243 | return $ret;  | 
                                                        
@@ -1924,11 +2269,12 @@ discard block  | 
                                                    ||
| 1924 | 2269 |  		{
 | 
                                                        
| 1925 | 2270 | $obj = $db->fetch_object($resql);  | 
                                                        
| 1926 | 2271 | $listofid[]=$obj->rowid;  | 
                                                        
| 1927 | - if ($obj->parent_id > 0) $listofparentid[$obj->rowid]=$obj->parent_id;  | 
                                                        |
| 2272 | +			if ($obj->parent_id > 0) { | 
                                                        |
| 2273 | + $listofparentid[$obj->rowid]=$obj->parent_id;  | 
                                                        |
| 2274 | + }  | 
                                                        |
| 1928 | 2275 | $i++;  | 
                                                        
| 1929 | 2276 | }  | 
                                                        
| 1930 | - }  | 
                                                        |
| 1931 | - else  | 
                                                        |
| 2277 | + } else  | 
                                                        |
| 1932 | 2278 |  	{
 | 
                                                        
| 1933 | 2279 | dol_print_error($db);  | 
                                                        
| 1934 | 2280 | }  | 
                                                        
@@ -1963,9 +2309,11 @@ discard block  | 
                                                    ||
| 1963 | 2309 | while ($cursor > 0)  | 
                                                        
| 1964 | 2310 |  			{
 | 
                                                        
| 1965 | 2311 | $arrayidparsed[$cursor]=1;  | 
                                                        
| 1966 | - if ($arrayidparsed[$listofparentid[$cursor]]) // We detect a loop. A record with a parent that was already into child  | 
                                                        |
| 2312 | +				if ($arrayidparsed[$listofparentid[$cursor]]) { | 
                                                        |
| 2313 | + // We detect a loop. A record with a parent that was already into child  | 
                                                        |
| 1967 | 2314 |  				{
 | 
                                                        
| 1968 | - print 'Found a loop between id '.$id.' - '.$cursor.'<br>';  | 
                                                        |
| 2315 | + print 'Found a loop between id '.$id.' - '.$cursor.'<br>';  | 
                                                        |
| 2316 | + }  | 
                                                        |
| 1969 | 2317 | unset($arrayidparsed);  | 
                                                        
| 1970 | 2318 | $listofidtoclean[$cursor]=$id;  | 
                                                        
| 1971 | 2319 | break;  | 
                                                        
@@ -1973,7 +2321,9 @@ discard block  | 
                                                    ||
| 1973 | 2321 | $cursor=$listofparentid[$cursor];  | 
                                                        
| 1974 | 2322 | }  | 
                                                        
| 1975 | 2323 | |
| 1976 | - if (count($listofidtoclean)) break;  | 
                                                        |
| 2324 | +			if (count($listofidtoclean)) { | 
                                                        |
| 2325 | + break;  | 
                                                        |
| 2326 | + }  | 
                                                        |
| 1977 | 2327 | }  | 
                                                        
| 1978 | 2328 | |
| 1979 | 2329 | $sql = "UPDATE ".MAIN_DB_PREFIX.$tabletocleantree;  | 
                                                        
@@ -2120,9 +2470,15 @@ discard block  | 
                                                    ||
| 2120 | 2470 | $classfile='fournisseur.facture';  | 
                                                        
| 2121 | 2471 | }  | 
                                                        
| 2122 | 2472 | |
| 2123 | - if (!isset($classfile)) $classfile = strtolower($subelement);  | 
                                                        |
| 2124 | - if (!isset($classname)) $classname = ucfirst($subelement);  | 
                                                        |
| 2125 | - if (!isset($classpath)) $classpath = $module.'/class';  | 
                                                        |
| 2473 | +    if (!isset($classfile)) { | 
                                                        |
| 2474 | + $classfile = strtolower($subelement);  | 
                                                        |
| 2475 | + }  | 
                                                        |
| 2476 | +    if (!isset($classname)) { | 
                                                        |
| 2477 | + $classname = ucfirst($subelement);  | 
                                                        |
| 2478 | + }  | 
                                                        |
| 2479 | +    if (!isset($classpath)) { | 
                                                        |
| 2480 | + $classpath = $module.'/class';  | 
                                                        |
| 2481 | + }  | 
                                                        |
| 2126 | 2482 | |
| 2127 | 2483 | $element_properties = array(  | 
                                                        
| 2128 | 2484 | 'module' => $module,  | 
                                                        
@@ -2176,8 +2532,12 @@ discard block  | 
                                                    ||
| 2176 | 2532 | */  | 
                                                        
| 2177 | 2533 | function colorArrayToHex($arraycolor,$colorifnotfound='888888')  | 
                                                        
| 2178 | 2534 |  {
 | 
                                                        
| 2179 | - if (! is_array($arraycolor)) return $colorifnotfound;  | 
                                                        |
| 2180 | - if (empty($arraycolor)) return $colorifnotfound;  | 
                                                        |
| 2535 | +	if (! is_array($arraycolor)) { | 
                                                        |
| 2536 | + return $colorifnotfound;  | 
                                                        |
| 2537 | + }  | 
                                                        |
| 2538 | +	if (empty($arraycolor)) { | 
                                                        |
| 2539 | + return $colorifnotfound;  | 
                                                        |
| 2540 | + }  | 
                                                        |
| 2181 | 2541 |  	return sprintf("%02s",dechex($arraycolor[0])).sprintf("%02s",dechex($arraycolor[1])).sprintf("%02s",dechex($arraycolor[2]));
 | 
                                                        
| 2182 | 2542 | }  | 
                                                        
| 2183 | 2543 | |
@@ -2193,12 +2553,17 @@ discard block  | 
                                                    ||
| 2193 | 2553 | */  | 
                                                        
| 2194 | 2554 | static function colorStringToArray($stringcolor, $colorifnotfound = array(88, 88, 88))  | 
                                                        
| 2195 | 2555 |      {
 | 
                                                        
| 2196 | - if (is_array($stringcolor)) return $stringcolor; // If already into correct output format, we return as is  | 
                                                        |
| 2556 | +	if (is_array($stringcolor)) { | 
                                                        |
| 2557 | + return $stringcolor;  | 
                                                        |
| 2558 | + }  | 
                                                        |
| 2559 | + // If already into correct output format, we return as is  | 
                                                        |
| 2197 | 2560 |  	$tmp=preg_match('/^#?([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])$/',$stringcolor,$reg);
 | 
                                                        
| 2198 | 2561 | if (! $tmp)  | 
                                                        
| 2199 | 2562 |  	{
 | 
                                                        
| 2200 | 2563 |  		$tmp=explode(',',$stringcolor);
 | 
                                                        
| 2201 | - if (count($tmp) < 3) return $colorifnotfound;  | 
                                                        |
| 2564 | +		if (count($tmp) < 3) { | 
                                                        |
| 2565 | + return $colorifnotfound;  | 
                                                        |
| 2566 | + }  | 
                                                        |
| 2202 | 2567 | return $tmp;  | 
                                                        
| 2203 | 2568 | }  | 
                                                        
| 2204 | 2569 | return array(hexdec($reg[1]),hexdec($reg[2]),hexdec($reg[3]));  | 
                                                        
@@ -2244,69 +2609,51 @@ discard block  | 
                                                    ||
| 2244 | 2609 | function getModuleDirForApiClass($module)  | 
                                                        
| 2245 | 2610 |  {
 | 
                                                        
| 2246 | 2611 | $moduledirforclass=$module;  | 
                                                        
| 2247 | -    if ($moduledirforclass != 'api') $moduledirforclass = preg_replace('/api$/i','',$moduledirforclass);
 | 
                                                        |
| 2612 | +    if ($moduledirforclass != 'api') { | 
                                                        |
| 2613 | +        $moduledirforclass = preg_replace('/api$/i','',$moduledirforclass); | 
                                                        |
| 2614 | + }  | 
                                                        |
| 2248 | 2615 | |
| 2249 | 2616 |      if ($module == 'contracts') {
 | 
                                                        
| 2250 | 2617 | $moduledirforclass = 'contrat';  | 
                                                        
| 2251 | - }  | 
                                                        |
| 2252 | -    elseif (in_array($module, array('admin', 'login', 'setup', 'access', 'status', 'tools', 'documents'))) {
 | 
                                                        |
| 2618 | +    } elseif (in_array($module, array('admin', 'login', 'setup', 'access', 'status', 'tools', 'documents'))) {
 | 
                                                        |
| 2253 | 2619 | $moduledirforclass = 'api';  | 
                                                        
| 2254 | - }  | 
                                                        |
| 2255 | -    elseif ($module == 'contact' || $module == 'contacts' || $module == 'customer' || $module == 'thirdparty' || $module == 'thirdparties') {
 | 
                                                        |
| 2620 | +    } elseif ($module == 'contact' || $module == 'contacts' || $module == 'customer' || $module == 'thirdparty' || $module == 'thirdparties') {
 | 
                                                        |
| 2256 | 2621 | $moduledirforclass = 'societe';  | 
                                                        
| 2257 | - }  | 
                                                        |
| 2258 | -    elseif ($module == 'propale' || $module == 'proposals') {
 | 
                                                        |
| 2622 | +    } elseif ($module == 'propale' || $module == 'proposals') {
 | 
                                                        |
| 2259 | 2623 | $moduledirforclass = 'comm/propal';  | 
                                                        
| 2260 | - }  | 
                                                        |
| 2261 | -    elseif ($module == 'agenda' || $module == 'agendaevents') {
 | 
                                                        |
| 2624 | +    } elseif ($module == 'agenda' || $module == 'agendaevents') {
 | 
                                                        |
| 2262 | 2625 | $moduledirforclass = 'comm/action';  | 
                                                        
| 2263 | - }  | 
                                                        |
| 2264 | -    elseif ($module == 'adherent' || $module == 'members' || $module == 'memberstypes' || $module == 'subscriptions') {
 | 
                                                        |
| 2626 | +    } elseif ($module == 'adherent' || $module == 'members' || $module == 'memberstypes' || $module == 'subscriptions') {
 | 
                                                        |
| 2265 | 2627 | $moduledirforclass = 'adherents';  | 
                                                        
| 2266 | - }  | 
                                                        |
| 2267 | -    elseif ($module == 'banque' || $module == 'bankaccounts') {
 | 
                                                        |
| 2628 | +    } elseif ($module == 'banque' || $module == 'bankaccounts') {
 | 
                                                        |
| 2268 | 2629 | $moduledirforclass = 'compta/bank';  | 
                                                        
| 2269 | - }  | 
                                                        |
| 2270 | -    elseif ($module == 'category' || $module == 'categorie') {
 | 
                                                        |
| 2630 | +    } elseif ($module == 'category' || $module == 'categorie') {
 | 
                                                        |
| 2271 | 2631 | $moduledirforclass = 'categories';  | 
                                                        
| 2272 | - }  | 
                                                        |
| 2273 | -    elseif ($module == 'order' || $module == 'orders') {
 | 
                                                        |
| 2632 | +    } elseif ($module == 'order' || $module == 'orders') {
 | 
                                                        |
| 2274 | 2633 | $moduledirforclass = 'commande';  | 
                                                        
| 2275 | - }  | 
                                                        |
| 2276 | -    elseif ($module == 'shipments') {
 | 
                                                        |
| 2634 | +    } elseif ($module == 'shipments') {
 | 
                                                        |
| 2277 | 2635 | $moduledirforclass = 'expedition';  | 
                                                        
| 2278 | - }  | 
                                                        |
| 2279 | -    elseif ($module == 'facture' || $module == 'invoice' || $module == 'invoices') {
 | 
                                                        |
| 2636 | +    } elseif ($module == 'facture' || $module == 'invoice' || $module == 'invoices') {
 | 
                                                        |
| 2280 | 2637 | $moduledirforclass = 'compta/facture';  | 
                                                        
| 2281 | - }  | 
                                                        |
| 2282 | -    elseif ($module == 'products') {
 | 
                                                        |
| 2638 | +    } elseif ($module == 'products') {
 | 
                                                        |
| 2283 | 2639 | $moduledirforclass = 'product';  | 
                                                        
| 2284 | - }  | 
                                                        |
| 2285 | -    elseif ($module == 'project' || $module == 'projects' || $module == 'tasks') {
 | 
                                                        |
| 2640 | +    } elseif ($module == 'project' || $module == 'projects' || $module == 'tasks') {
 | 
                                                        |
| 2286 | 2641 | $moduledirforclass = 'projet';  | 
                                                        
| 2287 | - }  | 
                                                        |
| 2288 | -    elseif ($module == 'task') {
 | 
                                                        |
| 2642 | +    } elseif ($module == 'task') {
 | 
                                                        |
| 2289 | 2643 | $moduledirforclass = 'projet';  | 
                                                        
| 2290 | - }  | 
                                                        |
| 2291 | -    elseif ($module == 'stock' || $module == 'stockmovements' || $module == 'warehouses') {
 | 
                                                        |
| 2644 | +    } elseif ($module == 'stock' || $module == 'stockmovements' || $module == 'warehouses') {
 | 
                                                        |
| 2292 | 2645 | $moduledirforclass = 'product/stock';  | 
                                                        
| 2293 | - }  | 
                                                        |
| 2294 | -    elseif ($module == 'supplierproposals' || $module == 'supplierproposal' || $module == 'supplier_proposal') {
 | 
                                                        |
| 2646 | +    } elseif ($module == 'supplierproposals' || $module == 'supplierproposal' || $module == 'supplier_proposal') {
 | 
                                                        |
| 2295 | 2647 | $moduledirforclass = 'supplier_proposal';  | 
                                                        
| 2296 | - }  | 
                                                        |
| 2297 | -    elseif ($module == 'fournisseur' || $module == 'supplierinvoices' || $module == 'supplierorders') {
 | 
                                                        |
| 2648 | +    } elseif ($module == 'fournisseur' || $module == 'supplierinvoices' || $module == 'supplierorders') {
 | 
                                                        |
| 2298 | 2649 | $moduledirforclass = 'fourn';  | 
                                                        
| 2299 | - }  | 
                                                        |
| 2300 | -    elseif ($module == 'expensereports') {
 | 
                                                        |
| 2650 | +    } elseif ($module == 'expensereports') {
 | 
                                                        |
| 2301 | 2651 | $moduledirforclass = 'expensereport';  | 
                                                        
| 2302 | - }  | 
                                                        |
| 2303 | -    elseif ($module == 'users') {
 | 
                                                        |
| 2652 | +    } elseif ($module == 'users') {
 | 
                                                        |
| 2304 | 2653 | $moduledirforclass = 'user';  | 
                                                        
| 2305 | - }  | 
                                                        |
| 2306 | -    elseif ($module == 'ficheinter' || $module == 'interventions') {
 | 
                                                        |
| 2654 | +    } elseif ($module == 'ficheinter' || $module == 'interventions') {
 | 
                                                        |
| 2307 | 2655 | $moduledirforclass = 'fichinter';  | 
                                                        
| 2308 | - }  | 
                                                        |
| 2309 | -    elseif ($module == 'tickets') {
 | 
                                                        |
| 2656 | +    } elseif ($module == 'tickets') {
 | 
                                                        |
| 2310 | 2657 | $moduledirforclass = 'ticket';  | 
                                                        
| 2311 | 2658 | }  | 
                                                        
| 2312 | 2659 | |
@@ -32,7 +32,7 @@ discard block  | 
                                                    ||
| 32 | 32 | * This script reads the conf file, init $lang, $db and and empty $user  | 
                                                        
| 33 | 33 | */  | 
                                                        
| 34 | 34 | |
| 35 | -require_once 'filefunc.inc.php'; // May have been already require by main.inc.php. But may not by scripts.  | 
                                                        |
| 35 | +require_once 'filefunc.inc.php'; // May have been already require by main.inc.php. But may not by scripts.  | 
                                                        |
| 36 | 36 | |
| 37 | 37 | |
| 38 | 38 | |
@@ -44,29 +44,29 @@ discard block  | 
                                                    ||
| 44 | 44 | |
| 45 | 45 | |
| 46 | 46 | // Chargement des includes principaux de librairies communes  | 
                                                        
| 47 | -if (! defined('NOREQUIREUSER')) require_once DOL_DOCUMENT_ROOT .'/user/class/user.class.php';		// Need 500ko memory
 | 
                                                        |
| 48 | -if (! defined('NOREQUIRETRAN')) require_once DOL_DOCUMENT_ROOT .'/core/class/translate.class.php';
 | 
                                                        |
| 49 | -if (! defined('NOREQUIRESOC'))  require_once DOL_DOCUMENT_ROOT .'/societe/class/societe.class.php';
 | 
                                                        |
| 47 | +if (!defined('NOREQUIREUSER')) require_once DOL_DOCUMENT_ROOT.'/user/class/user.class.php'; // Need 500ko memory
 | 
                                                        |
| 48 | +if (!defined('NOREQUIRETRAN')) require_once DOL_DOCUMENT_ROOT.'/core/class/translate.class.php';
 | 
                                                        |
| 49 | +if (!defined('NOREQUIRESOC'))  require_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php';
 | 
                                                        |
| 50 | 50 | |
| 51 | 51 | |
| 52 | 52 | |
| 53 | 53 | /*  | 
                                                        
| 54 | 54 | * Object $db  | 
                                                        
| 55 | 55 | */  | 
                                                        
| 56 | -if (! defined('NOREQUIREDB'))
 | 
                                                        |
| 56 | +if (!defined('NOREQUIREDB'))
 | 
                                                        |
| 57 | 57 |  {
 | 
                                                        
| 58 | - $db=getDoliDBInstance($conf->db->type,$conf->db->host,$conf->db->user,$conf->db->pass,$conf->db->name,$conf->db->port);  | 
                                                        |
| 58 | + $db = getDoliDBInstance($conf->db->type, $conf->db->host, $conf->db->user, $conf->db->pass, $conf->db->name, $conf->db->port);  | 
                                                        |
| 59 | 59 | |
| 60 | 60 | if ($db->error)  | 
                                                        
| 61 | 61 |  	{
 | 
                                                        
| 62 | - dol_print_error($db,"host=".$conf->db->host.", port=".$conf->db->port.", user=".$conf->db->user.", databasename=".$conf->db->name.", ".$db->error);  | 
                                                        |
| 62 | + dol_print_error($db, "host=".$conf->db->host.", port=".$conf->db->port.", user=".$conf->db->user.", databasename=".$conf->db->name.", ".$db->error);  | 
                                                        |
| 63 | 63 | exit;  | 
                                                        
| 64 | 64 | }  | 
                                                        
| 65 | 65 | }  | 
                                                        
| 66 | 66 | |
| 67 | 67 | // Now database connexion is known, so we can forget password  | 
                                                        
| 68 | 68 | //unset($dolibarr_main_db_pass); // We comment this because this constant is used in a lot of pages  | 
                                                        
| 69 | -unset($conf->db->pass); // This is to avoid password to be shown in memory/swap dump  | 
                                                        |
| 69 | +unset($conf->db->pass); // This is to avoid password to be shown in memory/swap dump  | 
                                                        |
| 70 | 70 | |
| 71 | 71 | /*  | 
                                                        
| 72 | 72 | * Object $user  | 
                                                        
@@ -78,17 +78,17 @@ discard block  | 
                                                    ||
| 78 | 78 | */  | 
                                                        
| 79 | 79 | |
| 80 | 80 | // By default conf->entity is 1, but we change this if we ask another value.  | 
                                                        
| 81 | -if (session_id() && ! empty($_SESSION["dol_entity"])) // Entity inside an opened session  | 
                                                        |
| 81 | +if (session_id() && !empty($_SESSION["dol_entity"])) // Entity inside an opened session  | 
                                                        |
| 82 | 82 |  {
 | 
                                                        
| 83 | 83 | $conf->entity = $_SESSION["dol_entity"];  | 
                                                        
| 84 | 84 | }  | 
                                                        
| 85 | -else if (! empty($_ENV["dol_entity"])) // Entity inside a CLI script  | 
                                                        |
| 85 | +else if (!empty($_ENV["dol_entity"])) // Entity inside a CLI script  | 
                                                        |
| 86 | 86 |  {
 | 
                                                        
| 87 | 87 | $conf->entity = $_ENV["dol_entity"];  | 
                                                        
| 88 | 88 | }  | 
                                                        
| 89 | -else if (isset($_POST["loginfunction"]) && GETPOST("entity",'int'))	// Just after a login page
 | 
                                                        |
| 89 | +else if (isset($_POST["loginfunction"]) && GETPOST("entity", 'int'))	// Just after a login page
 | 
                                                        |
| 90 | 90 |  {
 | 
                                                        
| 91 | -	$conf->entity = GETPOST("entity",'int');
 | 
                                                        |
| 91 | +	$conf->entity = GETPOST("entity", 'int');
 | 
                                                        |
| 92 | 92 | }  | 
                                                        
| 93 | 93 |  else if (defined('DOLENTITY') && is_numeric(DOLENTITY))			// For public page with MultiCompany module
 | 
                                                        
| 94 | 94 |  {
 | 
                                                        
@@ -96,9 +96,9 @@ discard block  | 
                                                    ||
| 96 | 96 | }  | 
                                                        
| 97 | 97 | |
| 98 | 98 | // Sanitize entity  | 
                                                        
| 99 | -if (! is_numeric($conf->entity)) $conf->entity=1;  | 
                                                        |
| 99 | +if (!is_numeric($conf->entity)) $conf->entity = 1;  | 
                                                        |
| 100 | 100 | |
| 101 | -if (! defined('NOREQUIREDB'))
 | 
                                                        |
| 101 | +if (!defined('NOREQUIREDB'))
 | 
                                                        |
| 102 | 102 |  {
 | 
                                                        
| 103 | 103 | //print "Will work with data into entity instance number '".$conf->entity."'";  | 
                                                        
| 104 | 104 | |
@@ -107,7 +107,7 @@ discard block  | 
                                                    ||
| 107 | 107 | }  | 
                                                        
| 108 | 108 | |
| 109 | 109 | // Overwrite database value  | 
                                                        
| 110 | -if (! empty($conf->file->mailing_limit_sendbyweb))  | 
                                                        |
| 110 | +if (!empty($conf->file->mailing_limit_sendbyweb))  | 
                                                        |
| 111 | 111 |  {
 | 
                                                        
| 112 | 112 | $conf->global->MAILING_LIMIT_SENDBYWEB = $conf->file->mailing_limit_sendbyweb;  | 
                                                        
| 113 | 113 | }  | 
                                                        
@@ -115,7 +115,7 @@ discard block  | 
                                                    ||
| 115 | 115 |  {
 | 
                                                        
| 116 | 116 | $conf->global->MAILING_LIMIT_SENDBYWEB = 25;  | 
                                                        
| 117 | 117 | }  | 
                                                        
| 118 | -if (! empty($conf->file->mailing_limit_sendbycli))  | 
                                                        |
| 118 | +if (!empty($conf->file->mailing_limit_sendbycli))  | 
                                                        |
| 119 | 119 |  {
 | 
                                                        
| 120 | 120 | $conf->global->MAILING_LIMIT_SENDBYCLI = $conf->file->mailing_limit_sendbycli;  | 
                                                        
| 121 | 121 | }  | 
                                                        
@@ -125,27 +125,27 @@ discard block  | 
                                                    ||
| 125 | 125 | }  | 
                                                        
| 126 | 126 | |
| 127 | 127 | // If software has been locked. Only login $conf->global->MAIN_ONLY_LOGIN_ALLOWED is allowed.  | 
                                                        
| 128 | -if (! empty($conf->global->MAIN_ONLY_LOGIN_ALLOWED))  | 
                                                        |
| 128 | +if (!empty($conf->global->MAIN_ONLY_LOGIN_ALLOWED))  | 
                                                        |
| 129 | 129 |  {
 | 
                                                        
| 130 | - $ok=0;  | 
                                                        |
| 131 | - if ((! session_id() || ! isset($_SESSION["dol_login"])) && ! isset($_POST["username"]) && ! empty($_SERVER["GATEWAY_INTERFACE"])) $ok=1; // We let working pages if not logged and inside a web browser (login form, to allow login by admin)  | 
                                                        |
| 132 | - elseif (isset($_POST["username"]) && $_POST["username"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok=1; // We let working pages that is a login submission (login submit, to allow login by admin)  | 
                                                        |
| 133 | -	elseif (defined('NOREQUIREDB'))   $ok=1;				// We let working pages that don't need database access (xxx.css.php)
 | 
                                                        |
| 134 | -	elseif (defined('EVEN_IF_ONLY_LOGIN_ALLOWED')) $ok=1;	// We let working pages that ask to work even if only login enabled (logout.php)
 | 
                                                        |
| 135 | - elseif (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok=1; // We let working if user is allowed admin  | 
                                                        |
| 136 | - if (! $ok)  | 
                                                        |
| 130 | + $ok = 0;  | 
                                                        |
| 131 | + if ((!session_id() || !isset($_SESSION["dol_login"])) && !isset($_POST["username"]) && !empty($_SERVER["GATEWAY_INTERFACE"])) $ok = 1; // We let working pages if not logged and inside a web browser (login form, to allow login by admin)  | 
                                                        |
| 132 | + elseif (isset($_POST["username"]) && $_POST["username"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok = 1; // We let working pages that is a login submission (login submit, to allow login by admin)  | 
                                                        |
| 133 | +	elseif (defined('NOREQUIREDB'))   $ok = 1; // We let working pages that don't need database access (xxx.css.php)
 | 
                                                        |
| 134 | +	elseif (defined('EVEN_IF_ONLY_LOGIN_ALLOWED')) $ok = 1; // We let working pages that ask to work even if only login enabled (logout.php)
 | 
                                                        |
| 135 | + elseif (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok = 1; // We let working if user is allowed admin  | 
                                                        |
| 136 | + if (!$ok)  | 
                                                        |
| 137 | 137 |  	{
 | 
                                                        
| 138 | 138 | if (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] != $conf->global->MAIN_ONLY_LOGIN_ALLOWED)  | 
                                                        
| 139 | 139 |  		{
 | 
                                                        
| 140 | 140 | print 'Sorry, your application is offline.'."\n";  | 
                                                        
| 141 | 141 | print 'You are logged with user "'.$_SESSION["dol_login"].'" and only administrator user "'.$conf->global->MAIN_ONLY_LOGIN_ALLOWED.'" is allowed to connect for the moment.'."\n";  | 
                                                        
| 142 | - $nexturl=DOL_URL_ROOT.'/user/logout.php';  | 
                                                        |
| 142 | + $nexturl = DOL_URL_ROOT.'/user/logout.php';  | 
                                                        |
| 143 | 143 | print 'Please try later or <a href="'.$nexturl.'">click here to disconnect and change login user</a>...'."\n";  | 
                                                        
| 144 | 144 | }  | 
                                                        
| 145 | 145 | else  | 
                                                        
| 146 | 146 |  		{
 | 
                                                        
| 147 | 147 | print 'Sorry, your application is offline. Only administrator user "'.$conf->global->MAIN_ONLY_LOGIN_ALLOWED.'" is allowed to connect for the moment.'."\n";  | 
                                                        
| 148 | - $nexturl=DOL_URL_ROOT.'/';  | 
                                                        |
| 148 | + $nexturl = DOL_URL_ROOT.'/';  | 
                                                        |
| 149 | 149 | print 'Please try later or <a href="'.$nexturl.'">click here to change login user</a>...'."\n";  | 
                                                        
| 150 | 150 | }  | 
                                                        
| 151 | 151 | exit;  | 
                                                        
@@ -153,28 +153,28 @@ discard block  | 
                                                    ||
| 153 | 153 | }  | 
                                                        
| 154 | 154 | |
| 155 | 155 | // Create object $mysoc (A thirdparty object that contains properties of companies managed by Dolibarr.  | 
                                                        
| 156 | -if (! defined('NOREQUIREDB') && ! defined('NOREQUIRESOC'))
 | 
                                                        |
| 156 | +if (!defined('NOREQUIREDB') && !defined('NOREQUIRESOC'))
 | 
                                                        |
| 157 | 157 |  {
 | 
                                                        
| 158 | - require_once DOL_DOCUMENT_ROOT .'/societe/class/societe.class.php';  | 
                                                        |
| 158 | + require_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php';  | 
                                                        |
| 159 | 159 | |
| 160 | - $mysoc=new Societe($db);  | 
                                                        |
| 160 | + $mysoc = new Societe($db);  | 
                                                        |
| 161 | 161 | $mysoc->setMysoc($conf);  | 
                                                        
| 162 | 162 | |
| 163 | 163 | // For some countries, we need to invert our address with customer address  | 
                                                        
| 164 | - if ($mysoc->country_code == 'DE' && ! isset($conf->global->MAIN_INVERT_SENDER_RECIPIENT)) $conf->global->MAIN_INVERT_SENDER_RECIPIENT=1;  | 
                                                        |
| 164 | + if ($mysoc->country_code == 'DE' && !isset($conf->global->MAIN_INVERT_SENDER_RECIPIENT)) $conf->global->MAIN_INVERT_SENDER_RECIPIENT = 1;  | 
                                                        |
| 165 | 165 | }  | 
                                                        
| 166 | 166 | |
| 167 | 167 | |
| 168 | 168 | // Set default language (must be after the setValues setting global $conf->global->MAIN_LANG_DEFAULT. Page main.inc.php will overwrite langs->defaultlang with user value later)  | 
                                                        
| 169 | -if (! defined('NOREQUIRETRAN'))
 | 
                                                        |
| 169 | +if (!defined('NOREQUIRETRAN'))
 | 
                                                        |
| 170 | 170 |  {
 | 
                                                        
| 171 | -    $langcode=(GETPOST('lang','aZ09')?GETPOST('lang','aZ09',1):(empty($conf->global->MAIN_LANG_DEFAULT)?'auto':$conf->global->MAIN_LANG_DEFAULT));
 | 
                                                        |
| 172 | -    if (defined('MAIN_LANG_DEFAULT')) $langcode=constant('MAIN_LANG_DEFAULT');
 | 
                                                        |
| 171 | +    $langcode = (GETPOST('lang', 'aZ09') ?GETPOST('lang', 'aZ09', 1) : (empty($conf->global->MAIN_LANG_DEFAULT) ? 'auto' : $conf->global->MAIN_LANG_DEFAULT));
 | 
                                                        |
| 172 | +    if (defined('MAIN_LANG_DEFAULT')) $langcode = constant('MAIN_LANG_DEFAULT');
 | 
                                                        |
| 173 | 173 | $langs->setDefaultLang($langcode);  | 
                                                        
| 174 | 174 | }  | 
                                                        
| 175 | 175 | |
| 176 | 176 | |
| 177 | 177 | |
| 178 | 178 | |
| 179 | -if (! defined('MAIN_LABEL_MENTION_NPR') ) define('MAIN_LABEL_MENTION_NPR','NPR');
 | 
                                                        |
| 179 | +if (!defined('MAIN_LABEL_MENTION_NPR')) define('MAIN_LABEL_MENTION_NPR', 'NPR');
 | 
                                                        |
| 180 | 180 | |
@@ -44,9 +44,16 @@ discard block  | 
                                                    ||
| 44 | 44 | |
| 45 | 45 | |
| 46 | 46 | // Chargement des includes principaux de librairies communes  | 
                                                        
| 47 | -if (! defined('NOREQUIREUSER')) require_once DOL_DOCUMENT_ROOT .'/user/class/user.class.php';		// Need 500ko memory
 | 
                                                        |
| 48 | -if (! defined('NOREQUIRETRAN')) require_once DOL_DOCUMENT_ROOT .'/core/class/translate.class.php';
 | 
                                                        |
| 49 | -if (! defined('NOREQUIRESOC'))  require_once DOL_DOCUMENT_ROOT .'/societe/class/societe.class.php';
 | 
                                                        |
| 47 | +if (! defined('NOREQUIREUSER')) { | 
                                                        |
| 48 | + require_once DOL_DOCUMENT_ROOT .'/user/class/user.class.php';  | 
                                                        |
| 49 | +}  | 
                                                        |
| 50 | +// Need 500ko memory  | 
                                                        |
| 51 | +if (! defined('NOREQUIRETRAN')) { | 
                                                        |
| 52 | + require_once DOL_DOCUMENT_ROOT .'/core/class/translate.class.php';  | 
                                                        |
| 53 | +}  | 
                                                        |
| 54 | +if (! defined('NOREQUIRESOC')) { | 
                                                        |
| 55 | + require_once DOL_DOCUMENT_ROOT .'/societe/class/societe.class.php';  | 
                                                        |
| 56 | +}  | 
                                                        |
| 50 | 57 | |
| 51 | 58 | |
| 52 | 59 | |
@@ -78,25 +85,32 @@ discard block  | 
                                                    ||
| 78 | 85 | */  | 
                                                        
| 79 | 86 | |
| 80 | 87 | // By default conf->entity is 1, but we change this if we ask another value.  | 
                                                        
| 81 | -if (session_id() && ! empty($_SESSION["dol_entity"])) // Entity inside an opened session  | 
                                                        |
| 88 | +if (session_id() && ! empty($_SESSION["dol_entity"])) { | 
                                                        |
| 89 | + // Entity inside an opened session  | 
                                                        |
| 82 | 90 |  {
 | 
                                                        
| 83 | - $conf->entity = $_SESSION["dol_entity"];  | 
                                                        |
| 84 | -}  | 
                                                        |
| 85 | -else if (! empty($_ENV["dol_entity"])) // Entity inside a CLI script  | 
                                                        |
| 91 | + $conf->entity = $_SESSION["dol_entity"];  | 
                                                        |
| 92 | +}  | 
                                                        |
| 93 | +} else if (! empty($_ENV["dol_entity"])) { | 
                                                        |
| 94 | + // Entity inside a CLI script  | 
                                                        |
| 86 | 95 |  {
 | 
                                                        
| 87 | - $conf->entity = $_ENV["dol_entity"];  | 
                                                        |
| 88 | -}  | 
                                                        |
| 89 | -else if (isset($_POST["loginfunction"]) && GETPOST("entity",'int'))	// Just after a login page
 | 
                                                        |
| 96 | + $conf->entity = $_ENV["dol_entity"];  | 
                                                        |
| 97 | +}  | 
                                                        |
| 98 | +} else if (isset($_POST["loginfunction"]) && GETPOST("entity",'int')) { | 
                                                        |
| 99 | + // Just after a login page  | 
                                                        |
| 90 | 100 |  {
 | 
                                                        
| 91 | -	$conf->entity = GETPOST("entity",'int');
 | 
                                                        |
| 92 | -}  | 
                                                        |
| 93 | -else if (defined('DOLENTITY') && is_numeric(DOLENTITY))			// For public page with MultiCompany module
 | 
                                                        |
| 101 | +	$conf->entity = GETPOST("entity",'int'); | 
                                                        |
| 102 | +}  | 
                                                        |
| 103 | +} else if (defined('DOLENTITY') && is_numeric(DOLENTITY)) { | 
                                                        |
| 104 | + // For public page with MultiCompany module  | 
                                                        |
| 94 | 105 |  {
 | 
                                                        
| 95 | - $conf->entity = DOLENTITY;  | 
                                                        |
| 106 | + $conf->entity = DOLENTITY;  | 
                                                        |
| 107 | +}  | 
                                                        |
| 96 | 108 | }  | 
                                                        
| 97 | 109 | |
| 98 | 110 | // Sanitize entity  | 
                                                        
| 99 | -if (! is_numeric($conf->entity)) $conf->entity=1;  | 
                                                        |
| 111 | +if (! is_numeric($conf->entity)) { | 
                                                        |
| 112 | + $conf->entity=1;  | 
                                                        |
| 113 | +}  | 
                                                        |
| 100 | 114 | |
| 101 | 115 |  if (! defined('NOREQUIREDB'))
 | 
                                                        
| 102 | 116 |  {
 | 
                                                        
@@ -128,11 +142,26 @@ discard block  | 
                                                    ||
| 128 | 142 | if (! empty($conf->global->MAIN_ONLY_LOGIN_ALLOWED))  | 
                                                        
| 129 | 143 |  {
 | 
                                                        
| 130 | 144 | $ok=0;  | 
                                                        
| 131 | - if ((! session_id() || ! isset($_SESSION["dol_login"])) && ! isset($_POST["username"]) && ! empty($_SERVER["GATEWAY_INTERFACE"])) $ok=1; // We let working pages if not logged and inside a web browser (login form, to allow login by admin)  | 
                                                        |
| 132 | - elseif (isset($_POST["username"]) && $_POST["username"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok=1; // We let working pages that is a login submission (login submit, to allow login by admin)  | 
                                                        |
| 133 | -	elseif (defined('NOREQUIREDB'))   $ok=1;				// We let working pages that don't need database access (xxx.css.php)
 | 
                                                        |
| 134 | -	elseif (defined('EVEN_IF_ONLY_LOGIN_ALLOWED')) $ok=1;	// We let working pages that ask to work even if only login enabled (logout.php)
 | 
                                                        |
| 135 | - elseif (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) $ok=1; // We let working if user is allowed admin  | 
                                                        |
| 145 | +	if ((! session_id() || ! isset($_SESSION["dol_login"])) && ! isset($_POST["username"]) && ! empty($_SERVER["GATEWAY_INTERFACE"])) { | 
                                                        |
| 146 | + $ok=1;  | 
                                                        |
| 147 | + }  | 
                                                        |
| 148 | + // We let working pages if not logged and inside a web browser (login form, to allow login by admin)  | 
                                                        |
| 149 | +	elseif (isset($_POST["username"]) && $_POST["username"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) { | 
                                                        |
| 150 | + $ok=1;  | 
                                                        |
| 151 | + }  | 
                                                        |
| 152 | + // We let working pages that is a login submission (login submit, to allow login by admin)  | 
                                                        |
| 153 | +	elseif (defined('NOREQUIREDB')) { | 
                                                        |
| 154 | + $ok=1;  | 
                                                        |
| 155 | + }  | 
                                                        |
| 156 | + // We let working pages that don't need database access (xxx.css.php)  | 
                                                        |
| 157 | +	elseif (defined('EVEN_IF_ONLY_LOGIN_ALLOWED')) { | 
                                                        |
| 158 | + $ok=1;  | 
                                                        |
| 159 | + }  | 
                                                        |
| 160 | + // We let working pages that ask to work even if only login enabled (logout.php)  | 
                                                        |
| 161 | +	elseif (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] == $conf->global->MAIN_ONLY_LOGIN_ALLOWED) { | 
                                                        |
| 162 | + $ok=1;  | 
                                                        |
| 163 | + }  | 
                                                        |
| 164 | + // We let working if user is allowed admin  | 
                                                        |
| 136 | 165 | if (! $ok)  | 
                                                        
| 137 | 166 |  	{
 | 
                                                        
| 138 | 167 | if (session_id() && isset($_SESSION["dol_login"]) && $_SESSION["dol_login"] != $conf->global->MAIN_ONLY_LOGIN_ALLOWED)  | 
                                                        
@@ -141,8 +170,7 @@ discard block  | 
                                                    ||
| 141 | 170 | print 'You are logged with user "'.$_SESSION["dol_login"].'" and only administrator user "'.$conf->global->MAIN_ONLY_LOGIN_ALLOWED.'" is allowed to connect for the moment.'."\n";  | 
                                                        
| 142 | 171 | $nexturl=DOL_URL_ROOT.'/user/logout.php';  | 
                                                        
| 143 | 172 | print 'Please try later or <a href="'.$nexturl.'">click here to disconnect and change login user</a>...'."\n";  | 
                                                        
| 144 | - }  | 
                                                        |
| 145 | - else  | 
                                                        |
| 173 | + } else  | 
                                                        |
| 146 | 174 |  		{
 | 
                                                        
| 147 | 175 | print 'Sorry, your application is offline. Only administrator user "'.$conf->global->MAIN_ONLY_LOGIN_ALLOWED.'" is allowed to connect for the moment.'."\n";  | 
                                                        
| 148 | 176 | $nexturl=DOL_URL_ROOT.'/';  | 
                                                        
@@ -161,20 +189,26 @@ discard block  | 
                                                    ||
| 161 | 189 | $mysoc->setMysoc($conf);  | 
                                                        
| 162 | 190 | |
| 163 | 191 | // For some countries, we need to invert our address with customer address  | 
                                                        
| 164 | - if ($mysoc->country_code == 'DE' && ! isset($conf->global->MAIN_INVERT_SENDER_RECIPIENT)) $conf->global->MAIN_INVERT_SENDER_RECIPIENT=1;  | 
                                                        |
| 165 | -}  | 
                                                        |
| 192 | +	if ($mysoc->country_code == 'DE' && ! isset($conf->global->MAIN_INVERT_SENDER_RECIPIENT)) { | 
                                                        |
| 193 | + $conf->global->MAIN_INVERT_SENDER_RECIPIENT=1;  | 
                                                        |
| 194 | + }  | 
                                                        |
| 195 | + }  | 
                                                        |
| 166 | 196 | |
| 167 | 197 | |
| 168 | 198 | // Set default language (must be after the setValues setting global $conf->global->MAIN_LANG_DEFAULT. Page main.inc.php will overwrite langs->defaultlang with user value later)  | 
                                                        
| 169 | 199 |  if (! defined('NOREQUIRETRAN'))
 | 
                                                        
| 170 | 200 |  {
 | 
                                                        
| 171 | 201 |      $langcode=(GETPOST('lang','aZ09')?GETPOST('lang','aZ09',1):(empty($conf->global->MAIN_LANG_DEFAULT)?'auto':$conf->global->MAIN_LANG_DEFAULT));
 | 
                                                        
| 172 | -    if (defined('MAIN_LANG_DEFAULT')) $langcode=constant('MAIN_LANG_DEFAULT');
 | 
                                                        |
| 202 | +    if (defined('MAIN_LANG_DEFAULT')) { | 
                                                        |
| 203 | +        $langcode=constant('MAIN_LANG_DEFAULT'); | 
                                                        |
| 204 | + }  | 
                                                        |
| 173 | 205 | $langs->setDefaultLang($langcode);  | 
                                                        
| 174 | 206 | }  | 
                                                        
| 175 | 207 | |
| 176 | 208 | |
| 177 | 209 | |
| 178 | 210 | |
| 179 | -if (! defined('MAIN_LABEL_MENTION_NPR') ) define('MAIN_LABEL_MENTION_NPR','NPR');
 | 
                                                        |
| 211 | +if (! defined('MAIN_LABEL_MENTION_NPR') ) { | 
                                                        |
| 212 | +    define('MAIN_LABEL_MENTION_NPR','NPR'); | 
                                                        |
| 213 | +}  | 
                                                        |
| 180 | 214 | |
@@ -32,25 +32,25 @@ discard block  | 
                                                    ||
| 32 | 32 | * @param int $entitytotest Number of instance (always 1 if module multicompany not enabled)  | 
                                                        
| 33 | 33 | * @return string Login if OK, '' if KO  | 
                                                        
| 34 | 34 | */  | 
                                                        
| 35 | -function check_user_password_ldap($usertotest,$passwordtotest,$entitytotest)  | 
                                                        |
| 35 | +function check_user_password_ldap($usertotest, $passwordtotest, $entitytotest)  | 
                                                        |
| 36 | 36 |  {
 | 
                                                        
| 37 | - global $db,$conf,$langs;  | 
                                                        |
| 37 | + global $db, $conf, $langs;  | 
                                                        |
| 38 | 38 | global $_POST;  | 
                                                        
| 39 | - global $dolibarr_main_auth_ldap_host,$dolibarr_main_auth_ldap_port;  | 
                                                        |
| 40 | - global $dolibarr_main_auth_ldap_version,$dolibarr_main_auth_ldap_servertype;  | 
                                                        |
| 41 | - global $dolibarr_main_auth_ldap_login_attribute,$dolibarr_main_auth_ldap_dn;  | 
                                                        |
| 42 | - global $dolibarr_main_auth_ldap_admin_login,$dolibarr_main_auth_ldap_admin_pass;  | 
                                                        |
| 39 | + global $dolibarr_main_auth_ldap_host, $dolibarr_main_auth_ldap_port;  | 
                                                        |
| 40 | + global $dolibarr_main_auth_ldap_version, $dolibarr_main_auth_ldap_servertype;  | 
                                                        |
| 41 | + global $dolibarr_main_auth_ldap_login_attribute, $dolibarr_main_auth_ldap_dn;  | 
                                                        |
| 42 | + global $dolibarr_main_auth_ldap_admin_login, $dolibarr_main_auth_ldap_admin_pass;  | 
                                                        |
| 43 | 43 | global $dolibarr_main_auth_ldap_filter;  | 
                                                        
| 44 | 44 | global $dolibarr_main_auth_ldap_debug;  | 
                                                        
| 45 | 45 | |
| 46 | 46 | // Force master entity in transversal mode  | 
                                                        
| 47 | - $entity=$entitytotest;  | 
                                                        |
| 48 | - if (! empty($conf->multicompany->enabled) && ! empty($conf->global->MULTICOMPANY_TRANSVERSE_MODE)) $entity=1;  | 
                                                        |
| 47 | + $entity = $entitytotest;  | 
                                                        |
| 48 | + if (!empty($conf->multicompany->enabled) && !empty($conf->global->MULTICOMPANY_TRANSVERSE_MODE)) $entity = 1;  | 
                                                        |
| 49 | 49 | |
| 50 | - $login='';  | 
                                                        |
| 51 | - $resultFetchUser='';  | 
                                                        |
| 50 | + $login = '';  | 
                                                        |
| 51 | + $resultFetchUser = '';  | 
                                                        |
| 52 | 52 | |
| 53 | -	if (! function_exists("ldap_connect"))
 | 
                                                        |
| 53 | +	if (!function_exists("ldap_connect"))
 | 
                                                        |
| 54 | 54 |  	{
 | 
                                                        
| 55 | 55 |  		dol_syslog("functions_ldap::check_user_password_ldap Authentification ko failed to connect to LDAP. LDAP functions are disabled on this PHP");
 | 
                                                        
| 56 | 56 | sleep(1);  | 
                                                        
@@ -58,51 +58,51 @@ discard block  | 
                                                    ||
| 58 | 58 | // Load translation files required by the page  | 
                                                        
| 59 | 59 |          $langs->loadLangs(array('main', 'other'));
 | 
                                                        
| 60 | 60 | |
| 61 | -		$_SESSION["dol_loginmesg"]=$langs->trans("ErrorLDAPFunctionsAreDisabledOnThisPHP").' '.$langs->trans("TryAnotherConnectionMode");
 | 
                                                        |
| 61 | +		$_SESSION["dol_loginmesg"] = $langs->trans("ErrorLDAPFunctionsAreDisabledOnThisPHP").' '.$langs->trans("TryAnotherConnectionMode");
 | 
                                                        |
| 62 | 62 | return;  | 
                                                        
| 63 | 63 | }  | 
                                                        
| 64 | 64 | |
| 65 | 65 | if ($usertotest)  | 
                                                        
| 66 | 66 |  	{
 | 
                                                        
| 67 | -		dol_syslog("functions_ldap::check_user_password_ldap usertotest=".$usertotest." passwordtotest=".preg_replace('/./','*',$passwordtotest)." entitytotest=".$entitytotest);
 | 
                                                        |
| 67 | +		dol_syslog("functions_ldap::check_user_password_ldap usertotest=".$usertotest." passwordtotest=".preg_replace('/./', '*', $passwordtotest)." entitytotest=".$entitytotest);
 | 
                                                        |
| 68 | 68 | |
| 69 | 69 | // If test username/password asked, we define $test=false and $login var if ok, set $_SESSION["dol_loginmesg"] if ko  | 
                                                        
| 70 | - $ldaphost=$dolibarr_main_auth_ldap_host;  | 
                                                        |
| 71 | - $ldapport=$dolibarr_main_auth_ldap_port;  | 
                                                        |
| 72 | - $ldapversion=$dolibarr_main_auth_ldap_version;  | 
                                                        |
| 73 | - $ldapservertype=(empty($dolibarr_main_auth_ldap_servertype) ? 'openldap' : $dolibarr_main_auth_ldap_servertype);  | 
                                                        |
| 70 | + $ldaphost = $dolibarr_main_auth_ldap_host;  | 
                                                        |
| 71 | + $ldapport = $dolibarr_main_auth_ldap_port;  | 
                                                        |
| 72 | + $ldapversion = $dolibarr_main_auth_ldap_version;  | 
                                                        |
| 73 | + $ldapservertype = (empty($dolibarr_main_auth_ldap_servertype) ? 'openldap' : $dolibarr_main_auth_ldap_servertype);  | 
                                                        |
| 74 | 74 | |
| 75 | - $ldapuserattr=$dolibarr_main_auth_ldap_login_attribute;  | 
                                                        |
| 76 | - $ldapdn=$dolibarr_main_auth_ldap_dn;  | 
                                                        |
| 77 | - $ldapadminlogin=$dolibarr_main_auth_ldap_admin_login;  | 
                                                        |
| 78 | - $ldapadminpass=$dolibarr_main_auth_ldap_admin_pass;  | 
                                                        |
| 79 | - $ldapdebug=(empty($dolibarr_main_auth_ldap_debug) || $dolibarr_main_auth_ldap_debug=="false" ? false : true);  | 
                                                        |
| 75 | + $ldapuserattr = $dolibarr_main_auth_ldap_login_attribute;  | 
                                                        |
| 76 | + $ldapdn = $dolibarr_main_auth_ldap_dn;  | 
                                                        |
| 77 | + $ldapadminlogin = $dolibarr_main_auth_ldap_admin_login;  | 
                                                        |
| 78 | + $ldapadminpass = $dolibarr_main_auth_ldap_admin_pass;  | 
                                                        |
| 79 | + $ldapdebug = (empty($dolibarr_main_auth_ldap_debug) || $dolibarr_main_auth_ldap_debug == "false" ? false : true);  | 
                                                        |
| 80 | 80 | |
| 81 | 81 | if ($ldapdebug) print "DEBUG: Logging LDAP steps<br>\n";  | 
                                                        
| 82 | 82 | |
| 83 | 83 | require_once DOL_DOCUMENT_ROOT.'/core/class/ldap.class.php';  | 
                                                        
| 84 | - $ldap=new Ldap();  | 
                                                        |
| 85 | -		$ldap->server=explode(',',$ldaphost);
 | 
                                                        |
| 86 | - $ldap->serverPort=$ldapport;  | 
                                                        |
| 87 | - $ldap->ldapProtocolVersion=$ldapversion;  | 
                                                        |
| 88 | - $ldap->serverType=$ldapservertype;  | 
                                                        |
| 89 | - $ldap->searchUser=$ldapadminlogin;  | 
                                                        |
| 90 | - $ldap->searchPassword=$ldapadminpass;  | 
                                                        |
| 84 | + $ldap = new Ldap();  | 
                                                        |
| 85 | +		$ldap->server = explode(',', $ldaphost);
 | 
                                                        |
| 86 | + $ldap->serverPort = $ldapport;  | 
                                                        |
| 87 | + $ldap->ldapProtocolVersion = $ldapversion;  | 
                                                        |
| 88 | + $ldap->serverType = $ldapservertype;  | 
                                                        |
| 89 | + $ldap->searchUser = $ldapadminlogin;  | 
                                                        |
| 90 | + $ldap->searchPassword = $ldapadminpass;  | 
                                                        |
| 91 | 91 | |
| 92 | 92 | if ($ldapdebug)  | 
                                                        
| 93 | 93 |  		{
 | 
                                                        
| 94 | -			dol_syslog("functions_ldap::check_user_password_ldap Server:".join(',',$ldap->server).", Port:".$ldap->serverPort.", Protocol:".$ldap->ldapProtocolVersion.", Type:".$ldap->serverType);
 | 
                                                        |
| 94 | +			dol_syslog("functions_ldap::check_user_password_ldap Server:".join(',', $ldap->server).", Port:".$ldap->serverPort.", Protocol:".$ldap->ldapProtocolVersion.", Type:".$ldap->serverType);
 | 
                                                        |
| 95 | 95 |  			dol_syslog("functions_ldap::check_user_password_ldap uid/samacountname=".$ldapuserattr.", dn=".$ldapdn.", Admin:".$ldap->searchUser.", Pass:".$ldap->searchPassword);
 | 
                                                        
| 96 | -			print "DEBUG: Server:".join(',',$ldap->server).", Port:".$ldap->serverPort.", Protocol:".$ldap->ldapProtocolVersion.", Type:".$ldap->serverType."<br>\n";
 | 
                                                        |
| 96 | +			print "DEBUG: Server:".join(',', $ldap->server).", Port:".$ldap->serverPort.", Protocol:".$ldap->ldapProtocolVersion.", Type:".$ldap->serverType."<br>\n";
 | 
                                                        |
| 97 | 97 | print "DEBUG: uid/samacountname=".$ldapuserattr.", dn=".$ldapdn.", Admin:".$ldap->searchUser.", Pass:".$ldap->searchPassword."<br>\n";  | 
                                                        
| 98 | 98 | }  | 
                                                        
| 99 | 99 | |
| 100 | - $resultFetchLdapUser=0;  | 
                                                        |
| 100 | + $resultFetchLdapUser = 0;  | 
                                                        |
| 101 | 101 | |
| 102 | 102 | // Define $userSearchFilter  | 
                                                        
| 103 | 103 | $userSearchFilter = "";  | 
                                                        
| 104 | 104 |  		if (empty($dolibarr_main_auth_ldap_filter)) {
 | 
                                                        
| 105 | -			$userSearchFilter = "(" . $ldapuserattr . "=" . $usertotest . ")";
 | 
                                                        |
| 105 | +			$userSearchFilter = "(".$ldapuserattr."=".$usertotest.")";
 | 
                                                        |
| 106 | 106 |  		} else {
 | 
                                                        
| 107 | 107 |  			$userSearchFilter = str_replace('%1%', $usertotest, $dolibarr_main_auth_ldap_filter);
 | 
                                                        
| 108 | 108 | }  | 
                                                        
@@ -111,10 +111,10 @@ discard block  | 
                                                    ||
| 111 | 111 | // Code to get user in LDAP from an admin connection (may differ from user connection, done later)  | 
                                                        
| 112 | 112 | if ($ldapadminlogin)  | 
                                                        
| 113 | 113 |  		{
 | 
                                                        
| 114 | - $result=$ldap->connect_bind();  | 
                                                        |
| 114 | + $result = $ldap->connect_bind();  | 
                                                        |
| 115 | 115 | if ($result > 0)  | 
                                                        
| 116 | 116 |  			{
 | 
                                                        
| 117 | - $resultFetchLdapUser = $ldap->fetch($usertotest,$userSearchFilter);  | 
                                                        |
| 117 | + $resultFetchLdapUser = $ldap->fetch($usertotest, $userSearchFilter);  | 
                                                        |
| 118 | 118 |  				//dol_syslog('functions_ldap::check_user_password_ldap resultFetchLdapUser='.$resultFetchLdapUser);
 | 
                                                        
| 119 | 119 | if ($resultFetchLdapUser > 0 && $ldap->pwdlastset == 0) // If ok but password need to be reset  | 
                                                        
| 120 | 120 |  				{
 | 
                                                        
@@ -123,7 +123,7 @@ discard block  | 
                                                    ||
| 123 | 123 | $ldap->close();  | 
                                                        
| 124 | 124 | sleep(1);  | 
                                                        
| 125 | 125 |  					$langs->load('ldap');
 | 
                                                        
| 126 | -					$_SESSION["dol_loginmesg"]=$langs->trans("YouMustChangePassNextLogon",$usertotest,$ldap->domainFQDN);
 | 
                                                        |
| 126 | +					$_SESSION["dol_loginmesg"] = $langs->trans("YouMustChangePassNextLogon", $usertotest, $ldap->domainFQDN);
 | 
                                                        |
| 127 | 127 | return '';  | 
                                                        
| 128 | 128 | }  | 
                                                        
| 129 | 129 | }  | 
                                                        
@@ -137,41 +137,41 @@ discard block  | 
                                                    ||
| 137 | 137 | // Forge LDAP user and password to test with them  | 
                                                        
| 138 | 138 | // If LDAP need a dn with login like "uid=jbloggs,ou=People,dc=foo,dc=com", default dn may work even if previous code with  | 
                                                        
| 139 | 139 | // admin login no exectued.  | 
                                                        
| 140 | - $ldap->searchUser=$ldapuserattr."=".$usertotest.",".$ldapdn; // Default dn (will work if LDAP accept a dn with login value inside)  | 
                                                        |
| 140 | + $ldap->searchUser = $ldapuserattr."=".$usertotest.",".$ldapdn; // Default dn (will work if LDAP accept a dn with login value inside)  | 
                                                        |
| 141 | 141 | // But if LDAP need a dn with name like "cn=Jhon Bloggs,ou=People,dc=foo,dc=com", previous part must have been executed to have  | 
                                                        
| 142 | 142 | // dn detected into ldapUserDN.  | 
                                                        
| 143 | 143 | if ($resultFetchLdapUser && !empty($ldap->ldapUserDN)) $ldap->searchUser = $ldap->ldapUserDN;  | 
                                                        
| 144 | - $ldap->searchPassword=$passwordtotest;  | 
                                                        |
| 144 | + $ldap->searchPassword = $passwordtotest;  | 
                                                        |
| 145 | 145 | |
| 146 | 146 | // Test with this->seachUser and this->searchPassword  | 
                                                        
| 147 | 147 | //print $resultFetchLdapUser."-".$ldap->ldapUserDN."-".$ldap->searchUser.'-'.$ldap->searchPassword;exit;  | 
                                                        
| 148 | - $result=$ldap->connect_bind();  | 
                                                        |
| 148 | + $result = $ldap->connect_bind();  | 
                                                        |
| 149 | 149 | if ($result > 0)  | 
                                                        
| 150 | 150 |  		{
 | 
                                                        
| 151 | 151 | if ($result == 2) // Connection is ok for user/pass into LDAP  | 
                                                        
| 152 | 152 |  			{
 | 
                                                        
| 153 | 153 |  				dol_syslog("functions_ldap::check_user_password_ldap Authentification ok");
 | 
                                                        
| 154 | - $login=$usertotest;  | 
                                                        |
| 154 | + $login = $usertotest;  | 
                                                        |
| 155 | 155 | |
| 156 | 156 | // ldap2dolibarr synchronisation  | 
                                                        
| 157 | - if ($login && ! empty($conf->ldap->enabled) && $conf->global->LDAP_SYNCHRO_ACTIVE == 'ldap2dolibarr') // ldap2dolibarr synchronisation  | 
                                                        |
| 157 | + if ($login && !empty($conf->ldap->enabled) && $conf->global->LDAP_SYNCHRO_ACTIVE == 'ldap2dolibarr') // ldap2dolibarr synchronisation  | 
                                                        |
| 158 | 158 |  				{
 | 
                                                        
| 159 | 159 |  						dol_syslog("functions_ldap::check_user_password_ldap Sync ldap2dolibarr");
 | 
                                                        
| 160 | 160 | |
| 161 | 161 | // On charge les attributs du user ldap  | 
                                                        
| 162 | 162 | if ($ldapdebug) print "DEBUG: login ldap = ".$login."<br>\n";  | 
                                                        
| 163 | - $resultFetchLdapUser = $ldap->fetch($login,$userSearchFilter);  | 
                                                        |
| 163 | + $resultFetchLdapUser = $ldap->fetch($login, $userSearchFilter);  | 
                                                        |
| 164 | 164 | |
| 165 | -						if ($ldapdebug) print "DEBUG: UACF = ".join(',',$ldap->uacf)."<br>\n";
 | 
                                                        |
| 166 | - if ($ldapdebug) print "DEBUG: pwdLastSet = ".dol_print_date($ldap->pwdlastset,'day')."<br>\n";  | 
                                                        |
| 167 | - if ($ldapdebug) print "DEBUG: badPasswordTime = ".dol_print_date($ldap->badpwdtime,'day')."<br>\n";  | 
                                                        |
| 165 | +						if ($ldapdebug) print "DEBUG: UACF = ".join(',', $ldap->uacf)."<br>\n";
 | 
                                                        |
| 166 | + if ($ldapdebug) print "DEBUG: pwdLastSet = ".dol_print_date($ldap->pwdlastset, 'day')."<br>\n";  | 
                                                        |
| 167 | + if ($ldapdebug) print "DEBUG: badPasswordTime = ".dol_print_date($ldap->badpwdtime, 'day')."<br>\n";  | 
                                                        |
| 168 | 168 | |
| 169 | 169 | // On recherche le user dolibarr en fonction de son SID ldap  | 
                                                        
| 170 | 170 | $sid = $ldap->getObjectSid($login);  | 
                                                        
| 171 | 171 | if ($ldapdebug) print "DEBUG: sid = ".$sid."<br>\n";  | 
                                                        
| 172 | 172 | |
| 173 | - $usertmp=new User($db);  | 
                                                        |
| 174 | -						$resultFetchUser=$usertmp->fetch('',$login,$sid);
 | 
                                                        |
| 173 | + $usertmp = new User($db);  | 
                                                        |
| 174 | +						$resultFetchUser = $usertmp->fetch('', $login, $sid);
 | 
                                                        |
| 175 | 175 | if ($resultFetchUser > 0)  | 
                                                        
| 176 | 176 |  						{
 | 
                                                        
| 177 | 177 |  							dol_syslog("functions_ldap::check_user_password_ldap Sync user found user id=".$usertmp->id);
 | 
                                                        
@@ -189,17 +189,17 @@ discard block  | 
                                                    ||
| 189 | 189 | unset($usertmp);  | 
                                                        
| 190 | 190 | }  | 
                                                        
| 191 | 191 | |
| 192 | - if (! empty($conf->multicompany->enabled)) // We must check entity (even if sync is not active)  | 
                                                        |
| 192 | + if (!empty($conf->multicompany->enabled)) // We must check entity (even if sync is not active)  | 
                                                        |
| 193 | 193 |  				{
 | 
                                                        
| 194 | 194 | global $mc;  | 
                                                        
| 195 | 195 | |
| 196 | - $usertmp=new User($db);  | 
                                                        |
| 197 | -					$usertmp->fetch('',$login);
 | 
                                                        |
| 198 | - $ret=$mc->checkRight($usertmp->id, $entitytotest);  | 
                                                        |
| 196 | + $usertmp = new User($db);  | 
                                                        |
| 197 | +					$usertmp->fetch('', $login);
 | 
                                                        |
| 198 | + $ret = $mc->checkRight($usertmp->id, $entitytotest);  | 
                                                        |
| 199 | 199 | if ($ret < 0)  | 
                                                        
| 200 | 200 |  					{
 | 
                                                        
| 201 | 201 |  						dol_syslog("functions_ldap::check_user_password_ldap Authentification ko entity '".$entitytotest."' not allowed for user '".$usertmp->id."'");
 | 
                                                        
| 202 | - $login=''; // force authentication failure  | 
                                                        |
| 202 | + $login = ''; // force authentication failure  | 
                                                        |
| 203 | 203 | }  | 
                                                        
| 204 | 204 | unset($usertmp);  | 
                                                        
| 205 | 205 | }  | 
                                                        
@@ -212,7 +212,7 @@ discard block  | 
                                                    ||
| 212 | 212 | // Load translation files required by the page  | 
                                                        
| 213 | 213 |                  $langs->loadLangs(array('main', 'other'));
 | 
                                                        
| 214 | 214 | |
| 215 | -				$_SESSION["dol_loginmesg"]=$langs->trans("ErrorBadLoginPassword");
 | 
                                                        |
| 215 | +				$_SESSION["dol_loginmesg"] = $langs->trans("ErrorBadLoginPassword");
 | 
                                                        |
| 216 | 216 | }  | 
                                                        
| 217 | 217 | }  | 
                                                        
| 218 | 218 | else  | 
                                                        
@@ -232,12 +232,12 @@ discard block  | 
                                                    ||
| 232 | 232 | $ldap->ldapErrorText = ldap_error($ldap->connection);  | 
                                                        
| 233 | 233 |  				dol_syslog("functions_ldap::check_user_password_ldap ".$ldap->ldapErrorCode." ".$ldap->ldapErrorText);
 | 
                                                        
| 234 | 234 | }  | 
                                                        
| 235 | - sleep(2); // Anti brut force protection  | 
                                                        |
| 235 | + sleep(2); // Anti brut force protection  | 
                                                        |
| 236 | 236 | |
| 237 | 237 | // Load translation files required by the page  | 
                                                        
| 238 | 238 |              $langs->loadLangs(array('main', 'other', 'errors'));
 | 
                                                        
| 239 | 239 | ;  | 
                                                        
| 240 | -			$_SESSION["dol_loginmesg"]=($ldap->error?$ldap->error:$langs->trans("ErrorBadLoginPassword"));
 | 
                                                        |
| 240 | +			$_SESSION["dol_loginmesg"] = ($ldap->error ? $ldap->error : $langs->trans("ErrorBadLoginPassword"));
 | 
                                                        |
| 241 | 241 | }  | 
                                                        
| 242 | 242 | |
| 243 | 243 | $ldap->close();  | 
                                                        
@@ -45,7 +45,9 @@ discard block  | 
                                                    ||
| 45 | 45 | |
| 46 | 46 | // Force master entity in transversal mode  | 
                                                        
| 47 | 47 | $entity=$entitytotest;  | 
                                                        
| 48 | - if (! empty($conf->multicompany->enabled) && ! empty($conf->global->MULTICOMPANY_TRANSVERSE_MODE)) $entity=1;  | 
                                                        |
| 48 | +	if (! empty($conf->multicompany->enabled) && ! empty($conf->global->MULTICOMPANY_TRANSVERSE_MODE)) { | 
                                                        |
| 49 | + $entity=1;  | 
                                                        |
| 50 | + }  | 
                                                        |
| 49 | 51 | |
| 50 | 52 | $login='';  | 
                                                        
| 51 | 53 | $resultFetchUser='';  | 
                                                        
@@ -78,7 +80,9 @@ discard block  | 
                                                    ||
| 78 | 80 | $ldapadminpass=$dolibarr_main_auth_ldap_admin_pass;  | 
                                                        
| 79 | 81 | $ldapdebug=(empty($dolibarr_main_auth_ldap_debug) || $dolibarr_main_auth_ldap_debug=="false" ? false : true);  | 
                                                        
| 80 | 82 | |
| 81 | - if ($ldapdebug) print "DEBUG: Logging LDAP steps<br>\n";  | 
                                                        |
| 83 | +		if ($ldapdebug) { | 
                                                        |
| 84 | + print "DEBUG: Logging LDAP steps<br>\n";  | 
                                                        |
| 85 | + }  | 
                                                        |
| 82 | 86 | |
| 83 | 87 | require_once DOL_DOCUMENT_ROOT.'/core/class/ldap.class.php';  | 
                                                        
| 84 | 88 | $ldap=new Ldap();  | 
                                                        
@@ -116,20 +120,25 @@ discard block  | 
                                                    ||
| 116 | 120 |  			{
 | 
                                                        
| 117 | 121 | $resultFetchLdapUser = $ldap->fetch($usertotest,$userSearchFilter);  | 
                                                        
| 118 | 122 |  				//dol_syslog('functions_ldap::check_user_password_ldap resultFetchLdapUser='.$resultFetchLdapUser);
 | 
                                                        
| 119 | - if ($resultFetchLdapUser > 0 && $ldap->pwdlastset == 0) // If ok but password need to be reset  | 
                                                        |
| 123 | +				if ($resultFetchLdapUser > 0 && $ldap->pwdlastset == 0) { | 
                                                        |
| 124 | + // If ok but password need to be reset  | 
                                                        |
| 120 | 125 |  				{
 | 
                                                        
| 121 | -					dol_syslog('functions_ldap::check_user_password_ldap '.$usertotest.' must change password next logon');
 | 
                                                        |
| 122 | - if ($ldapdebug) print "DEBUG: User ".$usertotest." must change password<br>\n";  | 
                                                        |
| 126 | +					dol_syslog('functions_ldap::check_user_password_ldap '.$usertotest.' must change password next logon'); | 
                                                        |
| 127 | + }  | 
                                                        |
| 128 | +					if ($ldapdebug) { | 
                                                        |
| 129 | + print "DEBUG: User ".$usertotest." must change password<br>\n";  | 
                                                        |
| 130 | + }  | 
                                                        |
| 123 | 131 | $ldap->close();  | 
                                                        
| 124 | 132 | sleep(1);  | 
                                                        
| 125 | 133 |  					$langs->load('ldap');
 | 
                                                        
| 126 | 134 |  					$_SESSION["dol_loginmesg"]=$langs->trans("YouMustChangePassNextLogon",$usertotest,$ldap->domainFQDN);
 | 
                                                        
| 127 | 135 | return '';  | 
                                                        
| 128 | 136 | }  | 
                                                        
| 129 | - }  | 
                                                        |
| 130 | - else  | 
                                                        |
| 137 | + } else  | 
                                                        |
| 131 | 138 |  			{
 | 
                                                        
| 132 | - if ($ldapdebug) print "DEBUG: ".$ldap->error."<br>\n";  | 
                                                        |
| 139 | +				 if ($ldapdebug) { | 
                                                        |
| 140 | + print "DEBUG: ".$ldap->error."<br>\n";  | 
                                                        |
| 141 | + }  | 
                                                        |
| 133 | 142 | }  | 
                                                        
| 134 | 143 | $ldap->close();  | 
                                                        
| 135 | 144 | }  | 
                                                        
@@ -140,7 +149,9 @@ discard block  | 
                                                    ||
| 140 | 149 | $ldap->searchUser=$ldapuserattr."=".$usertotest.",".$ldapdn; // Default dn (will work if LDAP accept a dn with login value inside)  | 
                                                        
| 141 | 150 | // But if LDAP need a dn with name like "cn=Jhon Bloggs,ou=People,dc=foo,dc=com", previous part must have been executed to have  | 
                                                        
| 142 | 151 | // dn detected into ldapUserDN.  | 
                                                        
| 143 | - if ($resultFetchLdapUser && !empty($ldap->ldapUserDN)) $ldap->searchUser = $ldap->ldapUserDN;  | 
                                                        |
| 152 | +		if ($resultFetchLdapUser && !empty($ldap->ldapUserDN)) { | 
                                                        |
| 153 | + $ldap->searchUser = $ldap->ldapUserDN;  | 
                                                        |
| 154 | + }  | 
                                                        |
| 144 | 155 | $ldap->searchPassword=$passwordtotest;  | 
                                                        
| 145 | 156 | |
| 146 | 157 | // Test with this->seachUser and this->searchPassword  | 
                                                        
@@ -148,27 +159,41 @@ discard block  | 
                                                    ||
| 148 | 159 | $result=$ldap->connect_bind();  | 
                                                        
| 149 | 160 | if ($result > 0)  | 
                                                        
| 150 | 161 |  		{
 | 
                                                        
| 151 | - if ($result == 2) // Connection is ok for user/pass into LDAP  | 
                                                        |
| 162 | +			if ($result == 2) { | 
                                                        |
| 163 | + // Connection is ok for user/pass into LDAP  | 
                                                        |
| 152 | 164 |  			{
 | 
                                                        
| 153 | -				dol_syslog("functions_ldap::check_user_password_ldap Authentification ok");
 | 
                                                        |
| 165 | +				dol_syslog("functions_ldap::check_user_password_ldap Authentification ok"); | 
                                                        |
| 166 | + }  | 
                                                        |
| 154 | 167 | $login=$usertotest;  | 
                                                        
| 155 | 168 | |
| 156 | 169 | // ldap2dolibarr synchronisation  | 
                                                        
| 157 | - if ($login && ! empty($conf->ldap->enabled) && $conf->global->LDAP_SYNCHRO_ACTIVE == 'ldap2dolibarr') // ldap2dolibarr synchronisation  | 
                                                        |
| 170 | +				if ($login && ! empty($conf->ldap->enabled) && $conf->global->LDAP_SYNCHRO_ACTIVE == 'ldap2dolibarr') { | 
                                                        |
| 171 | + // ldap2dolibarr synchronisation  | 
                                                        |
| 158 | 172 |  				{
 | 
                                                        
| 159 | -						dol_syslog("functions_ldap::check_user_password_ldap Sync ldap2dolibarr");
 | 
                                                        |
| 173 | +						dol_syslog("functions_ldap::check_user_password_ldap Sync ldap2dolibarr"); | 
                                                        |
| 174 | + }  | 
                                                        |
| 160 | 175 | |
| 161 | 176 | // On charge les attributs du user ldap  | 
                                                        
| 162 | - if ($ldapdebug) print "DEBUG: login ldap = ".$login."<br>\n";  | 
                                                        |
| 177 | +						if ($ldapdebug) { | 
                                                        |
| 178 | + print "DEBUG: login ldap = ".$login."<br>\n";  | 
                                                        |
| 179 | + }  | 
                                                        |
| 163 | 180 | $resultFetchLdapUser = $ldap->fetch($login,$userSearchFilter);  | 
                                                        
| 164 | 181 | |
| 165 | -						if ($ldapdebug) print "DEBUG: UACF = ".join(',',$ldap->uacf)."<br>\n";
 | 
                                                        |
| 166 | - if ($ldapdebug) print "DEBUG: pwdLastSet = ".dol_print_date($ldap->pwdlastset,'day')."<br>\n";  | 
                                                        |
| 167 | - if ($ldapdebug) print "DEBUG: badPasswordTime = ".dol_print_date($ldap->badpwdtime,'day')."<br>\n";  | 
                                                        |
| 182 | +						if ($ldapdebug) { | 
                                                        |
| 183 | +						    print "DEBUG: UACF = ".join(',',$ldap->uacf)."<br>\n"; | 
                                                        |
| 184 | + }  | 
                                                        |
| 185 | +						if ($ldapdebug) { | 
                                                        |
| 186 | + print "DEBUG: pwdLastSet = ".dol_print_date($ldap->pwdlastset,'day')."<br>\n";  | 
                                                        |
| 187 | + }  | 
                                                        |
| 188 | +						if ($ldapdebug) { | 
                                                        |
| 189 | + print "DEBUG: badPasswordTime = ".dol_print_date($ldap->badpwdtime,'day')."<br>\n";  | 
                                                        |
| 190 | + }  | 
                                                        |
| 168 | 191 | |
| 169 | 192 | // On recherche le user dolibarr en fonction de son SID ldap  | 
                                                        
| 170 | 193 | $sid = $ldap->getObjectSid($login);  | 
                                                        
| 171 | - if ($ldapdebug) print "DEBUG: sid = ".$sid."<br>\n";  | 
                                                        |
| 194 | +						if ($ldapdebug) { | 
                                                        |
| 195 | + print "DEBUG: sid = ".$sid."<br>\n";  | 
                                                        |
| 196 | + }  | 
                                                        |
| 172 | 197 | |
| 173 | 198 | $usertmp=new User($db);  | 
                                                        
| 174 | 199 |  						$resultFetchUser=$usertmp->fetch('',$login,$sid);
 | 
                                                        
@@ -189,9 +214,11 @@ discard block  | 
                                                    ||
| 189 | 214 | unset($usertmp);  | 
                                                        
| 190 | 215 | }  | 
                                                        
| 191 | 216 | |
| 192 | - if (! empty($conf->multicompany->enabled)) // We must check entity (even if sync is not active)  | 
                                                        |
| 217 | +				if (! empty($conf->multicompany->enabled)) { | 
                                                        |
| 218 | + // We must check entity (even if sync is not active)  | 
                                                        |
| 193 | 219 |  				{
 | 
                                                        
| 194 | - global $mc;  | 
                                                        |
| 220 | + global $mc;  | 
                                                        |
| 221 | + }  | 
                                                        |
| 195 | 222 | |
| 196 | 223 | $usertmp=new User($db);  | 
                                                        
| 197 | 224 |  					$usertmp->fetch('',$login);
 | 
                                                        
@@ -214,8 +241,7 @@ discard block  | 
                                                    ||
| 214 | 241 | |
| 215 | 242 |  				$_SESSION["dol_loginmesg"]=$langs->trans("ErrorBadLoginPassword");
 | 
                                                        
| 216 | 243 | }  | 
                                                        
| 217 | - }  | 
                                                        |
| 218 | - else  | 
                                                        |
| 244 | + } else  | 
                                                        |
| 219 | 245 |  		{
 | 
                                                        
| 220 | 246 | /* Login failed. Return false, together with the error code and text from  | 
                                                        
| 221 | 247 | ** the LDAP server. The common error codes and reasons are listed below :  | 
                                                        
@@ -226,9 +252,11 @@ discard block  | 
                                                    ||
| 226 | 252 | ** 53 - Account inactive (manually locked out by administrator)  | 
                                                        
| 227 | 253 | */  | 
                                                        
| 228 | 254 |  			dol_syslog("functions_ldap::check_user_password_ldap Authentification ko failed to connect to LDAP for '".$usertotest."'");
 | 
                                                        
| 229 | - if (is_resource($ldap->connection)) // If connection ok but bind ko  | 
                                                        |
| 255 | +			if (is_resource($ldap->connection)) { | 
                                                        |
| 256 | + // If connection ok but bind ko  | 
                                                        |
| 230 | 257 |  			{
 | 
                                                        
| 231 | - $ldap->ldapErrorCode = ldap_errno($ldap->connection);  | 
                                                        |
| 258 | + $ldap->ldapErrorCode = ldap_errno($ldap->connection);  | 
                                                        |
| 259 | + }  | 
                                                        |
| 232 | 260 | $ldap->ldapErrorText = ldap_error($ldap->connection);  | 
                                                        
| 233 | 261 |  				dol_syslog("functions_ldap::check_user_password_ldap ".$ldap->ldapErrorCode." ".$ldap->ldapErrorText);
 | 
                                                        
| 234 | 262 | }  | 
                                                        
@@ -32,17 +32,17 @@  | 
                                                    ||
| 32 | 32 | * @param int $entitytotest Number of instance (always 1 if module multicompany not enabled)  | 
                                                        
| 33 | 33 | * @return string Login if OK, '' if KO  | 
                                                        
| 34 | 34 | */  | 
                                                        
| 35 | -function check_user_password_forceuser($usertotest,$passwordtotest,$entitytotest)  | 
                                                        |
| 35 | +function check_user_password_forceuser($usertotest, $passwordtotest, $entitytotest)  | 
                                                        |
| 36 | 36 |  {
 | 
                                                        
| 37 | 37 | // Variable dolibarr_auto_user must be defined in conf.php file  | 
                                                        
| 38 | 38 | global $dolibarr_auto_user;  | 
                                                        
| 39 | 39 | |
| 40 | 40 |  	dol_syslog("functions_forceuser::check_user_password_forceuser");
 | 
                                                        
| 41 | 41 | |
| 42 | - $login=$dolibarr_auto_user;  | 
                                                        |
| 43 | - if (empty($login)) $login='auto';  | 
                                                        |
| 42 | + $login = $dolibarr_auto_user;  | 
                                                        |
| 43 | + if (empty($login)) $login = 'auto';  | 
                                                        |
| 44 | 44 | |
| 45 | - if ($_SESSION["dol_loginmesg"]) $login='';  | 
                                                        |
| 45 | + if ($_SESSION["dol_loginmesg"]) $login = '';  | 
                                                        |
| 46 | 46 | |
| 47 | 47 |  	dol_syslog("functions_forceuser::check_user_password_forceuser ok. forced user = ".$login);
 | 
                                                        
| 48 | 48 | return $login;  | 
                                                        
@@ -40,9 +40,13 @@  | 
                                                    ||
| 40 | 40 |  	dol_syslog("functions_forceuser::check_user_password_forceuser");
 | 
                                                        
| 41 | 41 | |
| 42 | 42 | $login=$dolibarr_auto_user;  | 
                                                        
| 43 | - if (empty($login)) $login='auto';  | 
                                                        |
| 43 | +	if (empty($login)) { | 
                                                        |
| 44 | + $login='auto';  | 
                                                        |
| 45 | + }  | 
                                                        |
| 44 | 46 | |
| 45 | - if ($_SESSION["dol_loginmesg"]) $login='';  | 
                                                        |
| 47 | +	if ($_SESSION["dol_loginmesg"]) { | 
                                                        |
| 48 | + $login='';  | 
                                                        |
| 49 | + }  | 
                                                        |
| 46 | 50 | |
| 47 | 51 |  	dol_syslog("functions_forceuser::check_user_password_forceuser ok. forced user = ".$login);
 | 
                                                        
| 48 | 52 | return $login;  | 
                                                        
@@ -10,14 +10,14 @@  | 
                                                    ||
| 10 | 10 | * @param int $entitytotest Number of instance (always 1 if module multicompany not enabled)  | 
                                                        
| 11 | 11 | * @return string Login if OK, '' if KO  | 
                                                        
| 12 | 12 | */  | 
                                                        
| 13 | -function check_user_password_http($usertotest,$passwordtotest,$entitytotest)  | 
                                                        |
| 13 | +function check_user_password_http($usertotest, $passwordtotest, $entitytotest)  | 
                                                        |
| 14 | 14 |  {
 | 
                                                        
| 15 | -	DolUtils::dol_syslog("functions_http::check_user_password_http _SERVER[REMOTE_USER]=" . (empty($_SERVER["REMOTE_USER"]) ? '' : $_SERVER["REMOTE_USER"]));
 | 
                                                        |
| 15 | +	DolUtils::dol_syslog("functions_http::check_user_password_http _SERVER[REMOTE_USER]=".(empty($_SERVER["REMOTE_USER"]) ? '' : $_SERVER["REMOTE_USER"]));
 | 
                                                        |
| 16 | 16 | |
| 17 | - $login='';  | 
                                                        |
| 18 | - if (! empty($_SERVER["REMOTE_USER"]))  | 
                                                        |
| 17 | + $login = '';  | 
                                                        |
| 18 | + if (!empty($_SERVER["REMOTE_USER"]))  | 
                                                        |
| 19 | 19 |  	{
 | 
                                                        
| 20 | - $login=$_SERVER["REMOTE_USER"];  | 
                                                        |
| 20 | + $login = $_SERVER["REMOTE_USER"];  | 
                                                        |
| 21 | 21 | }  | 
                                                        
| 22 | 22 | |
| 23 | 23 | return $login;  |