Monday 06 June 2011 2:00:15 pm
By : Brandon Chambers
This is a short tutorial about using the powerful combination of AJAX (jQuery) and eZ Publish. Please note this was also originally released before the REST API was developed for the current community release of eZ Publish.
Original post: http://blog.divdesigns.com/2011/02/ajax-jquery-ez-publish-demystified/
eZ Publish is by nature, easy to understand in the administration panel, adding and editing content. However, once you look under the hood it's like a complex maze of code, intricately designed, but still a maze. While the template code, based on Smarty I believe, is well documented there's no single source to figure out how things work in PHP land. You just find out for yourself by looking through other extensions as well as the kernel code, ask other people or by just plain "elbow grease." Well here's some findings I came across fumbling around on a project as well as spare time.
Tutorial Skill requirements:
If you need to head over to eZ Systems' site for more information on installing and configuring an extension
I came across two main ways to implement AJAX (jQuery) with eZPublish.
AJAX + Custom Module:
So obviously you need a module and a view (and thus an extension). By looking at the JavaScript you'll see the module and view names I used. You can use whatever you want.
The JavaScript:
var data_sent = { message: "testing!"};$.ajax({ url: "/mymodule/post", type: 'POST', data: ( data_sent), dataType: 'json', success: function( data ){ if( data.response == "ok" ) { alert( data.message ); } }});
The Module code:
In post.php I usually have something along the lines of this initial setup:
if ( $http->hasPostVariable( 'message'' ) && $http->postVariable( 'message' ) ){ $response = array( 'response' => 'ok'); print( json_encode( $response ) ); eZExecution::cleanExit();}
That's IT!
AJAX + eZJSCore + Custom Class:
This approach requires you have eZJSCore installed and working.
One of the first things you'll notice with this approach by looking at the code is there's a little more of it, but it looks cleaner in the JavaScript code.
To get eZJSCore setup add your custom class to ezjscore.ini (preferably in your extension's settings directory):
[ezjscServer]FunctionList[]=ajaxFunc[ezjscServer_myajax]Class=MyAJAXFile=extension/myextension/classes/myajax.phpFunctions[]=ajaxFunc
The JavaScript:
//You can keep going with the argsvar dataSent = {arg1: "123", arg2: "456"};$.ez( 'myajax::ajaxfunc', dataSent, function( ezp_data ){ if ( ezp_data.error_text ) { alert( ezp_data.error_text ); } else { alert( ezp_data.content ); }}
Custom PHP Class setup:
class MyAJAX extends ezjscServerFunctions{ public static function ajaxFunc( $args ) { if ( isset( $args[0] ) && isset( $args[1] ) && isset( $args[2] ) && isset( $args[3] ) ) { $var1 = htmlspecialchars( $args[0] ); $var2 = htmlspecialchars( $args[1] ); $var3 = htmlspecialchars( $args[2] ); $var4 = htmlspecialchars( $args[3] ); } else if ( $http->hasPostVariable( 'arg1' ) && $http->hasPostVariable( 'arg2' ) && $http->hasPostVariable( 'arg3' ) && $http->hasPostVariable( 'arg4' ) ) { $var1 = htmlspecialchars( $http->postVariable( 'arg1') ); $var2 = htmlspecialchars( $http->postVariable( 'arg2') ); $var3 = htmlspecialchars( $http->postVariable( 'arg3') ); $var4 = htmlspecialchars( $http->postVariable( 'arg4') ); } else { return $error['args']; } return "ok"; }}
Use for debugging via HTTP:
http://dev.server.com/ezjscore/call/myajax::ajaxfunc::val1::val2::val3::val4
eZ Find definitely has its advantages and it would be a good idea to use eZ Find for large data sets.
Until then, get used to using the template code outlined in Ivo Lukac's guide to using eZ Find. There you can also find the advantages and disadvantages of eZ Find.
Timing: | Jan 17 2025 23:45:28 |
Script start | |
Timing: | Jan 17 2025 23:45:28 |
Module start 'layout' | |
Timing: | Jan 17 2025 23:45:28 |
Module start 'content' | |
Timing: | Jan 17 2025 23:45:28 |
Module end 'content' | |
Timing: | Jan 17 2025 23:45:28 |
Script end |
Total runtime | 0.0881 sec |
Peak memory usage | 6,144.0000 KB |
Database Queries | 43 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0050 | 595.0000 | 152.6406 |
Module start 'layout' | 0.0050 | 0.0024 | 747.6406 | 39.4844 |
Module start 'content' | 0.0074 | 0.0795 | 787.1250 | 394.4453 |
Module end 'content' | 0.0869 | 0.0012 | 1,181.5703 | 19.7031 |
Script end | 0.0881 | 1,201.2734 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0028 | 3.1556 | 15 | 0.0002 |
Check MTime | 0.0011 | 1.3009 | 15 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0007 | 0.8082 | 1 | 0.0007 |
Mysqli_queries | 0.0255 | 28.9780 | 43 | 0.0006 |
Looping result | 0.0003 | 0.3520 | 41 | 0.0000 |
Template Total | 0.0637 | 72.3 | 2 | 0.0319 |
Template load | 0.0022 | 2.4616 | 2 | 0.0011 |
Template processing | 0.0615 | 69.8483 | 2 | 0.0308 |
Template load and register function | 0.0001 | 0.1134 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0008 | 0.9432 | 1 | 0.0008 |
state_identifier_array | 0.0007 | 0.8396 | 2 | 0.0004 |
Override | ||||
Cache load | 0.0020 | 2.2200 | 60 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0020 | 2.2517 | 3 | 0.0007 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0087 | 3 | 0.0000 |
General | ||||
dbfile | 0.0007 | 0.7568 | 10 | 0.0001 |
String conversion | 0.0000 | 0.0068 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | blog_entry/full.tpl | extension/community_design/design/suncana/override/templates/blog_entry/full.tpl | ||
2 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
14 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
3 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
3 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
3 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
4 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
5 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
5 | content/datatype/view/ezxmltags/literal.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tpl | ||
1 | content/datatype/view/ezkeyword.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezkeyword.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 42 Number of unique templates used: 11 |
Time used to render debug report: 0.0001 secs