159 |
jpm |
1 |
<html>
|
|
|
2 |
<head>
|
|
|
3 |
<title>File Source for Log.php</title>
|
|
|
4 |
<meta http-equiv='Content-Type' content='text/html; charset=UTF-8'/>
|
|
|
5 |
<link rel="stylesheet" type="text/css" href="../media/style.css">
|
|
|
6 |
</head>
|
|
|
7 |
<body>
|
|
|
8 |
|
|
|
9 |
<table border="0" cellspacing="0" cellpadding="0" height="48" width="100%">
|
|
|
10 |
<tr>
|
|
|
11 |
<td class="header_top">Framework</td>
|
|
|
12 |
</tr>
|
|
|
13 |
<tr><td class="header_line"><img src="../media/empty.png" width="1" height="1" border="0" alt="" /></td></tr>
|
|
|
14 |
<tr>
|
|
|
15 |
<td class="header_menu">
|
|
|
16 |
|
|
|
17 |
|
|
|
18 |
[ <a href="../classtrees_Framework.html" class="menu">class tree: Framework</a> ]
|
|
|
19 |
[ <a href="../elementindex_Framework.html" class="menu">index: Framework</a> ]
|
|
|
20 |
[ <a href="../elementindex.html" class="menu">all elements</a> ]
|
|
|
21 |
</td>
|
|
|
22 |
</tr>
|
|
|
23 |
<tr><td class="header_line"><img src="../media/empty.png" width="1" height="1" border="0" alt="" /></td></tr>
|
|
|
24 |
</table>
|
|
|
25 |
|
|
|
26 |
<table width="100%" border="0" cellpadding="0" cellspacing="0">
|
|
|
27 |
<tr valign="top">
|
|
|
28 |
<td width="200" class="menu">
|
|
|
29 |
<b>Packages:</b><br />
|
|
|
30 |
<a href="../li_Framework.html">Framework</a><br />
|
|
|
31 |
<br /><br />
|
|
|
32 |
|
|
|
33 |
|
|
|
34 |
</td>
|
|
|
35 |
<td>
|
|
|
36 |
<table cellpadding="10" cellspacing="0" width="100%" border="0"><tr><td valign="top">
|
|
|
37 |
|
|
|
38 |
<h1 align="center">Source for file Log.php</h1>
|
|
|
39 |
<p>Documentation is available at <a href="../Framework/_Log.php.html">Log.php</a></p>
|
|
|
40 |
<div class="src-code">
|
|
|
41 |
<ol><li><div class="src-line"><a name="a1"></a><span class="src-php"><?php</span></div></li>
|
|
|
42 |
<li><div class="src-line"><a name="a2"></a><span class="src-comm">//declare(encoding='UTF-8');</span></div></li>
|
|
|
43 |
<li><div class="src-line"><a name="a3"></a><span class="src-doc">/**</span></div></li>
|
|
|
44 |
<li><div class="src-line"><a name="a4"></a><span class="src-doc"> * Classe permettant de logger des messages dans les fichier situés dans le dossier de log</span></div></li>
|
|
|
45 |
<li><div class="src-line"><a name="a5"></a><span class="src-doc"> *</span></div></li>
|
|
|
46 |
<li><div class="src-line"><a name="a6"></a><span class="src-doc"> * PHP Version 5</span></div></li>
|
|
|
47 |
<li><div class="src-line"><a name="a7"></a><span class="src-doc"> *</span></div></li>
|
|
|
48 |
<li><div class="src-line"><a name="a8"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@category</span><span class="src-doc"> PHP</span></div></li>
|
|
|
49 |
<li><div class="src-line"><a name="a9"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@package</span><span class="src-doc"> Framework</span></div></li>
|
|
|
50 |
<li><div class="src-line"><a name="a10"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> aurelien <aurelien@tela-botanica.org></span></div></li>
|
|
|
51 |
<li><div class="src-line"><a name="a11"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@copyright</span><span class="src-doc"> 2009 Tela-Botanica</span></div></li>
|
|
|
52 |
<li><div class="src-line"><a name="a12"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@license</span><span class="src-doc"> http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL</span></div></li>
|
|
|
53 |
<li><div class="src-line"><a name="a13"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@version</span><span class="src-doc"> SVN: <svn_id></span></div></li>
|
|
|
54 |
<li><div class="src-line"><a name="a14"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@link</span><span class="src-doc"> /doc/framework/</span></div></li>
|
|
|
55 |
<li><div class="src-line"><a name="a15"></a><span class="src-doc"> */</span></div></li>
|
|
|
56 |
<li><div class="src-line"><a name="a16"></a> </div></li>
|
|
|
57 |
<li><div class="src-line"><a name="a17"></a><span class="src-key">class </span><a href="../Framework/Log.html">Log</a> <span class="src-sym">{</span></div></li>
|
|
|
58 |
<li><div class="src-line"><a name="a18"></a> </div></li>
|
|
|
59 |
<li><div class="src-line"><a name="a19"></a> <span class="src-doc">/**</span></div></li>
|
|
|
60 |
<li><div class="src-line"><a name="a20"></a><span class="src-doc"> * Tableau associatif stockant les descripteurs de fichiers</span></div></li>
|
|
|
61 |
<li><div class="src-line"><a name="a21"></a><span class="src-doc"> */</span></div></li>
|
|
|
62 |
<li><div class="src-line"><a name="a22"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$fichiersLog </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
63 |
<li><div class="src-line"><a name="a23"></a> </div></li>
|
|
|
64 |
<li><div class="src-line"><a name="a24"></a> <span class="src-doc">/**</span></div></li>
|
|
|
65 |
<li><div class="src-line"><a name="a25"></a><span class="src-doc"> * Chemin de base du dossier log de l'application</span></div></li>
|
|
|
66 |
<li><div class="src-line"><a name="a26"></a><span class="src-doc"> */</span></div></li>
|
|
|
67 |
<li><div class="src-line"><a name="a27"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$cheminLogs </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
|
|
68 |
<li><div class="src-line"><a name="a28"></a> </div></li>
|
|
|
69 |
<li><div class="src-line"><a name="a29"></a> <span class="src-doc">/**</span></div></li>
|
|
|
70 |
<li><div class="src-line"><a name="a30"></a><span class="src-doc"> * Booleen indiquant si l'on peut correctement écrire dans les fichiers de logs</span></div></li>
|
|
|
71 |
<li><div class="src-line"><a name="a31"></a><span class="src-doc"> */</span></div></li>
|
|
|
72 |
<li><div class="src-line"><a name="a32"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$droitLogger </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
|
|
73 |
<li><div class="src-line"><a name="a33"></a> </div></li>
|
|
|
74 |
<li><div class="src-line"><a name="a34"></a> <span class="src-doc">/**</span></div></li>
|
|
|
75 |
<li><div class="src-line"><a name="a35"></a><span class="src-doc"> * Zone horaire (pour éviter des avertissements dans les dates)</span></div></li>
|
|
|
76 |
<li><div class="src-line"><a name="a36"></a><span class="src-doc"> */</span></div></li>
|
|
|
77 |
<li><div class="src-line"><a name="a37"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$timeZone </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
|
|
78 |
<li><div class="src-line"><a name="a38"></a> </div></li>
|
|
|
79 |
<li><div class="src-line"><a name="a39"></a> <span class="src-doc">/**</span></div></li>
|
|
|
80 |
<li><div class="src-line"><a name="a40"></a><span class="src-doc"> * Taille maximum d'un fichier de log avant que celui ne soit archivé (en octets)</span></div></li>
|
|
|
81 |
<li><div class="src-line"><a name="a41"></a><span class="src-doc"> */</span></div></li>
|
|
|
82 |
<li><div class="src-line"><a name="a42"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$tailleMax </span>= <span class="src-num">10000</span><span class="src-sym">;</span></div></li>
|
|
|
83 |
<li><div class="src-line"><a name="a43"></a> </div></li>
|
|
|
84 |
<li><div class="src-line"><a name="a44"></a> <span class="src-doc">/**</span></div></li>
|
|
|
85 |
<li><div class="src-line"><a name="a45"></a><span class="src-doc"> * séparateur de chemin</span></div></li>
|
|
|
86 |
<li><div class="src-line"><a name="a46"></a><span class="src-doc"> */</span></div></li>
|
|
|
87 |
<li><div class="src-line"><a name="a47"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$sd </span>= <span class="src-id">DIRECTORY_SEPARATOR</span><span class="src-sym">;</span></div></li>
|
|
|
88 |
<li><div class="src-line"><a name="a48"></a> </div></li>
|
|
|
89 |
<li><div class="src-line"><a name="a49"></a> <span class="src-doc">/**</span></div></li>
|
|
|
90 |
<li><div class="src-line"><a name="a50"></a><span class="src-doc"> * Extension des fichiers de log</span></div></li>
|
|
|
91 |
<li><div class="src-line"><a name="a51"></a><span class="src-doc"> */</span></div></li>
|
|
|
92 |
<li><div class="src-line"><a name="a52"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$ext </span>= <span class="src-str">'.log'</span><span class="src-sym">;</span></div></li>
|
|
|
93 |
<li><div class="src-line"><a name="a53"></a> </div></li>
|
|
|
94 |
<li><div class="src-line"><a name="a54"></a> <span class="src-doc">/**</span></div></li>
|
|
|
95 |
<li><div class="src-line"><a name="a55"></a><span class="src-doc"> * La classe registre se contient elle-même, (pour le pattern singleton)</span></div></li>
|
|
|
96 |
<li><div class="src-line"><a name="a56"></a><span class="src-doc"> */</span></div></li>
|
|
|
97 |
<li><div class="src-line"><a name="a57"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-var">$log</span><span class="src-sym">;</span></div></li>
|
|
|
98 |
<li><div class="src-line"><a name="a58"></a> </div></li>
|
|
|
99 |
<li><div class="src-line"><a name="a59"></a> <span class="src-doc">/**</span></div></li>
|
|
|
100 |
<li><div class="src-line"><a name="a60"></a><span class="src-doc"> * Constructeur par défaut, privé, car on accède à la classe par le getInstance</span></div></li>
|
|
|
101 |
<li><div class="src-line"><a name="a61"></a><span class="src-doc"> */</span></div></li>
|
|
|
102 |
<li><div class="src-line"><a name="a62"></a> <span class="src-key">private </span><span class="src-key">function </span><span class="src-id">__construct</span><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
103 |
<li><div class="src-line"><a name="a63"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$sd </span>= <span class="src-id">Config</span><span class="src-sym">::</span><span class="src-id">get</span><span class="src-sym">(</span><span class="src-str">'ds'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
104 |
<li><div class="src-line"><a name="a64"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs </span>= <span class="src-id">Config</span><span class="src-sym">::</span><span class="src-id">get</span><span class="src-sym">(</span><span class="src-str">'chemin_logs'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
105 |
<li><div class="src-line"><a name="a65"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$timeZone </span>= <span class="src-id">Config</span><span class="src-sym">::</span><span class="src-id">get</span><span class="src-sym">(</span><span class="src-str">'fw_timezone'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
106 |
<li><div class="src-line"><a name="a66"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$tailleMax </span>= <span class="src-id">Config</span><span class="src-sym">::</span><span class="src-id">get</span><span class="src-sym">(</span><span class="src-str">'fw_taille_max_logs'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
107 |
<li><div class="src-line"><a name="a67"></a> </div></li>
|
|
|
108 |
<li><div class="src-line"><a name="a68"></a> <span class="src-comm">// gestion de la timezone pour éviter des erreurs</span></div></li>
|
|
|
109 |
<li><div class="src-line"><a name="a69"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/function_exists">function_exists</a><span class="src-sym">(</span><span class="src-str">'date_default_timezone_set'</span><span class="src-sym">) </span>&& <a href="http://www.php.net/function_exists">function_exists</a><span class="src-sym">(</span><span class="src-str">'date_default_timezone_get'</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
110 |
<li><div class="src-line"><a name="a70"></a> <a href="http://www.php.net/date_default_timezone_set">date_default_timezone_set</a><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$timeZone</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
111 |
<li><div class="src-line"><a name="a71"></a> <span class="src-sym">}</span></div></li>
|
|
|
112 |
<li><div class="src-line"><a name="a72"></a> </div></li>
|
|
|
113 |
<li><div class="src-line"><a name="a73"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-sym">!</span><span class="src-id">is_dir</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span><span class="src-sym">) </span>|| <span class="src-sym">!</span><span class="src-id">is_writable</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
114 |
<li><div class="src-line"><a name="a74"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">desactiverEcriture</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
115 |
<li><div class="src-line"><a name="a75"></a> <span class="src-sym">}</span></div></li>
|
|
|
116 |
<li><div class="src-line"><a name="a76"></a> <span class="src-sym">}</span></div></li>
|
|
|
117 |
<li><div class="src-line"><a name="a77"></a> </div></li>
|
|
|
118 |
<li><div class="src-line"><a name="a78"></a> <span class="src-doc">/**</span></div></li>
|
|
|
119 |
<li><div class="src-line"><a name="a79"></a><span class="src-doc"> * Fonction qui renvoie l'instance de classe en assurant son unicité, c'est l'unique méthode qui doit être</span></div></li>
|
|
|
120 |
<li><div class="src-line"><a name="a80"></a><span class="src-doc"> * utilisée pour récupérer l'objet Registre</span></div></li>
|
|
|
121 |
<li><div class="src-line"><a name="a81"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Log </span><span class="src-doc"> le gestionnaire de log en cours</span></div></li>
|
|
|
122 |
<li><div class="src-line"><a name="a82"></a><span class="src-doc"> */</span></div></li>
|
|
|
123 |
<li><div class="src-line"><a name="a83"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../Framework/Log.html#methodgetInstance">getInstance</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
124 |
<li><div class="src-line"><a name="a84"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$log </span>instanceof <span class="src-id">Log</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
125 |
<li><div class="src-line"><a name="a85"></a> <span class="src-key">return </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$log</span><span class="src-sym">;</span></div></li>
|
|
|
126 |
<li><div class="src-line"><a name="a86"></a> <span class="src-sym">}</span></div></li>
|
|
|
127 |
<li><div class="src-line"><a name="a87"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$log </span>= <span class="src-key">new </span><span class="src-id">Log</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
128 |
<li><div class="src-line"><a name="a88"></a> <span class="src-key">return </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$log</span><span class="src-sym">;</span></div></li>
|
|
|
129 |
<li><div class="src-line"><a name="a89"></a> <span class="src-sym">}</span></div></li>
|
|
|
130 |
<li><div class="src-line"><a name="a90"></a> </div></li>
|
|
|
131 |
<li><div class="src-line"><a name="a91"></a> <span class="src-doc">/**</span></div></li>
|
|
|
132 |
<li><div class="src-line"><a name="a92"></a><span class="src-doc"> * Ajoute une entrée au log spécifié par le paramètre $nomFichier</span></div></li>
|
|
|
133 |
<li><div class="src-line"><a name="a93"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$nomFichier </span><span class="src-doc">le nom du fichier dans lequel écrire</span></div></li>
|
|
|
134 |
<li><div class="src-line"><a name="a94"></a><span class="src-doc"> */</span></div></li>
|
|
|
135 |
<li><div class="src-line"><a name="a95"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../Framework/Log.html#methodajouterEntree">ajouterEntree</a><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">,</span><span class="src-var">$entree</span><span class="src-sym">,</span><span class="src-var">$mode</span>=<span class="src-str">'a+'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
136 |
<li><div class="src-line"><a name="a96"></a> <span class="src-key">if</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$droitLogger</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
137 |
<li><div class="src-line"><a name="a97"></a> <span class="src-var">$date </span>= <span class="src-str">"\n"</span>.<span class="src-str">"\n"</span>.<span class="src-id">date</span><span class="src-sym">(</span><span class="src-str">'d m Y H:i'</span><span class="src-sym">)</span>.<span class="src-str">"\n" </span><span class="src-sym">;</span></div></li>
|
|
|
138 |
<li><div class="src-line"><a name="a98"></a> </div></li>
|
|
|
139 |
<li><div class="src-line"><a name="a99"></a> <span class="src-comm">// si le fichier est déjà dans le tableau et qu'on peut y écrire</span></div></li>
|
|
|
140 |
<li><div class="src-line"><a name="a100"></a> <span class="src-key">if</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">verifierOuvrirFichier</span><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">,</span><span class="src-var">$mode</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
141 |
<li><div class="src-line"><a name="a101"></a> <span class="src-comm">// on y écrit le message de log</span></div></li>
|
|
|
142 |
<li><div class="src-line"><a name="a102"></a> <a href="http://www.php.net/fwrite">fwrite</a><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$fichiersLog</span><span class="src-sym">[</span><span class="src-var">$nomFichier</span><span class="src-sym">]</span><span class="src-sym">,</span><span class="src-var">$date</span>.<span class="src-var">$entree</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
143 |
<li><div class="src-line"><a name="a103"></a> <span class="src-comm">// on vérifie si le fichier ne dépasse pas la taille maximale</span></div></li>
|
|
|
144 |
<li><div class="src-line"><a name="a104"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">verifierTailleFichierOuArchiver</span><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
145 |
<li><div class="src-line"><a name="a105"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
|
|
146 |
<li><div class="src-line"><a name="a106"></a> <span class="src-comm">// sinon on interdit l'écriture</span></div></li>
|
|
|
147 |
<li><div class="src-line"><a name="a107"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">desactiverEcriture</span><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
148 |
<li><div class="src-line"><a name="a108"></a> <span class="src-sym">}</span></div></li>
|
|
|
149 |
<li><div class="src-line"><a name="a109"></a> <span class="src-sym">}</span></div></li>
|
|
|
150 |
<li><div class="src-line"><a name="a110"></a> <span class="src-sym">}</span></div></li>
|
|
|
151 |
<li><div class="src-line"><a name="a111"></a> </div></li>
|
|
|
152 |
<li><div class="src-line"><a name="a112"></a> <span class="src-doc">/**</span></div></li>
|
|
|
153 |
<li><div class="src-line"><a name="a113"></a><span class="src-doc"> * Vide un fichier log indiqué</span></div></li>
|
|
|
154 |
<li><div class="src-line"><a name="a114"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$nomFichier </span><span class="src-doc">le nom du fichier à vider</span></div></li>
|
|
|
155 |
<li><div class="src-line"><a name="a115"></a><span class="src-doc"> */</span></div></li>
|
|
|
156 |
<li><div class="src-line"><a name="a116"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../Framework/Log.html#methodviderLog">viderLog</a><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
157 |
<li><div class="src-line"><a name="a117"></a> <a href="../Framework/Log.html#methodajouterEntree">ajouterEntree</a><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">, </span><span class="src-str">''</span><span class="src-sym">, </span><span class="src-str">'w'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
158 |
<li><div class="src-line"><a name="a118"></a> <span class="src-sym">}</span></div></li>
|
|
|
159 |
<li><div class="src-line"><a name="a119"></a> </div></li>
|
|
|
160 |
<li><div class="src-line"><a name="a120"></a> <span class="src-doc">/**</span></div></li>
|
|
|
161 |
<li><div class="src-line"><a name="a121"></a><span class="src-doc"> * Vérifie la présence d'un fichier dans le tableau, ses droits d'écriture,</span></div></li>
|
|
|
162 |
<li><div class="src-line"><a name="a122"></a><span class="src-doc"> * l'ouvre si nécessaire</span></div></li>
|
|
|
163 |
<li><div class="src-line"><a name="a123"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$nomFichier </span><span class="src-doc">le nom du fichier dont on doit vérifier la présence</span></div></li>
|
|
|
164 |
<li><div class="src-line"><a name="a124"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">boolean </span><span class="src-doc">true si le fichier est ouvert ou maintenant accessible, false sinon</span></div></li>
|
|
|
165 |
<li><div class="src-line"><a name="a125"></a><span class="src-doc"> */</span></div></li>
|
|
|
166 |
<li><div class="src-line"><a name="a126"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../Framework/Log.html#methodverifierOuvrirFichier">verifierOuvrirFichier</a><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">,</span><span class="src-var">$mode</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
167 |
<li><div class="src-line"><a name="a127"></a> <span class="src-comm">// le fichier est il déjà ouvert ?</span></div></li>
|
|
|
168 |
<li><div class="src-line"><a name="a128"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/in_array">in_array</a><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">, </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$fichiersLog</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
169 |
<li><div class="src-line"><a name="a129"></a> <span class="src-comm">// si oui peut on y écrire ?</span></div></li>
|
|
|
170 |
<li><div class="src-line"><a name="a130"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-id">is_writable</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
171 |
<li><div class="src-line"><a name="a131"></a> <span class="src-comm">// si oui on renvoie le descripteur</span></div></li>
|
|
|
172 |
<li><div class="src-line"><a name="a132"></a> <span class="src-key">return </span><span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
|
|
173 |
<li><div class="src-line"><a name="a133"></a> <span class="src-sym">}</span></div></li>
|
|
|
174 |
<li><div class="src-line"><a name="a134"></a> <span class="src-key">return </span><span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
|
|
175 |
<li><div class="src-line"><a name="a135"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
|
|
176 |
<li><div class="src-line"><a name="a136"></a> <span class="src-comm">// sinon on l'ouvre</span></div></li>
|
|
|
177 |
<li><div class="src-line"><a name="a137"></a> <span class="src-var">$fp </span>= <span class="src-sym">@</span><a href="http://www.php.net/fopen">fopen</a><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">,</span><span class="src-var">$mode</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
178 |
<li><div class="src-line"><a name="a138"></a> <span class="src-comm">// si l'ouverture a réussi et si le fichier a les droits d'écriture</span></div></li>
|
|
|
179 |
<li><div class="src-line"><a name="a139"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$fp </span>&& <span class="src-id">is_writable</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
|
180 |
<li><div class="src-line"><a name="a140"></a> <span class="src-comm">// si oui on renvoie le descripteur qu'on ajoute au tableau</span></div></li>
|
|
|
181 |
<li><div class="src-line"><a name="a141"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$fichiersLog</span><span class="src-sym">[</span><span class="src-var">$nomFichier</span><span class="src-sym">] </span>= <span class="src-var">$fp</span><span class="src-sym">;</span></div></li>
|
|
|
182 |
<li><div class="src-line"><a name="a142"></a> <span class="src-key">return </span><span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
|
|
183 |
<li><div class="src-line"><a name="a143"></a> <span class="src-sym">}</span></div></li>
|
|
|
184 |
<li><div class="src-line"><a name="a144"></a> <span class="src-key">return </span><span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
|
|
185 |
<li><div class="src-line"><a name="a145"></a> <span class="src-sym">}</span></div></li>
|
|
|
186 |
<li><div class="src-line"><a name="a146"></a> <span class="src-sym">}</span></div></li>
|
|
|
187 |
<li><div class="src-line"><a name="a147"></a> </div></li>
|
|
|
188 |
<li><div class="src-line"><a name="a148"></a> <span class="src-doc">/**</span></div></li>
|
|
|
189 |
<li><div class="src-line"><a name="a149"></a><span class="src-doc"> * Vérifie la taille d'un fichier donné et si celle ci est trop importante</span></div></li>
|
|
|
190 |
<li><div class="src-line"><a name="a150"></a><span class="src-doc"> * archive le fichier de log</span></div></li>
|
|
|
191 |
<li><div class="src-line"><a name="a151"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$nomFichier </span><span class="src-doc">nom du fichier à vérifier</span></div></li>
|
|
|
192 |
<li><div class="src-line"><a name="a152"></a><span class="src-doc"> */</span></div></li>
|
|
|
193 |
<li><div class="src-line"><a name="a153"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-key">function </span><span class="src-id">verifierTailleFichierOuArchiver</span><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
194 |
<li><div class="src-line"><a name="a154"></a> <span class="src-key">if</span><span class="src-sym">(</span><a href="http://www.php.net/filesize">filesize</a><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">) </span>> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$tailleMax</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
195 |
<li><div class="src-line"><a name="a155"></a> <span class="src-id">rename</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">,</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$cheminLogs</span>.<span class="src-var">$nomFichier</span>.<span class="src-id">date</span><span class="src-sym">(</span><span class="src-str">'d_m_Y_H:i'</span><span class="src-sym">)</span>.<span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$ext</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
196 |
<li><div class="src-line"><a name="a156"></a> <span class="src-id">ajouterEntree</span><span class="src-sym">(</span><span class="src-var">$nomFichier</span><span class="src-sym">,</span><span class="src-str">''</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
197 |
<li><div class="src-line"><a name="a157"></a> <span class="src-sym">}</span></div></li>
|
|
|
198 |
<li><div class="src-line"><a name="a158"></a> <span class="src-sym">}</span></div></li>
|
|
|
199 |
<li><div class="src-line"><a name="a159"></a> </div></li>
|
|
|
200 |
<li><div class="src-line"><a name="a160"></a> <span class="src-doc">/**</span></div></li>
|
|
|
201 |
<li><div class="src-line"><a name="a161"></a><span class="src-doc"> * Désactive l'écriture du log et envoie un message au gestionnaire d'erreurs</span></div></li>
|
|
|
202 |
<li><div class="src-line"><a name="a162"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$nomFichier </span><span class="src-doc">le nom du fichier qui a causé l'erreur</span></div></li>
|
|
|
203 |
<li><div class="src-line"><a name="a163"></a><span class="src-doc"> */</span></div></li>
|
|
|
204 |
<li><div class="src-line"><a name="a164"></a> <span class="src-key">private </span><span class="src-key">static </span><span class="src-key">function </span><span class="src-id">desactiverEcriture</span><span class="src-sym">(</span><span class="src-var">$nomFichier </span>= <span class="src-str">''</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
205 |
<li><div class="src-line"><a name="a165"></a> <span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$droitLogger </span>= <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
|
|
206 |
<li><div class="src-line"><a name="a166"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$nomFichier </span>!= <span class="src-str">''</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
207 |
<li><div class="src-line"><a name="a167"></a> <span class="src-var">$fichierDossier </span>= <span class="src-str">'fichier '</span>.<span class="src-var">$nomFichier </span><span class="src-sym">;</span></div></li>
|
|
|
208 |
<li><div class="src-line"><a name="a168"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
|
|
209 |
<li><div class="src-line"><a name="a169"></a> <span class="src-var">$fichierDossier </span>= <span class="src-str">'dossier des logs'</span><span class="src-sym">;</span></div></li>
|
|
|
210 |
<li><div class="src-line"><a name="a170"></a> <span class="src-sym">}</span></div></li>
|
|
|
211 |
<li><div class="src-line"><a name="a171"></a> <span class="src-var">$message </span>= <span class="src-str">'Écriture impossible dans le '</span>.<span class="src-var">$fichierDossier</span>.<span class="src-str">', Assurez-vous des droits du dossier et des fichiers'</span><span class="src-sym">;</span></div></li>
|
|
|
212 |
<li><div class="src-line"><a name="a172"></a> <span class="src-var">$e </span>= <span class="src-key">new </span><span class="src-id">ErrorException</span><span class="src-sym">(</span><span class="src-var">$message</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-id">E_USER_WARNING</span><span class="src-sym">, </span>__FILE__<span class="src-sym">, </span>__LINE__<span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
213 |
<li><div class="src-line"><a name="a173"></a> <span class="src-id"><a href="../Framework/GestionnaireException.html">GestionnaireException</a></span><span class="src-sym">::</span><a href="../Framework/GestionnaireException.html#methodgererException">gererException</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
214 |
<li><div class="src-line"><a name="a174"></a> <span class="src-sym">}</span></div></li>
|
|
|
215 |
<li><div class="src-line"><a name="a175"></a> </div></li>
|
|
|
216 |
<li><div class="src-line"><a name="a176"></a> <span class="src-doc">/**</span></div></li>
|
|
|
217 |
<li><div class="src-line"><a name="a177"></a><span class="src-doc"> * destructeur de classe, ferme les descripteurs ouverts</span></div></li>
|
|
|
218 |
<li><div class="src-line"><a name="a178"></a><span class="src-doc"> */</span></div></li>
|
|
|
219 |
<li><div class="src-line"><a name="a179"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Framework/Log.html#method__destruct">__destruct</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
220 |
<li><div class="src-line"><a name="a180"></a> <span class="src-key">foreach</span><span class="src-sym">(</span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-var">$fichiersLog </span><span class="src-key">as </span><span class="src-var">$nomFichier </span>=> <span class="src-var">$fp</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
|
221 |
<li><div class="src-line"><a name="a181"></a> <span class="src-id">fclose</span><span class="src-sym">(</span><span class="src-var">$fp</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
|
222 |
<li><div class="src-line"><a name="a182"></a> <span class="src-sym">}</span></div></li>
|
|
|
223 |
<li><div class="src-line"><a name="a183"></a> <span class="src-sym">}</span></div></li>
|
|
|
224 |
<li><div class="src-line"><a name="a184"></a><span class="src-sym">}</span></div></li>
|
|
|
225 |
<li><div class="src-line"><a name="a185"></a><span class="src-php">?></span></div></li>
|
|
|
226 |
</ol>
|
|
|
227 |
</div>
|
|
|
228 |
<div class="credit">
|
|
|
229 |
<hr />
|
|
|
230 |
Documentation generated on Thu, 04 Mar 2010 19:27:33 +0100 by <a href="http://www.phpdoc.org">phpDocumentor 1.4.3</a>
|
|
|
231 |
</div>
|
|
|
232 |
</td></tr></table>
|
|
|
233 |
</td>
|
|
|
234 |
</tr>
|
|
|
235 |
</table>
|
|
|
236 |
|
|
|
237 |
</body>
|
|
|
238 |
</html>
|