X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=include%2Fplatal.inc.php;h=f72c3a8146f870b57928de7391b5c3d4a6e71bdb;hb=bd5e1f3db498fab68593b5163df0f0b8c3b67791;hp=046807a90588f0e5b79b479d3520ccb52f8129fa;hpb=d3f26be98b879dc9df9be60fffe2f1e152b3b218;p=platal.git diff --git a/include/platal.inc.php b/include/platal.inc.php index 046807a..f72c3a8 100644 --- a/include/platal.inc.php +++ b/include/platal.inc.php @@ -21,8 +21,6 @@ $TIME_BEGIN = microtime(true); -date_default_timezone_set('Europe/Paris'); - define('AUTH_PUBLIC', 0); define('AUTH_COOKIE', 1); define('AUTH_MDP', 2); @@ -38,35 +36,50 @@ define('NO_SKIN', 2); define('NO_AUTH', 0); define('DO_AUTH', 1); +define('DEBUG_BT', 1); +define('DEBUG_VALID', 2); +define('DEBUG_SMARTY', 4); + function __autoload($cls) { - @include dirname(dirname(__FILE__)).'/classes/'.strtolower($cls).'.php'; + $cls = strtolower($cls); + $path = dirname(dirname(__FILE__)); + if (!@include "$path/classes/$cls.php") { + if (substr($cls, -3, 3) == 'req') { + @include 'validations.inc.php'; + return; + } + @include "$cls.inc.php"; + } } __autoload('Env'); function pl_error_handler($errno, $errstr, $errfile, $errline) { + static $errortype; if (!error_reporting()) return; - $errortype = array ( - E_ERROR => "Error", - E_WARNING => "Warning", - E_PARSE => "Parsing Error", - E_NOTICE => "Notice", - E_CORE_ERROR => "Core Error", - E_CORE_WARNING => "Core Warning", - E_COMPILE_ERROR => "Compile Error", - E_COMPILE_WARNING => "Compile Warning", - E_USER_ERROR => "User Error", - E_USER_WARNING => "User Warning", - E_USER_NOTICE => "User Notice", - E_STRICT => "Runtime Notice" - ); + if (!isset($errortype)) { + $errortype = array ( + E_ERROR => "Error", + E_WARNING => "Warning", + E_PARSE => "Parsing Error", + E_NOTICE => "Notice", + E_CORE_ERROR => "Core Error", + E_CORE_WARNING => "Core Warning", + E_COMPILE_ERROR => "Compile Error", + E_COMPILE_WARNING => "Compile Warning", + E_USER_ERROR => "User Error", + E_USER_WARNING => "User Warning", + E_USER_NOTICE => "User Notice", + E_STRICT => "Runtime Notice" + ); + } global $globals; if (isset($globals) && !$globals->debug) { - if (strpos($errortype[$errno], 'Notice') !== false) { + if ($errno == E_NOTICE || $errno == E_USER_NOTICE || $errno == E_STRICT) { return; } } @@ -79,6 +92,11 @@ function pl_error_handler($errno, $errstr, $errfile, $errline) ""; } +function pl_clear_errors() +{ + unset($GLOBALS['pl_errors']); +} + function pl_dump_env() { echo "
";
@@ -91,13 +109,33 @@ function pl_dump_env()
 
 function pl_print_errors()
 {
-    print join("\n", $GLOBALS['pl_errors']);
+    if (!empty($GLOBALS['pl_errors'])) {
+        print join("\n", $GLOBALS['pl_errors']);
+    }
 }
 
 set_error_handler('pl_error_handler', E_ALL | E_STRICT);
 register_shutdown_function('pl_print_errors');
 // register_shutdown_function('pl_dump_env');
 
+/** Check if the string is utf8 
+ */
+function is_utf8($s)
+{
+    return @iconv('utf-8', 'utf-8', $s) == $s;
+}
+
+/** vérifie si une adresse email est bien formatée  * ATTENTION, cette fonction ne doit pas être appelée sur une chaîne ayant subit un addslashes (car elle accepte le "'" qui it alors un "\'" 
+ * @param $email l'adresse email a verifier 
+ * @return BOOL  */
+function isvalid_email($email) 
+{
+    // la rfc2822 authorise les caractères "a-z", "0-9", "!", "#", "$", "%", "&", "'", "*", "+", "-", "/", "=", "?", "^",  `", "{", "|", "}", "~" aussi bien dans la partie locale que dans le domaine. 
+    // Pour la partie locale, on réduit cet ensemble car il n'est pas utilisé. 
+    // Pour le domaine, le système DNS limite à [a-z0-9.-], on y ajoute le "_" car il est parfois utilisé. 
+    return preg_match("/^[a-z0-9_.'+-]+@[a-z0-9._-]+\.[a-z]{2,4}$/i", $email); 
+}
+
 function pl_url($path, $query = null, $fragment = null)
 {
     global $platal;