Blogs / Bayron Guevara / Installing and configuring Ez Comments

Installing and configuring Ez Comments

Wednesday 29 September 2010 2:29:02 pm

  • Currently 5 out of 5 Stars.
  • 1
  • 2
  • 3
  • 4
  • 5

By : Bayron Guevara

Previously to the launching of the Ez Comments extension, we needed to implement commenting system through to a custom comment class and configure a pre-publish trigger to enable pre-moderation. The UI for comments managment was ugly and approving or denying multiple comments was a painless task, and unless you were using an extension like power_content you didn't can put the comment form inside the article or post.

Ez Comments comes to improve usability and efficiency by using their own database tables for store comments, subscription information among other things. Now it's included together with Ez Publish 4.3 or above.

First of all, you can look up the official Ez Publish documentation here and found a more detailed reference. I also recommend the official page project to get the latest announcements, bug-fixes and releases . This post pretend to be more simplified, nevertheless it covers some topics related to deployment issues.

Requirements

  • Ez Publish 4.3 or later. This is the recommended version, although you can get a working installation running on a previous Ez Publish 4 release you'd consider the implications of the following issues:
    • Due that view cache is based on roles. When you grant access to edit/remove own comments, edit and delete buttons are shown in others comments too. If you don't give edit/delete permissions to registered users to edit himself comments, so it will work fine.
    • Preview tab in Administration Interface won't let you post new comments.
  • eZ jscore extension v1.0.0 or later. Currently bundled with Ez Flow site package.

Installation Process

1. Get the source code

The latest version is 1.1 at the time of writing this post. You can download it from here. Maybe you want to get the latest commits and cutting edge developments, in this case open your favorite SVN client and checkout the trunk branch. On *unix enviroments you'd make this:

svn co http://svn.projects.ez.no/ezcomments/trunk/ ezcomments

On Windows systems I recommend Tortoise as the SVN client, you can see the official site http://tortoisesvn.tigris.org/ for installation and usage instructions.

2. Install the database tables

Once you've copied the extension files in the extension directory of your ezpublish site, you need execute the SQL script that comes with the extension in order to install the database tables, so if you have MySQL run the script located at:

</path/to/your/ezpublish/root/directory>/extension/ezcomments/sql/mysql/schema.sql

Change mysql by your Database administration server. The possible options are oracle, postgre or mysql.

3. Activate the Extension

You can activate the extension either from the Administration Interface or editing settings/override/site.ini.append.php and adding ezcomments to the AvailableExtensions array.

Then re-generate the autoload array in case you've edited the file manually. To do this execute the following command:

php bin/php/ezpgenerateautoloads.php -e

And last clear all the caches.

4. Grant permissions

If you want this extension be available for users other than Administrators, you need to grant permission to the involved user role; for example, for the Anonymous Users you'd need to edit the Anonymous Role. Currently the comment module offers various functions, some of them like edit and remove have extended limitations to specify whether changes to all comments or only the owners are permitted. The functions available are:

  • read: Grant access to read the comments
  • add: Add comments
  • edit: Edit all or own comments only
  • delete: Remove all or own comments
  • activate: Concede rights for confirm subscriptions to new content notifications via e-mail.
  • settings: Allow edition of own subscription list and unsubscribe for receiving notifications messages per content object basis.
  • security: Allow bypass captcha antispam mechanism. Useful for editors that want to avoid the annoying process of re-write recaptcha code.

5. Add Class Attribute and Edit Template

This extension adds a new datatype named Comment. You need to add a new attribute with this datatype to any content class you wish enable comment support, also you have to tweak templates used by these content objects. Add the following code to the respective templates:

{attribute_view_gui attribute=$node.data_map.comments}

Where comments is the respective attribute identifier.

Optional Setup

If you wish use the notification system or the capcha valitation field in the comment forms, you need to perform the following actions.

  • Setup a cronjob to receive notifications of new comments

The e-mails notifications uses the Ez Publish notification system which require be executed periodically through a cronjob on Linux or scheduled task on Windows. On Linux you can edit the crontab file by typing:

crontab -e

And adding the following line:

*/5 * * * * cd /path/to/your/ezpublish/root/directory && php runcronjobs.php -q ezcomments 2>&1

This instructs your operating system to execute the ezcomments cronjob script every 5 minutes. For a more detailed description about how to setup cronjobs in Ez Publish, see the steps listed here.

  • Configure a Recaptcha account

Currently recaptcha is the more common method to include CAPTCHA capabilities to your website. Basically CAPTCHA is a technique to differentiate an human from an machine through a distorted text image that need to be written in order to validate the information and prevent that bots spam the website.

To get an recaptcha account, first create a Google account and then follow the instructions showed here: https://admin.recaptcha.net/recaptcha/createsite. At the end of the process you'll receive a Public and Private Key that need to be included in the RecaptchaSetting block of an settings/ezcomments.ini.append.php override. This file would see something as:

[RecaptchaSetting]
PublicKey=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
PrivateKey=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Customizing templates

EzComments uses some custom templates, here are the most important ones:

  • template/content/datatype/view/ezcomcomments.tpl. Show comment form and list current comments.
  • The template of the notification e-mail vary according to the value of ezcomments.ini.[NotificationSettings].CommentsInOne, whether it's true or false. When it's true all notifications will be send in one single email and if false an e-mail will be sent for each new comment notification. I suggest you the first option for be more efficient for and less annoying for the users.

    The following templates are used when the parameter is true:
    * template/comment/notification_subject.tpl
    * template/comment/notification_body.tpl
    And these others in case it's false:
    * template/comment/notification_multi_body.tpl
    * template/comment/notification_multi_subject.tpl

  • The templates used by the subscription activation e-mail. There are two, one for the subject and other for the body e-mail, located under:
    * template/comment/notification_activation_body.tpl
    * template/comment/notification_activation_subject.tpl

It's appropiate say than sometimes we need to configured the e-mail output format and this is done through the parameters ezcomments.ini.[NotificationSettings].MailContentType and ActivationEmailContentType. Here you can use the values text/plain or text/html.

Outside the Ez Publish scope, is important ensure that the notification emails aren't filter as junk or blocked at all, although each E-mail Service Provider are his own rules, you can send an email to check-auth@verifier.port25.com and get a response that brings simple checks of various sender authentication mechanisms. Also consider useful read this post http://www.comunidadhosting.com/web-hosting/5855-spf-hotmail.html

Usage

Editor Side

During the content object edition with an comment datatype, an editor can choose whether permit new comments posting or whether show the existing ones. It can be done by ticking the 'Enable commenting' and 'Show comments' checkboxes respectively.

Is important say that uncheck 'Show Comments' implies disable comments posting. For more info go to the official documentation.

Site Visitor Side

hen a visitor is authorized to view a content object with comments feature, the page present him/her a commenting form and the list of comments. The commenting form let you post a new comment from the same page unlike the traditional process that would require a redirection to a content edit form.

From the comment list you can also edit or delete comments either all or one's own according to the configured policies for the current user. For more information see http://doc.ez.no/Extensions/eZ-Comments/Setup-and-user-guide-1.1/Using-eZ-Comments/Viewing-and-posting-comments

Enabling/disabling fields

By default all the comment fields are enabled, but you can limited them to the desired ones. This is achieved by commenting out the fields listed in ezcomments.ini.append.php.[FormSettings].AvailableFields, here's an example:

[FormSettings]
AvailableFields[]
#AvailableFields[]=title
AvailableFields[]=name
#AvailableFields[]=website
AvailableFields[]=email
#The comment field can not be deleted!
AvailableFields[]=comment
AvailableFields[]=notificationField

So, only the name, email and comment will be asked in the commenting form. Also you can configure some fields behavior. Here's an example

#Make the website field required
[website]
Required=true
PostVarName=CommentWebsite
AttributeName=url

Here you probably change PostVarName -HTML input name-, but shouldn't modify AttributeName unless want to change some php files specifically classes/ezcomcomment.php

Well this is all for the moment. Stay tuned that I'll put further information soon.

eZ debug

Timing: Jan 17 2025 23:57:58
Script start
Timing: Jan 17 2025 23:57:58
Module start 'content'
Timing: Jan 17 2025 23:57:58
Module end 'content'
Timing: Jan 17 2025 23:57:58
Script end

Main resources:

Total runtime0.1712 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.0096 589.2578180.8359
Module start 'content' 0.00960.0055 770.0938107.6094
Module end 'content' 0.01520.1559 877.7031548.8828
Script end 0.1711  1,426.5859 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00382.2163200.0002
Check MTime0.00150.8502200.0001
Mysql Total
Database connection0.00110.615210.0011
Mysqli_queries0.105861.82001410.0008
Looping result0.00130.75451390.0000
Template Total0.155690.910.1556
Template load0.00100.566610.0010
Template processing0.154690.307210.1546
Override
Cache load0.00070.393110.0007
Sytem overhead
Fetch class attribute can translate value0.00140.845310.0014
XML
Image XML parsing0.00040.235510.0004
General
dbfile0.00935.4500200.0005
String conversion0.00000.003530.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