deleteing a node tree via PHP

Author Message

Jim Reverend

Thursday 05 February 2004 5:06:48 am

I have the following code:
function deleteallkids($nodeid) {
$folderobject = ezcontentobjecttreenode::fetch($nodeid);
$children = $folderobject->subTree();
foreach(array_keys($children) as $key) {
$children[$key]->remove();
}
print "\n";

}
-----

This SEEMS to work, kind of. It seems to have deleted all the nodes in the tree. When I run the script again, it finds nothing to delete. However, in the admin interface, the items are still there.

What am I doing wrong?

Is there any basic documentation for handling Objects, Nodes, and DataTypes in PHP? I've generated the Doxygen docs... but they don't help much at all.

Wenyue Yu

Thursday 05 February 2004 5:39:39 am

Hi,

Doing $node->remove() will only remove the content object from ezcontentobject_tree table. To completely remove this object, you need to do the following:
$objectID = $node->attribute( 'contentobject_id' );
$node->remove();
$object =& eZContentObject::fetch( $objectID );
$object->purge();

Regards,
wenyue

Jim Reverend

Thursday 05 February 2004 5:49:41 am

Thank you kindly for your quick response.

I tried what you said in the past, and I tried it again now, to no avail.

It seems that $node->subTree() isn't returning any items when there clearly ARE items in that node.

In one "folder" I have nothing but "folder"s. And they all seem to remove just fine. However, in another folder, I have objects belonging to a custom class... those items are not being returned by SubTree nor are they being removed. I built the custom class using the Admin interface. Could this be the problem?

Jim Reverend

Thursday 05 February 2004 5:52:46 am

To make things more interesting, I just added a "folder" to the node that it full of objects of a custom class. When I ran the script, the folder was deleted, yet the other items remained.

Jim Reverend

Thursday 05 February 2004 5:57:45 am

A few more tests.

I added a whole bunch of objects to the folder and then tried to delete them. And only one item type will not delete.

One of the items was "comment". I edited it via the admin interface, and it deleted just fine. The item that wont delete is "blog". I made it from a copy of "article" that I edited to suit my needs (got rid of Intro and Thumbnail and renamed Body). I hope this helps you figure out what is going on here.

Wenyue Yu

Thursday 05 February 2004 7:51:57 am

Hi,

I think the problem is of permission. When you run this script, you are treated as anoymous user, so you need to give content read * permission to anoymous user.

Regards,
wenyue

Jim Reverend

Thursday 05 February 2004 10:53:00 am

I gave read * to Anonymous user. This didn't seem to help. However, I believe that I must not be running the script as Anonymous. If I were, I don't think I would be capable of deleting ANYTHING at all. At least... that doesn't seem right.

I installed PLAIN system. That's what I've been editing to create the system I have now. And I've only made the changes I laid out to you earlier. I am convinced that it has something to do with the creation of new classes of content and the ability for those items to appear in the default data listed by subTree().

Is there anything more you can think of?

Wenyue Yu

Friday 06 February 2004 2:41:19 am

Hi,

Could you added print( "Here is my sql query-" . $query ); in function subTree() of class eZContentObjectTreeNode around line 1090 before "if ( !$offset && !$limit )"?

What sql query do you get when you run your script?

Regards,
wenyue

Jim Reverend

Friday 06 February 2004 4:19:45 am

Yesterday evening I figured it out. Or rather, you figured it out. It was a permissions issue, like you said. I wasn't pushing the right button to make the permissions changes active. It looked like they were... but they weren't. AS soon as I made them active, the script started working just fine.

Of course, this brings a whole host of new worries... like... if the script runs as an anonymous user... why is that anonymous user capable of deleting anything?? They didn't have any kind of edit permissions. Just "read" and "login".

I'd still really like to see some sample code for working with the different Objects in EZ (Node, Object, Attribute, Version, DataType, etc).

Thank you again, for all of your help. It really is appreciated.

Wenyue Yu

Friday 06 February 2004 6:03:09 am

Hi,

Actually, if you can run a script in your system, you can do everything. The permission issues in your script is only because you used function subTree() which will check current user ( this function is used in admin interface ) . Since you are not logged in, you are anonymous user. The actual deleting function you called will not check permissions and that is why you can delete anything. Permission will be checked in admin/user interface, so don't worry about that. There is no security hole.

Best regards,
wenyue

Jim Reverend

Friday 06 February 2004 6:44:49 am

Wenyue--

Thank you again for all of your help. I have 2 more questions:

1) Are any of the permissionless methods exported to the templates in any way?

2) Is there another function I can use that does the same thing as subTree() but without the permissions checking? I'd rather not have to make everything that is going to be removed by this script "readable" by anonymous.

3) In case there isn't another option for #2, is there a way that I can make my script "login" as a different user?

Thanks, again!

Wenyue Yu

Friday 06 February 2004 8:11:00 am

Hi,

To escape permision check in subTree function, use following:

$node->subTree( array( 'Limitation' => array() ) );

Regards,
wenyue

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 22:26:57
Script start
Timing: Jan 18 2025 22:26:57
Module start 'layout'
Timing: Jan 18 2025 22:26:57
Module start 'content'
Timing: Jan 18 2025 22:26:58
Module end 'content'
Timing: Jan 18 2025 22:26:58
Script end

Main resources:

Total runtime1.0029 sec
Peak memory usage4,096.0000 KB
Database Queries84

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 589.3438152.6250
Module start 'layout' 0.00570.0030 741.968839.4453
Module start 'content' 0.00870.9927 781.4141576.8984
Module end 'content' 1.00130.0015 1,358.312520.1641
Script end 1.0029  1,378.4766 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00310.3064160.0002
Check MTime0.00120.1207160.0001
Mysql Total
Database connection0.00090.091610.0009
Mysqli_queries0.928792.5984840.0111
Looping result0.00070.0707820.0000
Template Total0.971896.920.4859
Template load0.00180.181120.0009
Template processing0.969996.710920.4850
Template load and register function0.00020.017410.0002
states
state_id_array0.00090.093010.0009
state_identifier_array0.00120.122020.0006
Override
Cache load0.00170.1702750.0000
Sytem overhead
Fetch class attribute can translate value0.00070.071020.0004
Fetch class attribute name0.00150.1478120.0001
XML
Image XML parsing0.00020.024720.0001
class_abstraction
Instantiating content class attribute0.00000.0025120.0000
General
dbfile0.00070.0728100.0001
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
12content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
18content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 39
 Number of unique templates used: 5

Time used to render debug report: 0.0001 secs