<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Jon Segador &#187; logs</title>
	<atom:link href="http://jonsegador.com/tag/logs/feed/" rel="self" type="application/rss+xml" />
	<link>http://jonsegador.com</link>
	<description>Desarrollador web y android, con todo lo que ello implica</description>
	<lastBuildDate>Mon, 23 Jan 2012 19:24:37 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Logs manuales y personalizados en Symfony</title>
		<link>http://jonsegador.com/2010/07/logs-manuales-personalizados-en-symfony/</link>
		<comments>http://jonsegador.com/2010/07/logs-manuales-personalizados-en-symfony/#comments</comments>
		<pubDate>Wed, 07 Jul 2010 07:17:39 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Desarrollo]]></category>
		<category><![CDATA[Symfony]]></category>
		<category><![CDATA[logs]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=247</guid>
		<description><![CDATA[Suele ser una buena práctica tener un archivo de logs con las últimas acciones más importantes que se han hecho en nuestro sitio web: nuevo usuario registrado, se ha escrito un nuevo comentario, se ha editado o borrado un artículo, etc. Symfony tiene un sistema de logs bastante decente, que nos informa de todo lo [...]]]></description>
			<content:encoded><![CDATA[<p>Suele ser una buena práctica tener un archivo de logs con las últimas acciones más importantes que se han hecho en nuestro sitio web: nuevo usuario registrado, se ha escrito un nuevo comentario, se ha editado o borrado un artículo, etc.</p>
<p>Symfony tiene un sistema de logs bastante decente, que nos informa de todo lo que ocurre cada vez que cargamos una nueva página. Vamos a hacer algo sencillo: <strong>vamos a escribir nuestros propios mensajes de log personalizados y los escribiremos manualmente</strong> en el momento que consideremos oportuno y deseamos tener un control. Además, <strong>escribiremos estos logs en un archivo aparte</strong> del que utiliza Symfony por defecto. Así podremos leer directamente ese archivo sin tener otros logs mezclados con los que realmente nos interesa.</p>
<p>Primero, vamos a crear un nuevo archivo llamado CustomLog.class.php en la carpeta /lib/:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
&nbsp;
<span style="color: #000000; font-weight: bold;">class</span> CustomLog<span style="color: #009900;">&#123;</span>
  static <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> newLog<span style="color: #009900;">&#40;</span><span style="color: #000088;">$message</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
&nbsp;
        <span style="color: #000088;">$logFile</span> <span style="color: #339933;">=</span> sfConfig<span style="color: #339933;">::</span><span style="color: #004000;">get</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'sf_log_dir'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">.</span><span style="color: #0000ff;">'/custom_logs.log'</span><span style="color: #339933;">;</span>
        <span style="color: #000088;">$custom_log</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> sfFileLogger<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> sfEventDispatcher<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #990000;">array</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'file'</span> <span style="color: #339933;">=&gt;</span> <span style="color: #000088;">$logFile</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #000088;">$custom_log</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">info</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$message</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
  <span style="color: #009900;">&#125;</span>  
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>El archivo donde guardaremos nuestros logs personalizados, lo encontraremos en &#8220;/log/custom_logs.log&#8221;.</p>
<p>Para escribir un nuevo log desde cualquier parte del código, simplemente deberemos hacer:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="php" style="font-family:monospace;">CustomLog<span style="color: #339933;">::</span><span style="color: #004000;">newLog</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;Escribimos un nuevo log&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>Si abrimos nuestro archivo de logs personalizados, encontraremos algo como esto:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="php" style="font-family:monospace;">Jul <span style="color: #208080;">05</span> <span style="color: #cc66cc;">22</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">31</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">41</span> symfony <span style="color: #009900;">&#91;</span>info<span style="color: #009900;">&#93;</span> Escribimos un nuevo <span style="color: #990000;">log</span></pre></td></tr></table></div>

<p>Así podremos llevar un control de lo que ocurre en nuestra web.</p>
<p>Quizás haya una forma mejor de hacerlo. Si es así, no dudes en dejar tu propuesta en los comentarios. A lo mejor también sería conveniente escribir esas 3 lineas dentro de un try.. catch, por lo que pudiera pasar.</p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/07/logs-manuales-personalizados-en-symfony/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>

