webfactory / piwik-bundle
Symfony Bundle that adds a twig-function for the Matomo tracking code.
Installs: 124 417
Dependents: 1
Suggesters: 0
Security: 0
Stars: 38
Watchers: 8
Forks: 16
Open Issues: 4
Type:symfony-bundle
pkg:composer/webfactory/piwik-bundle
Requires
- php: >=7.1
- ext-json: *
- symfony/config: ~3.0|~4.0|~5.0|~6.0|~7.0
- symfony/dependency-injection: ~3.0|~4.0|~5.0|~6.0|~7.0
- symfony/http-kernel: ~3.0|~4.0|~5.0|~6.0|~7.0
- twig/twig: ^1.34|^2.0|^3.0
Requires (Dev)
- phpunit/phpunit: ^8.5
- symfony/phpunit-bridge: >= 4.4
README
A Symfony Bundle that helps you to use the Matomo (formerly known as Piwik) Open Analytics Platform with your project.
It contains a Twig function that can insert the tracking code into your website. Plus, you can turn it off with a simple configuration switch so you don't track your dev environment.
Installation
composer require webfactory/piwik-bundle
And enable the bundle in app/AppKernel.php:
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new Webfactory\Bundle\PiwikBundle\WebfactoryPiwikBundle(), ); }
Usage
Somewhere in your views, right before the closing </body> tag, insert
{{ piwik_code() }}
This will add the appropriate Matomo tracking code as described in the API reference.
When you want to display the opt-out dialog as described in the documentation, use the following Twig code:
{{ piwik_opt_out_code() }}
Configuration
You can configure the bundle in your config.yml. Full Example:
webfactory_piwik: # Required, no default. Must be set to the site id found in the Matomo control panel site_id: 1 # Required. no default. Hostname and path to the Matomo host. piwik_host: my.piwik.hostname # Optional, has default. Usually, you only want to include the tracking code in a production environment disabled: '%kernel.debug%' # Optional, has default. Path to the tracking script on the host. tracker_path: "/js/" # Optional, has default. Disable cookies in favor of GDPR # https://matomo.org/faq/new-to-piwik/how-do-i-use-matomo-analytics-without-consent-or-cookie-banner/ & https://matomo.org/faq/general/faq_157/ disable_cookies: true
Add calls to the JavaScript tracker API
The JavaScript tracking API provides a lot of methods for setting the page name, tracking search results, using custom variables and much more.
The generic piwik() function allows you to control the _paq variable and add additional API calls to it. For example,
in your Twig template, you can write
<!-- Somewhere in your HTML, not necessarily at the end --> {{ piwik("setDocumentTitle", document.title) }} {{ piwik("trackGoal", 1) }} <!-- Then, at the end: --> {{ piwik_code() }} </body>
Note that when you call trackSiteSearch, this will automatically disable the trackPageView call made by default.
This is the recommended
behaviour.
Credits, Copyright and License
This code was written by webfactory GmbH, Bonn, Germany. We're a software development agency with a focus on PHP (mostly Symfony). If you're a developer looking for new challenges, we'd like to hear from you!
Copyright 2012 – 2020 webfactory GmbH, Bonn. Code released under the MIT license.