Forums / Developer / problems with creating and removing nodeassignments

problems with creating and removing nodeassignments

Author Message

Claudia Kosny

Friday 01 December 2006 4:29:36 am

Hi there

I have a content|publish|before workflow which creates or removes nodeassignments for the currently published object depending on some data in a table.

This works fine if I edit and publish an object from the admin siteaccess.

Now I have a form un my user siteaccess, which posts some node ids to a script in an extension. This script puts the verified posted data in a table and published the object which calls my workflow again. Creating new node assignments works fine, the problem is when I want to remove an nodeassignment from the object and then later on assign the object to the same parentnode again:
Directly after calling remove() on the nodeassignment, the opcode is set to 7, which looks ok to me.

When I check the node assignments after publishing using & eZNodeAssignment::fetchForObject( $objectId, $versionNr) then the removed nodeassignemnt is still listed there, but with opcode 6. When I check using object->assignedNodes(), the removed nodeassignment is not listed.
When I check the object->attribute('parent_nodes'), the removed parentnode is also not listed.

The problem is that when I some time later try to create a nodeassignment to a parentnode where the object had had a nodeassignment sometimes before. The new node assignment is created fine with opcode 3, but in the function publishNode of the ezcontentoperationcollection.php the nodeassignment is fetched by objectid, versionnr and parentnodeid. This causes problems because sometimes it will find the nodeassignment I removed before which has opcode 6, so it does not do anything. Sometimes it also fetches the newly created node assignment, I think this depends on the position in the table, I am not sure.

When I use nodeassignment->purge() instead of ->remove(), the nodeassignment is deleted but the information about the parentnodes is not updated. Thus the additional locations are still listed in the admin view and the parentnodes list the object as subitem, so this does not solve the problem.

I have cleared the cache before and after publishing the object so I don't think it is a caching problem. I also gave all users the administrator role (for testing only), in case it has something to do with permissions, but this did not change anything.

Here the part of the workflow that creates or removes the nodeassignments, which is partially stolen from the ezlocations contribution. $channelNodeIdArr is the array with node ids for the additional locations.

include_once('kernel/classes/eznodeassignment.php');
$db =& eZDB::instance();
$db->begin();
//fetch all parent nodes of the expert
$parentNodesArr = $object->attribute('parent_nodes');
eZDebug::writeDebug('parent nodes before: "' . print_r($parentNodesArr, true) . '"', 'ezlocationstype::execute' );    

$usedParentIdArr = array();
if(is_array($channelNodeIdArr))
{               
  foreach($channelNodeIdArr as $channelNodeId)
  {
    //check if the expert is already assigned to this channel
    if(in_array($channelNodeId, $parentNodesArr))
    {
      $usedParentIdArr[] = $channelNodeId;
      eZDebug::writeError('Expert already assigned to channel with id "' . $channelNodeId . '", nothing to do', 'ezlocationstype::execute' );    
      continue;
    }
    $nodeAssignment[$channelNodeId] =& eZNodeAssignment::create(
         array('contentobject_id' => $objectId,
               'contentobject_version' => $versionNr,
               'parent_node' => $channelNodeId,
               'is_main' => 0));
    $nodeAssignment[$channelNodeId]->store();
    
    eZDebug::writeDebug('Gave expert new node assignment under channel id "' . $channelNodeId . '"', 'ezlocationstype::execute' );    
  }
}
//remove any obsolete node assignments except node assignment in user group experts(node id 65)
$allNodeAssignmentsArr =& eZNodeAssignment::fetchForObject( $objectId, $versionNr);
$obsoleteParentNodeArr = array_diff($parentNodesArr, $usedParentIdArr);
eZDebug::writeDebug('before removing' . print_r($allNodeAssignmentsArr, true), 'ezlocationstype::execute' );    

if(is_array($allNodeAssignmentsArr) && count($allNodeAssignmentsArr)>0)
{
  $tmpKeyArr = array_keys($allNodeAssignmentsArr);
  foreach($tmpKeyArr as $key)
  {
    $nodeAssignment =& $allNodeAssignmentsArr[$key];
    if(in_array($nodeAssignment->attribute('parent_node'), $obsoleteParentNodeArr))
    {
      if($nodeAssignment->attribute('parent_node') != '65')
      {
        $nodeAssignment->remove();
      
        eZDebug::writeDebug('Removed assignment of this expert to channel with node id "' . $nodeAssignment->attribute('parent_node') . '"', 'ezlocationstype::execute' );    
      }
    }          
  }
}
$foo =& eZNodeAssignment::fetchForObject( $objectId, $versionNr);      
eZDebug::writeDebug('after removing ' . print_r($foo, true), 'ezlocationstype::execute' );    

$db->commit();   

I spent the last twelve hours first trying to find out what is going wrong and then how to fix it, so I would be very grateful (and rather desperate) for any hint...

Thanks

Claudia

Claudia Kosny

Friday 01 December 2006 8:57:09 am

I solved the problem by reusing the nodeassignments with an opcode of 6, I just set the opcode to 2 if the parentnode is the same. I just hope it does not bite me in the behind later on...

eZ debug

Timing: Jan 21 2025 20:24:01
Script start
Timing: Jan 21 2025 20:24:01
Module start 'content'
Timing: Jan 21 2025 20:24:01
Module end 'content'
Timing: Jan 21 2025 20:24:01
Script end

Main resources:

Total runtime0.1693 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.0143 588.9766180.8125
Module start 'content' 0.01430.0070 769.789197.9453
Module end 'content' 0.02130.1479 867.7344533.3750
Script end 0.1692  1,401.1094 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00392.2929200.0002
Check MTime0.00140.8505200.0001
Mysql Total
Database connection0.00231.376210.0023
Mysqli_queries0.104561.71531410.0007
Looping result0.00110.66771390.0000
Template Total0.147487.110.1474
Template load0.00120.695810.0012
Template processing0.146286.351510.1462
Override
Cache load0.00090.506110.0009
Sytem overhead
Fetch class attribute can translate value0.00080.486110.0008
XML
Image XML parsing0.00030.159510.0003
General
dbfile0.01227.2087200.0006
String conversion0.00000.005530.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.0001 secs