Usando Twitter desde CakePHP

Hace unos días empecé a construir un “componente” para conectar CakePHP con el API de Twitter. Tengo lista una primera versión (alpha) con algunas de las funcionalidades implementadas. Todavia quedan cosas por mejorar, como el manejo automático de errores, pero más de vale Release Early, Release Often[1], que echar a dormir el código.
Pueden descargarlo desde aqui: cakephp_twitter-v0.1alpha.zip (4Kb)
Documentación (:P)
La forma de uso es la siguiente. Si lo queremos usar desde un controlador:
var $uses = array("Twitter");
Y en la acción correspondiente:
$this->Twitter->metodo([parámetros], [autenticación]);
Si quisieran usarlo desde un modelo, lo mejor sería hacer:
App::import('model','Twitter');
$twitter = new Twitter();
$twitter->metodo([parámetros], [autenticación]);
No todos los métodos que el API soporta están implementados, en Twitter::$_methods pueden ver los que se implementaron, sus parametros y los valores por defecto. Los parámetros están definidos con los mismos nombre que en el API de Twitter
El parámetro parámetros, es un array con los parametros necesarios para la invocación.
El parámetro autenticación solo es necesario en los casos en que el método lo requiera. En la definición de cada método hay un atributo authentication que indica si es requerida. Este parametro es un array(‘user’ => $user, ‘pass’ => $password), pero para mayor facilidad pueden construirlo usando cualquiera de los siguientes dos métodos:

  1. Twitter::createAuthentication($user, $password)
  2. Twitter::setAuthentication($user, $password)

Ejemplos:
// Get the public timeline
$response = $this->Twitter->getPublicTimeline();

// Update an user status
$this->Twitter->setAuthentication($user, $pass);
$response = $this->Twitter->updateStatus(
array("status"=>"My new Status")
);

// Create a friend
$response = $this->Twitter->createFriend(
array(
"id"=>"newfriend"
),
$this->Twitter->createAuthentication(
$user,
$pass
)
);

Actualización: Está probado con la versión más reciente de CakePHP (1.2.0.6589) y en PHP 5, probablemente en PHP 4 no funciona porque usa json_decode (no incluido)
Related Posts