Brookins Consulting has created an extension called BC Website Statistics, licensed under the GPL, that we are happy to share with the eZ Publish community. This tutorial is the second in the eZ Publish “How to” series. The first article ( How to Configure an eZ Publish Site) described basic setup of an “eZ Tennis Club” website. In this tutorial we will add the BC Website Statistics extension to the eZ Tennis Club site. You will also learn how to use the Google Analytics service and gain a general understanding of the eZ Publish extension system.
In order to get the most out of this tutorial:
Keep in mind that the interfaces, buttons, screenshots and procedures may vary from those found in this article if you use a version other than eZ Publish 3.9.2 and the Website Interface 1.2. In most cases these variations will be minor and we encourage you to always work with the latest stable version available.
Let's assume that you are the webmaster of the eZ Tennis Club website. You want to know more about the features that attract and maintain the site’s international audience.
To gather this information, you need to collect page statistics either using page tagging or web server log file analysis. The former method – page tagging – can be used in conjunction with Google Analytics, and is the topic of this article. Log file analysis is another (and more traditional) method for analyzing site activity (although not discussed in this article). Awstats is a popular tool for performing this kind of analysis.
Google Analytics is a JavaScript-based client-side statistics collection tool. It is enabled by adding a snippet of JavaScript code to every page on a website. This code sends statistical information to Google whenever a page is loaded in a visitor’s web browser.
Google Analytics is an excellent solution to the problem of finding a simple, inexpensive way to perform website statistics collection. It also includes advanced tracking and reporting features that are not currently available via the traditional method of log file analysis.
Whether it's selling specific types of products, tracking user registration, learning the frequency of incomplete webshop checkouts or simply tracking specific URLs on a website, there are many possible tracking goals.
Before you begin measuring your site statistics, think about why you are measuring. Document your site goals, and plan what you are going to do with the results of the measurements. With a set of goals, you can use the information from Google Analytics to iterate through enhancement and measurement cycles.
For the eZ Tennis Club, the tracking goals are initially simple – we want to track international visitors, since one of the club's goals is to provide events, services, and news for a worldwide audience. We also want to find out how effective specific marketing activities are at promoting certain events. Generally, we want to know more about who is visiting the site, where they are from, and what they are looking for. We will keep this in mind for near the end of this tutorial, when we look at a few basic Google Analytics reports.
You can sign up for a free Google Analytics account at http://www.google.com/analytics/. If you do not already have a Google account (which is also free), then you must sign up for that first. Once you have activated and logged in to your Google Analytics account, click the Add Website Profile link, then enter the URL of your site and click the Continue button.
You should then see a page with some code in a text area. What you will need in order to configure the BC Website Statistics extension is the Urchin key, which is the value in quotation marks on this line:
_uacct = "your-urchin-key";
eZ Publish extensions are packages containing functionality that extend or alter the features of an eZ Publish site. eZ Publish is designed with a “plug-in” architecture, so that the system can be customized without affecting the core installation. After installation, extensions are either automatically detected by convention or specified via settings.
Extensions can provide custom functionality using the existing standard system of templates, designs, template operators, classes, datatypes, modules, fetches, extended attribute filters, views, workflow events, shop account handlers, shipping handlers, tax handlers, output handlers, login handlers, cli scripts, cronjobs, notifications, search engines, libraries, SQL files, packages, settings, patches and more.
This article does not describe how to create an extension. Instead, it explains how to install and use extensions created by other eZ Community members – specifically Brookins Consulting’s BC Website Statistics extension. If you want to learn how to create extensions, you can analyze the source code of existing eZ Publish extensions and refer to the documentation and other eZ Publish educational resources (such as the eZ Publish Basics book). Alternatively, there is a network of global eZ Partners who are available to build extensions according to your specifications.
There are a number of sources for obtaining extensions to eZ Publish. These include supported partner certified solutions and community-supported projects, contributions, SVN respository and public SVN repository.
This section describes how to install the BC Website Statistics extension on our eZ Tennis Club site. Most eZ Publish extensions are installed in a similar manner.
Extensions can be activated globally (which will affect every site – including translated sites – running from the eZ Publish installation) or can be activated for one or more specific siteaccesses.
There are two ways to activate extensions:
When you activate an extension through the Administration Interface, it will be activated for all siteaccesses.
When you manually enable an extension, you have greater control over the siteaccesses to which the extension applies. This gives you more granular control over the impact of the extension. As stated in the first article in this series, site settings follow an override order, where basic settings are overriden by siteaccess settings, which are overridden by global settings. Therefore, to enable the extension in only the “eng” siteaccess of the eZ Tennis Club site, we would edit settings/eng/site.ini.append.php and add an entry to the ActiveAccessExtensions[] array under the [ExtensionSettings] block:
[ExtensionSettings] ActiveAccessExtensions[] ActiveAccessExtensions[]=bcwebsitestatistics ActiveAccessExtensions[]=ezwebin
For the sake of this tutorial, we will activate the extension for all siteaccesses via the eZ Publish Administration Interface. To do so, click the Setup link on the top navigation bar. On the left menu, click the Extensions link. In the Available extensions window, mark the checkbox under the Activate column that corresponds to the bcwebsitestatistics extension. (Note that the extension name displayed in the Administration Interface corresponds to the directory name where the extension was installed.) Click the Apply changes button.
[BCWebsiteStatisticsSettings] # Required Settings Change Urchin=UA-2639251-2 # Default Settings OrderSubmit=enabled PageSubmit=enabled # Optional Settings # HostName=example.com HostName=disabled ShopName=eZPublishSite
The BC Website Statistics extension primarily consists of a template operator for the standard design. It could be considered a template operator extension.
If you are using a custom design extension (other than the Website Interface extension), you should create a pagelayout.tpl template override. Template overrides (see the documentation) and creating extensions (see the eZ Publish Basics book) are beyond the scope of this article. Therefore, in this article we will modify the pagelayout.tpl template for the Website Interface extension for the eZ Tennis Club site. However, on a real installation, you should do this through a template override because this file gets overwritten when you upgrade the Website Interface.
Place the template operator code {'false'|bc_ga_urchin()} as the last code element before the </head> tag in the extension/ezwebin/design/ezwebin/templates/pagelayout.tpl file.
{foreach ezini( 'JavaScriptSettings', 'JavaScriptList', 'design.ini' ) as $script} <script language="javascript" type="text/javascript" src={concat( 'javascript/', $script )|ezdesign}></script> {/foreach} {* The following is the required bcwebsitestatistics template operator *} {'false'|bc_ga_urchin()} </head> <body> <!-- Complete page area: START -->
To test that the BC Website Statistics extension has been correctly installed and configured:
Browse your site, loading several pages in order to generate activity that will be reported by Google Analytics. You will have to wait up to 24 hours after your first round of testing for the service to store and display the statistics in your reports.
If no statistics are reported by Google Analytics, the first thing to check is that you cleared the cache after installing the extension and template operator into the design template.
Then, check whether your template override for the pagelayout.tpl file is being recognized by the system. While viewing your site in a browser, right-click on an empty spot and select “View Page Source” (or the menu item specific to your browser). Then, look for this code:
<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
If that code is not present, enable template debugging by adding the following settings to the settings/override/site.ini.append.php file then clear the Ini settings and Static caches.
[DebugSettings] DebugOutput=enabled [TemplateSettings] Debug=enabled ShowUsedTemplates=enabled ShowXHTMLCode=disabled
Upon enabling the debug output, you will see a list of used templates, source code comments containing the path of templates used and general debug warnings, notices and errors. This information can be used to determine the cause of problems.
Google Analytics provides a portal for viewing reports on website activity. The portal uses dynamic HTML, JavaScript and Flash to provide access to a set of reports that describe various types of activity on your site.
With Google Analytics, the eZ Tennis Club site can track basic information such as page views, but also perform much more sophisticated operations, like gathering webshop statistics, setting goals, measuring the success of Google AdWords campaigns, seeing how much time people are spending on the site, exporting reports and more. Statistics can be filtered by many different properties, such as by specific keyword or URL, in order to produce refined results. This is documented in the Google Analytics Help Center.
In this tutorial, we will give a brief tour of some of the basic Google Analytics functionality and show you how to set up automatic report generation.
After logging into your Google Analytics account, click the View Reports link for your site.
The left menu of the reporting interface provides access to information about who your visitors are (the Visitors item), how they got to your site (the Traffic Sources item), and which pages they are accessing (the Content item). We will describe one of the pages under each of these sections. We strongly encourage you to explore the Google Analytics documentation and interface, as this article only presents a small portion of what can be done.
Under the Visitors menu item, the Map Overlay page is a visual representation of where site visitors are located. Since the eZ Tennis Club wishes to attract an international audience, it can track the progress of its efforts in reaching the different parts of the globe.
Under the Traffic Sources menu item, on the Search Engines page, you can see which search terms visitors are using in order to find your site. The eZ Tennis Club is able to use this information to reveal what people are looking for when they come to the site. They can then make decisions regarding what keywords they need to target more, or perhaps what unexpected topics could be expanded upon in order for the club to reach a broader audience.
Under the Content menu item, the Top Content page shows which URLs are the most popular on a site. If the eZ Tennis Club were to run a marketing campaign to promote an upcoming tournament, it could direct all interested visitors to a specific tournament page, such as http://tennisdemo.ezsystems.ca/eztourney. Using Google Analytics, it could then gauge the success of that marketing campaign based on how many people visited that page and how much time they spent on that page.
You can configure one-time or scheduled customized email reports with a variety of report export formats. Simply click the Email button on almost any report view. This will send an email with an attached report.
If you click the Schedule tab, you can send periodic reports to interested parties in order to track regular progress on your website.
You can export reports into a variety of output formats including PDF, CSV, XML and TSV. Simply click the Export button on almost any report view and select the desired report format by clicking the export format link. This will open a new window prompting you to save the exported report file.
In this article, we set up visitor tracking on the fictional eZ Tennis Club site powered by eZ Publish using Google Analytics.
With the BC Website Statistics extension installed and configured within your eZ Publish installation, your website will transmit page statistics to the Google Analytics service. You should now have gained some experience and understanding with the following features within eZ Publish:
Subsequent articles in this tutorial series will explain other ways to enhance eZ Publish websites, including workflows, community features, RSS feeds and more!
We hope this tutorial has been helpful and interesting to the eZ Publish community, providing useful information about extensions, the BC Website Statistics extension and the Google Analytics service. We invite you to leave a comment or question about anything in this article.
Brookins Consulting makes implementing statistics services within eZ Publish simple with the BC Website Statistics extension.
This work is licensed under the GNU Free Documentation License (GFDL).
Timing: | Jan 18 2025 02:13:09 |
Script start | |
Timing: | Jan 18 2025 02:13:09 |
Module start 'layout' | |
Timing: | Jan 18 2025 02:13:09 |
Module start 'content' | |
Timing: | Jan 18 2025 02:13:10 |
Module end 'content' | |
Timing: | Jan 18 2025 02:13:10 |
Script end |
Total runtime | 0.3216 sec |
Peak memory usage | 4,096.0000 KB |
Database Queries | 54 |
Checkpoint | Start (sec) | Duration (sec) | Memory at start (KB) | Memory used (KB) |
---|---|---|---|---|
Script start | 0.0000 | 0.0081 | 589.4297 | 153.4688 |
Module start 'layout' | 0.0081 | 0.0037 | 742.8984 | 39.4375 |
Module start 'content' | 0.0118 | 0.3055 | 782.3359 | 833.6016 |
Module end 'content' | 0.3173 | 0.0043 | 1,615.9375 | 32.8125 |
Script end | 0.3216 | 1,648.7500 |
Accumulator | Duration (sec) | Duration (%) | Count | Average (sec) |
---|---|---|---|---|
Ini load | ||||
Load cache | 0.0039 | 1.2142 | 16 | 0.0002 |
Check MTime | 0.0016 | 0.5084 | 16 | 0.0001 |
Mysql Total | ||||
Database connection | 0.0011 | 0.3352 | 1 | 0.0011 |
Mysqli_queries | 0.0901 | 28.0124 | 54 | 0.0017 |
Looping result | 0.0008 | 0.2393 | 52 | 0.0000 |
Template Total | 0.2726 | 84.8 | 2 | 0.1363 |
Template load | 0.0023 | 0.7216 | 2 | 0.0012 |
Template processing | 0.2703 | 84.0276 | 2 | 0.1351 |
Template load and register function | 0.0001 | 0.0364 | 1 | 0.0001 |
states | ||||
state_id_array | 0.0090 | 2.7988 | 8 | 0.0011 |
state_identifier_array | 0.0059 | 1.8491 | 9 | 0.0007 |
Override | ||||
Cache load | 0.0042 | 1.3111 | 265 | 0.0000 |
Sytem overhead | ||||
Fetch class attribute name | 0.0022 | 0.6983 | 8 | 0.0003 |
Fetch class attribute can translate value | 0.0001 | 0.0286 | 7 | 0.0000 |
class_abstraction | ||||
Instantiating content class attribute | 0.0000 | 0.0050 | 8 | 0.0000 |
XML | ||||
Image XML parsing | 0.0236 | 7.3413 | 7 | 0.0034 |
General | ||||
dbfile | 0.0229 | 7.1171 | 24 | 0.0010 |
String conversion | 0.0000 | 0.0033 | 4 | 0.0000 |
Note: percentages do not add up to 100% because some accumulators overlap |
Usage | Requested template | Template | Template loaded | Edit | Override |
---|---|---|---|---|---|
1 | node/view/full.tpl | full/article.tpl | extension/sevenx/design/simple/override/templates/full/article.tpl | ||
1 | content/datatype/view/ezxmltext.tpl | <No override> | extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tpl | ||
21 | content/datatype/view/ezxmltags/link.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/link.tpl | ||
43 | content/datatype/view/ezxmltags/paragraph.tpl | <No override> | extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tpl | ||
19 | content/datatype/view/ezxmltags/header.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/header.tpl | ||
18 | content/datatype/view/ezxmltags/li.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/li.tpl | ||
6 | content/datatype/view/ezxmltags/ul.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ul.tpl | ||
5 | content/datatype/view/ezxmltags/newpage.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/newpage.tpl | ||
14 | content/datatype/view/ezxmltags/strong.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/strong.tpl | ||
7 | content/datatype/view/ezxmltags/embed.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/embed.tpl | ||
7 | content/view/embed.tpl | embed/image.tpl | extension/sevenx/design/simple/override/templates/embed/image.tpl | ||
7 | content/datatype/view/ezimage.tpl | <No override> | extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tpl | ||
6 | content/datatype/view/ezxmltags/literal.tpl | <No override> | extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tpl | ||
12 | content/datatype/view/ezxmltags/emphasize.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/emphasize.tpl | ||
3 | content/datatype/view/ezxmltags/ol.tpl | <No override> | design/standard/templates/content/datatype/view/ezxmltags/ol.tpl | ||
1 | print_pagelayout.tpl | <No override> | extension/community/design/community/templates/print_pagelayout.tpl | ||
Number of times templates used: 171 Number of unique templates used: 16 |
Time used to render debug report: 0.0002 secs