In this implementation, an object can have multiple object states, but can have only one at a time in any defined object state collection.
Currently, the workflow engine in eZ Publish does not allow for objects to be edited with fine grained access control while being submitted for a workflow process. An example is the approval workflow currently bundled with eZ Publish: an object is locked and can only be rejected or accepted by the person in charge of approval. No corrections or other editing are possible in this phase with the default approval event provided.
With object states, this can be easily governed by setting correct permissions for the various object states together with policies and roles on the transitions between object states. Let's see how this can be achieved.
Here is the situation: you are managing a team of journalists, which is broken down into several specialized subteams :
Ok, this is simplistic, but stay focused please...
Each subteam should focus on its very task for every generated piece of content, in order to best leverage its skills, and then hand over the piece of content to the subsequent team. To achieve this, you will need to set up two key elements of the process :
Say Brad writes an articles about Obama's fresh election as President of the USA. When he is done, Stefan takes his work over, and checks the various grammar and spelling rules. Then Mélanie adds cool pictures of Barack Obama's inauguration, and sends the resulting almost-ready article to Telma, who is in charge of translating it to Spanish.
Here come the object states on stage !
When creating your eZ Publish-based web media application, you will create Object States matching the different phases of your editorial chain. From the administration interface, navigate to Setup, and click the « States » link in the left menu. You can see, listed, the different so-called «Content object state groups», as follows.
Enter the relevant information in the proposed object-state edition screen, in all applicable languages (the object states feature natively supports languages), as follows. Then click the « Create » button.
Then create the various object states, mapped to your editorial chain. In order to do so, you will need to click the «Create New» button under the «Object states in this group» block, from the object states group full view. Note that the first state in a group will be the one applied by default to objects. It should eventually look like this :
Note that the «Ready to go live» state was added, final logical step of our editorial chain.
Create, from the «User accounts» tab in the administration interface, as many user groups as your editorial chain requires. Then create our main characters in their respective groups (remember, Brad, Stefan, Mélanie, Telma).
Creating the adequate roles will help satisfy point 1. of the initial key elements :
«An access control mechanism, giving the right to each subteam to do its part of the work ( and only this ) on a piece of content, preventing any destructive interference.»
The first step will be to copy the built-in «Editor» , role, and slightly modify it. It is too permissive in our current use-case. Here is the new “Generic Editor” :
We then assign it to the four user groups used in the web-media application.
On top of the generic edition role, let's create roles controlling the state transitions between each step of our editorial chain, and also enforcing that every user group has the right to only perform the edit action it is allowed for. They are straight-forward, giving among other the right on the 'state' module, its 'assign' function, and narrowing down the allowed action to a specific transition between two steps. Here they are. Each of them is assigned to its eponymous user group.
This role is assigned to the «Bulk Editors» group, and allows Brad, once he finished writing the initial text of a piece of news, to push it one step ahead to the Spell Checking phase (Stefan).
This role is assigned to the «Spell Checkers» group, and allows Stefan, once he finished reviewing a piece of news, to push it one step ahead to the Media Enrichers (Mélanie).
This role is assigned to the «Media Enrichers» group, and allows Mélanie, once she finished adding media elements to a piece of news, to push it one step ahead to the Translaters (Telma).
This role is assigned to the «Translaters» group, and allows Telma, once she finished translating the piece of news into various languages, to push it live ! The content object will then be in the last step of our editorial chain: “Ready to go live”.
The anonymous role, in our simplistic proof of concept, shall be altered to properly reflect the editorial process. Indeed, the built-in Anonymous role gives read access on about any content in the standard section, with absolutely no restriction on the Object States. Hence the need to make sure all content classes involved in the editorial process are only visible when their instances are in the “Ready to go live” state. Here is our modified Anonymous role, assuming that only Article, Article (main-page), Article (sub-page) are used by the editors:
Ok, now the system is properly configured, only “Ready to go live” articles will be surfaced on front pages, and the four different teams are able to collaborate efficiently...but for point 2. of our initial key elements :
“A hand-over mechanism, communication channel between subteams.”
When Brad finished writing the bulk text of an Article, he needs to tell Stefan that there is some spellchecking work to do on this fresh Article. This would traditionally go through a workflow, in the eZ Publish sense of it, catching the state change and notifying the members of the Spell Checkers User Group that a new Article was submitted for spellchecking. This feature is not yet shipped by default in 4.1, but shall soon be, along with more use-cases for Object States. For now, the notification will be manual. Brad will send his new Article's URL to Stefan, right after he changed the state from “Bulk Edition” to “Spellchecking”. And so on.
Brads starts up by deciding to write about Barack Obama's fresh election as President of the United States. Logged-in in eZ Publish, he navigates to the suitable location in the content tree to write such an big piece of news, selects the Article class in the drop down list, English as a language, and hits the “Create here” button. History is being written, this is his first editorial workflow based on Object States. We all hope he is enjoying this moment. Once he is satisfied with what he wrote, he publishes the object, and changes its state to “Spellchecking”. In case Brad had chosen front-end editing ( eZ Flow here ), he can totally change the state of his article from there. When viewing the article, click the following button in the toolbar :
He lands on the following screen, where he can pursue his editor's destiny, as shown here :
He then notifies Stefan of this new Article about Obama. Stefan fixes the multiple mistakes ( Brad is bad with grammar .. ), and sets the content object in the “Media Enrichment” state. Once notified by Stefan, Mélanie populates the articles with relevant pictures, videos and interview-podcasts and finally send it to Telma, in “Translation” state. Telma, last person in the editorial process, translates the article to spanish, and sets its state to “Ready to go live”. And guess what ? The article is now online, after having completed this simplistic yet significant, multi-team editorial workflow !
Although the Object States feature shipped with 4.1 is at an early stage of its life, the hereby presented use-case, set up in half an hour, reveals its high potential. This example is a simple use-case for Object States. Yet a vast amount of applications and workflow-like implementations based on this new functionality can be easily implemented without further PHP coding :
More to come in eZ Publish 4.2 and Thanks for reading !
Timing: | Jan 18 2025 02:57:54 |
Script start | |
Timing: | Jan 18 2025 02:57:54 |
Module start 'layout' | |
Timing: | Jan 18 2025 02:57:54 |
Module start 'content' | |
Timing: | Jan 18 2025 02:57:54 |
Module end 'content' | |
Timing: | Jan 18 2025 02:57:54 |
Script end |
Total runtime | 0.0155 sec |
Peak memory usage | 2,048.0000 KB |
Database Queries | 3 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0055 | 588.1719 | 152.6563 |
Module start 'layout' | 0.0055 | 0.0029 | 740.8281 | 39.5234 |
Module start 'content' | 0.0084 | 0.0050 | 780.3516 | 102.3125 |
Module end 'content' | 0.0134 | 0.0021 | 882.6641 | 42.3047 |
Script end | 0.0155 | 924.9688 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0025 | 16.1036 | 14 | 0.0002 |
Check MTime | 0.0010 | 6.5063 | 14 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0007 | 4.4503 | 1 | 0.0007 |
Mysqli_queries | 0.0028 | 18.3041 | 3 | 0.0009 |
Looping result | 0.0000 | 0.0907 | 1 | 0.0000 |
Template Total | 0.0017 | 10.9 | 1 | 0.0017 |
Template load | 0.0009 | 5.7405 | 1 | 0.0009 |
Template processing | 0.0008 | 5.1669 | 1 | 0.0008 |
Override | ||||
Cache load | 0.0006 | 3.8060 | 1 | 0.0006 |
General | ||||
dbfile | 0.0002 | 1.5347 | 8 | 0.0000 |
String conversion | 0.0000 | 0.0523 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 1 Number of unique templates used: 1 |
Time used to render debug report: 0.0001 secs