lunes, 29 de noviembre de 2010

Compass Rose: Añade una orientación a tus nodos en Drupal

Después de un tiempo de saturación, en las últimas semanas he encontrado tiempo libre para poder dedicárselo a algunos entretenimientos. Entre estos hobbies, se encontraba Drupal, al que ya he dedicado bastante espacio en el blog. Una de las ideas que se me pasaron por la cabeza fue la de dedicarme a desarrollar algún módulo que me supusiera enfrentarme a nuevos retos y conocer mejor los entresijos de este CMS. Una vez tomada la decisión, quedaba lo más difícil, decidir qué iba a hacer este módulo. Tras un breve repaso al portal de Drupal, terminé un poco desilusionado porque me dí cuneta de que ya estaba casi todo inventado, y no se me ocurría cuál podría ser el resquicio que podría encontrar para hacer algo medianamente novedoso.

Casi por casualidad, me comentaron la necesidad de indicar una cierta orientación a unas fotografías, que se iba a indicar de forma textual. En ese momento se me ocurrió que sería más vistoso poder indicar esa orientación con una  pequeña brújula o rosa de los vientos que se pudiera asociar a la imagen. Supuse que ya existiría algo para esa situación, pero no encontré nada, así que de forma casual me encontré con la oportunidad perfecta para poder crear un nuevo módulo que no estuviera inventado todavía.

Así que me puse manos a la obra y me puse a desarrollar un breve módulo basado en el API de CCK que permitiera crear un campo al que dotar de una determinada orientación para girar la imagen de una rosa de los vientos en el ángulo adecuado.

Este módulo ofrece una sencilla interfaz de configuración en la que se selecciona la imagen que se desea utilizar para representar la rosa de los vientos de una lista a la que el usuario puede añadir más posibilidades. Una vez seleccionada la imagen, en el formulario de creación del nodo aparece un desplegable en el que se puede seleccionar el valor que indicará la brújula de entre losa valores más comunes (Norte, Noreste, Este, Sureste, Sur, Suroeste, Oeste y Noroeste).

En cuanto a al representación de esta rosa de los vientos, se ha utilizado la librería jQueryRotate, que es la encargada de girar la imagen de la brújula el ańgulo deseado para ofrecer la visualización deseada de la orientación.

Por el momento esta es la funcionalidad que implementa este pequeño y simple módulo, pero ya tengo en mente algunas nuevas posibilidades que incluirle, que aunque sean superfluas, me vendrán bien para conocer mejor Drupal y para ir adquiriendo nuevas experiencias...

martes, 16 de noviembre de 2010

Misery: Cómo hacer la vida imposible a algunos usuarios de tu site Drupal

A través de un comentario de Edu (azuledu en Drupal)he descubierto un módulo para Drupal que me ha parecido bastante gracioso en un primer momento, pero posteriormente me he dado cuenta de la infinidad de posibilidades que ofrece Drupal para hacer cualquier cosa (incluidas maldades) en nuestro site.

 Como se puede leer en la página de presentación del módulo (http://drupal.org/project/misery), este módulo da la posibilidad de invitar a algunos usuarios a dejar de visitarlo. Esto se puede realizar fácilmente baneándolos, pero este módulo permite hacerlo de una forma más sutil, haciéndoles la vida imposible.

Este hacer la vida imposible a ciertos usuarios consiste en hacer que mientras nevegan por la web sufran tiempos de carga desproporcionados, se encuentren continuamente con  la temida WSOD,  páginas de errores 403 y 404, aparecer en páginas diferentes de las deseadas, o que los formularios no se puedan enviar.


Este curioso módulo está bastante bien organizado y se gestiona a través de permisos. En concreto ofrece 2 permisos diferentes: administer misery y endure misery. El primero de ellos es el que gestiona el acceso a la página de configuración del módulo y permite configurar la manera en la que queremos hacer la vida imposible a nuestros visitantes, mientras que el segundo es el que se asociará a los roles que se desee hacer sufrir...


Una vez definidos los usuarios sobre los que se va a querer actuar, llega el momento de decidir la sutileza de nuestro plan, así como la forma en la que se va a llevar a cabo. En esta pantalla de configuración aparece una lista con los distintos castigos que se pueden llevar a cabo, a los que se les asigna la frecuencia con la que se desea que aparezcan. de esta forma se puede ser más o menos cruel con los usuarios seleccionados.

La verdad es que probar este módulo me ha parecido interesante y curioso al mismo tiempo, porque te hace ver la cantidad de cosas que se pueden hacer fácilmente con Drupal, así como de la imaginación que tiene el ser humano cuando de lo que se trata es de fastidiar al prójimo.

Por tanto os invito a que probéis el módulo, ya sea para alejar a algunos usuarios molestos de vuestro site, o simplemente por el placer de ver como sufren los demás. Un consejo, no seáis demasiado crueles con los usuarios anónimos de vuestro site si no les dais también el permiso de administración del módulo, ya que podéis tardar mucho tiempo en ser capaces de loguearos en vuestra propia web ;)

martes, 9 de noviembre de 2010

Los hooks del módulo CCK

El módulo Content Construction Kit (CCK) es uno de los módulos que debería tener implementada toda instalación de Drupal. Es tan imprescindible que en Drupal 7 va a ir incorporado de serie.

En Drupal la primera clasificación que tenemos es la de tipos de contenido, por defecto vienen creados el tipos de contenido historia y el tipos de contenido artículo. Estos contenidos tienen un título y un texto. Pero para poder crear tipos de contenidos más complejos y que tengan más campos aparte de estos 2, como pueden ser imágenes o fechas, será necesario utilizar el módulo CCK.

 Una vez lo hayamos hecho deberemos descargar e instalar módulos que proporcionen los tipos de campo especiales que necesitemos.Lo interesante de este sistema es que no hace falta programar una sola línea de código para crear un tipo de contenido completamente personalizado, a base de clicks de ratón podemos crear todos los tipos de contenido que requiera un gran portal.

Si nosotros como desarrolladores deseamos crear un nuevo tipo de contenido específico para nuestra aplicación, deberemos crear un módulo que utilice el API que proporciona CCK para poder crear el campo que necesitemos. El módulo CCK tiene un extenso API que principalmente se basa en distintos hooks, que son necesarios para poder crear los diferentes componentes que ofrece, como pueden ser widgets, campos y formatters. En este post hago un breve resumen de los principales hooks que ofrece este módulo. Para información más detallada se puede acudir a la documentación del módulo.





hook_field_info()

hook_field_info()
Declara información sobre un tipo de campo. Importante: El nombre del campo será truncado a 32 caracteres enla BD y arrays internos.

Parámetros

Este hook no tiene parámetros de entrada.

Retorna

Un array asociativo cuya llave es el nombre del tipo de campo. Cada elemento del array es un array con estas llaves y valores:
  •     'label': El nombre que se le mostrará al usuario del tipo de campo.

hook_field()

hook_field($op, &$node, $field, &$node_field, $teaser, $page)
Este hook define el comportamiento de un campo. En la mayoría de los casos, sólo la operación 'validate' es relevante, el resto están implementadas en content_field(), y son suficientes.

Parámetros

  •     $op, en el que se define la operación del campo que se requiere en ese momento:
    •     'load': Lo que ocurre cuando el nodo es cargado de la BD. Este hook debería ser usado para cargar el campo.
    •     'view': Lo que sucede cuando el campo es mostrado al usuario. El módulo debería preparar y devolver una cadena HTML que contenga la representación por defecto del campo. Será llamado sólo si 'view' es puesto a TRUE en el hook_field_settings('callbacks')
    •      'validate':El usuario acaba de editar el nodo y quiere ver la vista previa o enviarlo. Este hook puede usarse para comprobar o incluso modificar el nodo. Los errores deben mostrarse de la forma form_set_error().
    •      'submit': El usuario acaba de enviar el nodo y ha pasado la validación. Este hook se puede utilizar para modificar algun dato del nodo.
    •      'presave':Modificaciones en el nodo justo antes de ser guardado.
    •      'insert':El nodo está siendo creado.
    •      'update':El nodo está siendo actualizado.
    •      'delete':El nodo está siendo borrado.
  •     &$node: El nodo sobre el que se estaá actuando. Este argumento es pasado por referencia. Aconsejable no modificarlo.
  •     &$node_field:El contenido de ese campo para el nodo. Los cambios en esta variable serán guardados en el nodo.

Retorna

Esta valor varía en función del valor de '$op':
  •      $op=='load':Se debe retornar un objeto que contenga valores extra que añadir al objeto nodo.
  •     $op=='view':Una cadena HTML representando el campo 
  •     El resto de operaciones no retornan ningún valor.

hook_field_settings()

hook_field_settings($op, $field)
Maneja los parámetros de un campo.

Parámetros

  •     $op La operación a la que se refier, puede ser:
    •     'form':Muestra el formulario de configuración del campo.
    •     'validate':Comprueba la configuración del campo por posibles errores.
    •     'save':Declara que campos se deben guardar en la BD.
    •     'database columns':Declara las columnas que content.module deberá crear y manejar. Si el módulo de campo desea manejar por el mismo el almacenamiento en BD, deberá ser omitido.
    •      'callbacks:Describe el ámbito del comportamiento en relación con las operaciones del hook_field.
    •     'views data': Declara la información para Views del campo. Pueden ser tabla, argumentos, filtros... Usar este operador sólo si se quieren sobreescribir la implementación por defecto de CCK.
  •      $field: El campo sobre el que se hace la operación.

Retorna

Esto varía según el valor de $op:
  •      $op=='form': Un array de elementos de formulario para añadir a la página de configuración del campo.
  •      $op=='validate': No retorna nada. Los errores deben enviarse de la forma form_set_error().
  •     $op=='save': Un array de nombres de elementos del formulario que deben almacenarse en la BD.
  •     $op=='database columns': Un array asociativo por el nombre de la columna con arrays con la información sobre la columna. Se deben incluir los campos 'type',con el tipo de dato de MySQL para la columna, y puede incluir el campo 'sortable para indicar al módulo views uqe la columna contiene información ordenable.
  •   $op=='callbacks': Un array describiendo el comportamiento del campo respecto al comportamiento del hook_field(). El array está asociado por las acciones de hook_field()('view','validate'...)y sus posibles valores son los siguientes:
    • CONTENT_CALLBACK_NONE: No hace nada.
    • CONTENT_CALLBACK_CUSTOM: Usa el mismo comportamiento que en hook_field(operacion).
    • CONTENT_CALLBACK_DEFAULT:Usa el comportamiento por defecto.
  •     $op=='views data': Un array de tablas, argumentos y filtros utilizados por views.

hook_widget_info()

hook_widget_info()
Declara información sobre un tipo de widget. Importante: El nombre del widget será truncado a 32 caracteres enla BD y arrays internos.

Parámetros

Este hook no tiene parámetros de entrada.

Retorna

Un array asociativo cuya llave es el nombre del tipo de campo. Cada elemento del array es un array con estas llaves y valores:
  •     'label': El nombre que se le mostrará al usuario del tipo de campo.
  •     'field types': Un array con los tipos de campos a los que se puede asociar el widget.
  •     'multiple values': Pueden ser:
    • CONTENT_HANDLE_CORE (Por defecto)
    • CONTENT_HANDLE_MODULE Para manejar el caso de múltiples valores dentro del módulo.
  •    'callbacks:Un array de callbacks, para poner el valor del 'valor por defecto' a uno de los siguientes valores:
    •      CONTENT_CALLBACK_NONE: No hace nada.
    •      CONTENT_CALLBACK_CUSTOM: Usa el mismo comportamiento que en hook_field(operacion).
    •      CONTENT_CALLBACK_DEFAULT: Usa el comportamiento por defecto.
Normalmente estos 2 últimos valores se obvian y se utiliza el comportamiento por defecto.

hook_widget()

hook_widget(&$form, &$form_state, $field, $items, $delta = 0)
El hook widget() controla el comportamiento del widget, principalmente para crear y validar el formulario de edición, la operación de 'proccess form values' debería ser usada para manipular los valores antes de ser salvados

Parámetros

  •     $op, que puede tomar los siguientes valores:
    •    'prepare form values': Prepara el almacenamiento de los datos almacenados para mostrarlos en el widget.
    •    'form': El nodo está siendo editado y un formulario debe ser preparado para mostrar al usuario.
    •     'validate:El usuario acaba de editar el nodo y quiere ver la vista previa o enviarlo. Este hook puede usarse para comprobar o incluso modificar el nodo.Los errores deben mostrarse de la forma form_set_error().
    •     'proccess form values': El widget convierte los datos obtenidos al formato nativo de los datos
    •     'submit':El usuario acaba de enviar el nodo y ha pasado la validación. Este hook se puede utilizar para modificar algun dato del nodo.
  •     &$node: El nodo sobre el que se estaá actuando. Este argumento es pasado por referencia. Aconsejable no modificarlo.
  •     $field: El campo sobre el que se está actuando.
  •     &$node_field:El contenido de ese campo para el nodo. Los cambios en esta variable será guardados en el nodo.

Retorna

Depende del valor que tome $op:
  •     $op=='form': Retorna un array de elementos de formulario para mostrar.
  •     El resto de valores no retornan nada.

hook_widget_settings()

hook_widget_settings($op, $widget)
Este hoook controla el comportamiento de los datos insertados mediante el widget en cuestión. Este hook es muy parecido al hook_field_settings(), con la diferencia de que este afecta al comportamiento del widget.

Parámetros

  •     $op, que puede tomar los siguientes valores:
    •     'form':Muestra el formulario de configuración del campo.
    •     'validate':Comprueba la configuración del campo por posibles errores.
    •     'save':Declara que campos se deben guardar en la BD.
    •    'callbacks:Describe el comportamiento del campo en relación con las operaciones del hook_field.

Retorna

Esto varía según el valor de $op:
  •     $op=='form': Un array de elementos de formulario para añadir a la página de configuración del campo.
  •     $op=='validate': No retorna nada. Los errores deben enviarse de la forma form_set_error().
  •     $op=='save': Un array de nombres de elementos del formulario que deben almacenarse en la BD.
  •   $op=='callbacks': Un array describiendo el comportamiento del campo respecto al comportamiento del hook_field(). El array está asociado por las acciones de hook_field()('view','validate'...)y sus posibles valores son los siguientes:
    •        CONTENT_CALLBACK_NONE: No hace nada.
    •   CONTENT_CALLBACK_CUSTOM: Usa el mismo comportamiento que en hook_field(operacion).
    •        CONTENT_CALLBACK_DEFAULT:Usa el comportamiento por defecto.

miércoles, 3 de noviembre de 2010

whami.com: Un geoportal basado en el módulo Mapstraction CCK

Desde hace unas pocas semanas existe una nueva web social relacionada con el mundo de los viajes, su nombre es Whami y se accede a ella a través de http://www.whami.com.

Al acceder a la página principal se observa un mapa general en el que se incluyen todos los artículos georreferenciados que han incluido los usuarios de la web. Sobre este mapa aparece un campo que ayuda a centrar el mapa en un determinad punto y que resulta de gran ayuda a la hora de buscar información sobre una determinada zona o lugar. En el margen izquierdo aparece una lista con los últimos whamis (así se denominan las referencias incluidas en la página) introducidos.A partir de esta página inicial se puede comenzar a navegar por las distintas reseñas sobre multitud de lugares incluidas en la web.

Las posibilidades que ofrece este portal son muy numerosas, pudiéndose comentar los artículos de otros usuarios, calificarlos, etc. De esta forma se genera una completa red social entre los usuarios basándose en las relaciones espaciales entre los mismos. Esta red social permite hacerse seguidor de otros usuarios, mantener contacto a través de la web o correo electrónico o indicar que el usuario también ha visitado un determinado lugar. También puede resultar de ayuda esta página a la hora de preparar un viaje, ya que se pueden realizar distintos tipos de búsquedas personalizadas en función de los parámetros que introduzca el usuario.

Cabe destacar que este sitio web ha sido completamente desarrollado sobre Drupal, demostrando que cada vez están integrados dentro de este CMS los aspectos geográficos que hacen que la potencia del mismo se vea aumentada. Además, todos los mapas incluidos en la página han sido proporcionados a través del módulo Mapstraction CCK, que ha sido desarrollado por IDELab en colaboración con el Instituto Geográfico Nacional y las Infraestructuras de Datos Espaciales de España. 

Por lo ambicioso del proyecto, sus impulsores se pusieron en contacto conmigo para poder modificar algunos detalles del módulo Mapstraction CCK para que se pudieran lograr los avances necesarios para poder crear una red social basada en los mapas que ofrece el módulo. De esta forma, establecimos una relación de colaboración con ellos que ha resultado fructífera para ambas partes, ya que el módulo ha mejorado con las sugerencias que han realizado y al mismo tiempo ellos han sido capaces de lograr sus objetivos personales. No sólo eso, sino que todas estas mejoras han repercutido en la comunidad que utiliza el módulo, ya que todas estas mejoras se han publicado en el módulo de forma totalmente libre.

Desde aquí me gustaría dar las gracias a los creadores de esta web por haber confiado en nuestro módulo para llevar a cabo sus objetivos, deseándoles mucha suerte a ellos y animándoos a vosotros a conocer Whami y comenzar a utilizarla.