Category Archives: Recursos y Tutoriales

wordpress3.1

Custom Content Types y Custom Taxonomies en WordPress

Hace unos días me escribió un amigo para preguntar cuánto cobrar por implementar WordPress con Custom Post Types. Aunque no es algo que tenga valorizado como ítem extra, obviamente los Custom Post Types y las Custom Taxonomies le dan un valor agregado al resultado final. En resumen, la producción y la administración se tornan más simples.

Como existen numerosos tutoriales y plugins sobre el tema pasaré de repetir lo que ya otros se han tomado el esfuerzo de explicar, prefiero concentrarme en algunos tips que, aunque obvios, pueden ser de mayor utilidad.

Todo pasa por la Arquitectura de Contenidos

Antes de decidir su usar  Custom Post Types y Custom Taxonomies es necesario saber si realmente es meritorio hacerlo y para ello nada mejor un buen trabajo de AI previo. Es necesario visualizar con claridad la naturaleza y cantidad de los objetos (unidades o contenidos) que manipularemos y que convivirán en un sitio, vale decir: páginas de contenidos fijos, noticias, fichas de productos, posts de uno o más blogs, catálogos, etc.  Para mí, lo primordial es simplificar al máximo en función de las necesidades del cliente, entendiendo que éste es usuario de un sistema que, en principio, debe ser sencillo de administrar.

Post type básicos:  Posts y Pages

Es una obviedad, pero objetos diferentes en cuanto a la forma de su contenido son técnicamente post_type distintos. Por ejemplo, noticias y catálogo o fichas de portafolio y anotaciones de un blog.

Continue reading

Captura de pantalla 2010-03-29 a las 22.33.30

Montar particiones NFS (debian/ubuntu) en OSX Snow Leopard

Hace años que trabajo y administro servidores linux para pequeñas redes de oficina. El principal uso de estos servidores es centralizar los archivos compartidos y la base de datos, a la vez que contar con un entorno web de prueba para los sitios en desarrollo.

En cuanto a los archivos compartidos la política era simple: Mac y Windows usan Samba y Linux funciona mejor con NFS, que permite montar un sistema de archivos remoto como si fuera local y que, al estar configurado por ip/red, no pide ni usuario ni contraseña. Es más, cada vez que enciendes el PC el sistema está montado sin que tener que hacer nada especial.

Pero tenía una deuda con Mac, que por ser un sistema heredero de Unix, también permite este tipo de particiones de forma nativa. El problema era cómo.

Y la verdad es que es bastante simple, aunque tiene un truco y es que cuando configuras el archivo /etc/exports debes agregar la opción insecure (entre sistema Linux esto no es necesario).

$ sudo nano /etc/exports
# agregar algo similar a esto, en el ejemplo se acepta conexiones de toda la red 192.168.0
/home/serumax 192.168.0.1/24 (rw,sync,no_subtree_check,insecure)

Luego reincias el servicio NFS con

sudo /etc/init.d/nfs-kernel-server restart

Y lo que queda es agregar la partición en Mac usando la Utilidades de disco como se muestra a continuación:

Archivo -> Montajes NFS

Agregar un nuevo montaje con +

Y debería quedar algo como esto

Sincronizar mp3′s en iphone desde Ubuntu [linux]

Hace un año, cuando me compré el iPhone (con Claro), me vi forzado a hacerle el jailbreak -en ralidad lo hizo @huasocnic-, pero luego tuve que actualizar el firmeware y el jailbreak se volvió más bien un estorbo. Ergo, pasé seis meses si cambiar mi música de iCoso.

Por eso cuando encontré un tutorial para hacerlo sin necesidad de iTunes y sin robarle el mac a la @negracuriche no me la creía. O sea, encontré la libertad que necesitaba sin tener que cambiar Ubuntu ni Rhythmbox y tampoco tener el iPhone con jailbreak, que, en mi caso con Claro, no tiene sentido.

Como el tutorial ya está escrito dejo el link y los cŕeditos a su autor

Comparto también una noticia sobre el mismo tema

[ad#bannerpost]

¿Cómo configurar DNS con Bind9? segunda parte

La verdad es que no escribiré un extenso manual sobre las zonas inversas, básicamente porque en Internet hay muchos ejemplos. Además, la resolución de nombres inversa no es algo completamente necesario para tener un DNS sencillo funcionando de manera local, como podría ser para el uso de una oficina o pequeña red doméstica donde generalmente tenemos un sólo servidor web que responde a varios dominios ficticios.

Pero si lo que quieres obtener es el nombre de una máquina localizada en la IP 200.72.85.X, necesitarás configurar la zona de resolución de nombres que puede ser llamada, por ejemplo, 85.72.200.in-addr.arpa. Es decir, la numeración IP al revés y sin el último octeto.

Lo primero será editar /etc/bind/named.conf.local y añadir:

zone “85.72.200.in-addr.arpa” {
type master;
file “db-reverse-85.72.200″;
};

Luego escribiremos la información para el dns inverso en un archivo específico llamado db-reverse-85.72.200

nano /etc/bind/db-reverse-85.72.200

y copia las siguientes líneas:

;
; BIND reverse data file for local loopback interface
;
$TTL 604800
@ IN SOA dominio.cl. dominio.cl. (
1 ; Serial
604800 ; Refresh
86400 ; Retry
2419200 ; Expire
604800 ) ; Negative Cache TTL
;
@ IN NS dominio.cl.
55 IN PTR dominio.cl.
56 IN PTR sub1.dominio.cl.
57 IN PTR sub2.dominio.cl.

De forma que el último octeto de la IP (55, 56 o 57) escrito a la inversa y omitiendo el 85.72.200 que ya se especificó en “named.conf.local” corresponden a los dominios dominio.cl, sub1.dominio.cl y sub2.dominio.cl respectivamente.

Podemos comprobar su funcionamiento reiniciando el demonio BIND9 y realizando una consulta:

$ /etc/init.d/bind9 restart
$ host 200.72.85.55
85.72.200.55.in-addr.arpa domain name pointer dominio.cl

Finalmente, una de las grande confusiones respecto de el funcionamiento de las zonas inversas tiene que ver con la cantidad de octetos que se especifican al definir la zona inversa en el named.conf.local,  pues sería válido definir zone “72.200.in-addr.arpa” o zone “200.in-addr.arpa” y en dichos casos en el archivo db-reverse-85.72.200 (da igual el nombre) variarían las últimas líneas:

En el caso 72.200.in-addr.arpa

55.85 IN PTR dominio.cl.
56 .85 IN PTR sub1.dominio.cl.
57.85 IN PTR sub2.dominio.cl.

En el caso 200.in-addr.arpa

55.85.72 IN PTR dominio.cl.
56 .85 .72 IN PTR sub1.dominio.cl.
57.85.72 IN PTR sub2.dominio.cl.

Todo dependerá del tamaño del la red.

Tienes 6 mail

Email Push para iphone gratis

Tienes 6 mail

Como bien comenta @micronauta en Huasonic, una de las grandes promesas del iPhone 3G es poder recibir e-mails vía push, o sea, de forma inmediata. La ventaja de esto es que no hace falta revisar la cuenta de e-mail cada cierto tiempo para saber si tenemos un correo nuevo, más bien el teléfono nos avisa de ello con un ring, casi como si fuese un SMS.

Pues bien, ignorando las desventuras de @micronauta con el push de Yahoo (que aún no publicaba su nota) y no teniendo una cuenta de MobileMe, me puse a googlear para ver que alternativas encontraba. Así fue como llegué a mail2web.com que ofrece un servicio llamado “mail2web Live” con push, que en el fondo se trata de un servidor virtual Microsft Exchange. Después de probar la versión gratis o “basic” por una semana debo decir que ha funcionado bastante bien, aunque no ha estado exento de problemas:

  1. Cuando configuras la cuenta por primera vez, BORRA LOS CONTACTOS existentes en el iphone
  2. Te quedas con una segunda cuenta (en mi caso es la tercera) que salvo para esto del push no usaras para nada, pues no se compara con gmail en cuanto a interfaz web.

Pero vamos por paso, una vez que creas la cuenta tienes la posibilidad de enviar la configuración para el iphone por email, SMS o descargarla. El procedimiento es bastante sencillo por lo que pasaré por alto los detalles, sólo recuerda hacer un backup de los contactos.

Continue reading

pantallazo-gscrot-v0631

GScrot y Ubuntu Pics

pantallazo-gscrot-v063

Hace tiempo que veo -con sana envida- como mis amigos maqueros sacan pantallazos de sus escritorios y raudamente los suben a la web gracias a grab up. Pues bien, ahora los ubunteros podemos disfrutar de la misma utilidad con GScrot y Ubuntu-pics, algo estupendo para facilitar el trabajo colaborativo a distancia!

Para instalar GScrot debemos agregar los repostorios de launchpad:

deb http://ppa.launchpad.net/gscrot/ubuntu intrepid main
deb-src http://ppa.launchpad.net/gscrot/ubuntu intrepid main

Y luego buscarlo en Synaptic para instalarlo en un click!

Terminator, la consola perfecta

Terminator se ha transformado en una de las aplicaciones que más uso para hablar con Neo, al menos eso es lo que cree mvallejos cuando me ve con las pantallitas negras de este fantástico terminal para GNOME. Su mayor virtud es que cuenta con  la característica  de dividir la  ventana del terminal en varias partes.

Personalmente nunca me acostumbré a trabajar con pestañas,  por lo que terminaba con muchas consolas abiertas (por suerte, tanto en la casa como en la oficina, uso dos monitores). Por eso, para hacer varias cosas a la vez es sumamente útil, especialmente porque la ventana del emulador se puede dividir vertical u horizontalmente y para cambiar de terminal puedes usar ctrl + tab. Eso sí, la versión en español de Ubuntu 8.04 -que es la que  tengo en la oficina- confunde horizontal con vertical, pero en la 8.10 tiene ese bug corregido.

Terminator es un script simple creado en python que pone múltiples widgets vte en ventanas, el widget es el mismo que usa gnome-terminal, así, si necesitas “customizar” colores, tipografìas o ciertos comportamientos, debes hacerlo directamente en gnome-terminal.

Lo mejor es que  viene en el repositorio Universe de Ubuntu desde la versión 8.04, por lo que solo necesitas hacer sudo apt-get install terminator o buscarlo en synaptic.

Cómo borrar archivos de un sólo tipo y de froma recursiva

Simple, con este comando buscas (find) todos los archivos de un tipo determinado (zip, gz, jpg, gif, pdf, etc) y los borras recursivamente a lo largo del árbol de directorio, partiendo desde donde estás ubicado. Con la opción -i te pedirá confirmar ante de borrar un cierto archivo, mostrándote su nombre en la consulta.

Sin pedir confirmación

find . -type f -name “*.gz” -exec rm -f {} \;

Con confirmación

find . -type f -name “*.gz” -exec rm -i {} \;

Suerte!

Password random en php

Hace un par de años tuve que comenzar a generar claves aleatorias para algunos sistemas de registro de usuarios seguros y captchas en los que he trabajado. He utilizado varias fórmulas, pero hasta ahora la que considero más acabada y elegante es esta:

$claves = array_flip(array_merge(range(’a’,’z’),range(’A’,’Z’),range(0,9)));
$password = implode(“”,array_rand($claves, 6));

No necesita mucha explicación, pero lo que hace es generar tres arrays, uno de la “a” a la “z” en minúscula, otro en mayúscula y el tercero, del “0″ al “9″.  Luego unimos los arrays en uno gracias a array_merge, y con array_flip intercambiamos “keys” por “values“. En la segunda línea generamos un nuevo array compuesto por 6 “keys” aleatorias y, finalmente, obtenemos nuestra password random con el implode que nos devuelve un string de 6 dígitos.

Referencia
Generador de Password Aleatorios

Problemas comunes III: respaldos a distancia con rsync

Aunque existen numerosas herramientas de Escritorio para respaldar y sincronizar archivos en distintas máquinas, ninguno me ha gustado funcionado correctamente. Por lo mismo, prefiero usar el terminal y rsync. Una forma fácil de entender y comenzar con este comando es la siguiente:

serumax@bunbury:~$ comando -opciones /carpeta-o-archivo/origen /carpeta-o-archivo/destino

Es importante destacar que cuando se trata de carpetas  las rutas de origen y destino no se comportan de igual forma si se usa o no un salsh (/) final. De esta forma, si el ejemplo anterior fuese real, tendríamos como resultado la carpeta “destino” ahora contiene una llamada “origen”

Veamos entonces algo más concreto. Pongamos por caso que necesitamos respaldar todos los archivos de la carpeta /var/www/sitio1 en una carpeta de igual nombre pero en otra máquina. Para esto tenemos dos opciones:

Opción 1
rsync -avz /var/www/sitio1 usuario@192.168.0.1:/var/www

Opción 2
rsync -avz /var/www/sitio1/ usuario@192.168.0.1:/var/www/sitio1/

Como pueden observar, para indicar donde respaldaremos los archivos debemos escribir el usuario y la ip de la máquina de destino usuario@192.168.0.1, seguido de los “:” y de la ruta /var/www/sitio1/, esto nos permitirá autenticarnos en la máquina remota tal como lo hacemos con ssh. Para conocer el resto de las opciones de rsync podemos recurrir a man rsync, no obstante, en el ejemplo hemos usado -avc, que significa que respaldaremos la carpeta de froma recursiva en mdo verboso (con salida por pantalla) y con compresión.

Finalmente, para evitar que nos pregunte la password -por ejemplo para programar un crontab- podemas crear un certificado DSA.

Post relacionados