Installing and configuring Ez Comments

Wednesday 29 September 2010 2:29:02 pm

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.

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 03:07:31
Script start
Timing: Jan 18 2025 03:07:31
Module start 'layout'
Timing: Jan 18 2025 03:07:31
Module start 'content'
Timing: Jan 18 2025 03:07:31
Module end 'content'
Timing: Jan 18 2025 03:07:31
Script end

Main resources:

Total runtime0.1193 sec
Peak memory usage6,144.0000 KB
Database Queries43

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0057 588.0313152.6406
Module start 'layout' 0.00570.0031 740.671939.4844
Module start 'content' 0.00870.1092 780.1563450.9297
Module end 'content' 0.11790.0013 1,231.085923.7031
Script end 0.1192  1,254.7891 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00312.5923150.0002
Check MTime0.00121.0391150.0001
Mysql Total
Database connection0.00060.491410.0006
Mysqli_queries0.031326.2392430.0007
Looping result0.00030.2405410.0000
Template Total0.089875.320.0449
Template load0.00231.906020.0011
Template processing0.087573.373620.0438
Template load and register function0.00010.103210.0001
states
state_id_array0.00070.617910.0007
state_identifier_array0.00060.476220.0003
Override
Cache load0.00221.82061370.0000
Sytem overhead
Fetch class attribute name0.00282.337830.0009
class_abstraction
Instantiating content class attribute0.00000.013430.0000
General
dbfile0.00161.3180100.0002
String conversion0.00000.010040.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.tplblog_entry/full.tplextension/community_design/design/suncana/override/templates/blog_entry/full.tplEdit templateOverride template
2content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
7content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
34content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
5content/datatype/view/ezxmltags/header.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/header.tplEdit templateOverride template
14content/datatype/view/ezxmltags/strong.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/strong.tplEdit templateOverride template
9content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
6content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
9content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
17content/datatype/view/ezxmltags/emphasize.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/emphasize.tplEdit templateOverride template
6content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezkeyword.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezkeyword.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 112
 Number of unique templates used: 13

Time used to render debug report: 0.0002 secs