<?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>El blog de Deigote &#187; Informática, internet y tecnología</title>
	<atom:link href="http://blog.deigote.com/category/informatica-internet-y-tecnologia/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.deigote.com</link>
	<description>El mundo de Deigote. Un diario de cualquier cosa que me resulte interesante (si a alguien más se lo resulta, es otro cantar). Espero que os guste o disguste. Incluso que os deje indiferentes sería una opción tan buena como cualquier otra.</description>
	<lastBuildDate>Thu, 07 Apr 2011 15:29:52 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.1</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Homebrew for Mac Os X: cambiar entre distintas versiones de una instalación</title>
		<link>http://blog.deigote.com/2011/04/07/homebrew-for-mac-os-x-cambiar-entre-distintas-versiones-de-una-instalacion/</link>
		<comments>http://blog.deigote.com/2011/04/07/homebrew-for-mac-os-x-cambiar-entre-distintas-versiones-de-una-instalacion/#comments</comments>
		<pubDate>Thu, 07 Apr 2011 15:29:19 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[different]]></category>
		<category><![CDATA[grails]]></category>
		<category><![CDATA[homebrew]]></category>
		<category><![CDATA[mac os x]]></category>
		<category><![CDATA[versions]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=502</guid>
		<description><![CDATA[Uso Homebrew en Mac Os X para instalar algunas utilidades típicas de Unix sin mucho dolor. Grails se encuentra entre ellas. Sin embargo, no he visto una manera de cambiar entre las distintas versiones instaladas.
Seguro que hay formas más elegantes de hacerlo (incluso puede que esté soportado nativamente, Dios no lo quiera), pero para pasar [...]]]></description>
			<content:encoded><![CDATA[<p>Uso <a href="http://mxcl.github.com/homebrew/">Homebrew</a> en Mac Os X para instalar algunas utilidades típicas de Unix sin mucho dolor. Grails se encuentra entre ellas. Sin embargo, no he visto una manera de cambiar entre las distintas versiones instaladas.</p>
<p>Seguro que hay formas más elegantes de hacerlo (incluso puede que esté soportado <em>nativamente</em>, Dios no lo quiera), pero para pasar de usar la versión 1.3.5 a la 1.2.0, los siguientes mandatos hicieron el truco:</p>
<pre><code>$ cd /usr/local/bin/
$ for i in `ls ../Cellar/grails/1.3.5/bin/*`; do rm `basename $i`; done
$ for i in `ls ../Cellar/grails/1.2.0/bin/*`; ln -s $i `basename $i`; done</code></pre>
<p>Muy rico :-).</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2011/04/07/homebrew-for-mac-os-x-cambiar-entre-distintas-versiones-de-una-instalacion/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>Liberar, activar y hacer jailbreak a un iPhone Edge con firmware 3.1.3</title>
		<link>http://blog.deigote.com/2010/07/21/liberar-activar-y-hacer-jailbreak-a-un-iphone-edge-con-firmware-3-1-3/</link>
		<comments>http://blog.deigote.com/2010/07/21/liberar-activar-y-hacer-jailbreak-a-un-iphone-edge-con-firmware-3-1-3/#comments</comments>
		<pubDate>Wed, 21 Jul 2010 15:08:14 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[apple]]></category>
		<category><![CDATA[iphone]]></category>
		<category><![CDATA[jailbreak]]></category>
		<category><![CDATA[unlock]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=493</guid>
		<description><![CDATA[Cómo liberar un iPhone Edge (first generation, primera generación) que tenga el firmware 3.1.3 instalado.]]></description>
			<content:encoded><![CDATA[<p>Por motivos de <a href="http://www.osoco.es">trabajo</a> ha caído en mis manos un iPhone de primera generación (algunos lo llaman iPhone Edge) con el que, en primera instancia, intenté hacer las cosas &#8220;a la Apple&#8221;. Para ello, restauré el teléfono con iTunes, deshaciéndome del jailbreak que tenía instalado e instalando el firmware más moderno para esta versión, el 3.1.3.</p>
<p>Lamentablemente, al ser un iPhone <a href="http://twitter.com/YoNoSoyTu/status/19079333878">traído allende los mares</a>, está atado al operador AT&#038;T, y además necesita ser activado, por lo que al final tuvimos que volver al jailbreak (ah, ironía, cómo te gusta repartir patadas en el culo <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> ), ya que la activación y liberación sin hacer un jailbreak previo es, como poco, no trivial.</p>
<p>Hacerlo no es nada difícil una vez conoces los pasos, pero al ser un modelo antiguo, me costó bastantes prueba y error hasta dar con la fórmula. Básicamente hay que hacer tres  cosas:</p>
<ol>
<li>Obtener el software <a href="http://redsn0w.com"/>redsn0w</a> (en mi caso usé la versión <strong>0.92</strong>, el resto de instrucciones son para esta versión).</li>
<li><a href="http://www.hackint0sh.org/f127/22056.htm">Obtener el firware 3.1.2 para iPhone Edge</a>.</li>
<li>Usar redsn0w con el firmware 3.1.2 (iPhone1,1_3.1.2_7D11_Restore.ipsw).</li>
</ol>
<p>La clave es <strong>no</strong> usar el firmware que tienes instalado, el 3.1.3 (iPhone1,1_3.1.3_7E18_Restore.ipsw), pues si lo haces obtienes un bonito mensaje: <strong>Unable to recognize specified IPWS</strong>. Una vez sabes esto, hacer el jailbreak, y liberar el iPhone es coser y cantar.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/07/21/liberar-activar-y-hacer-jailbreak-a-un-iphone-edge-con-firmware-3-1-3/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>SyntaxError: invalid syntax usando equery en Gentoo</title>
		<link>http://blog.deigote.com/2010/07/14/syntaxerror-invalid-syntax-usando-equery-en-gentoo/</link>
		<comments>http://blog.deigote.com/2010/07/14/syntaxerror-invalid-syntax-usando-equery-en-gentoo/#comments</comments>
		<pubDate>Wed, 14 Jul 2010 10:33:23 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[equery]]></category>
		<category><![CDATA[error]]></category>
		<category><![CDATA[eselect]]></category>
		<category><![CDATA[gentoo]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[python]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=490</guid>
		<description><![CDATA[En Gentoo, cómo solucionar el error que da equery: print pp.path(" /" + c[0]) SyntaxError: invalid syntax ]]></description>
			<content:encoded><![CDATA[<p>Usando Gentoo, me encontré con el siguiente error al lanzar el mandato equery:</p>
<pre><code>$ sudo equery belongs somefile
  File "/usr/bin/equery", line 271
    print pp.path(" /" + c[0])
           ^
SyntaxError: invalid syntax
</code></pre>
<p>Tras darle unas vueltas y no encontrar gran cosa en <del datetime="2010-07-14T10:14:26+00:00">Internet</del> Google <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> , acabé pensando que podía tener que ver con el intérprete de python instalado. No estoy seguro de cómo llegué a esa conclusión, pero supongo que ayudaron el hecho de ver que equery está escrito en python, que mi sistema tenía instalados varios intérpretes (concretamente los más actuales de la versión 2 y 3 del mismo), y que otra máquina con Gentoo usaba otro intérprete y no sufría el problema.</p>
<p>Para resolverlo, lo primero es buscar pistas. Al trabajar con varias versiones, lo normal es que el ejecutable sea un enlace a la versión elegida. Así que fue cuestión de ver a dónde apuntaba dicho enlace y buscar el paquete involucrado.</p>
<pre><code>$ ls -l /usr/bin/python
lrwxrwxrwx 1 root root 14 jul 14 12:21 /usr/bin/python -> python-wrapper
$ equery belongs /usr/bin/python-wrapper
[ Searching for file(s) /usr/bin/python-wrapper in *... ]
app-admin/eselect-python-20100321 (/usr/bin/python-wrapper)
$ equery files app-admin/eselect-python
[ Searching for packages matching app-admin/eselect-python... ]
* Contents of app-admin/eselect-python-20100321:
/etc/env.d/python/.keep_app-admin_eselect-python-0
/usr/bin/python-wrapper
/usr/share/eselect/modules/python.eselect
</code></pre>
<p>Parece que eselect es la herramienta que usa portage para decidir qué versión se usa cuando un paquete tiene varias instaladas. Por lo que se ve arriba, cada paquete instala sus propios módulos para informar a eselect de qué versiones hay disponibles, etc. A partir de aquí, jugando un poco con el mandato eselect, encontrar la forma de cambiar la versión no es difícil:</p>
<pre><code>$ eselect
Usage: eselect <global options> <module name> <module options>
...
$ eselect python
Usage: eselect python <action> <options>
...
$ eselect python list
Available Python interpreters:
  [1]   python2.6
  [2]   python3.1 *
$ sudo eselect python set python2.6
</code></pre>
<p>Y, efectivamente, eso resuelve el problema y equery vuelve a funcionar <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':)' title=':)' class='wp-smiley smiley-19' /> .</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/07/14/syntaxerror-invalid-syntax-usando-equery-en-gentoo/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Mandato PS con salida &#8220;personalizada&#8221;</title>
		<link>http://blog.deigote.com/2010/03/08/custom-output-ps-command/</link>
		<comments>http://blog.deigote.com/2010/03/08/custom-output-ps-command/#comments</comments>
		<pubDate>Mon, 08 Mar 2010 11:56:14 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[command]]></category>
		<category><![CDATA[custom]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[output]]></category>
		<category><![CDATA[ps]]></category>
		<category><![CDATA[script]]></category>
		<category><![CDATA[scripting]]></category>
		<category><![CDATA[shell]]></category>
		<category><![CDATA[unix]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=476</guid>
		<description><![CDATA[Cómo definir salida personalizada o custom output para la orden ps en sistemas operativos tipo unix]]></description>
			<content:encoded><![CDATA[<p>Una opción del mandato <a href="http://www.google.es/search?q=ps+linux+command">ps</a> de los sistemas operativos tipo Unix que no suele estar muy bien documentada y que en mi opinión es tremendamente útil es la que permite personalizar la salida del mandato para que muestre la información que te interesa de cada proceso.
</p>
<p>La opción es <em>-o</em>, y acepta como argumentos una gran cantidad de posibilidades, que normalmente se encuentran descritas en la página del manual como <a href="http://ccrma.stanford.edu/planetccrma/man/man1/ps.1.html">standard format specifiers</a> (o directamente no se encuentran <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> ).
</p>
<p>Un ejemplo de cómo lucen normalmente las órdenes de tipo <em>ps</em> que suelo lanzar en mis terminales:</p>
<pre><code>$ ps fax -o user,uid,pid,ppid,pgrp,%cpu,%mem,rss,vsize,size,tname,etime,start_time,args
USER       UID   PID  PPID  PGRP %CPU %MEM   RSS    VSZ    SZ TTY          ELAPSED START COMMAND
root         0  3434     1  3434  0.0  0.1   552   5404   464 ?        12-22:14:08 Feb23 /usr/sbin/sshd
root         0 14466  3434 14466  0.0  0.5  2572   8124   512 ?              36:04 12:13  \_ sshd: deigote [priv]
deigote   1000 14469 14466 14466  0.0  0.2  1440   8280   668 ?              36:01 12:13      \_ sshd: deigote@pts/2
deigote   1000 14470 14469 14470  0.0  0.6  3344   6548  2172 pts/2          36:01 12:13          \_ -bash
root         0 16310 14470 16310  0.1  0.2  1196   4292   472 pts/2          00:06 12:49              \_ su -
root         0 16311 16310 16311  0.0  0.3  1688   4740   364 pts/2          00:03 12:49                  \_ -su
root         0 16315 16311 16315  0.0  0.2   992   4148   580 pts/2          00:00 12:50                      \_ ps fax -o user,uid,pid,ppid,pgrp,%cpu,%mem,rss,vsize,size,tname,etime,start_time,args
</code></pre>
<p>Y, de hecho, un par de alias que suelo tener siempre definidos, entre otros, son:</p>
<pre><code>alias ps='ps fax -o user,uid,pid,ppid,pgrp,%cpu,%mem,rss,vsize,size,tname,etime,start_time,args'
alias psg='ps | head -n 1 &#038;&#038; ps | grep'
</code></pre>
<p></code></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/03/08/custom-output-ps-command/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Idioma por defecto en Liferay</title>
		<link>http://blog.deigote.com/2010/01/28/idioma-por-defecto-en-liferay/</link>
		<comments>http://blog.deigote.com/2010/01/28/idioma-por-defecto-en-liferay/#comments</comments>
		<pubDate>Thu, 28 Jan 2010 09:56:34 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[default]]></category>
		<category><![CDATA[defecto]]></category>
		<category><![CDATA[español]]></category>
		<category><![CDATA[language]]></category>
		<category><![CDATA[lenguaje]]></category>
		<category><![CDATA[liferay]]></category>
		<category><![CDATA[locales]]></category>
		<category><![CDATA[system-ext.properties]]></category>
		<category><![CDATA[system.properties]]></category>
		<category><![CDATA[tomcat]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=454</guid>
		<description><![CDATA[Lenguaje por defecto en Liferay. Cómo seleccionarlo para una ínstalación nueva o para una instalación ya existente.]]></description>
			<content:encoded><![CDATA[<p>Un detalle que se me olvidó en la pequeña <a href="http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/" title="Guía de instalación de Liferay">guía para instalar Liferay</a> que escribí el otro día es la selección del idioma por defecto, que aunque a simple vista no parece gran cosa, como dirían los americanos, es un poco <em>tricky</em> (Wordreference lo traduce como <a href="http://www.wordreference.com/es/translation.asp?tranword=tricky">que tiene sus bemoles</a>, genial <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':lol:' title=':lol:' class='wp-smiley smiley-10' /> ).</p>
<p>Igual que Liferay incluye un <a href="http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/#liferay-con-mysql">fichero con todas las propiedades relacionadas con funcionalidad</a>, existe otro fichero, llamado <a href="http://svn.liferay.com/browse/portal/trunk/portal-impl/src/system.properties"><em>system-ext.properties</em></a>, que tiene las propiedades relacionadas con el sistema (codificación de los ficheros, zona horaria, <strong>lenguaje por defecto</strong>, etcétera). Este fichero puede extenderse creando el fichero <em>system-ext.properties.</em>
<p>Visto esto, para poner el portal en lenguaje español por defecto, debería bastar con anotar en ese fichero las propiedades relativas al lenguaje que queremos (las rutas corresponden a las mostradas en la <a href="http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/">guía</a> antes mencionada):</p>
<pre><code>$ echo "# Liferay default language
user.country=ES
user.language=es" >> /opt/websites/liferay.deigote.com/tomcat-6.0.18/webapps/ROOT/WEB-INF/classes/portal-ext.properties</code></pre>
<p>¿Fácil, verdad? Pues no funciona <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> . Para ser más exactos, no funciona para las compañías que ya tengamos creadas en la base de datos que estemos usando, ya que al crearlas, Liferay lee estas propiedades y las asocia a la compañía <strong>directamente en la base de datos</strong>.</p>
<p>Si ya tenéis el portal creado y no queréis empezar de cero, no es un problema grave, ya que estos datos pueden modificarse. Para ello, arrancad el portal accediendo a la compañía que queráis (en la mayoría de instalaciones se suele usar sólo una, ya que la <em>feature</em> de compañías no está muy bien documentada), y navegad por el menú superior escogiendo las opciones <em>Panel de control &#8211; Portal &#8211; Configuración &#8211; Preferencias de presentación</em> para seleccionar el idioma y país que por defecto.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/01/28/idioma-por-defecto-en-liferay/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Obtener las extensiones de fichero existentes en un directorio</title>
		<link>http://blog.deigote.com/2010/01/12/obtener-las-extensiones-fichero-existentes-en-un-directorio/</link>
		<comments>http://blog.deigote.com/2010/01/12/obtener-las-extensiones-fichero-existentes-en-un-directorio/#comments</comments>
		<pubDate>Tue, 12 Jan 2010 17:56:40 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[extension]]></category>
		<category><![CDATA[file]]></category>
		<category><![CDATA[find]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[script]]></category>
		<category><![CDATA[scripting]]></category>
		<category><![CDATA[sed]]></category>
		<category><![CDATA[shell]]></category>
		<category><![CDATA[unix]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=440</guid>
		<description><![CDATA[Cómo obtener la extensión de un fichero, o todas las extensiones que existan a partir de un directorio en bash o sh.]]></description>
			<content:encoded><![CDATA[<p>Una mini-receta rápida para obtener, de forma recursiva, todas las extensiones de fichero que existan a partir de un directorio dado:</p>
<p><code>find directorio_raiz -type f -exec sh -c 'basename $0 | sed "s/.*\.//"' {} \;  | sort | uniq</code></p>
<p>El truco viene del archipoderoso sed, que permite obtener las extensión de un fichero mediante la orden <em>sed &#8220;s/.*\.//&#8221;</em>, y funciona que yo sepa, para cualquier <em>Unix</em> con una shell compatible con <em>sh</em> y <em>find</em>, <em>basename</em> y <em>sed</em> instalados.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/01/12/obtener-las-extensiones-fichero-existentes-en-un-directorio/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Empezando con Liferay: una guía rápida de instalación</title>
		<link>http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/</link>
		<comments>http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/#comments</comments>
		<pubDate>Fri, 08 Jan 2010 12:37:09 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[apache]]></category>
		<category><![CDATA[como]]></category>
		<category><![CDATA[instalación]]></category>
		<category><![CDATA[liferay]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[portlets]]></category>
		<category><![CDATA[tomcat]]></category>
		<category><![CDATA[tutorial]]></category>
		<category><![CDATA[usar]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=423</guid>
		<description><![CDATA[Guía rápida de instalación de Liferay usando Apache y MySQL]]></description>
			<content:encoded><![CDATA[<p>Dado que reciéntemente he tenido que instalar un Liferay limpito en un servidor con Apache, dejo aquí una guía con los pasos que seguí:</p>
<ol>
<li><a href="#que-es-liferay">¿Qué es Liferay?</a></li>
<li><a href="#instalacion-basica">Instalación básica</a></li>
<li><a href="#liferay-con-mysql">Usando Liferay con MySQL</a></li>
<li><a href="#liferay-con-apache">Usando Liferay con Apache</a></li>
<li><a href="#usuario-por-defecto">Usuario por defecto y un par de ajustes más</a></li>
</ol>
<h4 id="que-es-liferay">¿Qué es Liferay?</h4>
<p><a href="http://www.liferay.com/">Liferay</a> es un gestor de portales web con una gran funcionalidad integrada (gestión de comunidades y usuarios, CMS, wiki, blogs, y mucho más), y a su vez es un contenedor de portlets, lo que le permite ser extendido de manera bastante rápida y flexible (siguiendo la especificación <a href="http://www.jcp.org/en/jsr/detail?id=286">JSR 286: Portlet Specification 2.0</a>). Además, cuenta con una versión <a href="http://www.liferay.com/web/guest/downloads/portal">Community</a> cuyo uso es gratuito y cuyo código es libre.</p>
<h4 id="instalacion-basica">Instalación básica</h4>
<p>Descargamos la última versión <em>Community</em> con el usuario que arrancará Liferay (en mi caso <em>www-data</em>) en el sitio que queramos (yo he escogido <em>/opt/websites/liferay.deigote.com</em> como directorio base de la instalación):</p>
<pre><code>$ su - www-data
$ cd /opt/websites/
$ wget 'http://sourceforge.net/projects/lportal/files/Liferay%20Portal/liferay-portal-tomcat-6.0-5.2.3.zip'
$ unzip liferay-portal-tomcat-6.0-5.2.3.zip
$ mv liferay-portal-5.2.3/ liferay.deigote.com
</code></pre>
<p>Si ahora arrancamos Liferay, podremos ver cómo nos informa en los log de que se usará una base de datos para testing (<em><a href="http://hsqldb.org/">Hipersonic</a></em>), y si navegamos por la web, podremos ver una serie de portlets a modo de demo:</p>
<pre><code>$ /opt/websites/liferay.deigote.com/tomcat-6.0.18/bin/startup.sh
$ tail -f logs/catalina.out &#038;
$ firefox http://localhost:8080
</code></pre>
<p>Este entorno de demo está bien para cacharrear un poco y ver cómo la gente de Liferay quiere vendernos sus capacidades para hacer un clon de Facebook <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> (vienen instanciados portlets de chat, de muro, de añadir usuarios como amigo, de actividad reciente&#8230;), pero los datos no persisten, por lo que no podréis pasar de ahí. Además, Liferay viene por defecto con usa serie de portlets (en forma de plugins) preparados para hacer la demostración antes mencionada. Yo normalmente borro dichos portlets antes de continuar (de hecho, en mi caso borro todos los plugins excepto el de web-form-portlet, que es el único que encuentro útil):</p>
<pre><code>$ rm -rf `ls /opt/websites/liferay.deigote.com/tomcat-6.0.18/webapps | grep -v ROOT | grep -v web-form-portlet`</code></pre>
<p>Para la persistencia de los datos, tenemos que conectar Liferay con un viejo conocido <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> .</p>
<h4 id="liferay-con-mysql">Usando Liferay con MySQL</h4>
<p>Para conectar Liferay con MySQL existen varias formas. De momento anotaré aquí la más sencilla (aunque para mi gusto un poco &#8220;fea&#8221;), puesto que no recuerdo exactamente cómo es la otra <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> . Liferay incluye en su <em>core</em> un fichero de propiedades (<em><a href="http://svn.liferay.com/browse/portal/trunk/portal-impl/src/portal.properties">portal.properties</a></em>) que configuran prácticamente todos los componentes del portal, base de datos incluida. Ese fichero puede ser extendido mediante el fichero <em>portal-ext.properties</em>, que por defecto no existe. Así que escribimos en él la configuración de la base de datos:</p>
<pre><code>$ echo "# Database connection
jdbc.default.driverClassName=com.mysql.jdbc.Driver
jdbc.default.url=jdbc:mysql://localhost/liferay_database?useUnicode=true&#038;characterEncoding=UTF-8&#038;useFastDateParsing=false
jdbc.default.username=mysql-user
jdbc.default.password=mysql-password" > /opt/websites/liferay.deigote.com/tomcat-6.0.18/webapps/ROOT/WEB-INF/classes/portal-ext.properties
</code></pre>
<p>A continuación nos conectamos al servidor de mysql (en mi caso, localhost) y creamos la base de datos y un usuario con permisos para la misma:</p>
<pre><code>$ mysql -h localhost -u root -p
$ create database liferay_database
$ grant all privileges on liferay_database.* to "mysql-user"@"localhost" identified by "mysql-password";
</code></pre>
<p>Si en este momento arrancamos Liferay de nuevo, deberíamos ver algunos mensajes haciendo mención a la base de datos utilizada (MySQL), y otros que indican que se están creando las tablas.</em>.</p>
<h4 id="liferay-con-apache">Usando Liferay con Apache</h4>
<p>Para usar Apache como servidor web, creamos un <em>host</em> virtual y lo conectamos al servidor de aplicaciones de Liferay (en mi caso Tomcat) usando un módulo de proxy. Podemos usar el módulo proxy_http, que funcionaría con cualquier servidor de aplicaciones, o el módulo proxy_ajp, específico de Apache, y que presenta algunas ventajas sobre http, aunque yo no las recuerde <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> . Dado que Tomcat soporta AJP, será el que usemos. Dado que yo uso Debian, necesito activar el módulo de proxy_ajp y crear un host virtual que use dicho módulo:</p>
<pre><code>$ su -
# a2enmod proxy_ajp
# nano /etc/apache2/sites-available/liferay.deigote.com
# a2ensite liferay.deigote.com
# /etc/init.d/apache2 restart
# exit
</code></pre>
<p>El contenido del fichero /etc/apache2/sites-available/liferay.deigote.com será el siguiente:</p>
<pre><code>&lt;VirtualHost *:80&gt;
        ServerName liferay.deigote.com
        ServerAdmin webmaster@localhost
        ErrorLog /var/log/apache2/liferay.deigote.com_error.log
        LogLevel warn
        CustomLog /var/log/apache2/liferay.deigote.com_access.log combined
        # Proxy to Tomcat
        &lt;Proxy *&gt;
                Order deny,allow
                Allow from all
        &lt;/Proxy&gt;
        ProxyPass / ajp://liferay.deigote.com:8009/
        ProxyPassReverse / ajp://liferay.deigote.com:8009/
&lt;/VirtualHost&gt;
</code></pre>
<p>Antes de echar a andar con esta configuración, debemos añadir un par de líneas al fichero de propiedades de Liferay, ya que si no éste dará por hecho que estamos atacando al puerto 8080 (el puerto por defecto de Tomcat) y escribirá las URL&#8217;s con dicho puerto. Una vez realizado este paso, deberíamos poder acceder a Liferay a través del host virtual que hemos usado (siempre y cuando nuestro servidor DNS sepa resolver dicho host, claro):</p>
<pre><code>$ /opt/websites/liferay.deigote.com/tomcat-6.0.18/bin/shutdown.sh
$ echo "
# Webserver configuration
web.server.http.port=80
web.server.https.port=443" >> /opt/websites/liferay.deigote.com/tomcat-6.0.18/webapps/ROOT/WEB-INF/classes/portal-ext.properties
$ /opt/websites/liferay.deigote.com/tomcat-6.0.18/bin/startup.sh
$ firefox http://liferay.deigote.com
</code></pre>
<h4 id="usuario-por-defecto">Usuario por defecto y un par de ajustes más</h4>
<p>Una vez estemos navegando por Liferay, podremos acceder usando el usuario <em>test@liferay.com</em> con la contraseña <em>test</em>, que es administrador de la comunidad por defecto (<em>guest</em>) Yo recomiendo un par de ajustes más:</p>
<ul>
<li>Cambiar la dirección de correo (y por tanto el login) y la contraseña del usuario administrador. Esto lo podéis hacer en el Panel de control, en el apartado de Usuarios.</li>
<li>Modificar el host virtual de la comunidad por defecto (o la que vayáis a usar) para que coincida con el que estéis usando para acceder a través de Apache. Esto se puede hacer en el panel de control, en el apartado <em>Communities &#8211; Guest &#8211; Manage pages &#8211; Settings &#8211; Virtual host</em>, usando el campo <em>Public virtual host</em>. Esto permitirá que las URL&#8217;s del tipo <em>http://virtual_host/web/nombre_de_la_comunidad/pagina</em> pasen a ser <em>http://virtual_host/pagina</em>, lo cual es más cómodo. Por ejemplo, la URL de la página por defecto (<em>home</em>) en la comunidad por defecto (guest) en mi caso pasaría de <em>http://liferay.deigote.com/web/guest/home</em> a <em>http://liferay.deigote.com/home</em></li>
</ul>
<p>Una vez finalizados estos pasos, ya podemos empezar a trabajar con Liferay en un entorno de producción (a falta, por supuesto, de configuraciones y optimizaciones de Tomcat, Apache y MySQL que no vienen al caso <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> ).</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2010/01/08/empezando-con-liferay-una-guia-rapida-de-instalacion/feed/</wfw:commentRss>
		<slash:comments>12</slash:comments>
		</item>
		<item>
		<title>Registros NS, A, CNAME, MX y SPF de un DNS: ¿y eso qué es lo que es?</title>
		<link>http://blog.deigote.com/2009/07/22/registros-a-cname-mx-y-spf-de-un-dns-%c2%bfy-eso-que-es-lo-que-es/</link>
		<comments>http://blog.deigote.com/2009/07/22/registros-a-cname-mx-y-spf-de-un-dns-%c2%bfy-eso-que-es-lo-que-es/#comments</comments>
		<pubDate>Wed, 22 Jul 2009 11:22:33 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[a]]></category>
		<category><![CDATA[alias]]></category>
		<category><![CDATA[apps]]></category>
		<category><![CDATA[canonical name]]></category>
		<category><![CDATA[cname]]></category>
		<category><![CDATA[dns]]></category>
		<category><![CDATA[domino]]></category>
		<category><![CDATA[google]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[ip]]></category>
		<category><![CDATA[mail]]></category>
		<category><![CDATA[mail exchange]]></category>
		<category><![CDATA[mx]]></category>
		<category><![CDATA[mx mail]]></category>
		<category><![CDATA[ns]]></category>
		<category><![CDATA[registro]]></category>
		<category><![CDATA[registro mx]]></category>
		<category><![CDATA[sender policy framework]]></category>
		<category><![CDATA[smtp]]></category>
		<category><![CDATA[spam]]></category>
		<category><![CDATA[spf]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=405</guid>
		<description><![CDATA[Explicación de los registros NS, A, CNAME, MX, SPF de un nombre de dominio o DNS de Internet, breve y sencilla.]]></description>
			<content:encoded><![CDATA[<p>Tras enfrentarme por primera vez a la gestión de un registro <a href="http://en.wikipedia.org/wiki/Dns" title="Domain name server">DNS</a> (uooooh <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':cool:' title=':cool:' class='wp-smiley smiley-4' /> <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':lol:' title=':lol:' class='wp-smiley smiley-10' /> ) voy a hacer un pequeño resumen de los principales campos que lo componen de cara a un usuario (tenéis una referencia rápida de todos los posibles en, como no, <a href="http://en.wikipedia.org/wiki/List_of_DNS_record_types" title="List of DNS record types en la Wikipedia">la wikipedia</a>).</p>
<ul>
<li>Registro <strong>NS</strong> (<em>name server</em>): indica los servidores de DNS autorizados para el dominio, es decir, <em>a quién tengo que preguntar para saber acerca de los registros de dominio.com</em>.<br />
Ejemplo: <em>toharia.com NS ns15.ovh.net</em></li>
<li>Registro <strong>A</strong> (<em>address</em>): indica la dirección IP a la que se debe traducir ese nombre de dominio.<br />
Ejemplo: <em>toharia.com A 94.23.62.64</em></li>
<li>Registro <strong>CNAME</strong> (<em>canonical name</em>): permite definir alias o nombres de domino equivalentes. Normalmente, se usa para definir subdominios (que casi siempre apuntarán al dominio principal, aunque no es obligatorio).<br />
Ejemplo: <em>mail.toharia.com CNAME toharia.com</em>, pero también <em>diego.toharia.com CNAME deigote.com</em></li>
<li>Registro <strong>MX</strong> (<em>mail exchange</em>): permite definir a qué servidor se envía el correo electrónico del dominio en cuestión. Cuenta con un campo prioridad, por lo que para un mismo dominio se pueden definir varios registros MX con distinta prioridad, escogiéndose el primero que esté disponible en cada momento.<br />
Ejemplo: <em>toharia.com MX 1 aspmx.l.google.com</em>, <em>toharia.com MX 5 alt1.aspmx.l.google.com</em>. En la práctica, cuando un servidor SMTP (es decir, que envía correo) tiene que enviar un correo a diego@toharia.com, inspecciona los registros MX para toharia.com, y envía el correo al de mayor prioridad que encuentre disponible (en este caso, empezaría por alt1.aspmx.l.google.com, y luego seguiría con el resto).</li>
<li>Registro <strong>SPF</strong> (sender policy framework): permite definir qué servidores están autorizados para enviar correo electrónico del dominio. Su uso surgió como propuesta para acabar o al menos dificultar el <em>spam</em> (correos no deseados con publicidad, <a href="http://es.wikipedia.org/wiki/Phishing">phishing</a>, etcétera). Normalmente, los spammers envían correo electrónico desde direcciones recopiladas en internet (y a direcciones recopiladas en internet <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> ), para que sea más difícil indentificar el correo como <em>spam</em>. Sin embargo, si el filtro <em>antispam</em> está bien implementado, mirará el registro SPF del  dominio del remitente de un correo entrante, y si la dirección IP origen del correo no está entre las adminitidas en dicho registro, lo marcará como <em>spam</em>. Podéis aprender más sobre SPF en <a href="http://www.openspf.org/" title="SPF: project overview">el sitio web oficial</a>.<br />
Ejemplo: <em>toharia.com SPF v=spf1 a mx include:aspmx.googlemail.com ~all</em>. Si os fijáis, lo que viene a decir es que el campo spf incluye el registro A, el registro MX y el servidor aspmx.googlemail.com. Esto es porque los correos los enviaré desde el propio servidor que aloja toharia.com, desde los servidores de recepción de correo MX, y desde aspmx.googlemail.com (en mi caso sería redundante ya que los registros MX ya incluyen este servidor).
</li>
</ul>
<p>Nota: mis registros MX y SPF incluyen direcciones MX de Google porque el correo de ese dominio lo tengo gestionado con <a href="http://www.google.com/a">Google Apps</a>. Por tanto, la recepción del correo siempre la hago en sus servidores, mientras que el envío la hago tanto desde sus servidores (cuando lo hago desde la aplicación web de correo electrónico de Google) como desde el servidor que aloja ese dominio (cuando lo hace alguna aplicación que corre en el mismo).</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2009/07/22/registros-a-cname-mx-y-spf-de-un-dns-%c2%bfy-eso-que-es-lo-que-es/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>Subversion desde Apache usando virtual hosts y locations</title>
		<link>http://blog.deigote.com/2009/07/17/subversion-desde-apache-usando-virtual-hosts-y-locations/</link>
		<comments>http://blog.deigote.com/2009/07/17/subversion-desde-apache-usando-virtual-hosts-y-locations/#comments</comments>
		<pubDate>Fri, 17 Jul 2009 12:41:57 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[apache]]></category>
		<category><![CDATA[dav]]></category>
		<category><![CDATA[debian]]></category>
		<category><![CDATA[location]]></category>
		<category><![CDATA[subversion]]></category>
		<category><![CDATA[svn]]></category>
		<category><![CDATA[virtualhost]]></category>
		<category><![CDATA[webdav]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=377</guid>
		<description><![CDATA[Descripción de cómo crear acceso a uno o varios repositorios de Subversion mediante HTTP usando Apache, configurándolo con virtual hosts y locations de la manera más correcta posible, usando usuarios y passwords públicos y privados.]]></description>
			<content:encoded><![CDATA[<p>Aunque hay bastantes guías que cubren cómo configurar un <a href="http://es.wikipedia.org/wiki/WebDAV">WebDAV</a> para acceder a un repositorio Subversion mediante HTTP usando el servidor Apache, aquí os presento la mía, en la que configuro el acceso a un conjunto de repositorios usando un <em>virtual host</em> y distintas <em>locations</em> (es decir, es una guía más con la configuración que a mi más me gusta <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> ).</p>
<p>Lo primero que debemos hacer es asegurarnos de que tenemos el módulo adecuado. En Debian, por ejemplo, podemos buscarlo e instalarlo si es necesario usando los siguientes mandatos:</p>
<p><code>$ aptitude search apache subversion  | grep svn<br />
# aptitude install libapache2-svn</code></p>
<p>Además, deberemos asegurarnos de que Apache habilita el módulo, lo cual, nuevamente en Debian, es trivial gracias a la buena organización que tiene de la configuración de Apache:</p>
<p><code>$ a2enmod dav_svn<br />
# /etc/init.d/apache2 restart<br />
</code></p>
<p>El siguiente paso es crear un repositorio Subversion. Lo habitual es crear uno por proyecto, aunque en mi caso no lo hago así exactamente. Por ejemplo, tengo un repositorio al que llamo <em>personal</em> en el que tengo mi CV, algunas prácticas y cosas pequeñas en las que es más que improbable que participe nadie más que yo. Depende del criterio de cada uno (por ejemplo, a mi siempre me resulta tentador tener un único respositorio para todo, y a la hora de hacer el <em>checkout</em>, hacerlo con ruta relativa al proyecto que necesito), pero recordad que los usuarios, contraseñas y permisos serán <strong>los mismos para todo un repositorio</strong>. La creación del repositorio la hacemos con los mandatos:</p>
<p><code>$ mkdir -p /opt/svn/<em>nombre_del_repositorio</em>/<br />
$ svnadmin create /opt/svn/<em>nombre_del_repositorio</em>/repo</code></p>
<p>Podemos verificar que funciona intentando hacer un <em>checkout</em>:</p>
<p><code>$ svn co file:////opt/svn/<em>nombre_del_repositorio</em>/repo /tmp/</code></p>
<p>Por último, creamos los usuarios y passwords del repositorio:</p>
<p><code>$ mkdir -p /opt/svn/<em>nombre_del_repositorio</em>/passwords/<br />
$ htpasswd -c /opt/svn/<em>nombre_del_repositorio</em>/passwords/.htpasswd <em>usuario</em></code></p>
<p>Y procedemos a crear el fichero de configuración del virtual host de Apache. En el ejemplo, lo voy a hacer para dos repositorios, uno llamado personal y otro llamado público, suponiendo que quiera acceder a ambos a través del mismo dominio (<em>svn.deigote.com</em>) pero con distintas localizaciones (<em>/personal</em> y <em>/publico</em>):</p>
<pre><code>&lt;VirtualHost *:80&gt;
   ServerName svn.deigote.com
   DocumentRoot /opt/websites/svn.deigote.com
</code></pre>
<p>Como véis, definimos un <em>virtual host</em> para el dominio elegido, y le asignamos un docroot, en el que podríamos poner una página de inicio o incluso vacía (para que si alguien entra directamente en el dominio, no vea el clásico <em>It works!</em> situado en /var/www <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':D' title=':D' class='wp-smiley smiley-2' /> )<a href="#nota_propfind_301" title="Error svn propfind 301 moved permanently">(1)</a>.</p>
<p>A partir de aquí, para cada localización (<em>personal</em> y <em>publico</em>) establecemos que es un WebDAV de tipo Subversion, e indicamos la ruta del repositorio y del fichero de passwords, tanto para el repositorio personal:</p>
<pre><code>   &lt;Location "/personal" &gt;
     DAV svn
     SVNPath /opt/svn/personal/repo

     AuthType Basic
     AuthName "SVN Deigote - Personal"
     AuthUserFile /opt/svn/personal/passwords/.htpasswd
     Require valid-user

     Order deny,allow
     Deny from all
     Allow from unaipdeconfianza.com
   &lt;/Location&gt;
</code></pre>
<p>como para el repositorio público:</p>
<pre><code>
   &lt;Location "/publico" &gt;
     DAV svn
     SVNPath /opt/svn/publico/repo

     AuthType Basic
     AuthName "SVN Deigote - Publico"
     AuthUserFile /opt/svn/publico/passwords/.htpasswd
     &lt;LimitExcept GET PROPFIND OPTIONS REPORT&gt;
       Require valid-user
     &lt;/LimitExcept&gt;
   &lt;/Location&gt;
</code></pre>
<p>Podemos ver un par de diferencias. Mientras que el repositorio personal pide un usuario válido para todos los casos (es decir, un usuario definido en el fichero de passwords), el repositorio público especifica que necesita un usuario válido excepto para algunas acciones. Básicamente, son el conjunto de acciones que permiten lectura y navegación por el repositorio. De esta manera, todo el mundo podrá <em>ver</em> (acciones checkout, update, etcétera) pero sólo los usuarios válidos podrán <em>escribir</em> (acción commit, add, etcétera) <a href="#nota_mod_authz">(2)</a></p>
<p>La otra diferencia es que el repositorio personal tiene una sección que especifica que el acceso es denegado para todos, y admitido para una ip o nombre de dominio. Esto te garantiza que la persona que accede a tu repositorio lo está haciendo desde una IP de tu confianza, aumentando ligeramente la <s>paranoia</s> seguridad.</p>
<p>Añadir que el directorio raiz (<em>/</em>) es un <em>location</em> válido, por lo que podemos configurar un único repositorio para el dominio, aunque sería equivalente a poner dicha configuración directamente en el contexto del <em>virtual host</em> en vez de en el del <em>location</em>.</p>
<p>Añadiendo la información de logs y demás, el fichero de virtual host de ejemplo (<em>/etc/apache2/sites-available/svn.deigote.com</em>) queda como se ve a continuación:</p>
<pre><code>&lt;VirtualHost *:80&gt;
   ServerName svn.deigote.com
   DocumentRoot /opt/websites/svn.deigote.com
   &lt;Location "/personal" &gt;
     DAV svn
     SVNPath /opt/svn/personal/repo

     AuthType Basic
     AuthName "SVN Deigote - Personal"
     AuthUserFile /opt/svn/personal/passwords/.htpasswd
     Require valid-user

     Order deny,allow
     Deny from all
     Allow from unaipdeconfianza.com
   &lt;/Location&gt;

   &lt;Location "/publico" &gt;
     DAV svn
     SVNPath /opt/svn/publico/repo

     AuthType Basic
     AuthName "SVN Deigote - Publico"
     AuthUserFile /opt/svn/publico/passwords/.htpasswd
     &lt;LimitExcept GET PROPFIND OPTIONS REPORT&gt;
       Require valid-user
     &lt;/LimitExcept&gt;
   &lt;/Location&gt;

   ErrorLog /var/log/apache2/error_svn.deigote.com.log
   LogLevel warn
   CustomLog /var/log/apache2/access_svn.deigote.com.log combined
&lt;/VirtualHost&gt;</code></pre>
<p>Lo añadimos a la lista de sites y reiniciamos Apache, y ya estamos listos para jugar:</p>
<p><code>$ a2ensite svn.deigote.com<br />
$ /etc/init.d/apache restart<br />
$ svn co http://svn.deigote.com/personal<br />
$ svn co http://svn.deigote.com/publico<br />
</code></p>
<p>Como nota final, <strong>ojo con los passwords</strong>. Tened en cuenta que estamos configurando un acceso a través de HTTP, por lo que la información no va encriptada. Para que sí lo fuera tendríamos que configurar el virtual host para ir a través de HTTPS, pero eso lo dejamos para un próximo capítulo (más que nada porque todavía no he aprendido a hacerlo <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':)' title=':)' class='wp-smiley smiley-19' /> ).</p>
<p class="footnote" id="nota_propfind_301">(1) Tened cuidado de no crear directorios en el <em>document root</em> <strong>con el mismo nombre que los <em>location</em></strong>. Os encontraréis con un error de este estilo al hacer el <em>checkout</em>:</p>
<p><code>$ ls /opt/websites/svn.deigote.com # Docroot<br />
personal<br />
$ svn co http://svn.deigote.com/personal/ /tmp/personal<br />
Authentication realm: <http://svn.deigote.com:80> SVN Deigote - Personal<br />
Password for 'deigote':<br />
svn: PROPFIND request failed on '/personal'<br />
svn: PROPFIND of '/personal': 301 Moved Permanently (http://svn.deigote.com)<br />
$ rmdir /opt/websites/svn.deigote.com/personal<br />
$ svn co http://svn.deigote.com/personal/ /tmp/personal<br />
...<br />
Checked out revision 1<br />
</code></p>
<p class="footnote" id="nota_mod_authz">(2) Se puede afinar más usando mod_authz_svn, que permite establecer qué usuarios pueden escribir y cuáles pueden leer  sin complicarse mucho, pero yo de momento no lo he necesitado, así que queda para el siguiente capítulo <img src='http://blog.deigote.com/wp-includes/images/blank.gif' alt=':-)' title=':-)' class='wp-smiley smiley-19' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2009/07/17/subversion-desde-apache-usando-virtual-hosts-y-locations/feed/</wfw:commentRss>
		<slash:comments>10</slash:comments>
		</item>
		<item>
		<title>uninitialized constant ApplicationController en Ruby on Rails</title>
		<link>http://blog.deigote.com/2009/07/16/uninitialized-constant-applicationcontroller-en-ruby-on-rails/</link>
		<comments>http://blog.deigote.com/2009/07/16/uninitialized-constant-applicationcontroller-en-ruby-on-rails/#comments</comments>
		<pubDate>Thu, 16 Jul 2009 18:16:16 +0000</pubDate>
		<dc:creator>Deigote</dc:creator>
				<category><![CDATA[Informática, internet y tecnología]]></category>
		<category><![CDATA[application controller]]></category>
		<category><![CDATA[error]]></category>
		<category><![CDATA[rails]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[tip]]></category>
		<category><![CDATA[upgrade]]></category>

		<guid isPermaLink="false">http://blog.deigote.com/?p=367</guid>
		<description><![CDATA[Es muy posible que si actualizáis de versión de Rails, al levantar la aplicación, os encontréis con el siguiente error:
uninitialized constant ApplicationController
A mi me ocurrió al pasar de Rails 2.2.2 a Rails 2.32. Por lo visto, han cambiado el nombre a una clase de Rails, por lo que es necesario actualizar el código fuente de [...]]]></description>
			<content:encoded><![CDATA[<p>Es muy posible que si actualizáis de versión de Rails, al levantar la aplicación, os encontréis con el siguiente error:</p>
<p><code>uninitialized constant ApplicationController</code></p>
<p>A mi me ocurrió al pasar de Rails 2.2.2 a Rails 2.32. Por lo visto, han cambiado el nombre a una clase de Rails, por lo que es necesario actualizar el código fuente de la aplicación que Rails incluyó en la misma al crearla. El siguiente mandato hará el trabajo:</p>
<p><code>rake rails:update</code></p>
<p>Rápido y fácil, pero me dio unos cuantos quebraderos de cabeza al <a href="http://blog.deigote.com/2009/07/16/ruby-on-rails-passenger-apache-mysql-sqlite-en-debian-5/" title="Rails con Passenger, Apache, MySQL y SQLite en Debian">actualizarme a la última de Rails usando Apache y Passenger</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.deigote.com/2009/07/16/uninitialized-constant-applicationcontroller-en-ruby-on-rails/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
<!-- WP Super Cache is installed but broken. The path to wp-cache-phase1.php in wp-content/advanced-cache.php must be fixed! -->
