Limiting within ViewList, possible?

Author Message

Clemens T

Monday 03 October 2005 8:36:27 am

Hey all, my module.php file (of my extension) looks like this:

$Module = array( 'name' => 'myModule', 
		'variable_params' => true );

$ViewList = array();
$ViewList['overzicht'] = array(
    'script' => 'overzicht.php',
    'params' => array ( 'filter' ) );

$ViewList['details'] = array(
    'script' => 'details.php',
    'params' => array ( 'rfcid' ));

How can I limit the access PER VIEW for a user (so some users have access to 'details' view and some to 'overzicht' view, and some, to both)? Is this an ezpublish feature, or should I handle it in some other way?

Thanks a lot,
Clemens Timmermans

Kristof Coomans

Monday 03 October 2005 11:55:12 am

You'll have to use the key 'functions' in a <i>$ViewList</i> entry to tell eZ which policy functions you'll need to run a specific view:

$ViewList['overzicht'] = array(
    'script' => 'overzicht.php',
    'params' => array( 'filter' )
    'functions' => array( 'read' )
);

The 'functions' entry must be an array, but after investigation of index.php I think only the first item in the array is taken into account in policy checking. Please correct me if I'm wrong.

Now you need to define another array in module.php, called <i>$FunctionList</i>. This array will contain a list of the policy functions.
A simple policy will look like this:

$FunctionList = array( );
$FunctionList['read']=array( );

Did you notice that the 'read' entry in $FunctionList is also an array? That's because you can also define complex policies with function limitations. Complex policies however are not cheked by index.php. You will need to check them in your view.
An example of a complex policy, which defines a file to include and an object method to be called:

$ClassID = array(
    'name'=> 'Class',
    'values'=> array(),
    'path' => 'classes/',
    'file' => 'ezcontentclass.php',
    'class' => 'eZContentClass',
    'function' => 'fetchList',
    'parameter' => array( 0, false )
    );
$FunctionList['read'] = array( 'Class' => $ClassID );

When you edit a policy, you select <i>myModule</i> and the function <i>read</i>, the file 'kernel/classes/ezcontentclass.php' will be included. A new instance of eZContentClass will be made (always with an empty array as parameter). On this object, the method fetchList will be called with the parameters 0 and false. The called method must return an array where each item is another array with the keys 'name' and 'id'. These values will become options in a multiple select box, with id as the value and name as the caption. The label for the select box will be the value associated with the key 'name' in your limitation array. A shame that only files from the kernel can be included by this way.

Note that the value of the key 'name' in the function limitation needs to be the same as the key you use for your limitation in $FunctionList, because there seems to be some inconsistency in eZ's code: when editing the policies the 'name' key in the limitation list is used, and this is the one that get's stored in the database. But when displaying the policies, the key of the limitation array in the $FunctionList is used.

You can also define the options for the select box without the need to call a function. For example, the owner limitation for content/edit is defined as follows:

$Assigned = array(
    'name'=> 'Owner',
    'values'=> array(
        array(
            'Name' => 'Self',
            'value' => '1')
        )
    );

Node and Subtree limitations are an exception. The values are handled by the role module itself (with the content browser), so you will only need to define that you want to use them:

$Node = array(
    'name'=> 'Node',
    'values'=> array()
    );

$Subtree = array(
    'name'=> 'Subtree',
    'values'=> array()
    );

...

$FunctionList['read'] = array( 'Class' => $ClassID,
                               'Section' => $SectionID,
                               'Owner' => $Assigned,
                               'Node' => $Node,
                               'Subtree' => $Subtree);

If node limitations are used, all other limitations will be dropped by default when creating the policy. But you can change this behaviour by defining an array with limitations that need to be dropped:

$FunctionList['create'] = array( 'Class' => $ClassID,
                                 'Section' => $SectionID,
                                 'ParentClass' => $ParentClassID,
                                 'Node' => array_merge(  $Node, array( 'DropList' => array( 'ParentClass', 'Section' ) ) ),
                                 'Subtree' => $Subtree
                                 );

The droplist is currently broken (eZ publish 3.6.2).

So far this explanation of policy programming.

independent eZ Publish developer and service provider | http://blog.coomanskristof.be | http://ezpedia.org

Xavier Dutoit

Tuesday 04 October 2005 12:22:22 am

Many thanks for this detailled analysis.
X+

http://www.sydesy.com

Clemens T

Tuesday 04 October 2005 5:29:33 am

I'll read it later on, thanks for the (on first sight) wonderful contribution!

Kristof Coomans

Thursday 23 November 2006 2:27:32 am

<b>A shame that only files from the kernel can be included by this way.</b>

This has been fixed in eZ publish 3.8.7 ( http://issues.ez.no/9092 ). You can now use the key 'extension' to define the name of the extension in which the file to include is placed.

independent eZ Publish developer and service provider | http://blog.coomanskristof.be | http://ezpedia.org

Piotrek Karaś

Thursday 20 November 2008 4:49:35 am

Hi there,

I've just written a wrapper that I intend to take care of two things:
- include calling for user object,
- provide slightly simplified/aggregated limitation array, so that it can be faster, easier and cleaner to verify limited access.

public static function getSimplifiedUserAccess( string $module, string $function )
{
    $user = eZUser::currentUser();
    $userAccess = $user->hasAccessTo( $module, $function );

    $userAccess['simplifiedLimitations'] = array();
    if( $userAccess['accessWord'] == 'limited' )
    {
        foreach( $userAccess['policies'] as $policy )
        {
            foreach( $policy as $limitationName => $limitationList )
            {
                foreach( $limitationList as $limitationValue )
                {
                    $userAccess['simplifiedLimitations'][$limitationName][] = $limitationValue;
                }
            }
        }
    }
    return $userAccess;
}

1) Do you think the above approach is a good one?
2) Have I reinvented the wheel? Is there a ready solution for that?

Thanks,
Piotrek

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Jérôme Vieilledent

Wednesday 03 February 2010 12:21:34 am

Hello !

I just reported 2 tickets about this subject :

  • http://issues.ez.no/IssueView.php?Id=16112&activeItem=1 (with Piotrek's function)
  • http://issues.ez.no/IssueView.php?Id=16113&activeItem= (for the eZJSCore policy checks to be implemented in the kernel :))

Bertrand Dunogier

Wednesday 03 February 2010 12:33:19 am

I was wondering if it wouldn't be appropriate to try using a struct to return these simplified permissions, the way it is done in the eZ Components ( http://www.ezcomponents.org/contributing/coding_standards#structs ). I kind of like the idea.

http://www.ezcomponents.org/contributing/coding_standards#structs

Bertrand Dunogier
eZ Systems Engineering, Lyon
http://twitter.com/bdunogier
http://gplus.to/BertrandDunogier

Jérôme Vieilledent

Wednesday 03 February 2010 1:04:09 am

Yep, this would be much cleaner :)

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 05:00:13
Script start
Timing: Jan 18 2025 05:00:13
Module start 'layout'
Timing: Jan 18 2025 05:00:13
Module start 'content'
Timing: Jan 18 2025 05:00:14
Module end 'content'
Timing: Jan 18 2025 05:00:14
Script end

Main resources:

Total runtime1.3471 sec
Peak memory usage4,096.0000 KB
Database Queries83

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0064 591.5547152.6250
Module start 'layout' 0.00640.0033 744.179739.4609
Module start 'content' 0.00971.3358 783.6406813.9922
Module end 'content' 1.34550.0015 1,597.632828.1563
Script end 1.3471  1,625.7891 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00430.3185160.0003
Check MTime0.00180.1351160.0001
Mysql Total
Database connection0.00130.098810.0013
Mysqli_queries1.253193.0198830.0151
Looping result0.00090.0689810.0000
Template Total1.311197.320.6555
Template load0.00270.199720.0013
Template processing1.308497.124120.6542
Template load and register function0.00020.016110.0002
states
state_id_array0.00170.123710.0017
state_identifier_array0.00160.121620.0008
Override
Cache load0.00250.1830640.0000
Sytem overhead
Fetch class attribute can translate value0.00150.114060.0003
Fetch class attribute name0.00100.0750140.0001
XML
Image XML parsing0.00370.274260.0006
class_abstraction
Instantiating content class attribute0.00000.0023160.0000
General
dbfile0.00190.1416420.0000
String conversion0.00000.000840.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
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
21content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
8content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
7content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
1content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 56
 Number of unique templates used: 9

Time used to render debug report: 0.0001 secs