Aplicaciones de administración

Un gestor de contenidos de una aplicación de administración, a lo largo de la historia de zenphp me he visto obligado a crear diversos tipos de administradores e ingeniármelas para hacerlo de forma tan general que pudiera compartir el código entre proyectos para no reescribir todo el código una y otra vez en función de las necesidades de los usuarios finales.
Para generar dichas aplicaciones, estoy diseñando un modelo general de aplicación web de administración con una serie de plantillas, el conjunto total de la aplicación con administración es el cartucho que carga el generador Gtk y es compilado por el generador POA de forma que obtenemos el esqueleto inicial de una aplicación en pocos segundos ,sobre la que vamos a trabajar, podemos cambiar las plantillas de administración pero realmente no es algo primordial ya que sólo con cambiar el logo para cada proyecto y un par de cosas más estará completado.
Adjunto una captura de una de las aplicaciones web de administración del modelo de “Portal” que estoy preparando como cartucho para incluir en el repositorio SVN del proyecto.

En la imagen se puede ver el visualizador HTML donde el único HTML que hay son pequeños mensajes de resultados, una pregunta, una confirmación, cosas simples, que han de estar mejor en funciones que lean una plantilla por defecto, asi está todo bien organizado. El resultado es una página de administración para mantener el contenido de una aplicación web cliente de forma que cualquier usuario pueda modificar cualquier parte de la misma.

Generar el esqueleto de una aplicación web en 15 segundos

Hagamos un repaso de los vídeos de la sección de documentos.

Toma 1:Validaciones

Después de ver los vídeos de las validaciones

Toma 2: modelo de datos

De como se construye un modelo de datos con su visualizador usando el MVC modificado

Toma 3: Visualizador avanzado:

Avanzamos con el visualizador:[ver]

Toma 4: El scaffolding

y le añadimos un andamio (scaffolding):[ver]

Todo en uno: el generador

Podemos ver como el generador de aplicaciones lo hace todo en 15 segundos (o menos :))[en acción] realiza nuestro trabajo más rápido que nosotros y nos permite concentrarnos en la parte importante del problema, lo que tenemos que presentar, finalmente.

Ir al vídeo

Operaciones automáticas del generador de aplicaciones

Para construir una aplicación el generador toma una serie de modelos de ficheros necesarios como base para completar la estructura del sistema.

La estructura del generador se puede ver en el siguiente diagrama:
Diagrama de clases del generador de aplicaciones PHP-GTK2 para zenphp
La macro zen_generador_gtk.php lanza la ventana principal (GtkWindow,PHP-GTK2:GtkWindow) que usa la clase zen_fabrica_gtk para “fabricar” todos los componentes de la ventana principal, asociándole los eventos que se agrupan en la clase zen_eventos_ventana_principal, de forma que tenemos siempre un puntero en todas las clases a ésta ventana principal que sirve para localizar cualquier componente,clase o método que necesitemos desde cualquier lugar, asi, se construyen los modelos de las estructuras de datos como las de los árboles con una clase info_configuracion_arbol asociada a la “fábrica”, que sólo inciarse, en su constructor lee las definiciones del fichero de configuración XML del generador, y genera los menús en el GtkMenuBar llamado zen_menu_gtk existiendo la posibilidad de definir nuestros propios menus de usuario, los eventos se asocian directamente y son “atrapados” por medio de la función “public function evento_menu($nombre) ;” de la clase zen_eventos_ventana_principal, sólo hemos de añadir nuestro “caso” al resto para que se ejecuten las órdenes que necesitemos…

Queda mencionar la última conexión con la fábrica, que estoy desarrollando, el generador GTK se conecta con el generador POA para compilar y aplicar los “aspectos” en los que se basa, esto es, nuestros modelos y ayudantes definidos en el cartucho, los visualizadores asociados, las bases de datos configuradas en la aplicación,etc. Esto se hace con el zen_generador_poa, asociado a la fábrica Gtk de forma que carga el motor de zenphp y conecta las 3 partes del proyecto a través del paradigma orientado a aspectos. Tras compilar, generar y construir todo el sistema de aplicaciones, se muestra el mensaje de confirmación. Ya se puede copiar el directorio de salida al directorio web y si todo estaba bien definido, probar la aplicación…

Quizás algo interesante es zen_ventana_mysql_admin , un administrador de bases de datos MySQL, podemos definir en el XML de nuestro cartucho el acceso a varios servidores y mediante la aplicación al hacer doble click sobre dicha línea de configuración conectarremos al servidor especificado para realizar las tareas que consideremos oportunas fácilmente.

Nuevos Videotutoriales : MVC modificado y un proyecto de ensayo


Nuevos videotutoriales han sido añadidos a la sección de documentos de la Forja.

En este caso para explicar como funciona el modelo+visualizador junto con la sencillez de añadir un andamio o Scaffolding.

Se añaden junton con un vídeo del generador de aplicaciones Gtk y el inicio de un ensayo científico sobre la meditación.

Instalar PHP+GTK2 en Linux

  1. Descargar todos los paquetes
    Primero, descargar todos los siguientes paquetes y ten en cuenta el número de versión.

    • pkg-config-0.21 – una herramienta para llevar el control de las banderas de compilación necesarias para las librerías usadas por GTK+ [descargar]
    • glib-2.12.4 – es el núcleo de librerías de bajo nivel que construyen las bases de GTK+ y GNOME [download]
    • libpng-1.2.8 – librería de imagen PNG [download]
      Elige la versión:  .tar.bz2 que contien configure. Es más fácil de compilar.
    • freetype-2.2.1 – un motor de fuentes que provee de una “API” simple y fácil de usar para acceder al contenido de una fuente con un método uniforme, independientemente del formato del fichero. Soporta fuentes escalables en formatos como TrueType o “Type 1” nativo. [download]
    • fontconfig-2.4.0 – le da a Pango la estandarización para la localización de fuentes para poder encontrarlas por sus nombres [download]
    • cairo-1.2.4 – una librería gráfica que soporta vectorización y composición de imágenes. Tanto Pango como GTK+ usan cairo para gran parte de su dibujado. [download]
      Atención: Descarga la versión v1.2.4 (o mayor) directamente de cairographics.org. NO USES la que viene en el ftp ftp://ftp.gtk.org/pub/gtk/v2.10/dependencies/. ¡En mi PC ha causado muchísimos bugs! Encontrarás que gtk+ no te compila si usas cairo-1.2.0. Y el mensaje de error dice que hay un problema con pango, aunque realmente el problema viene de esta versión, cairo-1.2.0 que es la que causa el problema. Además, la v1.2.6. parece que también da algunos errores.
    • pango-1.16.4 – una librería para manejar texto internacionalizado [download]
    • atk-1.9.1 – Herramientas de Accesibilidad [download]
    • gtk+-2.10.12 – la base para php-gtk2 [download]
    • libgnomeprint-2.12.1 – se necesita para gtksourceview [download]
    • gtksourceview-1.6.0 – permite que se pueda mostrar código fuente con numeración automática y coloreado de sintaxis (se usa en el generador) [download]
    • gtk+extra-2.1.1 – contiene un número de útiles widgets incluyendo: GtkSheet, GtkPlot y GtkDirTree [download]
    • php-5.2.3 – php5 [download]
    • php-mysql – módulo de MySQL para PHP5 [download]
    • mysql – Servidor de base de datos MySQL [download]
    • php-gtk-2.0.0beta – php-gtk2 [download]
  2. Librerías de desarrollo de las X-Window
    Haz una rápida comprobación de tu configuración y asegúrate de que tienes las librerías de desarrollo de las X instaladas…
  3. Variables de entorno necesarias
    Si estás usando bash, establece las siguientes variables:
    CPPFLAGS="-I/usr/local/include"
    LDFLAGS="-L/usr/local/lib"
    PKG_CONFIG_PATH="/usr/local/lib/pkgconfig"
    LD_LIBRARY_PATH="/usr/local/lib"
    PATH="/usr/local/bin:$PATH"
    export CPPFLAGS LDFLAGS PKG_CONFIG_PATH LD_LIBRARY_PATH PATH

    Si usas csh o tcsh, añade lo siguiente a tu $HOME/.cshrc
    setenv CPPFLAGS "-I/usr/local/include"
    setenv LDFLAGS "-L/usr/local/lib"
    setenv PKG_CONFIG_PATH "/usr/local/lib/pkgconfig"
    setenv LD_LIBRARY_PATH "/usr/local/lib"

    setenv PATH /usr/local/bin:${PATH}

  4. Compilar GTK+ primeroAtención: Para todos los paquetes, usa el ./configure por defecto. Los ficheros compilados irán a /usr/local/lib y /usr/local/include.

    Orden de compilación:

    1. Compilar glib-2.12.4
      tar xvzf glib-2.12.4.tar.gz
      cd glib-2.12.4
      ./configure
      make

      sudo make install
    2. Compilar libpng-1.2.12
      bunzip2 libpng-1.2.12.tar.bz2
      tar xvf libpng-1.2.12.tar
      cd libpng-1.2.12
      ./configure
      make

      sudo make install
    3. Compilar freetype-2.2.1
      tar xvzf freetype-2.2.1.tar.gz
      cd freetype-2.2.1
      ./configure
      make

      sudo make install
    4. Compilar fontconfig-2.4.0
      tar xvzf fontconfig-2.4.0.tar.gz
      cd fontconfig-2.4.0
      ./configure
      make

      sudo make install
    5. Compilar cairo-1.2.4
      tar xvzf cairo-1.2.4.tar.gz
      cd cairo-1.2.4
      ./configure
      make

      sudo make install
    6. Compilar pango-1.16.4
      tar xvzf pango-1.16.4.tar.gz
      cd pango-1.16.4
      ./configure
      make

      su (entrar como root)
      make install
      Atención: Algunos de vosotros encontraréis errores en este punto. No preocuparse. Esto es porque necesitas volver como usuario normal (que no administrador), y las variables de entorno previamente definidas lo están para la cuenta de usuario,y no para root. Sólo tienes que volver a especificarlas como root y volver  a lanzar
      make install
      “on more time” :] Todo debe de funcionar ahora.
    7. Compilar atk-1.9.1
      bunzip2 atk-1.9.1.tar.bz2
      tar xvf atk-1.9.1.tar
      cd atk-1.9.1
      ./configure
      make

      sudo make install
    8. Compile gtk+-2.10.12
      tar xvzf gtk+-2.10.12.tar.gz
      cd gtk+-2.10.12
      ./configure
      make

      su (entrar como root)
      make install
      Atención: Aquí es posible que encontréis otro error, igual que antes,el problema es por las  variables de entorno definidas como usuario que también necesitan ser declaradas como root, entonces se puede hacer make install de nuevo, y todo debe de ir bien.
      Si gtk+ compila ok, debe de haber una gtk-demo en /usr/local/bin. Ahora puedes probar que gtk+-2.10.6 está funcionando si la ejecutas.
  5. Añadir componentes adicionales útiles — GtkSourceView y GtkExtraGtkSourceView permite visualizar código fuente con coloreado automático así como autonumeración de líneas.
    • Primero compila libgnomeprint-2.12.1
      bunzip libgnomeprint-2.12.1.tar.bz2
      tar xvf libgnomeprint-2.12.1.tar
      cd libgnomeprint-2.12.1
      ./configure
      make

      sudo make install
    • Ahora compila gtksourceview-1.6.0
      tar xvzf gtksourceview-1.6.0.tar.gz
      cd gtksourceview-1.6.0
      ./configure
      make

      sudo make install
    • Compila gtk+extra-2.1.1
      tar xvzf gtk+extra-2.1.1.tar.gz
      cd gtk+extra-2.1.1
      ./configure
      make

      sudo make install
  6. Compila php-5.2.3
    • Primero necesitas compilar php5
      tar xvzf php-5.2.3.tar.gz
      cd php-5.2.3
      ./configure --prefix=/usr/local/php-5.2.3 --disable-cgi
      make

      sudo make install
    • Crear php.ini y añadir la extensión de php_gtk2.so:echo extension=php_gtk2.so >> /usr/local/php-5.2.3/lib/php.ini
      /usr/local/php-5.2.3/bin/php-config --extension-dir | xargs echo 'extension_dir=' >> /usr/local/php-5.2.3/lib/php.ini
  7. Compilar php-gtk-2.0.0
    • Construir configure
      tar xvzf php-gtk-2.0.0beta.tar.gz
      cd php-gtk-2.0.0
      ./buildconf --with-phpize=/usr/local/php-5.2.3/bin/phpize
    • Compilar php-gtk2
      Atención: No olvides usar “–enable-sourceview –enable-gtkextra” en tu configure para que se incluyan gtksourceview y gtkextra.

      ./configure --prefix=/usr/local/php-gtk-2.01 --enable-sourceview --enable-gtkextra --with-php-config=/usr/local/php-5.2.3/bin/php-config
      make

      sudo make install

Para llamar más fácilmente a php-gtk, crea un enlace simbólico al binario:
ln -s /usr/local/php-5.2.3/bin/php /usr/bin/php-gtk2

Si tu variable de entorno PATH contiene /usr/bin, puedes ejecutar los scripts PHP usando:
php-gtk2 script.php