Forums / Extensions / Extension to ezpublish subtree fetching methods.

Extension to ezpublish subtree fetching methods.

Author Message

Sergiy Pushchin

Friday 26 December 2008 5:26:23 am

Hello all, looking back to the old nice day I recall that we tried to have node storage that allows us to fetch subtree in correct order for unlimited depth. (f. ex. full sitemap or threaded forum.) But we were not able to achieve this. the problem is that when we try to fetch whole subtree and we order by a path_sting we may get incorrect results.
F.ex. we have subtree:

/1/2/10/
/1/2/10/12/
/1/2/20/
/1/2/20/35/
/1/2/100/
/1/2/100/130/

When we sort by a path_string mysql will return it in next order:

/1/2/10/      
/1/2/10/12/
/1/2/100/
/1/2/100/130/
/1/2/20/
/1/2/20/35/

And such order is not correct. But sorting would have been correct if the path_string looked like /1/2/000010/ /1/2/000100/ and so on. Although we still have limitation depth of elements since path_string is var_char(255).
Next thing how to implement this without touching kernel? :)
My idea works for mysql > 5.0 with triggers and user defined functions. I have added column called fixed_path varchar(255) to ezcontentobject_tree table and created a triiger that stores there modified path_string. it cuts out the first two elements form path_string and pads next path elements with 0 to 6 digists (so we have limitation 999999 nodes).
Then to enable custom sorting in subtree fetching I created empty extendedattributefilter, and my fetch to fetch full forum thread looks like:

{def  $reply_list=fetch('content','list', hash( parent_node_id, $node.node_id,
                                              limit, $reply_limit,
                                              offset, $reply_offset,
                                              'depth',0,
                                              'extended_attribute_filter',
                                               hash( 'id', 'CorrectSubtree',
                                                     'params', hash(  ) ),
                                              sort_by, array( array( 'fixed_path', true() ) ) ) )}

My question is, can such thing be interesting for others or not?
If so I will wrap all sql and extendedattributefilter code to extension and put it as contribution.

Heath

Friday 26 December 2008 12:15:59 pm

Hello Sergiy Pushchin!

I'm certain several people would like to test your solution.

Why not use a project as a place for users to gather? http://projects.ez.no/

Cheers,
Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

eZ debug

Timing: Jan 18 2025 05:05:53
Script start
Timing: Jan 18 2025 05:05:53
Module start 'content'
Timing: Jan 18 2025 05:05:54
Module end 'content'
Timing: Jan 18 2025 05:05:54
Script end

Main resources:

Total runtime0.7795 sec
Peak memory usage4,096.0000 KB
Database Queries191

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0081 587.8516180.8125
Module start 'content' 0.00810.6669 768.6641545.1875
Module end 'content' 0.67500.1045 1,313.8516332.7422
Script end 0.7794  1,646.5938 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00410.5238210.0002
Check MTime0.00150.1961210.0001
Mysql Total
Database connection0.00100.132910.0010
Mysqli_queries0.710091.08981910.0037
Looping result0.00170.21411890.0000
Template Total0.746295.720.3731
Template load0.00240.309420.0012
Template processing0.743895.419920.3719
Template load and register function0.00010.016110.0001
states
state_id_array0.00090.120010.0009
state_identifier_array0.00080.106120.0004
Override
Cache load0.00190.2486230.0001
Sytem overhead
Fetch class attribute can translate value0.00120.155130.0004
Fetch class attribute name0.00110.135940.0003
XML
Image XML parsing0.00120.153330.0004
class_abstraction
Instantiating content class attribute0.00000.001040.0000
General
dbfile0.00260.3397340.0001
String conversion0.00000.000830.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
2content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
4content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
6content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 19
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs