Forums / Developer / Fetching products related to a user

Fetching products related to a user

Author Message

Marat M.

Tuesday 19 July 2005 2:42:41 am

Hi all,

I've added an [Object relation] attribute to my product class. The related object is a user. Thus I can manually specify the user for each product or leave this attribute empty (No relation).

What I want to do is to list products belonging to a current user only.

Unfortunately, I don't know is there a special function to fetch objects related to a user. Can anyone help?

Thanks,
Marat

Marat M.

Tuesday 19 July 2005 4:55:09 am

Oh, I forgot. The section of the site where the products are going to be listed will be available only after logging in. So, the task is to capture the current user and make so that he/she will see only those items, that are related to him/her. Is it possible?

K259

Wednesday 20 July 2005 2:14:34 am

Hi!

Check out the template which lists the users draft (the template which is used in the admin-part under tab: "my drafts").

This template fetches draft produced by the "logged in" user.

Marat M.

Wednesday 20 July 2005 5:06:19 am

I enabled Debug template and captured the template name used in the Admin/MyAccount/Drafts. It is design/admin/templates/content/draft.tpl. But it makes no use for me because the template uses a special function, like this:


{let draft_list=fetch('content','draft_version_list',hash(limit,$page_limit,offset,$view_parameters.offset))}
{section show=$draft_list}

... etc.

Marat M.

Wednesday 20 July 2005 5:09:22 am

What I can do is to fetch the current user with this code:

{let user=fetch( 'user', 'current_user' )}
{$user.login}
{/let}

Displays login of the currently logged in user:

 marat

But how can I fetch the objects (products in my case) related to the current user ($user) then?

Tore Jørgensen

Wednesday 27 July 2005 12:35:09 am

Hi! This isn't quite an answer to your question, but might be usefull anyway...

If a user is allowed to read only some nodes within a tree, a fetch( 'content', 'tree',
hash( 'parent_node_id', $your_rootnode)
will return all the elements the user is allowed to read under $your_rootnode even if he is not allowed to read $your_rootnode.

So if using the role system is an alternative, this might be a solution.

Tore Jørgensen

Wednesday 27 July 2005 12:42:57 am

Or you can just fetch all the nodes, loop through them and only show them {if eq($user.contentobject_id, $node.data_map.<...>.your_related_object.contentobject_id)}

or something like that.

Tore Jørgensen

Wednesday 27 July 2005 2:11:47 am

It should probably be

{if eq($user.contentobject_id, $node.data_map.your_related_object.content.id)}

Use {$node.data_map|attribute("show")} to find what you need to compare.

Łukasz Serwatka

Wednesday 27 July 2005 2:25:44 am

<i>Or you can just fetch all the nodes, loop through them and only show them</i>

This will a less efficient when you have thousand of nodes. I suggest to create template operator where one of parameters will be user_id and which will return sql result array for example. All data are stored in database. Look in to documentation how to create template operator.

Personal website -> http://serwatka.net
Blog (about eZ Publish) -> http://serwatka.net/blog

Nabil Alimi

Friday 29 July 2005 9:37:24 am

I have (had) somehow the same problem and I solved it by the method described by Tore Jørgensen. But just like Lukasz warned, when the number of nodes increases, speed response awfully drops.
Will the search function help in this case ?
Or what is the syntax to use if I plan to use the "attribute_filter" parameter ?

My blog : http://www.starnab.com/ezpublish / http://www.starnab.com/ / http://www.assiki-consulting.com
eZ Publish Freelance developper. Feel free to contact me +33 674 367 057
nabil at assiki d0t fr

eZ debug

Timing: Jan 18 2025 10:40:11
Script start
Timing: Jan 18 2025 10:40:11
Module start 'content'
Timing: Jan 18 2025 10:40:12
Module end 'content'
Timing: Jan 18 2025 10:40:12
Script end

Main resources:

Total runtime1.5859 sec
Peak memory usage4,096.0000 KB
Database Queries221

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0079 587.7344180.8281
Module start 'content' 0.00791.4024 768.5625750.2734
Module end 'content' 1.41030.1755 1,518.8359344.4297
Script end 1.5858  1,863.2656 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00500.3145210.0002
Check MTime0.00200.1292210.0001
Mysql Total
Database connection0.00120.077110.0012
Mysqli_queries1.475993.06352210.0067
Looping result0.00270.16892190.0000
Template Total1.546597.520.7732
Template load0.00250.158120.0013
Template processing1.543997.352820.7720
Template load and register function0.00020.010710.0002
states
state_id_array0.00140.086710.0014
state_identifier_array0.00200.123720.0010
Override
Cache load0.00230.1422530.0000
Sytem overhead
Fetch class attribute can translate value0.00170.105560.0003
Fetch class attribute name0.00250.1548140.0002
XML
Image XML parsing0.00630.398060.0011
class_abstraction
Instantiating content class attribute0.00000.0025190.0000
General
dbfile0.00580.3667470.0001
String conversion0.00000.000630.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
9content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
10content/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/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 41
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs