Forums / Install & configuration / Building a navigation based on role-sections

Building a navigation based on role-sections

Author Message

Peter Bailey

Friday 28 February 2003 10:09:50 am

Hey all

I'm attempting to create a <UL> based list of links to all the SECTIONS that are assigned to the current user's ROLE. How can I retrieve all the URIs so I can create my <UL> tree?

I'm going to keep reading into eZUser to find my answer, but if you know you'd help me alot!

Thanks

Volker Lenz

Monday 03 March 2003 3:26:22 am

> Hey all
>
> I'm attempting to create a <UL> based list of links to all
> the SECTIONS that are assigned to the current user's ROLE.
> How can I retrieve all the URIs so I can create my <UL>
> tree?
>
> I'm going to keep reading into eZUser to find my answer, but
> if you know you'd help me alot!
>
> Thanks

What do you actually want to do ? 'Sections' are not related to URIs in ezp. So I wonder whether you want to display links to site access URI's, as they are defined in your site.ini. Note that in current ezp, you cannot directly assign site access URI's to sections.

Regards

Volker

Peter Bailey

Monday 03 March 2003 7:09:28 am

I see. Umm. Well, I have several groups of content all separated by SECTIONs, but if that won't work I need something that will allow me to:

Designate access to specific USER-GROUPs or ROLEs to specific content areas (folders, whatever) on the site. Preferably using ROLEs.

Using that information, build the NAV it mentioned directing the user to each "section"

How can I interface the data in the user's role for template building?

Peter Bailey

Monday 03 March 2003 7:09:28 am

I see. Umm. Well, I have several groups of content all separated by SECTIONs, but if that won't work I need something that will allow me to:

Designate access to specific USER-GROUPs or ROLEs to specific content areas (folders, whatever) on the site. Preferably using ROLEs.

Using that information, build the NAV it mentioned directing the user to each "section"

How can I interface the data in the user's role for template building?

Volker Lenz

Tuesday 04 March 2003 3:38:14 am

> I see. Umm. Well, I have several groups of content all
> separated by SECTIONs, but if that won't work I need
> something that will allow me to:
>
> Designate access to specific USER-GROUPs or ROLEs to
> specific content areas (folders, whatever) on the site.
> Preferably using ROLEs.
>
> Using that information, build the NAV it mentioned directing
> the user to each "section"
>
> How can I interface the data in the user's role for template
> building?

Ok, think I got it. In ezp3-rc2 you cannot assign contentobject authorization to users or groups or even roles. This is clearly a shortcoming in ezp3's current authorisation model and I have already issued a bunch of feature requests to the devs on that matter.

One possible workaround for this is the following one. However, I do not recommend to use it for the reasons I have outlined lateron.

--- Template based access check for content objects ------

After you have created different roles with "content read"-restrictions bound to sections, you can build a default content listing menu for a basic content node, where different subnodes of that node are bound to the distinct content-sections you have defined in your role-model. When you fetch that basic content node in your template as usual with the fetch()-function, in order to create, say a menu of article links, you may use the "can_read", "can_write", "can_edit" permission-control attributes of content objects to decide whether the current site visitor comes to see a content or not:

Use something like the following code to create your menu:
{let menucontents=fetch('content','tree',hash(parent_node_id,$your_basic_content_root_node_id,sort_by,$your_sorting_preference,depth,$your_preferred_tree_depth_to_fetch))}
{section name='Menu' loop=$menucontents}

{section show=$Menu:item.object.can_read}
... template code to display a content link for users who are allowed to read the content due to their section-role-setting ...
{section-else}
... possible template code to create a placeholder for a menuitem that the current user is not allowed to read
{/section}
{/section}
{/let}

However, this model of dynamic menu creation has two major disadvantages:

1. It is as slow as every complex template calculation is and becomes even slower with each additional content object to check permissions for. So if you intend to route dozens of articles through the template-oriented permission checker depicted above, your site visitors will easily loose their patience.

2. Template-oriented permission checking is likely to become weired once you activate template caching in order to boost the speed of ezp's rendering fetaure.
The caching of templates will not know which of the menus are designated to which user group, because the permission check IS NOT APPLIED OUTSIDE the template generation process. If it was, it could be applied as routine even before fetching cached templates.

With these two rather serious limitations in mind, I recommend that you do not follow that path of page design with dynamic menus that check access permissions in the course of template creation.

Instead, I recommend that you achieve a design that allows you to use as many STATIC templates as possible. In your situation, I would seperate the content for different users to different sections (as you already did) and then provide a distinct site access (say 'partner', 'client') with a distinct pagelayout for these site access zones and -- of course -- a require-login flag set in the site.ini-overrides for these zones. Once you users log in to a site access zone, they simply come to see all the content in the section bound to that zone in a static and caching-safe pagelayout_override.

Think about it.

Regards

Volker

Volker Lenz

Tuesday 04 March 2003 3:38:14 am

> I see. Umm. Well, I have several groups of content all
> separated by SECTIONs, but if that won't work I need
> something that will allow me to:
>
> Designate access to specific USER-GROUPs or ROLEs to
> specific content areas (folders, whatever) on the site.
> Preferably using ROLEs.
>
> Using that information, build the NAV it mentioned directing
> the user to each "section"
>
> How can I interface the data in the user's role for template
> building?

Ok, think I got it. In ezp3-rc2 you cannot assign contentobject authorization to users or groups or even roles. This is clearly a shortcoming in ezp3's current authorisation model and I have already issued a bunch of feature requests to the devs on that matter.

One possible workaround for this is the following one. However, I do not recommend to use it for the reasons I have outlined lateron.

--- Template based access check for content objects ------

After you have created different roles with "content read"-restrictions bound to sections, you can build a default content listing menu for a basic content node, where different subnodes of that node are bound to the distinct content-sections you have defined in your role-model. When you fetch that basic content node in your template as usual with the fetch()-function, in order to create, say a menu of article links, you may use the "can_read", "can_write", "can_edit" permission-control attributes of content objects to decide whether the current site visitor comes to see a content or not:

Use something like the following code to create your menu:
{let menucontents=fetch('content','tree',hash(parent_node_id,$your_basic_content_root_node_id,sort_by,$your_sorting_preference,depth,$your_preferred_tree_depth_to_fetch))}
{section name='Menu' loop=$menucontents}

{section show=$Menu:item.object.can_read}
... template code to display a content link for users who are allowed to read the content due to their section-role-setting ...
{section-else}
... possible template code to create a placeholder for a menuitem that the current user is not allowed to read
{/section}
{/section}
{/let}

However, this model of dynamic menu creation has two major disadvantages:

1. It is as slow as every complex template calculation is and becomes even slower with each additional content object to check permissions for. So if you intend to route dozens of articles through the template-oriented permission checker depicted above, your site visitors will easily loose their patience.

2. Template-oriented permission checking is likely to become weired once you activate template caching in order to boost the speed of ezp's rendering fetaure.
The caching of templates will not know which of the menus are designated to which user group, because the permission check IS NOT APPLIED OUTSIDE the template generation process. If it was, it could be applied as routine even before fetching cached templates.

With these two rather serious limitations in mind, I recommend that you do not follow that path of page design with dynamic menus that check access permissions in the course of template creation.

Instead, I recommend that you achieve a design that allows you to use as many STATIC templates as possible. In your situation, I would seperate the content for different users to different sections (as you already did) and then provide a distinct site access (say 'partner', 'client') with a distinct pagelayout for these site access zones and -- of course -- a require-login flag set in the site.ini-overrides for these zones. Once you users log in to a site access zone, they simply come to see all the content in the section bound to that zone in a static and caching-safe pagelayout_override.

Think about it.

Regards

Volker

Peter Bailey

Tuesday 04 March 2003 8:50:49 am

Volker

Thanks so much for the reply. You're right, based on the caching etc, doing the navigation this way won't work. I've become so accustomed to having the cachin off during the development I forgot about that effecting this.

Thank you very much for the example, just the same. It will help me learn the templating system better.

I only have 8-10 sections I am using for this, so doing them static for now is not a big deal.

Thanks again. If you ever need some serious javascript work done, I'm your man. =)

Peter Bailey

Tuesday 04 March 2003 8:50:49 am

Volker

Thanks so much for the reply. You're right, based on the caching etc, doing the navigation this way won't work. I've become so accustomed to having the cachin off during the development I forgot about that effecting this.

Thank you very much for the example, just the same. It will help me learn the templating system better.

I only have 8-10 sections I am using for this, so doing them static for now is not a big deal.

Thanks again. If you ever need some serious javascript work done, I'm your man. =)

eZ debug

Timing: Jan 18 2025 05:01:45
Script start
Timing: Jan 18 2025 05:01:45
Module start 'content'
Timing: Jan 18 2025 05:01:46
Module end 'content'
Timing: Jan 18 2025 05:01:46
Script end

Main resources:

Total runtime0.7041 sec
Peak memory usage4,096.0000 KB
Database Queries209

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0080 587.9609180.8047
Module start 'content' 0.00800.5475 768.7656611.2031
Module end 'content' 0.55560.1485 1,379.9688349.0313
Script end 0.7040  1,729.0000 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00420.5925210.0002
Check MTime0.00150.2124210.0001
Mysql Total
Database connection0.00110.161910.0011
Mysqli_queries0.603785.74132090.0029
Looping result0.00210.29562070.0000
Template Total0.670495.220.3352
Template load0.00190.273120.0010
Template processing0.668594.937020.3342
Template load and register function0.00010.018910.0001
states
state_id_array0.00150.212510.0015
state_identifier_array0.00100.148420.0005
Override
Cache load0.00180.26181210.0000
Sytem overhead
Fetch class attribute can translate value0.00200.289230.0007
Fetch class attribute name0.00130.181490.0001
XML
Image XML parsing0.00090.132430.0003
class_abstraction
Instantiating content class attribute0.00000.0031110.0000
General
dbfile0.00490.6997270.0002
String conversion0.00000.001430.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
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
8content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
14content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
9content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 36
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs