Forums / Extensions / eZ Find / Problem with not main nodes in SearchSubTreeArray

Problem with not main nodes in SearchSubTreeArray

Author Message

Serhey Dolgushev

Friday 29 October 2010 4:49:44 am

Hi everyone!

Today i discoverd a troubles with searching non main nodes. I`ll try to explaine the problem:

We have object O1 (name: "test"), with multiple locations:

  • N1 (main, node_id:101, path:1/2/60/101)
  • N2 (node_id:102, path: 1/2/62/102)
  • N3 (node_id:103, path: 1/2/63/103)

I`m doing the next:

$solrSearch   = new eZSolr();
$searchResult = $solrSearch->search(
    'test',
    array(
        'SearchSubTreeArray' => array( 62 ),
        'SpellCheck' => array( true ),
        'SearchType' => array( 'fulltext' ),
        'SearchLimit' => 10,
        'SearchOffset' => 0
    )
)

$searchResult['SearchResult'] should contain the eZFindResultNode object with node_id = 102. But it contains eZFindResultNode object with node_id = 101. Its because $searchResult['SearchResult'] allways contains just main nodes.

In my case i didn`t used score_percent and highlight attributes, so i fixed it the next way:

foreach( $searchResult['SearchResult'] as $key => $node ) {
    if( in_array( $parentNodeID, $node->attribute( 'path_array' ) ) === false ) {
        $locations = $node->attribute( 'object' )->attribute( 'assigned_nodes' );
        foreach( $locations as $locationNode ) {
            if( in_array( $parentNodeID, $locationNode->attribute( 'path_array' ) ) === true ) {
                $nodeRow  = eZContentObjectTreeNode::fetch( $locationNode->attribute( 'node_id' ), false, false );
                $findNode = new eZFindResultNode( $nodeRow );
                $findNode->setContentObject( new eZContentObject( $nodeRow ) );
                $findNode->setAttribute( 'name', $locationNode->attribute( 'name' ) );
                $findNode->setAttribute( 'published', $locationNode->attribute( 'published' ) );
                $findNode->setAttribute( 'global_url_alias', $locationNode->attribute( 'url_alias' ) );
                $findNode->setAttribute( 'language_code', $locationNode->attribute( 'object' )->attribute( 'current_language' ) );
                $findNode->setAttribute( 'is_local_installation', true );
                
                $searchResult['SearchResult'][ $key ] = $findNode;
                break;
            }
        }
    }
}

But i think it will be great if this bug will be fixed in eZ Find, and $searchResult['SearchResult'] will contain no only main nodes :)

Nicolas Pastorino

Friday 29 October 2010 7:02:29 am

Hi Serhey,

Which version of eZ Find are you using ?

Cheers,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Serhey Dolgushev

Saturday 30 October 2010 3:58:17 am

Its 2.2-0

Paul Borgermans

Sunday 31 October 2010 1:23:33 pm

Hi Serhey

Can you file a bug report/enhancement request referrring to this thread? Your use case is not the only one, so some flexibility on this should be introduced ... sometimes, the main node is what one really wants.

Regards

Paul

eZ Publish, eZ Find, Solr expert consulting and training
http://twitter.com/paulborgermans

Serhey Dolgushev

Thursday 04 November 2010 3:58:01 pm

Hi Paul. I did it: http://issues.ez.no/IssueView.php?Id=17576&activeItem=3

Paul Borgermans

Saturday 06 November 2010 3:08:21 am

Thanks Serhey!

eZ Publish, eZ Find, Solr expert consulting and training
http://twitter.com/paulborgermans

eZ debug

Timing: May 15 2025 18:19:03
Script start
Timing: May 15 2025 18:19:03
Module start 'content'
Timing: May 15 2025 18:19:03
Module end 'content'
Timing: May 15 2025 18:19:03
Script end

Main resources:

Total runtime0.2018 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0122 589.1406179.9297
Module start 'content' 0.01230.0092 769.0703103.9922
Module end 'content' 0.02140.1803 873.0625560.0156
Script end 0.2017  1,433.0781 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00783.8615260.0003
Check MTime0.00351.7263260.0001
Mysql Total
Database connection0.00130.654110.0013
Mysqli_queries0.124261.56071410.0009
Looping result0.00160.77511390.0000
Template Total0.179789.110.1797
Template load0.00150.746410.0015
Template processing0.178288.302310.1782
Override
Cache load0.00110.548210.0011
Sytem overhead
Fetch class attribute can translate value0.00130.627010.0013
XML
Image XML parsing0.00030.143210.0003
General
dbfile0.01125.5327210.0005
String conversion0.00000.008340.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
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0002 secs