Thursday 09 December 2010 8:01:18 am - 6 replies

» Read full tutorial

Introduction

This tutorial will guide you through the development of a simple eZ Publish workflow event. At the end of the tutorial, you should be able to create your own workflow event, configure a workflow that would execute the event and configure workflow triggers in the admin interface.

Note : the PDF version of this tutorial, as well as the downloadable extension are here.

 
Author Message

Robin Muilwijk

Saturday 11 December 2010 12:27:38 am

Hi,

Great tutorial! A very good addition to the online docs, I'm sure this will inspire others when setting up their workflows. It also shows the power of eZ Publish, thanks for this contribution!

-- Robin

Board member, eZ Publish Community Project Board - Member of the share.ez.no team - Key values: Openness and Innovation.

LinkedIn: http://nl.linkedin.com/in/robinmuilwijk // Twitter: http://twitter.com/i_robin // Skype: robin.muilwijk

Kristof Coomans

Saturday 11 December 2010 9:34:58 am

There seems to be a small typo on Step 8:

"

It’s not time to see how to retrieve them.

"

I guess "not" should have been "now".

Nice tutorial, posting Twitter updates is a perfect use case for workflows!

However, the used process of authorizing eZ Publish to have access to the twitter account looks quite cumbersome to me. I guess it could be made a lot easier by offering a screen for that in the eZ Publish administration interface that starts the full web-based authorization process instead of the out-of-band/PIN code authentication which was not really suitable for this kind of app. A good example of how this is done is the nxc_twitter extension available at http://projects.ez.no/nxc_twitter.

independent eZ Publish developer and service provider | http://blog.coomanskristof.be | http://ezpedia.org

Romeo Antony

Sunday 12 December 2010 12:29:49 am

Huy,

Good tutorial. Learned a lot from this like how to integrate 3rd party libraries, creating custom wrokflowevents.

Maxime Thomas

Monday 13 December 2010 4:46:56 am

Hi,

Excellent article which shows the power of workflows and how thing can be easily done with it.

However, I just regret you don't put some examples on how debug thoses workflows, it can be tricky for some people.

Max

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

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

Nicolas Pastorino

Wednesday 15 December 2010 4:46:39 am

"

There seems to be a small typo on Step 8:

"

It’s not time to see how to retrieve them.

"

I guess "not" should have been "now".

"

Thanks, fixed now.

"

Nice tutorial, posting Twitter updates is a perfect use case for workflows!

However, the used process of authorizing eZ Publish to have access to the twitter account looks quite cumbersome to me. I guess it could be made a lot easier by offering a screen for that in the eZ Publish administration interface that starts the full web-based authorization process instead of the out-of-band/PIN code authentication which was not really suitable for this kind of app. A good example of how this is done is the nxc_twitter extension available at http://projects.ez.no/nxc_twitter.

"

I agree here, although it is not exactly the scope of this already thorough tutorial. It could be a follow-up tutorial, showing how to create custom panels and tabs in the admin interface ? Easy, yet very useful.

Cheers Kristof,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Quoc Huy Nguyen Dinh

Wednesday 15 December 2010 4:50:29 am

Thank you all for the feedbacks. Very much appreciate it.

@Kristof, I've notified Nicolas to see if the typo can be corrected. Regarding the Twitter API you are correct, this is not the easiest way to handle this and NXC technique is sweet. But this allows one to also discover eZ Script.

@maxime, I usually debug my workflows with eZLog::write() which is used here.

You must be logged in to post messages in this topic!

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 17 2025 21:21:17
Script start
Timing: Jan 17 2025 21:21:17
Module start 'layout'
Timing: Jan 17 2025 21:21:17
Module start 'content'
Timing: Jan 17 2025 21:21:17
Module end 'content'
Timing: Jan 17 2025 21:21:17
Script end

Main resources:

Total runtime0.1525 sec
Peak memory usage4,096.0000 KB
Database Queries89

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0044 597.7969152.1406
Module start 'layout' 0.00440.0021 749.937539.5078
Module start 'content' 0.00650.1447 789.44531,017.3750
Module end 'content' 0.15120.0012 1,806.820326.4766
Script end 0.1524  1,833.2969 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00291.9038160.0002
Check MTime0.00130.8223160.0001
Mysql Total
Database connection0.00060.371210.0006
Mysqli_queries0.082153.8398890.0009
Looping result0.00060.4183870.0000
Template Total0.128484.220.0642
Template load0.00211.372720.0010
Template processing0.126382.801120.0631
Template load and register function0.00020.099810.0002
states
state_id_array0.00070.487820.0004
state_identifier_array0.00090.579030.0003
Override
Cache load0.00181.1954540.0000
Sytem overhead
Fetch class attribute name0.00080.5537130.0001
Fetch class attribute can translate value0.00050.338560.0001
class_abstraction
Instantiating content class attribute0.00000.0084130.0000
XML
Image XML parsing0.00251.662660.0004
General
dbfile0.00130.8781500.0000
String conversion0.00000.003840.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.tplforum_topic/full.tplextension/community_design/design/suncana/override/templates/forum_topic/full.tplEdit templateOverride template
7content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
13content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
2content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
1content/datatype/view/ezxmltags/emphasize.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/emphasize.tplEdit templateOverride template
1content/datatype/view/ezxmltags/separator.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltags/separator.tplEdit templateOverride template
6content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
4content/datatype/view/ezxmltags/quote.tpldatatype/ezxmltext/quote.tplextension/ezwebin/design/ezwebin/override/templates/datatype/ezxmltext/quote.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 36
 Number of unique templates used: 9

Time used to render debug report: 0.0001 secs