Bug in eZFind 2.3, objects + mainNode, ezsolr line 357

Author Message

Christian Rößler

Thursday 07 October 2010 2:40:17 am

Currently I am facing multiple issues regarding the new eZFind 2.3 and indexing/updating objects that are not within the table 'ezcontentobject_tree' thus have no node-object in its attribute 'main_node'.

When having such objects in your database and using eZFind 2.3 (official stable release) the cronjob fails with:

Fatal error: Call to a member function attribute() on a non-object in 
...../extension/ezfind/search/plugins/ezsolr/ezsolr.php on line 357

After poking in the code, I found the glitch that has been introduced in 2.3. 2.2 does not have this issue:

355: // Get global object values
356: $mainNode = $contentObject->attribute( 'main_node' );
357: $mainNodePathArray = $mainNode->attribute( 'path_array' );

Line 357 failes, because the return value $mainNode from line 356 is not checked before calling methods on this object (or in my case it's not an object, it is null).

I have this patch to provide a workaround and continue state to index other objects that are 'valid' and have a main-node ...

# This patch file was generated by NetBeans IDE
# It uses platform neutral UTF-8 encoding and \n newlines.
--- Base (BASE)
+++ Locally Modified (Based On LOCAL)
@@ -354,7 +354,7 @@
         }
         // Get global object values
         $mainNode = $contentObject->attribute( 'main_node' );
-        $mainNodePathArray = $mainNode->attribute( 'path_array' );
+        
         // initialize array of parent node path ids, needed for multivalued path field and subtree filters
         $nodePathArray = array();
         if ( !$mainNode )
@@ -362,6 +362,9 @@
             eZDebug::writeError( 'Unable to fetch main node for object: ' . $contentObject->attribute( 'id' ), 'eZSolr::addObject()' );
             return false;
         }
+        // get main-node contentobject-tree-node
+        $mainNodePathArray = $mainNode->attribute( 'path_array' );
+        
         //included in $nodePathArray
         //$pathArray = $mainNode->attribute( 'path_array' );
         $currentVersion = $contentObject->currentVersion();

But I am also curious. What is the reason, that i got contentobjects floating around without any node/tree attachment? What may be the possible initial cause for those ghost-objects?

Thanks,

chris

PS: eZPublish 4.2, imported content using the data_import extension, ezFind 2.2 manually updated to 2.3 due to 'date null import errors' in eZFind 2.2.

Hannover, Germany
eZ-Certified http://auth.ez.no/certification/verify/395613

Carlos Revillo

Thursday 07 October 2010 7:07:35 am

Hi. Probably is not the case, but one possible way to have these objects without nodes is the use of objectrelationbrowse extension. (don't know if the same goes for objectrelation list).

so, suppose you have an article class with a objectrelationbrowse attribute. if you want, you can add the option of adding new objects while you are filling all other attributes from the article. And you can also say that this objects will not be placed under any of the nodes of the content tree...

Don't know if this is the case, but yes, it's posible we can reach in something similar.

But, at the end, ezfind will return eZFindSearchResultsNodes, with their path and all of the usual ezcontentobjecttreenode objects. don't know if having those 'orphan' objects indexed can also leads in error while buidling the list of result nodes...

Christian Rößler

Thursday 07 October 2010 8:16:23 am

Thanks for your input Carlos,

well... we do not use the mentioned extension - but nice to know, thanks :-) May be useful sometime.

The site is a relatively new one, based on ezp 4.2.0, filled with approx 150.000 content-nodes and about 5000 users, all in about 15 languages. All the content-nodes have been imported in a 'import' folder. The customer now moves the imported articles from import-folder to the location he/she wants them to be.

In the process of moving, translating and adding related-objects to those articles, somehow the 'ghost-objects' appear. I just stumbled over them because the ezfindexcontent-cronjob was hardly quitting at one of such object which was in the 'pending_tasks' table about to be indexed using 'delayed indexing'.

 don't know if having those 'orphan' objects indexed can also leads in error while buidling the list of result nodes...

In eZFind 2.2 such ghost objects would never make it into ezfind. In eZF 2.3 the indexer crashes. So either way a search would never return such objects. So its no problem on this side. Returned nodes are all good.

Thanks again for your thoughts.

Chris

Hannover, Germany
eZ-Certified http://auth.ez.no/certification/verify/395613

Georg Franz

Wednesday 13 October 2010 3:58:35 am

Hi Chris,

as far as I know there are only two reasons why there is no mainnode:
a) the object isn't published (first version, first draft)
b) the object is deleted

But maybe your database is corrupted (failed transactions or something like that). You can check this with my "zombie check script":
http://issues.ez.no/IssueView.php?Id=16052&activeItem=2

Best wishes,

Georg.

Best wishes,
Georg.

--
http://www.schicksal.com Horoskop website which uses eZ Publish since 2004

Luca Realdi

Monday 21 March 2011 7:54:39 am

A trashed item loses the main_node_id. The cronjob ezfindexcontent verifies the content object, not if his node exsists.

In solr.php (ezFind 2.3.0) the main_node check - if ( !$mainNode ) - should be moved to the line 355 otherwise the $mainNodePathArray = $mainNode->attribute( 'path_array' ) generates error.

from

354 $mainNode = $contentObject->attribute( 'main_node' );
355 $mainNodePathArray = $mainNode->attribute( 'path_array' );
356 // initialize array of parent node path ids, needed for multivalued path field and subtree filters
357 $nodePathArray = array();
358 if ( !$mainNode )
359 {
360     eZDebug::writeError( 'Unable to fetch main node for object: ' . $contentObject->attribute( 'id' ), 'eZSolr::addObject()' );
361     return false;
362 }

to

354 $mainNode = $contentObject->attribute( 'main_node' );
355 if ( !$mainNode )
356 {
357     eZDebug::writeError( 'Unable to fetch main node for object: ' . $contentObject->attribute( 'id' ), 'eZSolr::addObject()' );
358     return false;
359 }
360 $mainNodePathArray = $mainNode->attribute( 'path_array' );
361 // initialize array of parent node path ids, needed for multivalued path field and subtree filters
362 $nodePathArray = array();

Bertrand Dunogier

Monday 21 March 2011 8:32:36 am

This is already fixed in ezfind/master:

https://github.com/ezsystems/ezfind/blob/master/search/plugins/ezsolr/ezsolr.php#L371

This will be part of the upcoming eZ Find 2.4 release: https://github.com/ezsystems/ezfind/commit/78edf846c84608fc80d784539cba18264216c05e.

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 02:08:53
Script start
Timing: Jan 18 2025 02:08:53
Module start 'layout'
Timing: Jan 18 2025 02:08:53
Module start 'content'
Timing: Jan 18 2025 02:08:54
Module end 'content'
Timing: Jan 18 2025 02:08:54
Script end

Main resources:

Total runtime0.5260 sec
Peak memory usage4,096.0000 KB
Database Queries75

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0076 589.2578153.4844
Module start 'layout' 0.00760.0035 742.742239.4609
Module start 'content' 0.01120.5134 782.2031717.0000
Module end 'content' 0.52460.0013 1,499.203120.1016
Script end 0.5259  1,519.3047 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00340.6546160.0002
Check MTime0.00140.2694160.0001
Mysql Total
Database connection0.00080.148510.0008
Mysqli_queries0.452285.9759750.0060
Looping result0.00070.1378730.0000
Template Total0.486592.520.2432
Template load0.00260.500220.0013
Template processing0.483891.989420.2419
Template load and register function0.00010.020910.0001
states
state_id_array0.00080.151410.0008
state_identifier_array0.00080.146220.0004
Override
Cache load0.00220.4219540.0000
Sytem overhead
Fetch class attribute can translate value0.00050.096050.0001
Fetch class attribute name0.00130.241690.0001
XML
Image XML parsing0.00160.313350.0003
class_abstraction
Instantiating content class attribute0.00000.002790.0000
General
dbfile0.00420.8069280.0002
String conversion0.00000.001540.0000
Note: percentages do not add up to 100% because some accumulators overlap

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
6content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
15content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
6content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
2content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 36
 Number of unique templates used: 8

Time used to render debug report: 0.0001 secs