Monday 18 October 2010 1:38:30 am - 5 replies

» Read full tutorial

Introduction

At the end of this tutorial you should be comfortable with exporting multiple users from PHP scripts into a external file using a cronjob. You should also be comfortable with filtering fetch statements in PHP.

Author Message

Jérôme Renard

Thursday 21 October 2010 7:54:13 am

Please do not use mail() but eZMailTransport::send instead, for an example, have a look here:

- http://github.com/ezsystems/ezpublish/blob/master/kernel/user/register.php#L315

'Hope that helps :)

Marco Rogers

Tuesday 02 November 2010 1:43:40 pm

Maybe you can help me with a related issue. Recently had the task of pulling all users who have a particular role. There is a fetch user by role function. But it turns out that this only returns the users and groups that have the role explicitly assigned to them. It does not pick up users that inherit the role. And I can't use the subtree fetch you're talking about here because the attribute filter doesn't support querying user roles.

I ended up doing the next easiest thing which is to detect a user group with the role and do another fetch to get users under that group.

Here's a modified version of my code:

$judgeRole = eZRole::fetch( $roleId );
$judgeGroups = array();
$judges = $judgeRole->fetchUserByRole();

foreach($judges as $judge) {
    $classID = $judge['user_object']->ClassIdentifier;
    $content_object = $judge['user_object'];
      if($classID == 'user_group') {
        if( $content_object->Name == 'Awards Judges') {
              $children = eZFunctionHandler::execute('content', 'list',  array('parent_node_id' => $content_object->mainNodeID()
                                                                               , 'class_filter_type' => 'include'
                                                                               , 'class_filter_array' => array( 'user' )
                                                                               , 'depth' => 2));
              foreach($children as $child) {
                  $data_map = $child->dataMap();
                  $judge = $data_map['user_account']->content();
                  array_push($judges, $judge);
              }
          } else {
              $judgeGroups[$content_object->attribute('id') . ''] = $content_object->Name;
          }
      } else {
        array_push($judges, eZUser::fetch($content_object->attribute('id')));
      }
  }

Bruce Morrison

Tuesday 23 November 2010 11:27:36 pm

For those playing at home eZRole::fetchUsersByRole doesn't actually do what the name implies. It will return an array of hashes that contains the eZContentObjects that have been assigned to the role. It's up to you to check the type of Object and retrieve users (for any groups returned)

See http://pubsvn.ez.no/doxygen/trunk/html/ezrole_8php_source.html#l00791

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

Sergey Gedeon

Wednesday 16 February 2011 1:13:45 am

Sometimes we need to disable limitations (e.g. when running the cronscript)

so code should be like this

$params = array( 'Depth' => $depth,
                 'ClassFilterType' => 'include',
                 'ClassFilterArray' => $includeClasses,
                 'Limitation' => array() );

---------------------------------------
To Live Is To Die...
To Die Is To Wake...

Nicolas Pastorino

Wednesday 16 February 2011 1:52:44 am

"

Sometimes we need to disable limitations (e.g. when running the cronscript)

so code should be like this

$params = array( 'Depth' => $depth,
                 'ClassFilterType' => 'include',
                 'ClassFilterArray' => $includeClasses,
                 'Limitation' => array() );
"

Thanks Sergey, good tip !

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

You must be logged in to post messages in this topic!

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 17 2025 20:55:52
Script start
Timing: Jan 17 2025 20:55:52
Module start 'layout'
Timing: Jan 17 2025 20:55:52
Module start 'content'
Timing: Jan 17 2025 20:55:52
Module end 'content'
Timing: Jan 17 2025 20:55:52
Script end

Main resources:

Total runtime0.0212 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0065 597.4844152.1406
Module start 'layout' 0.00650.0030 749.625039.5078
Module start 'content' 0.00940.0099 789.1328103.7344
Module end 'content' 0.01930.0018 892.867238.3672
Script end 0.0211  931.2344 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002511.9362140.0002
Check MTime0.00125.4695140.0001
Mysql Total
Database connection0.00083.644110.0008
Mysqli_queries0.004219.772430.0014
Looping result0.00000.061910.0000
Template Total0.00146.710.0014
Template load0.00073.422410.0007
Template processing0.00073.295210.0007
Override
Cache load0.00052.392610.0005
General
dbfile0.005124.306780.0006
String conversion0.00000.032640.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_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