Archive: cakePhp

Bake en cakePhp por consola

 

cakePhp, Código, Productividad

Bake nos facilita una vez teniendo la base de datos, poder crear modelos controladores y vistas, de una forma sencilla.
Algo importante antes de nada, es crear la base de datos correctamente y con los estándares de cakePhp.

  • Tablas en plural ( users )
  • Campos en singular ( name, email )
  • Campo id auto incremento y único
  • Relaciones simples nombreDeLaTabla + _ + id ( category_id, si queremos relacionar users a la tabla de categories)
  • Relaciones hasAndBelongsToMany, una tabla aparte ( users_categories ), y los campos ids de las tablas a relacionar (user_id y cateogry_id)
  • Como aporte siempre es bueno tener los campos created y modified tipo datetime, los interpreta cakephp y los rellena automáticamente

Sabiendo esto como base, ya nos podemos meter en la terminal y buscar nuestro proyecto e ir a la carpeta app y añadir lo siguiente en nuestra terminal : Console/cake bake

bake

A partir de aquí es seguir las instrucciones, primero empezar por configurar la base de datos, luego modelos, controladores y por último las vistas.

Eso sí antes de hacer esto tiene que estar montado vuestro cake en un servidor local tipo Mamp, y la base de datos creada.

Instalar entorno para Tests Unitarios en cakePhp 2 (macosx)

 

cakePhp

Una peculiaridad de cakePhp2, es que Usa PhpUnit para la creación de test, y no viene instalada.

Al usar Mamp como servidor local, era algo complicado la instalación de PhpUnit en un projecto en cakePhp, encontré el siguiente Plugin que nos ayuda: https://github.com/Hyra/PHPUnit-Cake2 Gracías a Stef van den Ham.

Como instalar este vendor:

  1. Descargar el zip y descomprimirla en tu proyecto en la carpeta Plugin o bien ejecutar el siguiente código en tu proyecto “git clone https://github.com/Hyra/PHPUnit-Cake2 app/Plugin/Phpunit”
  2. Ejecutar el siguiente código en tu consola dentro de tu proyecto “cake Phpunit.Phpunit install”, si no tienes configurado en el path cake, puede ayudarte este video , recomendamos que se instale en la opción 1 “app/vendors”.
  3. En tu archivo bootstrap.php añade al final “CakePlugin::loadAll();” para que se carguen todos los plugins o bien “CakePlugin::load(‘Phpunit’);” para cargar solo el plugin phpunit.
  4. Con estos pasos ya tiene instalado el entorno de testing con phpUnit, que funcionará en otros sistemas operativos.

 

 

Píldora – Traducción de fechas en cakephp 2.0.

 

cakePhp

Si usamos el Helper Form para construir nuestro formularios, cuando tenemos un campo fecha, los meses no salen en inglés. ¿Como traducir esto?

Primero fijarnos en el Helper Form, como están construidos los textos traducibles

__d('cake', 'January');

Viendo en el código vemos que el archivo que va a buscar las traducciones no es el default.po ( como en otras versiones de cakePhp, sino uno llamado cake.po, habría que crear este archivo con las traducciones de todos los meses o descargar el que tengo hecho.

El último paso para que esto funcione, es configurar el cakePhp para que el idioma definido sea castellano.

Para probar ponemos el siguiente código en el controlador que necesitemos esa traducción.

Configure::write('Config.language', 'spa');

Píldora – Usar paginación con varios modelos en cakephp.

 

cakePhp

A veces en cakePhp nos encontramos con que queremos usar varios modelos en un mismo controlador, y paginar los modelos.
y como es algo que me ha surgido varias veces, y siempre me tengo que para a pensar, lo dejo colgado en el blog, como una pequeña píldora.

Decimos que queremos usar dos modelos.

public $uses = array( 'User', 'Profile');

En lo que siempre fallo es que pongo $this->paginate(); pero si hay varios modelos tengo que decir que modelo quiero paginar, sino por defecto siempre será el primero en la array $uses.

un ejemplo:

public function Profile() {
		$this->Profile->recursive = -1;
		$this->set('profile', $this->paginate('Profile'));
}

Componente REST para cakePhp

 

cakePhp, Código

Buenas, acabo de subir un componente RESTfull para cakePhp en mi cuenta de github https://github.com/deldan/RestAndCurl-component-cakePhp

¿Como hacerlo funcionar?

Descargar los dos componentes y guardarlos en la carpeta app/controller/components de tu proyecto cakePhp

Llamalo en el controlador que se necesite, como con cualquier componente

var $components=array('Curl', 'Restclient');

Y crear las llamadas REST

Dejo un pequeño ejemplo de conexión y llamada a la api de 11870.com con estos componentes


//uri REST
$uri = "http://api.11870.com/api/v2/search";


//parametro de busqueda
 $params['q'] = $search;

 //parametro ciudad
 $params['ls'] = $city;
 
//parametro categoria
 $params['category'] = $tipo;

 //params
 $params['fields'] = 'title,summary,link';
 $params['oauth_token'] = '**********************';
 $params['oauth_token_secret'] = '**********************';
 $params['appToken'] = '**********************';

 
 // REST call
 $result = $this->Restclient->get($uri, $params, 'xml');

Cambiar url navegador desde Ajax en cakePhp (location.hash)

 

cakePhp

Cuando usamos Ajax,  y cargamos información, no se refresca nuestra url.
A veces nos interesa que si sea así, que nuestra url cambié.

Una manera sencilla de hacerlo en cakePhp

echo $ajax->link(
‘ver Usuario’,
array(‘controller’ => ‘User’, ‘action’ => ‘ver/’.$id),

array(‘update’ => ‘ver_usuario’, ‘complete’ => ‘window.location.hash = “usuario”‘)
);

Lo que tenemos en window.location.hash es lo que luego saldrá en nuestra url tipo:  http://localhost/user/ver#usuario

Imagen Preloader con Ajax y Cakephp

 

cakePhp

En un anterior post comentaba como crear formularios Ajax en Php. Está vez necesitaba un link en vez d eun formulario, pero además con una imagen con el típico preloader, mientras procesaba los datos, y fue más sencillo de lo esperado. aquí os dejó el código, el secreto está en el “indicator”.

Código html, donde se mostrá el resultado, la imagen que se mostrará al hacer el preload.


 

resultados

Código php, donde ultilzamos el helper ajax.

//debe estar declarado el ajax helper var $helpers = array('Ajax');
 $ajax->link('El navegador confirmará antes de enviar la respuesta ajax', array( 'controller' => 'ajax', 'action' => 'add', 5 ), array( 'update' => 'add5', 'indicator' => 'loading'));

FirePHP para cakePHP

 

cakePhp

Primero decir que firePHP es complemento  de firebug para firefox, ¿en que nos facilita la vida? nos ahorra tener que sacar por pantalla echos, o var_dump(), esto es extremadamente útil cuando un proyecto web en php ya está en subido, y hay usuarios conectados.

Pasos a seguir para poder utilizar firePHP en Cakephp:
He sacado la parte de como instalarlo de: http://www.utoxin.name/2009/02/cakephp-firephp/.

Requerimientos:

Vamos a preparar cakePHP para el correcto funcionamiento de firePHP.

Lo primero que debemos haces es descomprimir la biblioteca principal de firePHP que hemos descargado, dentro de la carpeta lib, copiar la carpeta FirePHPCore, en “app/vendors/”.

Copiamos el archivo dbo_source.php de “cake/lib/models/datasources” y lo pegamos en “app/models/datasources/”, buscamos dentro del archivo la función showLog() y la cambiamos por la siguiente.

function showLog($sorted = false) {
	if ($sorted) {
		$log = sortByKey($this->_queriesLog, 'took', 'desc', SORT_NUMERIC);
	} else {
		$log = $this->_queriesLog;
	}
 
	if ($this->_queriesCnt > 1) {
		$text = 'queries';
	} else {
		$text = 'query';
	}
 
	if (PHP_SAPI != 'cli') {
		$summary = "{$this->_queriesCnt} {$text} took {$this->_queriesTime} ms";
 
		$body = array();
		$body[] = array("Nr", "Query", "Error", "Affected", "Num. rows", "Took (ms)");
		foreach ($log as $k => $i) {
			$body[] = array(($k + 1), $i['query'], $i['error'], $i['affected'], $i['numRows'], $i['took']);
		}
 
		fb(array($summary, $body), FirePHP::TABLE);
	} else {
		foreach ($log as $k => $i) {
			print (($k + 1) . ". {$i['query']} {$i['error']}\n");
		}
	}
}

Ahora debemos pegar el siguiente código en “app/config/bootstrap.php”.

App :: import ( 'Vendor' , 'FirePHP' , array ( 'file' => 'FirePHPCore/FirePHP.class.php' )); 
function fb() {
	$debug = Configure::read('debug');
	if ($debug) {
		$ob_setting = ini_get('output_buffering');
		if (!$ob_setting) {
			ob_start();
		}
 
		$instance = FirePHP::getInstance(true);
		$args = func_get_args();
		return call_user_func_array(array($instance, 'fb'), $args);
	} else {
		return true;
	}
}

Ahora crearemos un componente para poderlo utilizar en todos nuestros controladores, app/controllers/components/fire_p_h_p.php y copiamos el siguiente código:

class FirePHPComponent {
	private $instance;
 
	public function __construct() {
		$ob_setting = ini_get('output_buffering');
		if (!$ob_setting) {
			ob_start();
		}
		$this->instance = FirePHP::getInstance(true);
		$this->instance->setEnabled(Configure::read('debug'));
	}
 
	public function __call($name, $args) {
		return call_user_func_array(array($this->instance, $name), $args);
	}
}

Ya estaría instalado, vamos a probarlo, primero deberiamos llamar al componente en el controlador donde queramos usarlo.

var $components = array('FirePHP');

También dejo una pequeña idea de como usarlo en el controlador.

public function index() {
                $users = $this->Users->AllUsers();
		$this->FirePHP->error($users,'array users');
	}

Estamos simulado que recogemos todos los usuarios de la base de datos en una variable $users, la salida será un array, como habíamos comentado, la idea era no tener que poner var_dump o echos. Ahora en pantalla no nos saldrá nada, pero si vamos a la consola de firebug, vermos ahí nuestra array reflejada con el nombre de error array users.

Decidokit beta lanzado!

 

cakePhp, Novedades

Buenas este es un anunció que me agrada dar.
Un proyecto interno de bonzzay la empresa que tengo con otros 3 socios, ha sido lanzado.
Se llama decidokit, la idea es simple, que el mundo decido por ti.

Sí quereis hechar un vistazo, y ayudarnos a mejorarlo.  Si no sabes aún que teléfono comprarte quizás la gente pueda ayudarte a decidirte. decidokit.com