texxasrulez / matomo_analytics
Matomo Analytics integration plugin for Roundcube
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
Type:roundcube-plugin
pkg:composer/texxasrulez/matomo_analytics
Requires
- php: >=7.4
- composer/installers: ^2.2
README
This plugin integrates Matomo Analytics into Roundcube by injecting the official Matomo tracking snippet on rendered pages.
Why this exists
Older Roundcube plugins targeted Piwik (Matomo's former name). This plugin is a clean Matomo-first replacement with simple configuration and privacy-aware defaults.
Features
- Injects Matomo tracking script on all Roundcube pages.
- Optional Do Not Track (DNT) honoring.
- Optionally disable tracking for authenticated users.
- Composer-installable, using composer/installers.
- Zero changes required to Roundcube templates.
Installation
A) Composer (recommended)
From your Roundcube installation root:
composer require texxasrulez/matomo_analytics
This will install the plugin into plugins/matomo_analytics/.
B) Manual installation
- Download the release archive.
- Extract into your Roundcube plugins/directory so it looks like:
roundcubemail/
└── plugins/
    └── matomo_analytics/
        ├── matomo_analytics.php
        ├── config.inc.php.dist
        └── composer.json
Configuration
Note on Matomo URL: You may set
matomo_analytics_urlto a full URL (https://analytics.example.com/matomo) or a relative path (e.g.,/matomo). The plugin normalizes relative values to an absolute URL usingwindow.location.origin. If you see.../mail/matomo.js404s, your URL was relative without a leading slash (matomo); use/matomoor the full URL.
Copy the sample config and edit values:
cp plugins/matomo_analytics/config.inc.php.dist plugins/matomo_analytics/config.inc.php
Open plugins/matomo_analytics/config.inc.php and set:
// Matomo base URL (no trailing slash) $config['matomo_analytics_url'] = 'https://analytics.example.com'; // Matomo site ID (integer) $config['matomo_analytics_site_id'] = 1; // Respect browser Do Not Track header $config['matomo_analytics_respect_dnt'] = true; // Disable tracking for authenticated Roundcube users $config['matomo_analytics_disable_for_authenticated'] = false;
Enabling the plugin
Edit config/config.inc.php in your Roundcube installation and add the plugin:
$config['plugins'][] = 'matomo_analytics';
Clear Roundcube caches if necessary:
bin/cleancache.sh
How it works
The plugin hooks into Roundcube's render_page event and injects the official Matomo loader:
var _paq = window._paq = window._paq || []; _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u = '<MATOMO_URL>/'; _paq.push(['setTrackerUrl', u+'matomo.php']); _paq.push(['setSiteId', '<SITE_ID>']); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s); })();
When respect_dnt is enabled, the plugin checks the browser's DNT flags and skips injection if enabled. When disable_for_authenticated is true, no tracking is injected for logged-in users.
Debugging
Set options in plugins/matomo_analytics/config.inc.php:
$config['matomo_analytics_debug_enabled'] = true; // write debug entries to Roundcube logs $config['matomo_analytics_debug_html_comments'] = true; // add HTML comment after injection $config['matomo_analytics_debug_log_channel'] = 'matomo_analytics'; // optional custom log channel
View logs at logs/matomo_analytics (or your custom channel). Entries are JSON-encoded with event tags like
init, render_page:start, render_page:skip:*, render_page:injected, render_page:error.
Smoke test
- Enable the plugin and set debug_enabled = true.
- Load Roundcube UI and check:
- View Source: find the Matomo snippet, and optionally the <!-- matomo_analytics: injected tracking snippet -->comment.
- logs/matomo_analytics: verify entries for injection and config.
 
- View Source: find the Matomo snippet, and optionally the 
- Toggle disable_for_authenticatedandrespect_dntto verify skip paths.
Debugging & Verification
Enable debug in plugins/matomo_analytics/config.inc.php:
$config['matomo_analytics_debug_enabled'] = true; $config['matomo_analytics_debug_html_comments'] = true; $config['matomo_analytics_debug_console'] = true;
Open the Roundcube UI:
- View Source → Confirm the Matomo snippet and optional <!-- matomo_analytics: injected tracking snippet -->.
- Browser Console → Look for [matomo_analytics] injectinginfo line.
- Network tab → Verify matomo.jsloads 200 andmatomo.phprequests show 200/204 withidsite=<your id>.
- Roundcube logs (logs/matomo_analytics) → JSON events for injection/skip/errors.
Common blockers
- Content-Security-Policy headers must allow script-srcfrom your Matomo origin andimg-srcfor the beacon.
- Ad/tracking blockers can block matomo.jsormatomo.php. Test in a private window with blockers disabled.
- Mixed Content: Roundcube must be served over HTTPS if Matomo URL is HTTPS (and vice versa). Avoid protocol mismatches.
- Wrong Site ID / URL: Confirm the Site IDmatches exactly in your Matomo UI and that the URL points to the Matomo root.
Extras
- Cross-domain/subdomain tracking:
$config['matomo_analytics_cookie_domain'] = '.example.com'; $config['matomo_analytics_domains'] = ['*.example.com']; 
- Time-on-page accuracy:
$config['matomo_analytics_enable_heartbeat'] = true; 
- JS-blocked environments: enable <noscript>beacon:$config['matomo_analytics_fallback_img_beacon'] = true; 
Requirements
- PHP >= 7.4
- Roundcube >= 1.4
- A running Matomo server (URL + Site ID)
Uninstall
Composer:
composer remove texxasrulez/matomo_analytics
Manual: delete the plugins/matomo_analytics/ directory.
License
MIT