Editing a limited set of object's attributes

Author Message

Piotrek Karaś

Thursday 27 December 2007 4:04:48 am

I've observed apparently different behaviors of eZ Publish when editing a subset of object's attributes:
a) new version of an object is created out of new values of the attributes being edited + previous version of all other attributes
b) new version of an object is created out of new values of the attributes being edited + empty values of other attributes, no matter what the previous versions were.

My questions:
1) What's the desired, default way that eZ Publish should handle such editing?
2) Should one the above behaviors be considered a bug or maybe an illegal operation on the content model?
3) Is there a configuration setting for controlling/switching the above?

I'd be grateful for any help on that subject,
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

Maxime Thomas

Wednesday 16 January 2008 8:48:04 am

Hi,

I also thought about that because I would like to improve the edit interface for single attribute edit.
It might very useful to design a subtree very quiclky or either to change the content name in "one click".
But there's an issue if we tried to apply that to a content with several attributes. If you try to edit only one, you will have to make a new version for all the attributes. It will be a plus for the eZ ergonomy.

Maxime Thomas
maxime.thomas@wascou.org | www.wascou.org | http://twitter.com/wascou

Company Blog : http://www.wascou.org/eng/Company/Blog
Technical Blog : http://share.ez.no/blogs/maxime-thomas

Piotrek Karaś

Wednesday 16 January 2008 12:28:28 pm

Hello Maxime,

I can't actually believe that this issue has drawn attention eventually ;)

Yes, in what you're saying might be the thing behind single attribute edit - it seems to me that it's encouraged to concentrate on content objects as smallest editable entities, because of version control as well as other issues. From that perspective, what you're describing as an issue, I would call following the model. I may not like the idea that I've only edited one character and eZ produces another db load of data, but it seems like a good idea when looking from the perspective of an object.

There's another way - that is direct data modification in existing objects and their attributes. I've recently written few extensions that rely on this approach. For example, an object view counter that stores view counts in its custom DB table, but periodically synchronizes (cronjob) an integer of my choice within last version of objects of given class, so that later I can sort and filter the objects based on their dynamically changing popularity or whatever. This obviously breaks the model, there's no version created in between synchronizations. Is that a wrong approach, though? I'd be grateful for pros and cons.

My latest tests have shown, that for majority of basic datatypes it is possible to skip attributes (the earlier problems with attributes being wiped out must have been datatype-related, I think). Is that desired, is that a feature or a bug - don't know yet ;)

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

*- pike

Saturday 12 April 2008 5:18:29 pm

Hi Piotrek

As you've noticed, it depends on how you alter your data - if you directly set your values in the node>object>version>datamap and store the version, you can even edit archived and draft versions, without creating a new version at all. You might need to clear some caches.

Looking very closely at what happens in ContentObject::copyVersion, there is indeed a bit of voodoo related to wether it should copy existing attributes or to initialize new ones:
http://pubsvn.ez.no/doxygen/3.10/html/ezcontentobject_8php-source.html#l01263

If it was called with either $languageCode or $copyFromLanguageCode, and these codes are correct and exist, the attributes are cloned from the latter (or the first, if the latter is omitted), regardless of wether these attributes are translatable or not.
But if that doesn't work out in any way, it depends: if the attribute is translatable, it is initialized from scratch. if it not translatable, it is cloned from that same attribute in the initial language of the object but in the current version (even if you are copying some other version, for some reason). But in that last situation, if such an attribute can not be found (which should never happen, i think) the new attribute is again initialized from scratch.

So that's confusing enough :-)

*-pike

---------------
The class eZContentObjectTreeNode does.

Nathan Kelly

Monday 02 June 2008 1:13:54 am

I agree with the other comments, it all depends on the data you need to change without affecting the version, but without versioning there could be some pitfalls.

I have my own extension that allows editing selected attributes of the current version without affecting the version, that allows me to change the status of an object attribute without entering /content/edit. I have been using this for a number of content classes that usually have only one modifier or owner. This is handy if you are trying to give certain users the ability to modify their own content quickly and without slowing them down by forcing them to create a new version every time they need to change attribute_a value from 1 to 0 or visa versa.

I do however limit the use to one user if I can help it, if you're talking about allowing multiple users to manipulate one attribute you could run into issues where 2 people are editing the same object at the same time which will either cause an error on publish or wipe out the change made to the single attribute by one of the users by forcing it back a version.

I'm currently setting up a ticket system that enables admin's to change the status of a ticket in one click (open/closed), so this will be a good field test of the single attribute edit extension. My guess is that there will be the odd occasion where 2 people will try to change the same attribute of the same object at the same time. I'm yet to figure out a way to circumvent this exact scenario short of using full blown versioning? All of that said I am currently running this ability on a production site and so far (3 years) I haven't encountered an issue though I have limited its use to the owner of the object so its practically impossible to have 2 people editing it at the same time.

Once I have figured out the best way to allow multiple users to edit synchronously (with and without AJAX) I'll release the extension to public, but first I want to make sure its 100% stable and reliable.

As for your issue I'd say it really is a matter of the content that you need to edit and weigh up the likelihood of multiple users editing synchronously, if that's very low allow it if its high you might be better off forcing full version editing?

I hope that helps, probably not exatly what you were after though?

Cheers
Nathan.

Pardon me while I burst into flames...

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 11:18:48
Script start
Timing: Jan 18 2025 11:18:48
Module start 'layout'
Timing: Jan 18 2025 11:18:48
Module start 'content'
Timing: Jan 18 2025 11:18:49
Module end 'content'
Timing: Jan 18 2025 11:18:49
Script end

Main resources:

Total runtime0.9630 sec
Peak memory usage4,096.0000 KB
Database Queries67

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0069 588.0469152.6406
Module start 'layout' 0.00700.0030 740.687539.4766
Module start 'content' 0.00990.9517 780.1641670.3672
Module end 'content' 0.96170.0013 1,450.531320.1250
Script end 0.9629  1,470.6563 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00330.3442160.0002
Check MTime0.00130.1396160.0001
Mysql Total
Database connection0.00080.081110.0008
Mysqli_queries0.898993.3425670.0134
Looping result0.00080.0782650.0000
Template Total0.927296.320.4636
Template load0.00220.225420.0011
Template processing0.925196.059420.4625
Template load and register function0.00010.008610.0001
states
state_id_array0.00150.154110.0015
state_identifier_array0.00110.111220.0005
Override
Cache load0.00190.1961480.0000
Sytem overhead
Fetch class attribute can translate value0.00090.088640.0002
Fetch class attribute name0.00160.169780.0002
XML
Image XML parsing0.00170.174240.0004
class_abstraction
Instantiating content class attribute0.00000.001490.0000
General
dbfile0.00120.1217290.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
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
5content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
8content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
12content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 31
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs