2011-09-25 10:56:03 +02:00
< ? php
/**
2019-02-19 07:21:05 +01:00
* Name : Matomo / Piwik Analytics
* Description : Matomo / Piwik Analytics Addon for Friendica
2016-07-28 16:32:05 +02:00
* Version : 1.3
2013-06-14 19:40:10 +02:00
* Author : Tobias Diekershoff < https :// f . diekershoff . de / profile / tobias >
2012-02-19 10:17:38 +01:00
* Author : Klaus Weidenbach
2011-09-25 10:56:03 +02:00
*/
2018-01-20 14:57:41 +01:00
/* Piwik Analytics Addon for Friendica
2011-09-25 10:56:03 +02:00
*
* Author : Tobias Diekershoff
* tobias . diekershoff @ gmx . net
*
2012-02-19 10:17:38 +01:00
* License : 3 - clause BSD license
2011-09-25 10:56:03 +02:00
*
* Configuration :
2014-08-11 09:07:25 +02:00
* Use the administration panel to configure the Piwik tracking addon , or
2018-11-25 08:15:18 +01:00
* in case you don ' t use this add the following lines to your config / addon . config . php
2014-08-11 09:07:25 +02:00
* file :
2011-09-25 10:56:03 +02:00
*
2018-06-28 05:18:33 +02:00
* [ piwik ]
* baseurl = example . com / piwik /
* sideid = 1
* optout = true ; set to false to disable
* async = false ; set to true to enable
2011-09-25 10:56:03 +02:00
*
2012-01-31 12:08:46 +01:00
* Change the siteid to the ID that the Piwik tracker for your Friendica
2011-09-25 10:56:03 +02:00
* installation has . Alter the baseurl to fit your needs , don ' t care
* about http / https but beware to put the trailing / at the end of your
* setting .
*/
2019-02-03 22:22:03 +01:00
2017-11-07 00:55:24 +01:00
use Friendica\Core\Config ;
2018-12-26 08:28:16 +01:00
use Friendica\Core\Hook ;
2018-10-30 00:40:18 +01:00
use Friendica\Core\Logger ;
2018-10-31 15:55:15 +01:00
use Friendica\Core\Renderer ;
2019-12-30 03:55:10 +01:00
use Friendica\DI ;
2019-06-23 19:56:21 +02:00
use Friendica\Util\ConfigFileLoader ;
2018-11-08 17:45:19 +01:00
use Friendica\Util\Strings ;
2017-11-07 00:55:24 +01:00
2011-09-25 10:56:03 +02:00
function piwik_install () {
2018-12-26 08:28:16 +01:00
Hook :: register ( 'load_config' , 'addon/piwik/piwik.php' , 'piwik_load_config' );
Hook :: register ( 'page_end' , 'addon/piwik/piwik.php' , 'piwik_analytics' );
2011-09-25 10:56:03 +02:00
2018-10-30 00:40:18 +01:00
Logger :: log ( " installed piwik addon " );
2011-09-25 10:56:03 +02:00
}
function piwik_uninstall () {
2018-12-26 08:28:16 +01:00
Hook :: unregister ( 'load_config' , 'addon/piwik/piwik.php' , 'piwik_load_config' );
Hook :: unregister ( 'page_end' , 'addon/piwik/piwik.php' , 'piwik_analytics' );
2011-09-25 10:56:03 +02:00
2018-10-30 00:40:18 +01:00
Logger :: log ( " uninstalled piwik addon " );
2011-09-25 10:56:03 +02:00
}
2019-03-24 12:54:26 +01:00
function piwik_load_config ( \Friendica\App $a , ConfigFileLoader $loader )
2018-06-28 05:18:33 +02:00
{
2019-02-10 20:10:59 +01:00
$a -> getConfigCache () -> load ( $loader -> loadAddonConfig ( 'piwik' ));
2018-06-28 05:18:33 +02:00
}
2011-09-25 10:56:03 +02:00
function piwik_analytics ( $a , & $b ) {
/*
2018-01-20 14:57:41 +01:00
* styling of every HTML block added by this addon is done in the
2012-01-31 12:08:46 +01:00
* associated CSS file . We just have to tell Friendica to get it
2011-09-25 10:56:03 +02:00
* into the page header .
*/
2019-12-30 21:53:43 +01:00
DI :: page ()[ 'htmlhead' ] .= '<link rel="stylesheet" type="text/css" href="' . DI :: baseUrl () -> get () . '/addon/piwik/piwik.css' . '" media="all" />' ;
2011-09-25 10:56:03 +02:00
/*
2018-11-25 08:15:18 +01:00
* Get the configuration variables from the config / addon . config . php file .
2011-09-25 10:56:03 +02:00
*/
2020-01-19 21:21:12 +01:00
$baseurl = DI :: config () -> get ( 'piwik' , 'baseurl' );
$siteid = DI :: config () -> get ( 'piwik' , 'siteid' );
$optout = DI :: config () -> get ( 'piwik' , 'optout' );
$async = DI :: config () -> get ( 'piwik' , 'async' );
2011-09-25 10:56:03 +02:00
/*
2012-02-19 10:17:38 +01:00
* Add the Piwik tracking code for the site .
* If async is set to true use asynchronous tracking
2011-09-25 10:56:03 +02:00
*/
2012-02-19 10:17:38 +01:00
if ( $async ) {
2014-08-11 09:07:25 +02:00
$b .= " <!-- Piwik --> <script type= \" text/javascript \" > var _paq = _paq || []; _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u=(( \" https: \" == document.location.protocol) ? \" https \" : \" http \" ) + \" :// " . $baseurl . " \" ; _paq.push(['setTrackerUrl', u+'piwik.php']); _paq.push(['setSiteId', " . $siteid . " ]); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.type='text/javascript'; g.defer=true; g.async=true; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s); })(); </script> <!-- End Piwik Code --> \r \n " ;
2012-08-14 18:22:31 +02:00
$b .= " <div id='piwik-code-block'> <!-- Piwik --> \r \n <noscript><p><img src= \" // " . $baseurl . " piwik.php?idsite= " . $siteid . " \" style= \" border:0 \" alt= \" \" /></p></noscript> \r \n <!-- End Piwik Tracking Tag --> </div> " ;
2012-02-19 10:17:38 +01:00
} else {
2014-08-11 09:07:25 +02:00
$b .= " <!-- Piwik --> <script type= \" text/javascript \" > var _paq = _paq || []; _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u=(( \" https: \" == document.location.protocol) ? \" https \" : \" http \" ) + \" :// " . $baseurl . " \" ; _paq.push(['setTrackerUrl', u+'piwik.php']); _paq.push(['setSiteId', " . $siteid . " ]); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.type='text/javascript'; g.defer=true; g.async=false; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s); })(); </script> <!-- End Piwik Code --> \r \n " ;
2012-02-19 10:17:38 +01:00
}
2011-09-25 10:56:03 +02:00
/*
* If the optout variable is set to true then display the notice
* otherwise just include the above code into the page .
*/
if ( $optout ) {
2012-02-19 10:17:38 +01:00
$b .= " <div id='piwik-optout-link'> " ;
2020-01-18 20:52:33 +01:00
$b .= DI :: l10n () -> t ( " This website is tracked using the <a href='http://www.matomo.org'>Matomo</a> analytics tool. " );
2012-02-19 10:17:38 +01:00
$b .= " " ;
2012-08-14 18:33:24 +02:00
$the_url = " http:// " . $baseurl . " index.php?module=CoreAdminHome&action=optOut " ;
2020-01-18 20:52:33 +01:00
$b .= DI :: l10n () -> t ( " If you do not want that your visits are logged in this way you <a href='%s'>can set a cookie to prevent Matomo / Piwik from tracking further visits of the site</a> (opt-out). " , $the_url );
2012-02-19 10:17:38 +01:00
$b .= " </div> " ;
2011-09-25 10:56:03 +02:00
}
}
2018-01-20 14:57:41 +01:00
function piwik_addon_admin ( & $a , & $o ) {
2018-10-31 15:55:15 +01:00
$t = Renderer :: getMarkupTemplate ( " admin.tpl " , " addon/piwik/ " );
$o = Renderer :: replaceMacros ( $t , [
2020-01-18 20:52:33 +01:00
'$submit' => DI :: l10n () -> t ( 'Save Settings' ),
2020-01-19 21:21:12 +01:00
'$piwikbaseurl' => [ 'baseurl' , DI :: l10n () -> t ( 'Matomo (Piwik) Base URL' ), DI :: config () -> get ( 'piwik' , 'baseurl' ), DI :: l10n () -> t ( 'Absolute path to your Matomo (Piwik) installation. (without protocol (http/s), with trailing slash)' )],
'$siteid' => [ 'siteid' , DI :: l10n () -> t ( 'Site ID' ), DI :: config () -> get ( 'piwik' , 'siteid' ), '' ],
'$optout' => [ 'optout' , DI :: l10n () -> t ( 'Show opt-out cookie link?' ), DI :: config () -> get ( 'piwik' , 'optout' ), '' ],
'$async' => [ 'async' , DI :: l10n () -> t ( 'Asynchronous tracking' ), DI :: config () -> get ( 'piwik' , 'async' ), '' ],
2018-01-15 14:15:33 +01:00
]);
2011-09-25 10:56:03 +02:00
}
2018-01-20 14:57:41 +01:00
function piwik_addon_admin_post ( & $a ) {
2018-11-30 15:11:56 +01:00
$url = ( ! empty ( $_POST [ 'baseurl' ]) ? Strings :: escapeTags ( trim ( $_POST [ 'baseurl' ])) : '' );
$id = ( ! empty ( $_POST [ 'siteid' ]) ? trim ( $_POST [ 'siteid' ]) : '' );
$optout = ( ! empty ( $_POST [ 'optout' ]) ? trim ( $_POST [ 'optout' ]) : '' );
$async = ( ! empty ( $_POST [ 'async' ]) ? trim ( $_POST [ 'async' ]) : '' );
2020-01-19 21:21:52 +01:00
DI :: config () -> set ( 'piwik' , 'baseurl' , $url );
DI :: config () -> set ( 'piwik' , 'siteid' , $id );
DI :: config () -> set ( 'piwik' , 'optout' , $optout );
DI :: config () -> set ( 'piwik' , 'async' , $async );
2020-01-18 20:52:33 +01:00
info ( DI :: l10n () -> t ( 'Settings updated.' ) . EOL );
2011-09-25 10:56:03 +02:00
}