Forums / Developer / Extra logic for a feedback form

Extra logic for a feedback form

Author Message

Ronan Limon Duparcmeur

Friday 02 April 2010 9:16:36 am

After hitting my head against the wall and blowing off much steam on Twitter, I've finally been able to add some logic to what should have been a simple feedback form. For the record, here is my problem and how I solved it.

One of our eZP-powered website features a simple feedback form. The catch ? Instead of sending an email, the submitted data has to be used to fill our CRM. This involves consuming a webservice, and thus some backend code.

Since triggers aren't available on feedback forms (or, if they are, I just couldn't figure it out), we had to find another way. A custom module+action was out of question, so instead, we choose to add the extra logic in the feedback email template.

So, basically, what we do is activate the sending of feedback emails (even though we don't want them), and in the overridden template for this email, we call a custom template operator. This operator, in turn, handles the call to the CRM's webservice.

This is an ugly solution to a problem that shouldn't even exist in the first place. It may not be the best solution, but hey, at least the problem is solved for now.

eZ debug

Timing: Jan 18 2025 02:49:42
Script start
Timing: Jan 18 2025 02:49:42
Module start 'content'
Timing: Jan 18 2025 02:49:42
Module end 'content'
Timing: Jan 18 2025 02:49:43
Script end

Main resources:

Total runtime0.1347 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0056 590.8906180.8359
Module start 'content' 0.00560.0048 771.726689.7578
Module end 'content' 0.01040.1242 861.4844518.7734
Script end 0.1346  1,380.2578 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00352.6005200.0002
Check MTime0.00151.1126200.0001
Mysql Total
Database connection0.00060.421710.0006
Mysqli_queries0.093369.26881410.0007
Looping result0.00120.90951390.0000
Template Total0.123891.910.1238
Template load0.00100.740110.0010
Template processing0.122891.153610.1228
Override
Cache load0.00060.452910.0006
Sytem overhead
Fetch class attribute can translate value0.00050.366010.0005
XML
Image XML parsing0.00030.213810.0003
General
dbfile0.00282.0784200.0001
String conversion0.00000.004230.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
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs