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
2022-11-20 17:43:42 +01:00
* in case you don ' t use this , add the following lines to your config / piwik . config . php
2014-08-11 09:07:25 +02:00
* file :
2011-09-25 10:56:03 +02:00
*
2022-11-20 17:43:42 +01:00
* return [
* 'piwik' => [
* 'baseurl' => '' ,
* 'sideid' => '' ,
* 'optout' => true ,
* 'async' => false ,
* ],
* ];
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
2022-06-23 07:16:22 +02:00
use Friendica\App ;
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 ;
2023-01-01 20:21:56 +01:00
use Friendica\Core\Config\Util\ConfigFileManager ;
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
2021-10-21 08:04:27 +02:00
Logger :: notice ( " installed piwik addon " );
2011-09-25 10:56:03 +02:00
}
2023-01-01 20:21:56 +01:00
function piwik_load_config ( App $a , ConfigFileManager $loader )
2018-06-28 05:18:33 +02:00
{
2022-11-20 18:44:53 +01:00
$a -> getConfigCache () -> load ( $loader -> loadAddonConfig ( 'piwik' ), \Friendica\Core\Config\ValueObject\Cache :: SOURCE_STATIC );
2018-06-28 05:18:33 +02:00
}
Hook::register has changed API
`Hook::register` now takes a string as the second parameter, not an array. Without this change Friendica fails to start, with errors such as:
```
2022-11-07T11:40:20Z index [ERROR]: Uncaught Exception TypeError: "Argument 2 passed to piwik_analytics() must be of the type array, string given, called in /var/www/html/src/Core/Hook.php on line 223" at /var/www/html/addon/piwik/piwik.php line 53 {"exception":"TypeError: Argument 2 passed to piwik_analytics() must be of the type array, string given, called in /var/www/html/src/Core/Hook.php on line 223 and defined in /var/www/html/addon/piwik/piwik.php:53\nStack trace:\n#0 /var/www/html/src/Core/Hook.php(223): piwik_analytics(Object(Friendica\\App), '<h1><img width=...')\n#1 /var/www/html/src/Core/Hook.php(198): Friendica\\Core\\Hook::callSingle(Object(Friendica\\App), 'page_end', Array, '<h1><img width=...')\n#2 /var/www/html/src/App/Page.php(493): Friendica\\Core\\Hook::callAll('page_end', '<h1><img width=...')\n#3 /var/www/html/src/App.php(722): Friendica\\App\\Page->run(Object(Friendica\\App), Object(Friendica\\App\\BaseURL), Object(Friendica\\App\\Arguments), Object(Friendica\\App\\Mode), Object(GuzzleHttp\\Psr7\\Response), Object(Friendica\\Core\\L10n), Object(Friendica\\Util\\Profiler), Object(Friendica\\Core\\Config\\Type\\JitConfig), Object(Friendica\\Core\\PConfig\\Type\\JitPConfig))\n#4 /var/www/html/index.php(44): Friendica\\App->runFrontend(Object(Friendica\\App\\Router), Object(Friendica\\Core\\PConfig\\Type\\JitPConfig), Object(Friendica\\Security\\Authentication), Object(Friendica\\App\\Page), Object(Friendica\\Util\\HTTPInputData), 1667821218.5153)\n#5 {main}"} - {"file":null,"line":null,"function":null,"uid":"73d499","process_id":52}
```
2022-11-07 12:42:31 +01:00
function piwik_analytics ( App $a , string & $b )
2022-06-23 07:16:22 +02:00
{
2011-09-25 10:56:03 +02:00
/*
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
/*
2022-11-20 17:43:42 +01:00
* Get the configuration values .
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
}
}
2022-06-30 13:32:13 +02:00
function piwik_addon_admin ( App $a , string & $o )
{
2018-10-31 15:55:15 +01:00
$t = Renderer :: getMarkupTemplate ( " admin.tpl " , " addon/piwik/ " );
2022-06-30 13:32:13 +02:00
2018-10-31 15:55:15 +01:00
$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
}
2022-06-30 13:32:13 +02:00
function piwik_addon_admin_post ( App $a )
{
DI :: config () -> set ( 'piwik' , 'baseurl' , trim ( $_POST [ 'baseurl' ] ? ? '' ));
DI :: config () -> set ( 'piwik' , 'siteid' , trim ( $_POST [ 'siteid' ] ? ? '' ));
DI :: config () -> set ( 'piwik' , 'optout' , trim ( $_POST [ 'optout' ] ? ? '' ));
DI :: config () -> set ( 'piwik' , 'async' , trim ( $_POST [ 'async' ] ? ? '' ));
2011-09-25 10:56:03 +02:00
}