Zend_Log-Factory.xml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 23675 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.log.factory">
  5. <title>Utiliser la fabrique pour créer des logs</title>
  6. <para>
  7. En plus de pouvoir instancier les objets directement, il est possible d'utiliser une fabrique,
  8. la méthode <methodname>factory()</methodname> d'une instance Log, et il est possible de configurer
  9. les objets d'écriture (writers) et leurs filtres. En utilisant la fabrique, vous pouvez attacher
  10. plusieurs objets d'écriture dont la configuration peut être passée sous forme de tableau ou d'objet
  11. <classname>Zend_Config</classname>.
  12. </para>
  13. <para>
  14. Un exemple:
  15. </para>
  16. <programlisting language="php"><![CDATA[
  17. $logger = Zend_Log::factory(array(
  18. array(
  19. 'writerName' => 'Stream',
  20. 'writerParams' => array(
  21. 'stream' => '/tmp/zend.log',
  22. ),
  23. 'formatterName' => 'Simple',
  24. 'filterParams' => array(
  25. 'format' => '%timestamp%: %message% -- %info%',
  26. ),
  27. 'filterName' => 'Priority',
  28. 'filterParams' => array(
  29. 'priority' => Zend_Log::WARN,
  30. ),
  31. ),
  32. array(
  33. 'writerName' => 'Firebug',
  34. 'filterName' => 'Priority',
  35. 'filterParams' => array(
  36. 'priority' => Zend_Log::INFO,
  37. ),
  38. ),
  39. ));
  40. ]]></programlisting>
  41. <para>
  42. Le code ci-dessus instancie un objet journal et 2 objets d'écriture dont un vers un
  43. fichier local, puis un vers Firebug. Chacun possède un filtre.
  44. </para>
  45. <para>
  46. Chaque objet d'écriture support les options suivantes:
  47. </para>
  48. <variablelist>
  49. <varlistentry>
  50. <term>writerName (requis)</term>
  51. <listitem>
  52. <para>
  53. Le nom "court" de l'objet d'écriture; le nom sans le préfixe. Voyez
  54. "writerNamespace" pour plus de détails, des exemples sont : "Mock",
  55. "Stream", "Firebug".
  56. </para>
  57. </listitem>
  58. </varlistentry>
  59. <varlistentry>
  60. <term>writerParams (optionnel)</term>
  61. <listitem>
  62. <para>
  63. Tableau associatif de paramètre à utiliser à l'instanciation de l'objet d'écriture.
  64. Chaque méthode <methodname>factory()</methodname> fera suivre ces paramètres.
  65. </para>
  66. </listitem>
  67. </varlistentry>
  68. <varlistentry>
  69. <term>writerNamespace (optionnel)</term>
  70. <listitem>
  71. <para>
  72. Le préfixe de classe ou espace de nom(namespace) à utiliser pour créer le nom de classe
  73. complet de l'objet d'écriture. Par défault : "Zend_Log_Writer".
  74. </para>
  75. </listitem>
  76. </varlistentry>
  77. <varlistentry>
  78. <term>formatterName (optionnel)</term>
  79. <listitem>
  80. <para>
  81. Le nom "court" d'un formateur à utiliser sur l'objet d'écriture. Voyez
  82. "formatterNamespace" pour plus de détails. Exemples: "Simple", "Xml".
  83. </para>
  84. </listitem>
  85. </varlistentry>
  86. <varlistentry>
  87. <term>formatterParams (optionnel)</term>
  88. <listitem>
  89. <para>
  90. Tableau associatif de paramètre à utiliser à l'instanciation de l'objet formateur.
  91. Chaque méthode <methodname>factory()</methodname> fera suivre ces paramètres.
  92. </para>
  93. </listitem>
  94. </varlistentry>
  95. <varlistentry>
  96. <term>formatterNamespace (optionnel)</term>
  97. <listitem>
  98. <para>
  99. Le préfixe de classe ou espace de nom(namespace) à utiliser pour créer le nom de classe
  100. complet de l'objet formateur. Par défault : "Zend_Log_Formatter".
  101. </para>
  102. </listitem>
  103. </varlistentry>
  104. <varlistentry>
  105. <term>filterName (optionnel)</term>
  106. <listitem>
  107. <para>
  108. Le nom "court" d'un filtre à utiliser sur l'objet d'écriture. Voyez "filterNamespace"
  109. pour plus de détails. Exemples: "Message", "Priority".
  110. </para>
  111. </listitem>
  112. </varlistentry>
  113. <varlistentry>
  114. <term>filterParams (optionnel)</term>
  115. <listitem>
  116. <para>
  117. Tableau associatif de paramètre à utiliser à l'instanciation de l'objet filtre.
  118. Chaque méthode <methodname>factory()</methodname> fera suivre ces paramètres.
  119. </para>
  120. </listitem>
  121. </varlistentry>
  122. <varlistentry>
  123. <term>filterNamespace (optionnel)</term>
  124. <listitem>
  125. <para>
  126. Le préfixe de classe ou espace de nom(namespace) à utiliser pour créer le nom de classe
  127. complet de l'objet filtre. Par défault : "Zend_Log_Filter".
  128. </para>
  129. </listitem>
  130. </varlistentry>
  131. </variablelist>
  132. <para>
  133. Chaque objet d'écriture et chaque filtre possède des options.
  134. </para>
  135. <sect2 id="zend.log.factory.writer-options">
  136. <title>Options pour les objets d'écriture</title>
  137. <sect3 id="zend.log.factory.writer-options.db">
  138. <title>Zend_Log_Writer_Db Options</title>
  139. <variablelist>
  140. <varlistentry>
  141. <term>db</term>
  142. <listitem>
  143. <para>
  144. Une instance de <classname>Zend_Db_Adapter</classname>
  145. </para>
  146. </listitem>
  147. </varlistentry>
  148. <varlistentry>
  149. <term>table</term>
  150. <listitem>
  151. <para>
  152. Nom de la table à utiliser.
  153. </para>
  154. </listitem>
  155. </varlistentry>
  156. <varlistentry>
  157. <term>columnMap</term>
  158. <listitem>
  159. <para>
  160. Tableau associatif de correspondance entre les noms des colonnes de la table
  161. et les champs des évènements du journal.
  162. </para>
  163. </listitem>
  164. </varlistentry>
  165. </variablelist>
  166. </sect3>
  167. <sect3 id="zend.log.factory.writer-options.firebug">
  168. <title>Zend_Log_Writer_Firebug Options</title>
  169. <para>
  170. Aucune option n'est acceptée par cet objet d'écriture.
  171. </para>
  172. </sect3>
  173. <sect3 id="zend.log.factory.writer-options.mail">
  174. <title>Zend_Log_Writer_Mail Options</title>
  175. <table id="zend.log.factory.writer-options.mail.table">
  176. <title>Zend_Log_Writer_Mail Options</title>
  177. <tgroup cols="4">
  178. <thead>
  179. <row>
  180. <entry>Option</entry>
  181. <entry>Type de données</entry>
  182. <entry>Valeur par défaut</entry>
  183. <entry>Description</entry>
  184. </row>
  185. </thead>
  186. <tbody>
  187. <row>
  188. <entry><emphasis>mail</emphasis></entry>
  189. <entry><type>String</type></entry>
  190. <entry><classname>Zend_Mail</classname></entry>
  191. <entry>
  192. Une instance de <classname>Zend_Mail</classname>
  193. </entry>
  194. </row>
  195. <row>
  196. <entry><emphasis>charset</emphasis></entry>
  197. <entry><type>String</type></entry>
  198. <entry>iso-8859-1</entry>
  199. <entry>
  200. L'encodage pour le courriel
  201. </entry>
  202. </row>
  203. <row>
  204. <entry><emphasis>from</emphasis></entry>
  205. <entry><type>String</type> or <type>Array</type></entry>
  206. <entry><constant>NULL</constant></entry>
  207. <entry>
  208. Expéditeur du courriel.
  209. Les paramètres pour un type <type>Array</type> sont :
  210. <itemizedlist>
  211. <listitem>
  212. <para>
  213. <property>email</property> : adresse de l'expéditeur
  214. </para>
  215. </listitem>
  216. <listitem>
  217. <para>
  218. <property>name</property> : nom de l'expéditeur
  219. </para>
  220. </listitem>
  221. </itemizedlist>
  222. </entry>
  223. </row>
  224. <row>
  225. <entry><emphasis>to</emphasis></entry>
  226. <entry><type>String</type> or <type>Array</type></entry>
  227. <entry><constant>NULL</constant></entry>
  228. <entry>
  229. Destinataire(s) du courriel
  230. </entry>
  231. </row>
  232. <row>
  233. <entry><emphasis>cc</emphasis></entry>
  234. <entry><type>String</type> or <type>Array</type></entry>
  235. <entry><constant>NULL</constant></entry>
  236. <entry>
  237. Destinataire(s) en copie(s) du courriel
  238. </entry>
  239. </row>
  240. <row>
  241. <entry><emphasis>bcc</emphasis></entry>
  242. <entry><type>String</type> or <type>Array</type></entry>
  243. <entry><constant>NULL</constant></entry>
  244. <entry>
  245. Destinataire(s) en copie(s) cachée(s) du courriel
  246. </entry>
  247. </row>
  248. <row>
  249. <entry><emphasis>subject</emphasis></entry>
  250. <entry><type>String</type></entry>
  251. <entry><constant>NULL</constant></entry>
  252. <entry>
  253. Sujet du courriel
  254. </entry>
  255. </row>
  256. <row>
  257. <entry><emphasis>subjectPrependText</emphasis></entry>
  258. <entry><type>String</type></entry>
  259. <entry><constant>NULL</constant></entry>
  260. <entry>
  261. Un résumé du nombre de chaque niveau d'erreurs sera ajouté
  262. à la suite du sujet du courriel
  263. </entry>
  264. </row>
  265. <row>
  266. <entry><emphasis>layout</emphasis></entry>
  267. <entry><type>String</type></entry>
  268. <entry><constant>NULL</constant></entry>
  269. <entry>
  270. Une instance de <classname>Zend_Layout</classname>
  271. </entry>
  272. </row>
  273. <row>
  274. <entry><emphasis>layoutOptions</emphasis></entry>
  275. <entry><type>Array</type></entry>
  276. <entry><constant>NULL</constant></entry>
  277. <entry>
  278. Voir la section <xref linkend="zend.layout.options" />
  279. </entry>
  280. </row>
  281. <row>
  282. <entry><emphasis>layoutFormatter</emphasis></entry>
  283. <entry><type>String</type></entry>
  284. <entry><constant>NULL</constant></entry>
  285. <entry>
  286. Une instance de <classname>Zend_Log_Formatter_Interface</classname>
  287. </entry>
  288. </row>
  289. </tbody>
  290. </tgroup>
  291. </table>
  292. </sect3>
  293. <sect3 id="zend.log.factory.writer-options.mock">
  294. <title>Zend_Log_Writer_Mock Options</title>
  295. <para>
  296. Aucune option n'est acceptée par cet objet d'écriture.
  297. </para>
  298. </sect3>
  299. <sect3 id="zend.log.factory.writer-options.null">
  300. <title>Zend_Log_Writer_Null Options</title>
  301. <para>
  302. Aucune option n'est acceptée par cet objet d'écriture.
  303. </para>
  304. </sect3>
  305. <sect3 id="zend.log.factory.writer-options.stream">
  306. <title>Zend_Log_Writer_Stream Options</title>
  307. <variablelist>
  308. <varlistentry>
  309. <term>stream|url</term>
  310. <listitem>
  311. <para>
  312. Un identifiant de flux <acronym>PHP</acronym> valide vers lequel journaliser.
  313. </para>
  314. </listitem>
  315. </varlistentry>
  316. <varlistentry>
  317. <term>mode</term>
  318. <listitem>
  319. <para>
  320. Le mode I/O (Lecture/Ecriture) à utiliser; défaut : "a" pour "append".
  321. </para>
  322. </listitem>
  323. </varlistentry>
  324. </variablelist>
  325. </sect3>
  326. <sect3 id="zend.log.factory.writer-options.syslog">
  327. <title>Zend_Log_Writer_Syslog Options</title>
  328. <variablelist>
  329. <varlistentry>
  330. <term>application</term>
  331. <listitem>
  332. <para>
  333. Nom de l'application utilisé par le journaliseur syslog.
  334. </para>
  335. </listitem>
  336. </varlistentry>
  337. <varlistentry>
  338. <term>facility</term>
  339. <listitem>
  340. <para>
  341. Facility utilisée par le journal syslog.
  342. </para>
  343. </listitem>
  344. </varlistentry>
  345. </variablelist>
  346. </sect3>
  347. <sect3 id="zend.log.factory.writer-options.zendmonitor">
  348. <title>Zend_Log_Writer_ZendMonitor Options</title>
  349. <para>
  350. Aucune option n'est acceptée par cet objet d'écriture.
  351. </para>
  352. </sect3>
  353. </sect2>
  354. <sect2 id="zend.log.factory.filter-options">
  355. <title>Options des filtres</title>
  356. <sect3 id="zend.log.factory.filter-options.message">
  357. <title>Zend_Log_Filter_Message Options</title>
  358. <variablelist>
  359. <varlistentry>
  360. <term>regexp</term>
  361. <listitem>
  362. <para>
  363. Expression régulière à faire correspondre par rapport au message du journal.
  364. </para>
  365. </listitem>
  366. </varlistentry>
  367. </variablelist>
  368. </sect3>
  369. <sect3 id="zend.log.factory.filter-options.priority">
  370. <title>Zend_Log_Filter_Priority Options</title>
  371. <variablelist>
  372. <varlistentry>
  373. <term>priority</term>
  374. <listitem>
  375. <para>
  376. La priorité maximale à journaliser.
  377. </para>
  378. </listitem>
  379. </varlistentry>
  380. <varlistentry>
  381. <term>operator</term>
  382. <listitem>
  383. <para>
  384. L'opérateur de comparaison (supérieur ou inférieur) à utiliser pour la comparaison,
  385. "&lt;=" est utilisé par défaut.
  386. </para>
  387. </listitem>
  388. </varlistentry>
  389. </variablelist>
  390. </sect3>
  391. <sect3 id="zend.log.factory.filter-options.suppress">
  392. <title>Zend_Log_Filter_Suppress Options</title>
  393. <para>
  394. Aucune option n'est acceptée par cet objet d'écriture.
  395. </para>
  396. </sect3>
  397. </sect2>
  398. <sect2 id="zend.log.factory.custom">
  399. <title>Créer des objets d'écriture et des filtres configurés</title>
  400. <para>
  401. SI vous souhaitez créer vos propres objets d'écriture du journal, ou vos propres filtres, il est
  402. possible de les rendre compatibles avec <methodname>Zend_Log::factory()</methodname> facilement.
  403. </para>
  404. <para>
  405. Vous devez au minimum implémenter
  406. <interfacename>Zend_Log_FactoryInterface</interfacename>, qui attend une méthode statique
  407. <methodname>factory()</methodname> accéptant un seul argument,
  408. <varname>$config</varname>, de types tableau ou instance de
  409. <classname>Zend_Config</classname>. Si vos objets étendent
  410. <classname>Zend_Log_Writer_Abstract</classname>, ou vos filtres étendent
  411. <classname>Zend_Log_Filter_Abstract</classname>, alors ce sera tout.
  412. </para>
  413. <para>
  414. Après, définissez la correspondance entre les options de configuration et les arguments du
  415. constructeur. Par exemple :
  416. </para>
  417. <programlisting language="php"><![CDATA[
  418. class My_Log_Writer_Foo extends Zend_Log_Writer_Abstract
  419. {
  420. public function __construct($bar, $baz)
  421. {
  422. // ...
  423. }
  424. public static function factory($config)
  425. {
  426. if ($config instanceof Zend_Config) {
  427. $config = $config->toArray();
  428. }
  429. if (!is_array($config)) {
  430. throw new Exception(
  431. 'factory attend un tableau ou un Zend_Config'
  432. );
  433. }
  434. $default = array(
  435. 'bar' => null,
  436. 'baz' => null,
  437. );
  438. $config = array_merge($default, $config);
  439. return new self(
  440. $config['bar'],
  441. $config['baz']
  442. );
  443. }
  444. }
  445. ]]></programlisting>
  446. <para>
  447. Aussi, il est possible d'appeler les setters après l'instanciation, mais avant de retourner
  448. l'instance:
  449. </para>
  450. <programlisting language="php"><![CDATA[
  451. class My_Log_Writer_Foo extends Zend_Log_Writer_Abstract
  452. {
  453. public function __construct($bar = null, $baz = null)
  454. {
  455. // ...
  456. }
  457. public function setBar($value)
  458. {
  459. // ...
  460. }
  461. public function setBaz($value)
  462. {
  463. // ...
  464. }
  465. public static function factory($config)
  466. {
  467. if ($config instanceof Zend_Config) {
  468. $config = $config->toArray();
  469. }
  470. if (!is_array($config)) {
  471. throw new Exception(
  472. 'factory attend un tableau ou un Zend_Config'
  473. );
  474. }
  475. $writer = new self();
  476. if (isset($config['bar'])) {
  477. $writer->setBar($config['bar']);
  478. }
  479. if (isset($config['baz'])) {
  480. $writer->setBaz($config['baz']);
  481. }
  482. return $writer;
  483. }
  484. }
  485. ]]></programlisting>
  486. </sect2>
  487. </sect1>