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...

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 19 2025 11:46:16
Script start
Timing: Jan 19 2025 11:46:16
Module start 'layout'
Timing: Jan 19 2025 11:46:16
Module start 'content'
Timing: Jan 19 2025 11:46:17
Module end 'content'
Timing: Jan 19 2025 11:46:17
Script end

Main resources:

Total runtime0.9946 sec
Peak memory usage4,096.0000 KB
Database Queries52

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0055 589.3047152.6406
Module start 'layout' 0.00550.0031 741.945339.4766
Module start 'content' 0.00860.9848 781.4219444.3047
Module end 'content' 0.99340.0012 1,225.726612.1250
Script end 0.9946  1,237.8516 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00340.3393160.0002
Check MTime0.00130.1288160.0001
Mysql Total
Database connection0.00070.074610.0007
Mysqli_queries0.951195.6260520.0183
Looping result0.00050.0504500.0000
Template Total0.957096.220.4785
Template load0.00210.207920.0010
Template processing0.954996.007320.4775
Template load and register function0.00020.017010.0002
states
state_id_array0.00190.187710.0019
state_identifier_array0.00120.119220.0006
Override
Cache load0.00160.1649200.0001
Sytem overhead
Fetch class attribute can translate value0.00080.076110.0008
Fetch class attribute name0.00160.163920.0008
XML
Image XML parsing0.00010.013310.0001
class_abstraction
Instantiating content class attribute0.00000.001120.0000
General
dbfile0.00250.2506100.0002
String conversion0.00000.000640.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
2content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
5content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
2content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 12
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs