Forums / Developer / Interesting (I think) design issue regarding caches

Interesting (I think) design issue regarding caches

Author Message

Massimiliano Bariola

Thursday 05 January 2006 1:42:10 am

Well, here we are. new project, new issues!

The client is migrating a huge amount of data from their old cms to ezpublish; one of the things they liked less was the need to manually publish the same content in different locations.

So I said "great! let's use multiple node locations!" but the answer was ... "no, still too manual. we want something like I put keywords in my content and all the folders in the site which are associated with those keywords will show a link to the content".

of course, developer-wise, this translates to creating a custom folder class with a keyword list attribute so that its template will fetch the objects which contain those keywords.

So far, looks good. now, enter cache.

Every time a new content object is entered / modified / published, I need a way to clear cache of all the "enhanced folder"' nodes who contain the any of the keywords related to the newly published object.

Egads! so far, it seems to me that it is not possible, but I might be wrong. I suspect the answer is in the SmartCacheClear settings tweaking and in that switch which says "cache as soon as an object is published", but I'd like to know if anyone ever tried anything like this. eZ Crew ?

Another possible solution would be to use cache blocks with keys depending on the node list which should be displayed by the folder, but this kinda voids the caching .....

Finally (yes I know) the best solution would be a post-publish custom workflow which generates additional node locations based on both all special folders' associated keywords and the published object's keywords. but will this solve my caching conundrum?

Thanks y'all for your input

Max

Xavier Dutoit

Thursday 05 January 2006 2:56:05 am

Hi,

I've done something similar with the enhanced object relation.

http://ez.no/community/contribs/datatypes/enhanced_objectrelation

here the idea is to fetch the reverse related object as "children".

On the smart cache, I set up to clear the content object and the related objects and it works fine.

This being said, you can set the locations while editing the content and create your custom template to set the locations.

The trick is to add:

<input type="hidden" name="useNodeAssigments" value='1' />

Then you can set placements. The doc is kind of laking last time I checked, so have a look at the forums and source code.

There are the variables I use:

<input type="hidden" name="MainAssignmentElementNumber" value="1" /> 
<input type="hidden" name="SortOrderMap" value="" />
<input type="hidden" name="SortFieldMap" value="" />
<select name="SetPlacementNodeIDArray[1]" ...

Good luck and keep us informed

X+

http://www.sydesy.com

eZ debug

Timing: Jan 18 2025 16:25:06
Script start
Timing: Jan 18 2025 16:25:06
Module start 'content'
Timing: Jan 18 2025 16:25:07
Module end 'content'
Timing: Jan 18 2025 16:25:07
Script end

Main resources:

Total runtime0.8516 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.0058 587.8594180.8125
Module start 'content' 0.00580.7185 768.6719539.9609
Module end 'content' 0.72430.1273 1,308.6328332.7422
Script end 0.8516  1,641.3750 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00410.4855210.0002
Check MTime0.00150.1790210.0001
Mysql Total
Database connection0.00070.080710.0007
Mysqli_queries0.785292.19661910.0041
Looping result0.00200.23211890.0000
Template Total0.824596.820.4122
Template load0.00210.241920.0010
Template processing0.822496.570820.4112
Template load and register function0.00010.010610.0001
states
state_id_array0.00100.113410.0010
state_identifier_array0.00100.114420.0005
Override
Cache load0.00170.1987300.0001
Sytem overhead
Fetch class attribute can translate value0.00120.136030.0004
Fetch class attribute name0.00120.136940.0003
XML
Image XML parsing0.00110.128030.0004
class_abstraction
Instantiating content class attribute0.00000.000740.0000
General
dbfile0.00310.3584340.0001
String conversion0.00000.000630.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/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
2content/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: 12
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs