English Manual KumbiaPHP Framework 1.0 Index

De KumbiaPHP Framework Wiki
Revisión del 01:41 9 oct 2009 de Pabloa (discusión | contribuciones) (creacion)
(dif) ← Revisión anterior | Revisión actual (dif) | Revisión siguiente → (dif)

This manual is an english port of Manual Kumbia PHP Framework. It is work in progress. You are free to help to improve it.

Until the work is finished, the manual will have spanish text mixed with english text. You are free to help us with the translation :-).


AGRADECIMIENTOS

   Este manual es para agradecer a quienes con su tiempo y apoyo en gran o en poca medida han ayudado a que este framework sea cada día mejor.
   A todos ellos Gracias Totales:
      Andres Felipe Gutierrez gutierrezandresfelipe@gmail.com
      Deivinson Tejeda deivinsontejeda@kumbiaphp.com
      Emilio Silveira emilio.rst@kumbiaphp.com
      César Caballero aka Phillipo phillipo@kumbiaphp.com
   Y a toda la comunidad que rodea a Kumbia, con sus preguntas, notificaciones de errores(Bug's), aportaciones, etc...

PREFACIO

  1. Sobre este libro
  2. Sobre Kumbia
  3. Sobre la comunidad
  4. Historia de Kumbia
  5. Que aporta Kumbia
  6. ¿Porque usar Kumbia?
  7. Modelo, Vista, Controlador (MVC)
    1. ¿Que es?
    2. Implementación y uso
    3. Información adicional
    4. Caso práctico

GETTING STARTED WITH KUMBIA PHP FRAMEWORK

Instalar Kumbia

  1. Requisitos
  2. Descargar Kumbia
  3. Configuración de módulos (Apache, PHP y bbdd)
    1. Configurando Apache
      1. ¿Por qué es importante Mod-Rewrite?
    2. Configuración de PHP
      1. ¿Porque Kumbia utiliza PHP5?
    3. Configurando BB.DD
      1. Configuración de MySQL
      2. Configurando Oracle
  4. Configurar XAMPP
    1. Instalando XAMPP bajo Windows
    2. Instalando XAMPP bajo GNU/Linux
    3. Instalando XAMPP bajo Debian/Ubuntu Linux
  5. Configurar Apache2Triad
  6. Verificar la instalación de Kumbia
    1. Instalar Kumbia PHP en producción de forma segura

Kumbia Structure

  1. Introducción
  2. Directorios de entorno
    1. Explicación
  3. Archivos de entorno
    1. config.ini
      1. Explicación de los parámetros ./config/config.ini
    2. environment.ini
      1. Estructura del archivo ./config/environment.ini
      2. Explicación de los parámetros ./config/environment.ini
    3. routes.ini
      1. Explicación de los parámetros ./config/routes.ini
      2. Gestionar extensiones. Ejemplo práctico
  4. Resumen

Características avanzadas

  1. ¡Parámetros con Nombre!
  2. Obtener valores en una aplicación Kumbia
  3. Uso de Paquetes (Namespaces)
  4. Programación modular

Primera Aplicación en Kumbia

  1. Creando una nueva aplicación
  2. Hola Kumbia
  3. Kumbia URLS
  4. Nuestra Primera Acción
  5. Agregando más Contenido
  6. Repitiendo la Historia

WORKING WITH KUMBIA PHP FRAMEWORK

MODELOS

  1. Introducción
  2. ¿Por qué usar una capa de Abstracción?
  3. Capa de Abstracción Independiente en Kumbia
  4. Adaptadores Kumbia
  5. Esquema de Acceso a BB.DD en Kumbia
  6. Modelos
    1. Características de los modelos:
    2. Acceso Directo a RDBMS
      1. La Clase DdBase
      2. Propiedades de la Clase DB
        1. $db->Id_Connection
        2. $db->dbUser
        3. $db->dbPass
        4. $db->dbHost
        5. $db->dbName
        6. $db->dbPort
        7. $db->lastError
        8. $db->lastResultQuery
      3. Métodos de la Clase DB
        1. connect()
        2. query()
        3. close()
        4. fetch_array()
        5. field_name()
        6. data_seek()
        7. affected_rows()
        8. error()
        9. no_error()
        10. find()
        11. in_query()
        12. in_query_assoc()
        13. in_query_num()
        14. fetch_one()
        15. table_exists()

ACTIVE RECORD

  1. Ventajas del ActiveRecord
  2. Crear un Modelo en Kumbia PHP Framework
  3. Columnas y Atributos
  4. Llaves Primarias y el uso de IDs

CRUD: Create, Read, Update, Delete

  1. Creando Registros
  2. Consultando Registros
  3. El poderoso Find
  4. Promedio, Contando, Sumando, Mínimo y Máximo
  5. Actualizando Registros existentes
  6. Borrando Registros
  7. Propiedades Soportadas

Convenciones en ActiveRecord

  1. Convenciones Generales
  2. id
  3. campo_id
  4. campo_at
  5. campo_in

Convenciones para RDBMs

  1. Convenciones Especiales para PostgreSQL
  2. Convenciones Especiales para Oracle

ACTIVE RECORD API

This is a reference of the methods in ActiveRecord class sorted in alphabetic order:

Consultas

Métodos para hacer consulta de Registros:

  1. distinct
  2. find_all_by_sql(string $sql)
  3. find_by_sql(string $sql)
  4. find_first
  5. find
  6. select_one(string $select query)
  7. select_one(string $select query) (static)
  8. exists
  9. find_all_by
  10. find_by_*campo*
  11. find_all_by_*campo*

Conteos y Sumatorias

  1. count
  2. sum
  3. count_by_sql

Promedios, Máximo y Mínimo

  1. average
  2. maximum
  3. minimum

Creación-Actualización-Borrado de Registros

  1. create
  2. update
  3. update_all
  4. save
  5. create_from_request
  6. save_from_request
  7. delete
  8. delete_all

Validación

  1. validates_presence_of
  2. validates_length_of
  3. validates_numericality_of
  4. validates_email_in
  5. validates_uniqueness_of
  6. validates_date_in
  7. validates_format_of

Transacciones

  1. commit()
  2. begin()
  3. rollback()

Otros Métodos

  1. sql(string $sql)

Callbacks ActiveRecord

  1. Introduccion
  2. before_validation
  3. before_validation_on_create
  4. before_validation_on_update
  5. after_validation_on_create
  6. after_validation_on_update
  7. after_validation
  8. before_save
  9. before_update
  10. before_create
  11. after_update
  12. after_create
  13. after_save
  14. before_delete
  15. after_delete

Asociaciones

  1. Introducción
  2. Pertenece (belongs_to)
  3. Tiene un (has_one)
  4. Tiene muchos (has_many)
  5. Tiene y pertenece a muchos (has_and_belongs_to_many)

Paginadores

  1. Paginate
  2. Paginate_by_sql
  3. Paginando en ActiveRecord
  4. Ejemplo completo de uso del paginador

APPLICATION CONTROLLER

Métodos de la Clase ApplicationController

This class has several useful methods to work with controllers.

ApplicationController Class Methods

This class has several useful methods to work with controllers.

render($view)

Shows a view belonging to the same controller.

Examples:

<?php
   class ProductsController extends ApplicationController {
      function index(){
         $this->render('list');
      }
    } //end of class

?> In this case, the view views/products/list.phtml will be rendered.

redirect($url, $seconds=0.5)

Redirecciona la ejecución a otro controlador en un tiempo de ejecución determinado

Ejemplos de uso: <?php

  class ProductosController extends ApplicationController {
     function index(){
        $this->redirect('facturas/nueva', 2);
     }
  }

?>

En el ejemplo va a facturas/nueva después de 2 segundos

post($value)

   Obtiene acceso orientado a objetos a los valores de $_POST, $value es el índice para pasar
al array asociativo.

get($value)

   Obtiene acceso orientado a objetos a los valores de $_GET, $value es el índice para

pasar al array asociativo.

request($value)

   Obtiene acceso orientado a objetos a los valores de $_REQUEST, $value es el índice para pasar al
array asociativo.

render_partial($name)

Visualiza una vista parcial (partial) que pertenece al mismo controlador. Ejemplo:

Ejemplos de uso: <?php

   class ProductosController extends ApplicationController {
       function index(){
           $this->render_partial('mostrar_menu');
       }//fin del metodo
    }//fin de la clase

?>

   En este caso se visualizaría la vista parcial views/productos/_mostrar_menu.phtml

route_to([params: valor])

  Hace el enrutamiento desde un controlador a otro, o desde una acción a otra. Recibe los parámetros 

con nombre:

     • controller: A qué controlador se va a redireccionar
     • action: A que acción se va a redireccionar
     • id: Id de la redirección

Ejemplos: return $this->route_to("controller: clientes", "action: consultar", "id:1");

El tipo de enrutamiento que realiza es interno, es decir que lo usuarios no notan cuando están siendo redireccionados en la aplicación.

redirect($url_controlador)

   Realiza un redireccionamiento a otro controlador/accion mediante HTTP. Es útil cuando queremos hacer
una real redirección que incluso cambie la URL que aparece en el

explorador.

Ejemplo: $this->redirect(“/productos/query”);

cache_layout($minutes)

   Caché de la vista views/layout/ correspondiente al controlador durante $minutes.

not_found($controller, $action) =

   Puedes definir el método not_found en cualquier controlador, en caso de estar definido se llamará
cuando no encuentre definida alguna acción así es más fácil controlar este tipo de errores:

Ejemplo <?php

   class PruebaController extends ApplicationController {
       function index(){
           $this->render_text("Este es el index");
       }
       function not_found($controller, $action){
           Flash::error("No esta definida la accion $action, redireccionando a index...");
           return $this->route_to('action: index');
       }
   }

?> NOTA: Ahora en la versión 0.5 se incluye un vista views/not_found.phtml, esto hace que no se haga necesario la implementacion del metodo not_found, ya que cuando no exista un controller o una acción se renderizara dicha vista, esta puede ser totalmente personalizada de manera que sea mas comodo el desarrollo.

set_response($type)

   Especifica el tipo de respuesta que va a generar el controlador. Cuando es el valor de $type
es view solamente envía la salida de la vista más no del layout, el template o cualquier cabecera
html. Es ideal en salidas AJAX o PDF. Otro valor para $type es XML.

Ejemplo <?php

   class PruebaController extends ApplicationController {
       function accion_ajax(){
           $this->set_response(“view”);
       }
   }

?>

is_alnum($valor)

Evalúa si un campo es alfanumérico o no. Es útil para validar la entrada de datos al recibirlos por parte de usuarios.

<?php

   class PruebaController extends ApplicationController {
       function adicionar(){
          $nombre = $this->request(“nombre”);
          if($this->is_alnum($nombre)==false){
              Flash::error(“Entrada invalidad para precio”);
              return;
           }
          /* ..*/
      }
  }

?>

load_reacord($record)

Carga los campos de un registro ActiveRecord como atributos del controlador, recibe como parámetro $record ActiveRecord o string registro ActiveRecord a cargar, si es un string este debe corresponder al nombre de un modelo Soporta argumento variable.

    field: campos a cargar separados por coma
    except: campos que no se cargaran separados por coma
    suffix: sufijo para el atributo en el controlador
    preffix: prefijo para el atributo en el controlador

//Ejemplo1: $usuario = $this->Usuario->find(1); $this->load_record($usuario);

//Ejemplo2: $usuario = $this->Usuario->find(1); $this->load_record($usuario, 'except: id, sexo');

//Ejemplo3: $usuario = $this->Usuario->find(1); $this->load_record($usuario, 'field: nombre, apellido');

//Ejemplo4: $usuario = $this->Usuario->find(1); $this->load_record($usuario, 'preffix: c_');

//Ejemplo5: $this->load_record('Usuario');

//Ejemplo6: $this->load_record('Usuario', 'field: nombre, apellido');

== is_numeric($valor) ==

Evalúa si un campo es numérico o no. Es útil para validar la entrada de datos al recibirlos por parte de usuarios.

<?php

   class PruebaController extends ApplicationController {
      function adicionar(){
          $precio = $this->request(“precio”);
          if($this->is_numeric($precio)==false){
               Flash::error(“Entrada invalida para precio”);
               return;
          }
          /* ..*/
      }
   }

?>

Obtener valores desde el controller

ApplicationControllerBase (Clase padre)

Enrutamiento y redirecciones

VISTAS Y HELPERS

  1. ¿Porque usar vistas?

Vistas

Layouts

Templates

Partials

CCS en KumbiaPHP

content()

Helpers

AJAX

EXTENSIONS (Módulos extras de KumbiaPHP)

Filter

  1. Qué es un Filtro?
  2. Utilización básica
  3. Métodos de la clase Filter

GENERADOR DE FORMULARIOS

  1. Tipos de Formularios
  2. Ventajas Generadores de Formularios
  3. Desventajas Generadores de Formularios

EJEMPLOS

GLOSARIO