Creando módulos en Drupal 7
Edgar Dueñas
Senior Web Developer
edgar@pixtig.com
@ieddu
http://www.pixtig.com
http://www.linkedin.com/in/ieddu
¿Qué es Drupal?
Drupal es una plataforma de gestión de contenidos web muy potente que
ofrece multitud de funcionalidades para el desarrollo web.
Drupal ha sido varias veces elegido el mejor CMS de código abierto a
nivel mundial por:
Por su estructura modular.
● La consistencia de todo el sistema.
● La calidad de su código y la seguridad.
● Estándares.
● Accesibilidad y usabilidad web.
●
Drupal tiene licencia GNU/GPL
y está escrito en PHP.
¿Qué es un módulo en Drupal?

El módulo (module) es un software que extiende las
funcionalidades o características de Drupal.
Cuando crear un módulo

●

Comunicación con sistemas externos.

●

Creación de funcionalidades muy a la medida.
Temas de hoy

Ubicación del nuevo módulo.
✔ Idioma base y codificación de los archivos.
✔ Archivos principales del módulo: .info y .module.
✔ La función t() para traducción de cadenas de texto.
✔ Activación del módulo.
✔ Ejemplo de desarrollo de un módulo.
✔
Ubicación del módulo
sites/all/modules
En Drupal cada módulo dispone de su propio
directorio, que recibe generalmente el mismo nombre
que el módulo para simplificar la organización.
Importante

El nombre del directorio no debe contener espacios ni
caracteres especiales.
Podemos utilizar el guion bajo como separador.
Idioma base y codificación

El idioma base siempre será el inglés
Drupal trabaja con UTF-8 en la codificación de archivos
Crear archivos con codificación UTF-8 sin BOM
Archivos principales del módulo

.info y .module
.info
Se trata de un archivo de texto escrito de forma
similar a un archivo php.ini, que contiene
información básica sobre el módulo
(nombre, descripción, versión de Drupal, etc.)
El nombre debe ser similar al de la carpeta
<nombre_modulo>.info
Ejemplo
sites/all/modules/primer_modulo/
.info
Puede contener otros campos como:
files (archivos, campo opcional). Drupal 7 permite el registro de
código de forma dinámica, a través de funciones de autoload.
php (campo opcional). Indica la versión mínima de PHP requerida.
dependencies (dependencias, campo opcional). Nuestro módulo
puede necesitar de otros módulos para su funcionamiento. El campo
dependencies será un vector con los nombres de estos módulos
requeridos.
.info
required (requerido, campo opcional). Especifica que el módulo
actual es indispensable y siempre debe estar activado.
configure (configuración, campo opcional). Especifica la ruta a la
página de configuración del módulo.
package (paquete, campo opcional). Cuando un módulo pertenece a
un conjunto de módulos.
.module
El archivo .module incluye el código del módulo, en
forma de funciones PHP. Es en este archivo donde se
realizarán las llamada a los hooks.
El estándar para nombrar al archivo .module es
similar al de los archivos .info, siguiendo el patrón
<nombremodulo>.module.
El fichero .module no es más que un script PHP, de
manera que la primera línea comienza con la marca
de inicio de código PHP "<?php", pero no se cierra
con este código ?>.
¿Qué es una hook?
Son funciones PHP que utilizamos en nuestros
módulos, el nombre de las mismas se compone de la
siguiente forma:
¿Para qué sirven las hooks?
Aumentan la funcionalidad de Drupal permitiendo a los
módulos interactuar con el core.
De esta manera podemos alterar los comportamientos default
de Drupal, y agregar nueva funcionalidad, si esos son los
requerimientos para nuestro sitio.
La función t()

La función t() permite que el sistema pueda traducir
las cadenas de texto al resto de idiomas activos en el
sitio.
Activación del módulo
Ingresar al menu, ir a module, buscar, seleccionar y
por ultimo grabar los cambios.
Tipos de módulos más usados

tipo bloque
tipo página
Módulo de tipo bloque
Programando un bloque
hook_block_info(), define todos los bloques que
nuestro módulo va a proveer.
hook_block_view(), construye el bloque.
hook_theme(), formateará la salida del tema hacia
un archivo tpl
hook_block_info()
En el array $blocks definimos todos los bloques de
nuestro módulo y proporcionamos las opciones por
defecto de cada bloque.
hook_block_view()
En esta función definimos lo que se ve en cada bloque
que implementa nuestro módulo. La variable $delta es
la que nos identifica el bloque.
$block['content']
En esta variable llamamos a la función que contiene
el contenido a imprimir.
Veamos el código y funcionamiento
Theming
Theming: maquetar el resultado
Ahora estamos introduciendo “Hola Mundo” en el array de
variables que le vamos a pasar a la plantilla, y a continuación
utilizamos la función theme() para generar el resultado de
salida. Para ello la función theme() invoca el hook_theme().
hook_theme()
En nuestro hook_theme() estamos llamando a la
plantilla (template): “saludar-hola-mundo”, para
maquetar el callback: “saludar_hola_mundo”.
Creando un archivo de plantilla
El siguiente paso es crear nuestro archivo tpl que
hemos definido en el hook_theme(), en nuestro caso
se llama saludar-hola-mundo.tpl
Modulo de tipo pagina
hook_menu()

Sirve para crear una página, es decir, programar la
respuesta para una determinada url.
Por ejemplo acceder desde:
http://localhost/drupal/saludar/hola-mundo
hook_menu()
Lo que hemos hecho es añadir una url al array de
elementos $items, y para esa dirección elegimos un
título para la página y la función que implementa el
contenido.
Función page callback
Veamos el código y funcionamiento
Form API
https://api.drupal.org/api/drupal/developer%21topics
%21forms_api_reference.html/7
Ejemplo
¿Preguntas?
Gracias
Charla impartida por:
Edgar Dueñas
edgar@pixtig.com

Creando módulos en Drupal 7

  • 1.
    Creando módulos enDrupal 7 Edgar Dueñas Senior Web Developer edgar@pixtig.com @ieddu http://www.pixtig.com http://www.linkedin.com/in/ieddu
  • 2.
    ¿Qué es Drupal? Drupales una plataforma de gestión de contenidos web muy potente que ofrece multitud de funcionalidades para el desarrollo web. Drupal ha sido varias veces elegido el mejor CMS de código abierto a nivel mundial por: Por su estructura modular. ● La consistencia de todo el sistema. ● La calidad de su código y la seguridad. ● Estándares. ● Accesibilidad y usabilidad web. ●
  • 3.
    Drupal tiene licenciaGNU/GPL y está escrito en PHP.
  • 4.
    ¿Qué es unmódulo en Drupal? El módulo (module) es un software que extiende las funcionalidades o características de Drupal.
  • 5.
    Cuando crear unmódulo ● Comunicación con sistemas externos. ● Creación de funcionalidades muy a la medida.
  • 6.
    Temas de hoy Ubicacióndel nuevo módulo. ✔ Idioma base y codificación de los archivos. ✔ Archivos principales del módulo: .info y .module. ✔ La función t() para traducción de cadenas de texto. ✔ Activación del módulo. ✔ Ejemplo de desarrollo de un módulo. ✔
  • 7.
    Ubicación del módulo sites/all/modules EnDrupal cada módulo dispone de su propio directorio, que recibe generalmente el mismo nombre que el módulo para simplificar la organización.
  • 8.
    Importante El nombre deldirectorio no debe contener espacios ni caracteres especiales. Podemos utilizar el guion bajo como separador.
  • 9.
    Idioma base ycodificación El idioma base siempre será el inglés Drupal trabaja con UTF-8 en la codificación de archivos Crear archivos con codificación UTF-8 sin BOM
  • 10.
    Archivos principales delmódulo .info y .module
  • 11.
    .info Se trata deun archivo de texto escrito de forma similar a un archivo php.ini, que contiene información básica sobre el módulo (nombre, descripción, versión de Drupal, etc.) El nombre debe ser similar al de la carpeta <nombre_modulo>.info
  • 12.
  • 13.
    .info Puede contener otroscampos como: files (archivos, campo opcional). Drupal 7 permite el registro de código de forma dinámica, a través de funciones de autoload. php (campo opcional). Indica la versión mínima de PHP requerida. dependencies (dependencias, campo opcional). Nuestro módulo puede necesitar de otros módulos para su funcionamiento. El campo dependencies será un vector con los nombres de estos módulos requeridos.
  • 14.
    .info required (requerido, campoopcional). Especifica que el módulo actual es indispensable y siempre debe estar activado. configure (configuración, campo opcional). Especifica la ruta a la página de configuración del módulo. package (paquete, campo opcional). Cuando un módulo pertenece a un conjunto de módulos.
  • 15.
    .module El archivo .moduleincluye el código del módulo, en forma de funciones PHP. Es en este archivo donde se realizarán las llamada a los hooks. El estándar para nombrar al archivo .module es similar al de los archivos .info, siguiendo el patrón <nombremodulo>.module.
  • 16.
    El fichero .moduleno es más que un script PHP, de manera que la primera línea comienza con la marca de inicio de código PHP "<?php", pero no se cierra con este código ?>.
  • 17.
    ¿Qué es unahook? Son funciones PHP que utilizamos en nuestros módulos, el nombre de las mismas se compone de la siguiente forma:
  • 18.
    ¿Para qué sirvenlas hooks? Aumentan la funcionalidad de Drupal permitiendo a los módulos interactuar con el core. De esta manera podemos alterar los comportamientos default de Drupal, y agregar nueva funcionalidad, si esos son los requerimientos para nuestro sitio.
  • 19.
    La función t() Lafunción t() permite que el sistema pueda traducir las cadenas de texto al resto de idiomas activos en el sitio.
  • 20.
    Activación del módulo Ingresaral menu, ir a module, buscar, seleccionar y por ultimo grabar los cambios.
  • 21.
    Tipos de módulosmás usados tipo bloque tipo página
  • 22.
  • 23.
    Programando un bloque hook_block_info(),define todos los bloques que nuestro módulo va a proveer. hook_block_view(), construye el bloque. hook_theme(), formateará la salida del tema hacia un archivo tpl
  • 24.
    hook_block_info() En el array$blocks definimos todos los bloques de nuestro módulo y proporcionamos las opciones por defecto de cada bloque.
  • 25.
    hook_block_view() En esta funcióndefinimos lo que se ve en cada bloque que implementa nuestro módulo. La variable $delta es la que nos identifica el bloque.
  • 26.
    $block['content'] En esta variablellamamos a la función que contiene el contenido a imprimir.
  • 27.
    Veamos el códigoy funcionamiento
  • 28.
  • 29.
    Theming: maquetar elresultado Ahora estamos introduciendo “Hola Mundo” en el array de variables que le vamos a pasar a la plantilla, y a continuación utilizamos la función theme() para generar el resultado de salida. Para ello la función theme() invoca el hook_theme().
  • 30.
    hook_theme() En nuestro hook_theme()estamos llamando a la plantilla (template): “saludar-hola-mundo”, para maquetar el callback: “saludar_hola_mundo”.
  • 31.
    Creando un archivode plantilla El siguiente paso es crear nuestro archivo tpl que hemos definido en el hook_theme(), en nuestro caso se llama saludar-hola-mundo.tpl
  • 32.
  • 33.
    hook_menu() Sirve para crearuna página, es decir, programar la respuesta para una determinada url. Por ejemplo acceder desde: http://localhost/drupal/saludar/hola-mundo
  • 34.
    hook_menu() Lo que hemoshecho es añadir una url al array de elementos $items, y para esa dirección elegimos un título para la página y la función que implementa el contenido.
  • 35.
  • 36.
    Veamos el códigoy funcionamiento
  • 37.
  • 38.
  • 39.
  • 40.
    Gracias Charla impartida por: EdgarDueñas edgar@pixtig.com