Linux vps-61133.fhnet.fr 4.9.0-19-amd64 #1 SMP Debian 4.9.320-2 (2022-06-30) x86_64
Apache/2.4.25 (Debian)
Server IP : 93.113.207.21 & Your IP : 216.73.216.35
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
var /
www /
html_old /
btm2000.bak /
admin /
Delete
Unzip
Name
Size
Permission
Date
Action
dolistore
[ DIR ]
drwxr-xr-x
2025-11-25 12:58
menus
[ DIR ]
drwxr-xr-x
2025-11-25 13:10
system
[ DIR ]
drwxr-xr-x
2025-11-25 13:10
tools
[ DIR ]
drwxr-xr-x
2025-11-25 13:10
accountant.php
12.01
KB
-rw-r--r--
2025-11-25 13:10
agenda.php
6.71
KB
-rw-r--r--
2025-11-25 13:10
agenda_extrafields.php
4.01
KB
-rw-r--r--
2025-11-25 13:10
agenda_extsites.php
8.17
KB
-rw-r--r--
2025-11-25 13:10
agenda_other.php
13.6
KB
-rw-r--r--
2025-11-25 13:10
agenda_reminder.php
7.6
KB
-rw-r--r--
2025-11-25 13:10
agenda_xcal.php
8.41
KB
-rw-r--r--
2025-11-25 13:10
bank.php
15.95
KB
-rw-r--r--
2025-11-25 13:10
bank_extrafields.php
3.89
KB
-rw-r--r--
2025-11-25 13:10
barcode.php
12.23
KB
-rw-r--r--
2025-11-25 13:10
boxes.php
16.42
KB
-rw-r--r--
2025-11-25 13:10
chequereceipts.php
9.11
KB
-rw-r--r--
2025-11-25 13:10
clicktodial.php
4.94
KB
-rw-r--r--
2025-11-25 13:10
commande.php
22.87
KB
-rw-r--r--
2025-11-25 13:10
company.php
49.4
KB
-rw-r--r--
2025-11-25 13:10
compta.php
5.04
KB
-rw-r--r--
2025-11-25 13:10
confexped.php
4.42
KB
-rw-r--r--
2025-11-25 13:10
const.php
8.74
KB
-rw-r--r--
2025-11-25 13:10
contract.php
16.72
KB
-rw-r--r--
2025-11-25 13:10
dav.php
4.41
KB
-rw-r--r--
2025-11-25 13:10
defaultvalues.php
14.15
KB
-rw-r--r--
2025-11-25 13:10
delais.php
14.2
KB
-rw-r--r--
2025-11-25 13:10
dict.php
96.79
KB
-rw-r--r--
2025-11-25 13:10
ecm.php
2.94
KB
-rw-r--r--
2025-11-25 13:10
events.php
3.23
KB
-rw-r--r--
2025-11-25 13:10
expedition.php
17.26
KB
-rw-r--r--
2025-11-25 13:10
expedition_extrafields.php
4.07
KB
-rw-r--r--
2025-11-25 13:10
expeditiondet_extrafields.php
4.14
KB
-rw-r--r--
2025-11-25 13:10
expensereport.php
16.31
KB
-rw-r--r--
2025-11-25 13:10
expensereport_extrafields.php
4.01
KB
-rw-r--r--
2025-11-25 13:10
expensereport_ik.php
6.13
KB
-rw-r--r--
2025-11-25 13:10
expensereport_rules.php
10.98
KB
-rw-r--r--
2025-11-25 13:10
export.php
2.99
KB
-rw-r--r--
2025-11-25 13:10
external_rss.php
9.69
KB
-rw-r--r--
2025-11-25 13:10
facture.php
29.19
KB
-rw-r--r--
2025-11-25 13:10
fckeditor.php
7.59
KB
-rw-r--r--
2025-11-25 13:10
fichinter.php
21.12
KB
-rw-r--r--
2025-11-25 13:10
geoipmaxmind.php
4.41
KB
-rw-r--r--
2025-11-25 13:10
ihm.php
24.92
KB
-rw-r--r--
2025-11-25 13:10
index.php
4.67
KB
-rw-r--r--
2025-11-25 13:10
ldap.php
12.54
KB
-rw-r--r--
2025-11-25 13:10
ldap_contacts.php
14.88
KB
-rw-r--r--
2025-11-25 13:10
ldap_groups.php
9.08
KB
-rw-r--r--
2025-11-25 13:10
ldap_members.php
19.79
KB
-rw-r--r--
2025-11-25 13:10
ldap_members_types.php
8.71
KB
-rw-r--r--
2025-11-25 13:10
ldap_users.php
19.73
KB
-rw-r--r--
2025-11-25 13:10
limits.php
11.65
KB
-rw-r--r--
2025-11-25 13:10
livraison.php
15.89
KB
-rw-r--r--
2025-11-25 13:10
livraison_extrafields.php
4.07
KB
-rw-r--r--
2025-11-25 13:10
livraisondet_extrafields.php
4.14
KB
-rw-r--r--
2025-11-25 13:10
loan.php
3.22
KB
-rw-r--r--
2025-11-25 13:10
mailing.php
5.39
KB
-rw-r--r--
2025-11-25 13:10
mailman.php
7.63
KB
-rw-r--r--
2025-11-25 13:10
mails.php
37.08
KB
-rw-r--r--
2025-11-25 13:10
mails_emailing.php
25.19
KB
-rw-r--r--
2025-11-25 13:10
mails_senderprofile_list.php
19.76
KB
-rw-r--r--
2025-11-25 13:10
mails_templates.php
44.67
KB
-rw-r--r--
2025-11-25 13:10
menus.php
9.84
KB
-rw-r--r--
2025-11-25 13:10
modulehelp.php
18.65
KB
-rw-r--r--
2025-11-25 13:10
modules.php
43.45
KB
-rw-r--r--
2025-11-25 13:10
multicurrency.php
12.72
KB
-rw-r--r--
2025-11-25 13:10
notification.php
10.17
KB
-rw-r--r--
2025-11-25 13:10
oauth.php
4.73
KB
-rw-r--r--
2025-11-25 13:10
oauthlogintokens.php
13.28
KB
-rw-r--r--
2025-11-25 13:10
order_extrafields.php
3.95
KB
-rw-r--r--
2025-11-25 13:10
orderdet_extrafields.php
4.03
KB
-rw-r--r--
2025-11-25 13:10
payment.php
9.84
KB
-rw-r--r--
2025-11-25 13:10
pdf.php
24.66
KB
-rw-r--r--
2025-11-25 13:10
perms.php
6.56
KB
-rw-r--r--
2025-11-25 13:10
prelevement.php
17.78
KB
-rw-r--r--
2025-11-25 13:10
propal.php
21.95
KB
-rw-r--r--
2025-11-25 13:10
proxy.php
6.73
KB
-rw-r--r--
2025-11-25 13:10
receiptprinter.php
16.72
KB
-rw-r--r--
2025-11-25 13:10
resource.php
4.13
KB
-rw-r--r--
2025-11-25 13:10
resource_extrafields.php
3.92
KB
-rw-r--r--
2025-11-25 13:10
salaries.php
3.22
KB
-rw-r--r--
2025-11-25 13:10
security.php
15.43
KB
-rw-r--r--
2025-11-25 13:10
security_file.php
6.87
KB
-rw-r--r--
2025-11-25 13:10
security_other.php
6.07
KB
-rw-r--r--
2025-11-25 13:10
sms.php
11.25
KB
-rw-r--r--
2025-11-25 13:10
spip.php
4.72
KB
-rw-r--r--
2025-11-25 13:10
stock.php
23.42
KB
-rw-r--r--
2025-11-25 13:10
supplier_invoice.php
18.36
KB
-rw-r--r--
2025-11-25 13:10
supplier_order.php
20.44
KB
-rw-r--r--
2025-11-25 13:10
supplier_payment.php
16.34
KB
-rw-r--r--
2025-11-25 13:10
supplier_proposal.php
20.24
KB
-rw-r--r--
2025-11-25 13:10
supplierinvoice_extrafields.php
4.15
KB
-rw-r--r--
2025-11-25 13:10
supplierinvoicedet_extrafields.php
4.16
KB
-rw-r--r--
2025-11-25 13:10
supplierorder_extrafields.php
4.01
KB
-rw-r--r--
2025-11-25 13:10
supplierorderdet_extrafields.php
4.08
KB
-rw-r--r--
2025-11-25 13:10
syslog.php
10.08
KB
-rw-r--r--
2025-11-25 13:10
taxes.php
8.76
KB
-rw-r--r--
2025-11-25 13:10
ticket.php
25.76
KB
-rw-r--r--
2025-11-25 13:10
ticket_extrafields.php
3.75
KB
-rw-r--r--
2025-11-25 13:10
translation.php
22.54
KB
-rw-r--r--
2025-11-25 13:10
triggers.php
2.69
KB
-rw-r--r--
2025-11-25 13:10
user.php
11.37
KB
-rw-r--r--
2025-11-25 13:10
usergroup.php
10.09
KB
-rw-r--r--
2025-11-25 13:10
website.php
22.92
KB
-rw-r--r--
2025-11-25 13:10
website_options.php
4.64
KB
-rw-r--r--
2025-11-25 13:10
workflow.php
6.59
KB
-rw-r--r--
2025-11-25 13:10
Save
Rename
<?php /* Copyright (C) 2007-2012 Laurent Destailleur <eldy@users.sourceforge.net> * Copyright (C) 2009-2012 Regis Houssin <regis.houssin@capnetworks.com> * Copyright (C) 2010 Juanjo Menent <jmenent@2byte.es> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ /** * \file htdocs/admin/limits.php * \brief Page to setup limits */ require '../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/price.lib.php'; // Load translation files required by the page $langs->loadLangs(array('companies', 'products', 'admin')); if (! $user->admin) accessforbidden(); $action = GETPOST('action','alpha'); if ($action == 'update') { $error=0; $MAXDEC=8; if ($_POST["MAIN_MAX_DECIMALS_UNIT"] > $MAXDEC || $_POST["MAIN_MAX_DECIMALS_TOT"] > $MAXDEC || $_POST["MAIN_MAX_DECIMALS_SHOWN"] > $MAXDEC) { $error++; setEventMessages($langs->trans("ErrorDecimalLargerThanAreForbidden",$MAXDEC), null, 'errors'); } if ($_POST["MAIN_MAX_DECIMALS_UNIT"] < 0 || $_POST["MAIN_MAX_DECIMALS_TOT"] < 0 || $_POST["MAIN_MAX_DECIMALS_SHOWN"] < 0) { $langs->load("errors"); $error++; setEventMessages($langs->trans("ErrorNegativeValueNotAllowed"), null, 'errors'); } if ($_POST["MAIN_ROUNDING_RULE_TOT"]) { if ($_POST["MAIN_ROUNDING_RULE_TOT"] * pow(10,$_POST["MAIN_MAX_DECIMALS_TOT"]) < 1) { $langs->load("errors"); $error++; setEventMessages($langs->trans("ErrorMAIN_ROUNDING_RULE_TOTCanMAIN_MAX_DECIMALS_TOT"), null, 'errors'); } } if (! $error) { dolibarr_set_const($db, "MAIN_MAX_DECIMALS_UNIT", $_POST["MAIN_MAX_DECIMALS_UNIT"],'chaine',0,'',$conf->entity); dolibarr_set_const($db, "MAIN_MAX_DECIMALS_TOT", $_POST["MAIN_MAX_DECIMALS_TOT"],'chaine',0,'',$conf->entity); dolibarr_set_const($db, "MAIN_MAX_DECIMALS_SHOWN", $_POST["MAIN_MAX_DECIMALS_SHOWN"],'chaine',0,'',$conf->entity); dolibarr_set_const($db, "MAIN_ROUNDING_RULE_TOT", $_POST["MAIN_ROUNDING_RULE_TOT"],'chaine',0,'',$conf->entity); header("Location: ".$_SERVER["PHP_SELF"]."?mainmenu=home&leftmenu=setup"); exit; } } /* * View */ $form=new Form($db); llxHeader(); print load_fiche_titre($langs->trans("LimitsSetup"),'','title_setup'); print $langs->trans("LimitsDesc")."<br>\n"; print "<br>\n"; if ($action == 'edit') { print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'">'; print '<input type="hidden" name="token" value="'.$_SESSION['newtoken'].'">'; print '<input type="hidden" name="action" value="update">'; clearstatcache(); print '<table class="noborder" width="100%">'; print '<tr class="liste_titre"><td>'.$langs->trans("Parameter").'</td><td>'.$langs->trans("Value").'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_UNIT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="MAIN_MAX_DECIMALS_UNIT" size="3" value="' . $conf->global->MAIN_MAX_DECIMALS_UNIT . '"></td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_TOT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="MAIN_MAX_DECIMALS_TOT" size="3" value="' . $conf->global->MAIN_MAX_DECIMALS_TOT . '"></td></tr>'; print '<tr class="oddeven"><td>'.$langs->trans("MAIN_MAX_DECIMALS_SHOWN").'</td><td><input class="flat" name="MAIN_MAX_DECIMALS_SHOWN" size="3" value="' . $conf->global->MAIN_MAX_DECIMALS_SHOWN . '"></td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_ROUNDING_RULE_TOT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td><input class="flat" name="MAIN_ROUNDING_RULE_TOT" size="3" value="' . $conf->global->MAIN_ROUNDING_RULE_TOT . '"></td></tr>'; print '</table>'; print '<br><div class="center">'; print '<input class="button" type="submit" value="'.$langs->trans("Save").'">'; print '</div>'; print '</form>'; print '<br>'; } else { print '<table class="noborder" width="100%">'; print '<tr class="liste_titre"><td>'.$langs->trans("Parameter").'</td><td>'.$langs->trans("Value").'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_UNIT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.$conf->global->MAIN_MAX_DECIMALS_UNIT.'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_MAX_DECIMALS_TOT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.$conf->global->MAIN_MAX_DECIMALS_TOT.'</td></tr>'; print '<tr class="oddeven"><td>'.$langs->trans("MAIN_MAX_DECIMALS_SHOWN").'</td><td align="right">'.$conf->global->MAIN_MAX_DECIMALS_SHOWN.'</td></tr>'; print '<tr class="oddeven"><td>'; print $form->textwithpicto($langs->trans("MAIN_ROUNDING_RULE_TOT"),$langs->trans("ParameterActiveForNextInputOnly")); print '</td><td align="right">'.$conf->global->MAIN_ROUNDING_RULE_TOT.'</td></tr>'; print '</table>'; print '<div class="tabsAction">'; print '<a class="butAction" href="'.$_SERVER["PHP_SELF"].'?action=edit">'.$langs->trans("Modify").'</a>'; print '</div>'; } if (empty($mysoc->country_code)) { $langs->load("errors"); $warnpicto=img_warning($langs->trans("WarningMandatorySetupNotComplete")); print '<br><a href="'.DOL_URL_ROOT.'/admin/company.php?mainmenu=home">'.$warnpicto.' '.$langs->trans("WarningMandatorySetupNotComplete").'</a>'; } else { // Show examples print '<b>'.$langs->trans("ExamplesWithCurrentSetup").":</b><br>\n"; // Always show vat rates with vat 0 $s=2/7;$qty=1;$vat=0; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0,0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s=10/3;$qty=1;$vat=0; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0,0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s=10/3;$qty=2;$vat=0; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; // Add vat rates examples specific to country $vat_rates=array(); $sql="SELECT taux as vat_rate"; $sql.=" FROM ".MAIN_DB_PREFIX."c_tva as t, ".MAIN_DB_PREFIX."c_country as c"; $sql.=" WHERE t.active=1 AND t.fk_pays = c.rowid AND c.code='".$mysoc->country_code."' AND t.taux <> 0"; $sql.=" ORDER BY t.taux ASC"; $resql=$db->query($sql); if ($resql) { $num = $db->num_rows($resql); if ($num) { for ($i = 0; $i < $num; $i++) { $obj = $db->fetch_object($resql); $vat_rates[$i] = $obj->vat_rate; } } } else dol_print_error($db); if (count($vat_rates)) { foreach($vat_rates as $vat) { for ($qty=1; $qty<=2; $qty++) { $s=10/3; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; } } } else { // More examples if not specific vat rate found // This example must be kept for test purpose with current value because value used (2/7, 10/3, and vat 0, 10) // were calculated to show all possible cases of rounding. If we change this, examples becomes useless or show the same rounding rule. $s=10/3;$qty=1;$vat=10; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; $s=10/3;$qty=2;$vat=10; $tmparray=calcul_price_total(1,$qty*price2num($s,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); print $langs->trans("UnitPriceOfProduct").": ".price2num($s,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$tmparray[0].' / '.$tmparray[1].' / '.$tmparray[2]."<br>\n"; } // Important: can debug rounding, to simulate the rounded total /* print '<br><b>'.$langs->trans("VATRoundedByLine").' ('.$langs->trans("DolibarrDefault").')</b><br>'; foreach($vat_rates as $vat) { for ($qty=1; $qty<=2; $qty++) { $s1=10/3; $s2=2/7; // Round by line $tmparray1=calcul_price_total(1,$qty*price2num($s1,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); $tmparray2=calcul_price_total(1,$qty*price2num($s2,'MU'),0,$vat,0,0,0,'HT',0, 0,$mysoc); $total_ht = $tmparray1[0] + $tmparray2[0]; $total_tva = $tmparray1[1] + $tmparray2[1]; $total_ttc = $tmparray1[2] + $tmparray2[2]; print $langs->trans("UnitPriceOfProduct").": ".(price2num($s1,'MU') + price2num($s2,'MU')); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$total_ht.' / '.$total_tva.' / '.$total_ttc."<br>\n"; } } print '<br><b>'.$langs->trans("VATRoundedOnTotal").'</b><br>'; foreach($vat_rates as $vat) { for ($qty=1; $qty<=2; $qty++) { $s1=10/3; $s2=2/7; // Global round $subtotal_ht = (($qty*price2num($s1,'MU')) + ($qty*price2num($s2,'MU'))); $tmparray3=calcul_price_total(1,$subtotal_ht,0,$vat,0,0,0,'HT',0, 0,$mysoc); $total_ht = $tmparray3[0]; $total_tva = $tmparray3[1]; $total_ttc = $tmparray3[2]; print $langs->trans("UnitPriceOfProduct").": ".price2num($s1+$s2,'MU'); print " x ".$langs->trans("Quantity").": ".$qty; print " - ".$langs->trans("VAT").": ".$vat.'%'; print " -> ".$langs->trans("TotalPriceAfterRounding").": ".$total_ht.' / '.$total_tva.' / '.$total_ttc."<br>\n"; } } */ } llxFooter(); $db->close();