alle / kohana-jsend
JSend model for Kohana 3.3 (consistent JSON responses)
Installs: 571
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 4
Type:kohana-module
Requires
- php: >=5.3.3
- composer/installers: ~1.0
- kohana/core: >=3.3
This package is not auto-updated.
Last update: 2022-02-01 12:29:37 UTC
README
Author: Kemal Delalic
See: http://labs.omniti.com/labs/jsend
Example multiple scenario action
public function action_create()
{
$json = new JSend;
$post = new Model_Post;
if ($this->request->method() === Request::POST)
{
try
{
$post->values($this->request->post())
->create();
$json->data('post', $post); // success is default anyways
}
catch (ORM_Validation_Exception $e)
{
// Errors are extracted
// from ORM_Validation_Exception objects
$json->status(JSend::FAIL)
->data('errors', $e);
}
catch (Exception $e)
{
// Exception message will be extracted
// and status will be set to JSend::ERROR
// because only error responses support messages
$json->message($e);
}
}
$json->render_into($this->response);
}
Example data retrieval action
public function action_posts()
{
// Success is the default JSend status
JSend::factory(array('posts' => ORM::factory('post')->find_all()))
->render_into($this->response);
}
Example jQuery response handling
$.post('/posts', {from: 1337}, function(jsend) {
if (jsend.status === 'success') {
$.each(jsend.data.posts, function(key, post) {
$('#posts').append('<a href="' + post.url + '">' + post.title + '</a>')
})
}
else if (jsend.status === 'fail') {
$.each(jsend.data.errors, function(field, error) {
$('#form').find('#' + field).append('<span class="error">' + error + '</span>')
})
}
else {
$('#posts').addClass('error').text('Internal error: ' + post.message)
}
});
This can also be overriden on more 'global' level, by overriding or adding jQuery methods.