This plugin adds a Piwik stats site to your WordPress or WordPress multisite dashboard.
This plugin adds a Piwik stats site to your WordPress dashboard. It's also able to add the Piwik tracking code to your blog.
Requirements: PHP 5.4 (or higher), WordPress 4.0 (or higher), Piwik 2.9 (or higher; 2.16 or higher recommended)
Languages: English, Albania, Dutch, French, German, Greek, Hungarian, Italian, Portuguese (Brazil). Partially supported: Azerbaijani, Belarusian, Chinese (simplified), Hindi, Lithuanian, Luxembourgish, Norwegian, Persian, Romanian, Russian, Spanish, Swedish, Turkish, Ukrainian
Note: If you vote "It's broken", please tell me about your problem. It's hard to fix a bug I don't know about! ;-)
You can use following shortcodes if activated:
[wp-piwik module="overview" title="" period="day" date="yesterday"]
Shows overview table like WP-Piwik's overview dashboard. See Piwik API documentation on VisitsSummary.get to get more information on period and day. Multiple data arrays will be cumulated. If you fill the title attribute, its content will be shown in the table's title.
[wp-piwik module="opt-out" language="en" width="100%" height="200px"]
Shows the Piwik opt-out Iframe. You can change the Iframe's language by the language attribute (e.g. de for German language) and its width and height using the corresponding attributes.
[wp-piwik module="post" range="last30" key="sum_daily_nb_uniq_visitors"]
Shows the chosen keys value related to the current post. You can define a range (format: lastN, previousN or YYYY-MM-DD,YYYY-MM-DD) and the desired value's key (e.g., sum_daily_nb_uniq_visitors, nb_visits or nb_hits - for details see Piwik's API method Actions.getPageUrl using a range).
is equal to [wp-piwik module="overview" title="" period="day" date="yesterday"].
- Graphs powered by jqPlot (GPL 2.0 and MIT) and and jQuery Sparklines (New BSD License).
- All translators at the Transifex translation community.
- Donations: Marco L., Rolf W., Tobias U., Lars K., Donna F., Kevin D., Ramos S., Thomas M., John C., Andreas G., Ben M., Myra R. I., Carlos U. R.-S., Oleg I., M. N., Daniel K., James L., Jochen K., Cyril P., Thomas K., Patrik K., Zach, Sebastian W., Peakkom, Patrik K., Kati K., the Piwik team itself, and all people flattering this.
- All users who send me mails containing criticism, commendation, feature requests and bug reports - you help me to make WP-Piwik much better!
Thank you all!
|Tags||analytics, piwik, statistics, stats, wpmu|
Install WP-Piwik on a simple WordPress blog
Upload the full
wp-piwikdirectory into your
Activate the plugin through the 'Plugins' menu in WordPress.
Open the new 'Settings/WP-Piwik Settings' menu and follow the instructions to configure your Piwik connection. Save settings.
If you have view access to multiple site stats and did not enable "auto config", choose your blog and save settings again.
Look at 'Dashboard/WP-Piwik' to see your site stats.
Install WP-Piwik on a WordPress blog network (WPMU/WP multisite)
There are two differents methods to use WP-Piwik in a multisite environment: * As a Site Specific Plugin it behaves like a plugin installed on a simple WordPress blog. Each user can enable, configure and use WP-Piwik on his own. Users can even use their own Piwik instances (and accordingly they have to). * Using WP-Piwik as a Network Plugin equates to a central approach. A single Piwik instance is used and the site admin configures the plugin completely. Users are just allowed to see their own statistics, site admins can see each blog's stats.
Site Specific Plugin
Just add WP-Piwik to your /wp-content/plugins folder and enable the Plugins page for individual site administrators. Each user has to enable and configure WP-Piwik on his own if he want to use the plugin.
The Network Plugin support is still experimental. Please test it on your own (e.g. using a local copy of your WP multisite) before you use it in an user context.
Add WP-Piwik to your /wp-content/plugins folder and enable it as Network Plugin. Users can access their own statistics, site admins can access each blog's statistics and the plugin's configuration.
- Feature: Show "per post stats" and the "custom variable meta box" also on page and custom post edit
- Bugfix: Fixed user tracking (moved the user tracking changes from general modifications to runtime modifications)
- Bugfix: Fixed namespace error. Thx to thelfensdrfer, see https://github.com/braekling/WP-Piwik/pull/18
- Bugfix: Warning on blog name change, see https://wordpress.org/support/topic/wp-piwik-triggers-warning-when-changing-blog-name
- Feature: User ID Tracking. Thx to Danw33, see https://github.com/braekling/WP-Piwik/pull/16
- Feature: Site ID parameter added to opt-out shortcode. Thx to christianhennen, see https://github.com/braekling/WP-Piwik/pull/17
- Feature: Allow a local config file to affect the proxy script, see https://wordpress.org/support/topic/proxy-config-require-wp-loadphp-path
- Bugfix: No script tag is not auto-inserted if the tracking code is manually defined.
- Language updates
- Encoding & gettext fixes
- Better error messages. Thx to mcguffin, see https://github.com/braekling/WP-Piwik/pull/14
- Several language updates.
- Important security fix: XSS vulnerability
- Several language updates.
- Feature: Offer setDownloadExtensions option (see expert settings).
- Feature: Consider configured HHTP connection method in proxy script.
- Widget: Visitor country added.
- Bugfix: Annotations on scheduled posts will work.
- Bugfix: Donation button will work again.
- Several language updates.
- Switch to JSON renderer (Piwik 3 compatibility preparation)
- Workaround: PHP API will work with Piwik 2.14+, see https://github.com/piwik/piwik/issues/8311 for further information.
- Feature: Heartbeat timer support
- Feature: Expanded token & URL/path input fields
- Bugfix: Site duplication fix.
- Bugfix: Avoid notice on empty overview response.
- Bugfix: Return request error responses.
- Bugfix: Opt-out URL fixed.
- Bugfix: Capabilities: "Do not track"-filter and "show stats"-limit will work on multisites as expected again.
- Several language updates.
- Feature: Disable update notifications (expert settings).
- Feature: Choose between cURL and fopen if both are available (expert settings).
- Feature: Choose between POST and GET (expert settings).
- Widget: System details added.
- Widget: SEO widget re-enabled.
- Update: Replaced deprecated Piwik API calls.
- Bugfix: Settings link (toolbar, network mode) fixed.
- Bugfix: Encode blog titles in PHP mode.
- Bugfix: Pie charts won't show to long legends if more than 10 items are available.
- Several language updates, amongst others Portuges (Brazil) finished. See https://www.transifex.com/organization/piwik/dashboard/wp-piwik for further information.
- Feature: Expand "other" values on click
- Bugfix: Avoid notices on invalid file path (PHP API)
- Bugfix: Cookie lifetime input boxes are in some cases shown or hidden by mistake
- Network (multisite): Updated plugin to use wp_get_sites if possible
- Test script: Settings dump added
- Bugfix: Fixed memory & timeout issue on multisites
- Add clear cache function.
- Add clear settings (reset) function.
- Bugfix: Sitebrowser link (settings page, support) fixed
- Bugfix: Use new settings directly after saving (reloading is not necessary anymore)
- Optimized caching behaviour
- Language update (German, French)
- Bugfix: Opt-out shortcode output fix
- Bugfix: Opt-out shortcode will also work in "pro" and "php" mode
- Bugfix: Test script link (settings page, support) fixed
- Bugfix: Removed test script errors and notices
- Bugfix: Keep sure the revion ID is stored and avoid re-installing the plugin again and again
- Bugfix: http/pro - after configuration the settings page had to be reloaded once to start working
- Typo fixes
- Bugfix: Option storage bug if WP-Piwik is used as single site plugin on blog networks
- Bugfix: WP-Piwik will work without Piwik superuser access, again
- Bugfix: Choosing the site without auto config works again
- Bugfix: In some cases the update message did not disappear -> fixed
- Important change: If you want to upgrade from 0.8.x to 0.10.x, please install 0.9.9.18 first: https://downloads.wordpress.org/plugin/wp-piwik.0.9.9.18.zip
- Bugfix: Settings link in admin notices fixed
- Bugfix: Shortcode result will appear where expected
- Bugfix: 0.9.9.18 settings will be kept (if WP-Piwik was not reconfigured after updating to 0.10.0.3, yet)
- Feature: If Piwik returns an error instead of a tracking code, this error will be visible
- Public beta of WP-Piwik 1.0
- Full refactored code
- Feature: Limit referral cookie lifetime
- Feature: Enable content tracking
- Improvement: Define additional file extensions for tracking downloads
- Improvement: Added a POT file to support translators (Note: 1.0 will change a lot, so please don't spend too much time in translating the current version, e.g., by creating an all new translation. With 1.0 I will also offer a translation platform to support your work.)
- Improvement: If necessary, you can force Piwik to use HTTP or HTTPS now (e.g., to avoid redirections from http to https)
- Avoided a naming collision with Woo Theme
- Improvement: Updated the Piwik proxy script and added cURL support if url_fopen is not available
- Bugfix: Setup bug, see https://wordpress.org/support/topic/piwik-urlpath-not-saved
- Bugfix: CDN URL notice, see https://wordpress.org/support/topic/tracking-cdn-blank-gives-php-notice-which-breaks-the-trackback-js-code
- Bugfix: Fixed zlib compression notice, see https://wordpress.org/support/topic/v09914-is-bad
- Bugfix: Proxy script label links to proxy script checkbox
- Fixed a typo in German language file
- Bugfix: PHP API causes plain text output issue (see 0.9.9.11)
- Bugfix: Shortcode output translated
- Bugfix: One more commit error
- Bugfix: Adding up problem related to the overview widget
- Bugfix: Fixes missing brackets on ob_start
- Hotfix: Adds /0.9.9.15 to js/index.php to force a reload
- Bugifx: Replaced broken support link
- Added a bitcoin donation link
- Bugfix: Commit errors in 0.9.9.13
- Improvement: Only activate/ load admin components if an admin page is actually loaded. Thanks to Michael!
- Bugfix: Proxy tracking will work again. Piwik 2.7 or higher is recommended.
- Bugfix: Avoid a PHP notice in dashboard
- NOTE: If you update Piwik and use the "add tracking code" feature, please also update your WP-Piwik tracking code: Just open the WP-Piwik tracking code settings and save them again.
- Bugfix: Avoid forced relogin on site change (WP network)
- Bugfix: Avoid multiple annotations on post updates
- Bugfix: User mergeSubdomains instead of mergeAliasURLs
- Feature: Added mergeAliasURLs as additional feature
- Bugfix: PHP API causes plain text output issue, see http://wordpress.org/support/topic/bug-cant-access-to-tabs-in-setting-after-configuration
- Bugfix: PHP API causes WordPress multisite login issue, see http://wordpress.org/support/topic/causes-multisite-superadmin-subsite-login-problem
- Bugfix: Removed PHP warning if annotations are enabled and annotations will work again, see http://wordpress.org/support/topic/warning-message-everywhere-in-the-backend-call_user_func_array-expects
- Feature: "Track visitors across all subdomains" script changes are done by Piwik now, see http://wordpress.org/support/topic/track-across-subdomains-wp-on-subdomain?replies=2
- Update: Flattr API update
- Bugfix: Multisite login issue, see http://wordpress.org/support/topic/0999-multisite-frontend-not-logged-in
- Bugfix: wpMandrill compatibility, see http://wordpress.org/support/topic/version-0999-conflicts-with-wpmandrill
- Feature: Show page views (actions) in "visitors last 30"
- Update: PHP API will use namespaces (Piwik 2.x compatibility)
- Update: Piwik URL isn't necessary to use PHP API anymore.
- Feature: Limit cookie lifetime
- Feature: Track visitors across all subdomains
- Feature: Disable custom var box if necessary
- Feature: Choose if you like to add the tracking code to your site's footer or header
- Feature: New shortcode (post)
- Feature: Add data-cfasync=false to script tag if necessary.
- Feature: Add annotations on new posts, see http://linuxundich.de/webhosting/beim-veroeffentlichen-von-wordpress-posts-eine-anmerkung-in-piwik-setzen/
- Bugfix: Do not load sparklines plugin if toolbar not shown
- Bugfix: PHP API will work again (urlencoding removed)
- jqPlot and jquery.sparkline updated
- Partly refactored code
- Feature: Per post stats (shown at the edit post page)
- Feature: Track RSS views using a measurement pixel
- Bugfix: Error messages won't by cached anymore
- Bugfix: Custom vars will now be added properly
- Bugfix: Missing slash in proxy mode added
- Feature: Track users on admin pages
- Bugfix: Proxy script will work again
- Option: Enable/disable one week caching
- Load config file using full path to avoid side effects
- Fatal error on statistics settings page fixed
- Use Transients API (one week caching)
- Sparkline script update (IE 10 compatibility)
- Syntax error fixes
- Bugfix regarding tracking code changes in proxy mode, see http://wordpress.org/support/topic/problem-with-https-in-proxy-mode
- Feature: Change text "WP-Piwik" in menu items and dashboard widgets
- Code cleanup ("new" first step)
- Debugging: Logger added
- Avoid double slash (//) in tracking code
- CDN support: http and https separated, see http://wordpress.org/support/topic/request-cdn-support-1
- Made code optional. Move code to site footer.
- Piwik 1.11 compaitbility fixes (Piwik 1.11 required now!)
- Depending on Piwik 1.11 WP-Piwik will use async tracking now
- CDN support added, see http://wordpress.org/support/topic/request-cdn-support-1
- Warning on empty data removed (overview table)
- Removed a possible deadlock
- Bugfix: Apply tracking code settings everytime the tracking code is updated
- Reset/uninstall script bugfix regarding network mode
- WordPress 3.5 compatibility fix: http://wordpress.org/support/topic/v35-errors-fix?replies=5 (Thanks Christian Foellmann!)
- Site Search stats added
- Use js/index.php: Replaces piwik.js and piwik.php by js/ (instead of piwik.js only)
- Connection timeout setting added
- Full reset option added
- Uninstall script added
- Stats metaboxes: Date formatted
- Use proxy settings defined in wp-config.php
- Piwik.php proxy script added (see http://piwik.org/faq/how-to/#faq_132)
- Bugfix: After upgrade, Piwik automatically places cookies again (http://wordpress.org/support/topic/after-upgrade-piwik-automatically-places-cookies-again)
- Shortcodes added
- WP-Piwik will rename sites in Piwik if site name changes in WordPress
- Bugfix: Tracking code changes should stay active after WP-Piwik updates
- Piwik 1.9+ compatibility fix (Piwik 1.9 required!)
- Browser version details added
- Toolbar graph bugfix
- Option: Disable SSL peer verification (REST API)
- Option: Use own user agent
- Test script displays additional information (e.g. response headers)
- Using WordPress metabox concept properly
- Bugfix: Sparkline script only loaded if required
- Stats site supports up to 3 columns
- Network admin stats: Choose site using a paged table (instead of a select box).
- Feature: Custom variables, using custom post meta boxes.
- Some minor bugfixes
- WordPress 3.4 compatible (workaround)
- Requires at least Piwik 1.8.2!
- Choose between HTTP API or PHP API
- Show graph on WordPress Toolbar
- Add option to disable cookies - Thanks to Mathias T.!
- Update bugfix: Upgrading from WP-Piwik 0.8.7 or less will work again
- Some minor bugfixes
- Bugfix: Adding a new site will work again.
- Uses $wpdb->blogs instead of $wpdb->prefix.'blogs' to keep it compatible to different database plugins
- Bugfix: SEO dashboard widget will work even if "last 30" is selected
- Bugfix: New created blogs won't show "Please specify a value for 'idSite'." anymore.
- Bugfix: New network sites without title will be created
- Bugfix: Upgrading from old versions will work again
- Tabbed settings
- Debug tools added (testscript, site configuration overview and WP-Piwik reset)
- Support forum RSS feed
- Language updates
- Optionally use of set_time_limit(0) on stats page time out
- Bugfix: Usage as "Site Specific Plugin" mixed up the different sites settings (network mode)
- Hotfix: Avoid "Unknown site/blog" message without giving a chance to choose an existing site. Thank you, Taimon!
- No code change required to enable WPMU mode anymore (Still experimental. Please create a backup before trying 0.9.0!)
- All features in WPMU available
- Bugfix: Removed unnecessary API calls done with each site request - Thank you, Martin B.!
- Bugfix: No stats on dashboard (sometimes this issue still occured, should be fixed now)
- Code cleanup (still not finished)
- Minor UI fixes
- Minor language/gettext improvements
- Security improvements
- Show SEO rank stats (very slow, caching will be added in 0.9.1)
- WordPress dashboard SEO rank widget (very slow, caching will be added in 0.9.1)
- New option: use js/index.php
- New option: avoid mod_security
- Mulisite: Order blog list alphabetically (Network Admin stats site)
- Settings: Order site list alphabetically (site list shown if order conf is disabled)
- jqplot update (IE 9 compatibility) - Thank you, Martin!
- Bugfix: No stats on dashboard
- Layout fix: Graph width on dashboard
- Minor code cleanup
- WP 3.2 compatible, metabox support
- Bugfix: Will also work with index.php in Piwik path
- Bugfix: last30 dashboard widget - show correct bounce rate
- New language files (Azerbaijani, Greek, Russian)
- Fixed hardcoded database prefix (WPMU-Piwik)
- Minor bugfixes: avoid some PHP warnings
- Added an optional visitor chart to the WordPress dashboard
- WPMU/multisite bug fixed
- Minor bugfixes
- Select default date (today or yesterday) shown on statistics page
- Bugfix: Shortcut links are shown again
- German language file update
- Minor optical fixes (text length)
- New stats in overview box
- WP 3.x compability fixes (capability and deprecated function warnings)
- Some minor bugfixes
- New config handling
- Code clean up (not finished)
- Piwik 1.1+ compatibility fix
- Bugfix: WPMU URL update bug
- Use load_plugin_textdomain instead of load_textdomain
- Fixed js/css links if symbolic links are used
- Changed experimental WPMU support to experimental WP multisite support
- Try curl() before fopen() to avoid an OpenSSL bug
- Added Norwegian language file by Gormer.
- Don't worry - new features will follow soon. ;)
- Using jqPlot instead of Google Chart API
- Some facelifting
- Some minor bugfixes
- Track 404-pages in an own category
- Get some page (and article) details
- Language updates
- Bugfix: Percent calculation fixed
- Bugfix: Visitor chart: No label overlapping if < 50 visitory/day
- Visitor chart: Added a red unique visitor average line
- Visitor table: Added a TOTAL stats line
- Pie charts: Show top 9 + "others", new color range
- Option: Show Piwik shortcut in overview box
- Some performance optimization
- Unnecessary debug output removed
- German language file update
- WordPress dashboard widget: last 30 days view added
- Click at a visitor stats day-row to load its details.
- Add stats overview to your WordPress dashboard
- Added experimental WPMU support
- Switch to disable Google Chart API
- Added Albanian [sq] language file
- Added Belorussian [be_BY] language file
- Display statistics to selected user roles
- Some HTML fixes (settings page)
- Tracking filter added
- Resolution stats
- Operating System stats
- Plugin stats
- If allow_url_fopen is disabled in php.ini, WP-Piwik tries to use CURL instead of file_get_contents.
- WordPress 2.8 compatible
- Bugfix: Warnings on WP 2.8 plugins site
- Dashboard revised
- Partly optimized code
- WP-Piwik dashboard widgetized.
- Stats-boxes sortable and closeable.
- German language file added
- Browser stats and bounced visitors
- First public version.
Where can I find the Piwik URL and the Piwik auth token?
As soon as Piwik works, you'll be able to configure WP-Piwik: The Piwik URL is the same URL you use to access your Piwik, e.g. for the demo site: http://demo.piwik.org. The auth token is some kind of a secret password, which allows WP-Piwik to get the necessary data from Piwik. To get your auth token, log in to Piwik, click at your user name (top right) and click at "API" (left sidebar menu).
You can get a more detailed description here: https://piwik.org/blog/2015/05/wordpress-integration-wp-piwik-1-0/
Can I contribute to WP-Piwik as a translator?
You like to contribute to WP-Piwik translations? Please use the Transifex translation community.
Of course, I will add missing languages if requested, and I will also upload the existing language files of older WP-Piwik releases.
If you can't (or don not want to) use transifex, you can also translate languages/wp-piwik.pot delivered with WP-Piwik.
Thank you very much! :-)
Why does WP-Piwik require a newer PHP version than WordPress?
WP-Piwik requires a working Piwik instance which requires a higher PHP version, too. Furthermore, please have a look at the official PHP Unsupported Branches page. Even if your software still works with PHP 5.2, the PHP team stopped to deliver security patches in January 2011. Even PHP 5.3 does not get security patches anymore (end of life date was August 2014).
Tracking does not work on HostGator! / The test script shows an empty response.
Try to enable the "avoid mod_security" option (WP-Piwik settings, Tracking tab) or create a mod_security whitelist.
Overview shortcode shows no unique visitors using a yearly range.
See Piwik FAQ.