Forums / Developer / How to fetch drafts ?

How to fetch drafts ?

Author Message

Samuel Torton

Monday 11 October 2010 8:56:08 am

Hello,

I would like to fetch all contents with "draft" status, and especially all drafts in a specific parent node.

I feel a bit embarrassed, because I've read the following note, regarding the "fetch (section, object_list ...":

"Note that fetching all draft objects that belong to a certain section is not supported"

Thus, what would be a nice workaround ?

Thanks a lot for your answers.

Samuel Torton

Heath

Monday 11 October 2010 3:27:48 pm

Hello Again Samuel,

It sure sounds like fetching all draft objects is not provided by the built-in fetch functions.

Perhaps you could create your own custom fetch function which does provide this feature?

Cheers,

Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

kracker (the)

Monday 11 October 2010 3:44:09 pm

Hello,

I think in a case like this I would learn from the content/draft module view and template code.

I would create your own custom fetch function to be similar in design to the draft_version_list.

http://doc.ez.no/eZ-Publish/Technical-manual/4.x/Reference/Modules/content/Fetch-functions/draft_version_list

The following snippet is from, kernel/content/ezcontentfunctioncollection.php

static public function fetchDraftVersionList( $offset, $limit )    {        $userID = eZUser::currentUserID();        $draftVersionList =  eZPersistentObject::fetchObjectList( eZContentObjectVersion::definition(),                                                                   null, array(  'creator_id' => $userID,                                                                                 'status' => eZContentObjectVersion::STATUS_DRAFT ),                                                                   array( 'modified' => true,                                                                          'initial_language_id' => true ),                                                                   array( 'length' => $limit, 'offset' => $offset ),                                                                   true );        return array( 'result' => $draftVersionList );    }
static public function fetchDraftVersionList( $offset, $limit )    {        $userID = eZUser::currentUserID();        $draftVersionList =  eZPersistentObject::fetchObjectList( eZContentObjectVersion::definition(),                                                                   null, array(  'creator_id' => $userID,                                                                                 'status' => eZContentObjectVersion::STATUS_DRAFT ),                                                                   array( 'modified' => true,                                                                          'initial_language_id' => true ),                                                                   array( 'length' => $limit, 'offset' => $offset ),                                                                   true );        return array( 'result' => $draftVersionList );    }

I would first fetch all users and then per user iterate over their draft list as desired. Bingo problem solved.

This is also a good article about how to create custom fetch functions.

http://share.ez.no/learn/ez-publish/understanding-and-developing-fetch-functions

Cheers,

//kracker

Member since: 2001.07.13 || http://ezpedia.se7enx.com/

Samuel Torton

Monday 11 October 2010 4:16:34 pm

Hello Heath,

Yes, today I could create my own functions based on the code you mentioned, and I was successful ! ;-)

(solution: function fetchDraftVersionList_in_a_node(): I've removed the user_id parameter, and added parent_node_id in order to fetch into a specific node)

Thus I went further into my project.

Now, I'm facing another problem ! ;-)

Ezpublish doesn't allow users to edit other users drafts.

Thus I thought it could be possible to copy one draft to a second draft, but... the second draft is loosing the original parent id because this new draft is not linked to any contentobject_id ! :-(

My objective is to allow people editing the same draft, without sending it for publication, for instance:

. user1 creates a new object, he starts editing it, and he saves it as a draft without sending for publication (= draft v1);

. user2 edits and modifies this draft... and saves it again as a draft (= draft v2);

... and so on ... (= draft v7)

. and then, user3 edits and modifies this "draft v7"... and send it for publishing;

I would really want ezpublish to allow a user to edit another user's draft.

I keep investigating and search for a solution... if you have hints, I'm interested.

Thank you.

Samuel Torton

Heath

Monday 11 October 2010 5:06:30 pm

Samuel,

The default content module is limited in this regard.

I strongly suggest you look further into ezapprove2 which provides for editing of other peoples drafts before actual publish.

Otherwise you may find yourself having to build your own custom module view to provide the features you need.

There is no simple solution if you can't change your requirements to fit ezapprove2.

Cheers,

Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Samuel Torton

Tuesday 12 October 2010 1:50:25 am

Heath,

Yes, I have to say I'm limited with the default content module.

Before going any further with a custom solution, I'll try to get back to eZApprove2.

But eZApprove2 doesn't seem to work with eZp4: I can create a new workflow with a new "event/ezapprove2", but I cannnot configure it...

I will post again on the eZApprove2 forum.

Thank you for your help.

Samuel Torton

Heath

Tuesday 12 October 2010 2:04:59 am

Samuel,

I am using the very same eZApprove2 to power another eZ Publish 4.x site.

So your installation may need help but the extension software is fairly solid.

Best to post to the project forum though.

Cheers,

Heath

Brookins Consulting | http://brookinsconsulting.com/
Certified | http://auth.ez.no/certification/verify/380350
Solutions | http://projects.ez.no/users/community/brookins_consulting
eZpedia community documentation project | http://ezpedia.org

Samuel Torton

Tuesday 12 October 2010 6:01:44 am

Hi Heath,
I found the solution!
There is a bug in the "affected section" template.
The solution is here:
http://projects.ez.no/ezapprove2/forum/general/problem_saving_affected_sections
Then I started testing this extension, and seems to meet my requirements, thank you !
Now, I'm facing another issue.
If I select "Users select approvers themselves" parameter in my event/approve2.
When an editor modifies a content, as soon as he sends article for publication, there is an interface asking him to select users.... and when clicks on "select users", there is a kernel_error: not authorized to access this page.
What rule/policy do I have to activate to give them access ?
Thank you.

Samuel Torton

eZ debug

Timing: Jan 17 2025 21:06:22
Script start
Timing: Jan 17 2025 21:06:22
Module start 'content'
Timing: Jan 17 2025 21:06:23
Module end 'content'
Timing: Jan 17 2025 21:06:23
Script end

Main resources:

Total runtime0.9778 sec
Peak memory usage4,096.0000 KB
Database Queries212

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0060 595.9453180.8516
Module start 'content' 0.00600.8635 776.7969706.1484
Module end 'content' 0.86950.1083 1,482.9453349.3047
Script end 0.9778  1,832.2500 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00360.3648210.0002
Check MTime0.00130.1356210.0001
Mysql Total
Database connection0.00080.080910.0008
Mysqli_queries0.856187.55602120.0040
Looping result0.00220.22522100.0000
Template Total0.952197.420.4761
Template load0.00230.238920.0012
Template processing0.949897.131320.4749
Template load and register function0.00010.014810.0001
states
state_id_array0.00070.074910.0007
state_identifier_array0.00060.062020.0003
Override
Cache load0.00210.2160860.0000
Sytem overhead
Fetch class attribute can translate value0.00100.101440.0002
Fetch class attribute name0.00110.1156110.0001
XML
Image XML parsing0.00360.370340.0009
class_abstraction
Instantiating content class attribute0.00010.0082160.0000
General
dbfile0.00780.7955420.0002
String conversion0.00000.001530.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/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
8content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
10content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
1content/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: 31
 Number of unique templates used: 8

Time used to render debug report: 0.0001 secs