diff options
author | sualko <klaus@jsxc.org> | 2018-10-29 11:44:27 +0300 |
---|---|---|
committer | sualko <klaus@jsxc.org> | 2018-10-29 11:44:27 +0300 |
commit | 69ad1c540150c061054d38f3bdafda87a7e1ce16 (patch) | |
tree | f7ce07a69ea3d3fba05ac6eca603fad6024d253c | |
parent | f971a918586602ba8592363a831f19a0d247da5a (diff) |
build v0.5.0v0.5.0
-rw-r--r-- | Gruntfile.js | 1 | ||||
-rwxr-xr-x | appinfo/info.xml | 2 | ||||
-rw-r--r-- | build/appinfo/Application.php | 19 | ||||
-rw-r--r-- | build/appinfo/app.php | 25 | ||||
-rw-r--r-- | build/appinfo/info.xml | 12 | ||||
-rw-r--r-- | build/appinfo/routes.php | 5 | ||||
-rw-r--r-- | build/js/track.js | 146 | ||||
-rw-r--r-- | build/js/track.min.js | 2 | ||||
-rw-r--r-- | build/js/track.min.js.map | 1 | ||||
-rw-r--r-- | build/lib/Config.php | 34 | ||||
-rw-r--r-- | build/lib/Controller/JavaScriptController.php | 52 | ||||
-rw-r--r-- | build/lib/Controller/SettingsController.php | 36 | ||||
-rw-r--r-- | build/lib/Settings/Admin.php | 1 | ||||
-rw-r--r-- | build/templates/settings/admin.php | 9 | ||||
-rw-r--r-- | js/track.js | 2 | ||||
-rw-r--r-- | package.json | 10 |
16 files changed, 211 insertions, 146 deletions
diff --git a/Gruntfile.js b/Gruntfile.js index f761e52..00135c4 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -69,7 +69,6 @@ module.exports = function(grunt) { }, files: { 'build/js/settings/admin.min.js': ['js/settings/admin.js'], - 'build/js/track.min.js': ['js/track.js'] } } }, diff --git a/appinfo/info.xml b/appinfo/info.xml index 2147689..7abef05 100755 --- a/appinfo/info.xml +++ b/appinfo/info.xml @@ -4,7 +4,7 @@ <name>Piwik/Matomo Tracking</name> <summary>Track users with Piwik/Matomo</summary> <description>Track users with Piwik/Matomo</description> - <version>0.4.1</version> + <version>0.5.0</version> <licence>agpl</licence> <author>Klaus Herberth</author> <category>tools</category> diff --git a/build/appinfo/Application.php b/build/appinfo/Application.php index 72591f3..c483b35 100644 --- a/build/appinfo/Application.php +++ b/build/appinfo/Application.php @@ -1,7 +1,9 @@ <?php namespace OCA\Piwik\AppInfo; +use OCA\Piwik\Config; use OCA\Piwik\Controller\SettingsController; +use OCA\Piwik\Controller\JavaScriptController; use OCA\Piwik\Migration\Settings as SettingsMigration; use OCP\AppFramework\App; use OCP\IContainer; @@ -15,6 +17,13 @@ class Application extends App $container = $this->getContainer(); + $container->registerService('OCA\Piwik\Config', function (IContainer $c) { + return new Config( + $c->query('AppName'), + $c->query('OCP\IConfig') + ); + }); + /** * Controllers */ @@ -22,7 +31,15 @@ class Application extends App return new SettingsController( $c->query('AppName'), $c->query('Request'), - $c->query('OCP\IConfig') + $c->query('OCA\Piwik\Config') + ); + }); + + $container->registerService('JavaScriptController', function (IContainer $c) { + return new JavaScriptController( + $c->query('AppName'), + $c->query('Request'), + $c->query('OCA\Piwik\Config') ); }); diff --git a/build/appinfo/app.php b/build/appinfo/app.php index 8ded64a..44b441c 100644 --- a/build/appinfo/app.php +++ b/build/appinfo/app.php @@ -2,20 +2,21 @@ $url = \OC::$server->getConfig()->getAppValue('piwik', 'url'); if (!empty($url)) { - OCP\Util::addScript('piwik', 'track'); + \OCP\Util::addHeader( + 'script', + [ + 'src' => \OC::$server->getURLGenerator()->linkToRoute('piwik.JavaScript.tracking'), + 'nonce' => \OC::$server->getContentSecurityPolicyNonceManager()->getNonce(), + ], '' + ); - if (class_exists('\\OCP\\AppFramework\\Http\\ContentSecurityPolicy')) { - $url = parse_url($url, PHP_URL_HOST); + $url = parse_url($url, PHP_URL_HOST); + $policy = new OCP\AppFramework\Http\ContentSecurityPolicy(); - $policy = new OCP\AppFramework\Http\ContentSecurityPolicy(); - $policy->addAllowedScriptDomain('\'self\' '); - $policy->addAllowedImageDomain('\'self\' '); - - if ($url !== false && array_key_exists('HTTP_HOST', $_SERVER) - && $_SERVER['HTTP_HOST'] !== $url && !empty($url)) { - $policy->addAllowedScriptDomain($url); - $policy->addAllowedImageDomain($url); - } + if ($url !== false && array_key_exists('HTTP_HOST', $_SERVER) + && $_SERVER['HTTP_HOST'] !== $url && !empty($url)) { + $policy->addAllowedScriptDomain($url); + $policy->addAllowedImageDomain($url); \OC::$server->getContentSecurityPolicyManager()->addDefaultPolicy($policy); } diff --git a/build/appinfo/info.xml b/build/appinfo/info.xml index f187c5b..7abef05 100644 --- a/build/appinfo/info.xml +++ b/build/appinfo/info.xml @@ -4,7 +4,7 @@ <name>Piwik/Matomo Tracking</name> <summary>Track users with Piwik/Matomo</summary> <description>Track users with Piwik/Matomo</description> - <version>0.4.1</version> + <version>0.5.0</version> <licence>agpl</licence> <author>Klaus Herberth</author> <category>tools</category> @@ -14,16 +14,16 @@ <repository type="git">https://github.com/sualko/cloud_piwik.git</repository> <dependencies> - <nextcloud min-version="11.0" max-version="14"/> + <nextcloud min-version="13.0" max-version="15"/> </dependencies> - <settings> - <admin>OCA\Piwik\Settings\Admin</admin> - </settings> - <repair-steps> <post-migration> <step>OCA\Piwik\Migration\Settings</step> </post-migration> </repair-steps> + + <settings> + <admin>OCA\Piwik\Settings\Admin</admin> + </settings> </info> diff --git a/build/appinfo/routes.php b/build/appinfo/routes.php index 6a4e821..2fd1fa6 100644 --- a/build/appinfo/routes.php +++ b/build/appinfo/routes.php @@ -3,7 +3,8 @@ return [ 'routes' => [ ['name' => 'settings#index', 'url' => '/settings', 'verb' => 'GET'], - ['name' => 'settings#update', 'url' => '/settings/{key}', 'verb' => 'PUT'] + ['name' => 'settings#update', 'url' => '/settings/{key}', 'verb' => 'PUT'], + ['name' => 'JavaScript#tracking', 'url' => '/js/tracking.js', 'verb' => 'GET'] ], ]; -?> +?>
\ No newline at end of file diff --git a/build/js/track.js b/build/js/track.js index df124eb..94a18ca 100644 --- a/build/js/track.js +++ b/build/js/track.js @@ -1,121 +1,101 @@ /*! - * owncloud_piwik v0.4.1 - 2018-05-11 + * cloud_piwik v0.5.0 - 2018-10-29 * * Copyright (c) 2018 Klaus Herberth <klaus@jsxc.org> <br> * Released under the MIT license * - * Please see https://github.com/sualko/owncloud_piwik + * Please see https://github.com/sualko/cloud_piwik * * @author Klaus Herberth <klaus@jsxc.org> - * @version 0.4.1 + * @version 0.5.0 * @license MIT */ -/* global OC, oc_debug */ +/* global OC */ var _paq = _paq || []; (function() { "use strict"; - var piwik; + var options; - if (typeof localStorage !== 'undefined') { - var piwikString = localStorage.getItem('piwik'); + try { + options = JSON.parse('%OPTIONS%'); + } catch (err) {} - try { - piwik = JSON.parse(piwikString); - } catch (err) {} + if (!options || !options.url || !options.siteId) { + return; } - if (piwik && (piwik.validUntil || 0) > (new Date()).getTime() && !oc_debug) { - // use cached options - track(piwik); - } else { - // load options - $.ajax({ - method: 'GET', - url: OC.generateUrl('apps/piwik/settings'), - }) - .done(function(response) { - var data = response ? response.data : {}; - - if (data.siteId && data.url) { - data.validUntil = (new Date()).getTime() + (data.validity * 1000); - - localStorage.setItem('piwik', JSON.stringify(data)); - - track(data); - } - }); + if (options.url[options.url.length - 1] !== '/') { + options.url += '/'; } - function track(options) { - var app = null; - var path = window.location.pathname; - var pathparts = path.match(/(?:index\.php\/)?apps\/([a-z0-9]+)\/?/i) || path.match(/(?:index\.php\/)?([a-z0-9]+)(\/([a-z0-9]+))?/i) || []; + var app = null; + var path = window.location.pathname; + var pathParts = path.match(/(?:index\.php\/)?apps\/([a-z0-9]+)\/?/i) || path.match(/(?:index\.php\/)?([a-z0-9]+)(\/([a-z0-9]+))?/i) || []; - if (pathparts.length >= 2) { - app = pathparts[1]; + if (pathParts.length >= 2) { + app = pathParts[1]; - if (app === 's') { - // rewrite app name - app = 'share'; + if (app === 's') { + // rewrite app name + app = 'share'; - var sharevalue = $('input[name="filename"]').val(); + var shareValue = $('input[name="filename"]').val(); - if (sharevalue) { - sharevalue = pathparts[3] + ' (' + sharevalue + ')'; + if (shareValue) { + shareValue = pathParts[3] + ' (' + shareValue + ')'; - // save share id + share name in slot 3 - _paq.push(['setCustomVariable', '3', 'ShareNodes', sharevalue, 'page']); - } else { - sharevalue = pathparts[3]; - } - - // save share id in slot 2 - _paq.push(['setCustomVariable', '2', 'Shares', pathparts[3], 'page']); + // save share id + share name in slot 3 + _paq.push(['setCustomVariable', '3', 'ShareNodes', shareValue, 'page']); + } else { + shareValue = pathParts[3]; } - // save app name in slot 1 - _paq.push(['setCustomVariable', '1', 'App', app, 'page']); - } - - if (OC && OC.currentUser) { - // set user id - _paq.push(['setUserId', OC.currentUser]); + // save share id in slot 2 + _paq.push(['setCustomVariable', '2', 'Shares', pathParts[3], 'page']); } - if (options.trackDir === 'on' || options.trackDir === true) { - // track file browsing + // save app name in slot 1 + _paq.push(['setCustomVariable', '1', 'App', app, 'page']); + } - $('#app-content').delegate('>div', 'afterChangeDirectory', function() { - // update title and url for next page view - _paq.push(['setDocumentTitle', document.title]); - _paq.push(['setCustomUrl', window.location.href]); - _paq.push(['trackPageView']); - }); - } + if (OC && OC.currentUser && options.trackUser) { + // set user id + _paq.push(['setUserId', OC.currentUser]); + } - // set piwik options - _paq.push(['setTrackerUrl', options.url + 'piwik.php']); - _paq.push(['setSiteId', options.siteId]); + if (options.trackDir === 'on' || options.trackDir === true) { + // track file browsing - if (app !== 'files' || options.trackDir !== 'on') { - // track page view + $('#app-content').delegate('>div', 'afterChangeDirectory', function() { + // update title and url for next page view + _paq.push(['setDocumentTitle', document.title]); + _paq.push(['setCustomUrl', window.location.href]); _paq.push(['trackPageView']); - } + }); + } - if (typeof Piwik === 'undefined') { - // load piwik library - var d = document, - g = d.createElement('script'), - s = d.getElementsByTagName('script')[0]; - g.type = 'text/javascript'; - g.async = true; - g.defer = true; - g.src = options.url + 'piwik.js'; - s.parentNode.insertBefore(g, s); - } + // set piwik options + _paq.push(['setTrackerUrl', options.url + 'piwik.php']); + _paq.push(['setSiteId', options.siteId]); + + if (app !== 'files' || options.trackDir !== 'on') { + // track page view + _paq.push(['trackPageView']); + } + + if (typeof Piwik === 'undefined') { + // load piwik library + var d = document, + g = d.createElement('script'), + s = d.getElementsByTagName('script')[0]; + g.type = 'text/javascript'; + g.async = true; + g.defer = true; + g.src = options.url + 'piwik.js'; + s.parentNode.insertBefore(g, s); } }()); diff --git a/build/js/track.min.js b/build/js/track.min.js deleted file mode 100644 index d5c6223..0000000 --- a/build/js/track.min.js +++ /dev/null @@ -1,2 +0,0 @@ -var _paq=_paq||[];!function(){"use strict";function track(options){var app=null,path=window.location.pathname,pathparts=path.match(/(?:index\.php\/)?apps\/([a-z0-9]+)\/?/i)||path.match(/(?:index\.php\/)?([a-z0-9]+)(\/([a-z0-9]+))?/i)||[];if(pathparts.length>=2){if("s"===(app=pathparts[1])){app="share";var sharevalue=$('input[name="filename"]').val();sharevalue?(sharevalue=pathparts[3]+" ("+sharevalue+")",_paq.push(["setCustomVariable","3","ShareNodes",sharevalue,"page"])):sharevalue=pathparts[3],_paq.push(["setCustomVariable","2","Shares",pathparts[3],"page"])}_paq.push(["setCustomVariable","1","App",app,"page"])}if(OC&&OC.currentUser&&_paq.push(["setUserId",OC.currentUser]),"on"!==options.trackDir&&!0!==options.trackDir||$("#app-content").delegate(">div","afterChangeDirectory",function(){_paq.push(["setDocumentTitle",document.title]),_paq.push(["setCustomUrl",window.location.href]),_paq.push(["trackPageView"])}),_paq.push(["setTrackerUrl",options.url+"piwik.php"]),_paq.push(["setSiteId",options.siteId]),"files"===app&&"on"===options.trackDir||_paq.push(["trackPageView"]),"undefined"==typeof Piwik){var d=document,g=d.createElement("script"),s=d.getElementsByTagName("script")[0];g.type="text/javascript",g.async=!0,g.defer=!0,g.src=options.url+"piwik.js",s.parentNode.insertBefore(g,s)}}var piwik;if("undefined"!=typeof localStorage){var piwikString=localStorage.getItem("piwik");try{piwik=JSON.parse(piwikString)}catch(err){}}piwik&&(piwik.validUntil||0)>(new Date).getTime()&&!oc_debug?track(piwik):$.ajax({method:"GET",url:OC.generateUrl("apps/piwik/settings")}).done(function(response){var data=response?response.data:{};data.siteId&&data.url&&(data.validUntil=(new Date).getTime()+1e3*data.validity,localStorage.setItem("piwik",JSON.stringify(data)),track(data))})}(); -//# sourceMappingURL=track.min.js.map
\ No newline at end of file diff --git a/build/js/track.min.js.map b/build/js/track.min.js.map deleted file mode 100644 index cb32883..0000000 --- a/build/js/track.min.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["../../js/track.js"],"names":["_paq","track","options","app","path","window","location","pathname","pathparts","match","length","sharevalue","$","val","push","OC","currentUser","trackDir","delegate","document","title","href","url","siteId","Piwik","d","g","createElement","s","getElementsByTagName","type","async","defer","src","parentNode","insertBefore","piwik","localStorage","piwikString","getItem","JSON","parse","err","validUntil","Date","getTime","oc_debug","ajax","method","generateUrl","done","response","data","validity","setItem","stringify"],"mappings":"AAEA,IAAIA,KAAOA,UAEV,WACE,aAkCA,SAASC,MAAMC,SACZ,IAAIC,IAAM,KACNC,KAAOC,OAAOC,SAASC,SACvBC,UAAYJ,KAAKK,MAAM,2CAA6CL,KAAKK,MAAM,qDAEnF,GAAID,UAAUE,QAAU,EAAG,CAGxB,GAAY,OAFZP,IAAMK,UAAU,IAEC,CAEdL,IAAM,QAEN,IAAIQ,WAAaC,EAAE,0BAA0BC,MAEzCF,YACDA,WAAaH,UAAU,GAAK,KAAOG,WAAa,IAGhDX,KAAKc,MAAM,oBAAqB,IAAK,aAAcH,WAAY,UAE/DA,WAAaH,UAAU,GAI1BR,KAAKc,MAAM,oBAAqB,IAAK,SAAUN,UAAU,GAAI,SAIhER,KAAKc,MAAM,oBAAqB,IAAK,MAAOX,IAAK,SA4BpD,GAzBIY,IAAMA,GAAGC,aAEVhB,KAAKc,MAAM,YAAaC,GAAGC,cAGL,OAArBd,QAAQe,WAA0C,IAArBf,QAAQe,UAGtCL,EAAE,gBAAgBM,SAAS,OAAQ,uBAAwB,WAExDlB,KAAKc,MAAM,mBAAoBK,SAASC,QACxCpB,KAAKc,MAAM,eAAgBT,OAAOC,SAASe,OAC3CrB,KAAKc,MAAM,oBAKjBd,KAAKc,MAAM,gBAAiBZ,QAAQoB,IAAM,cAC1CtB,KAAKc,MAAM,YAAaZ,QAAQqB,SAEpB,UAARpB,KAAwC,OAArBD,QAAQe,UAE5BjB,KAAKc,MAAM,kBAGO,oBAAVU,MAAuB,CAE/B,IAAIC,EAAIN,SACLO,EAAID,EAAEE,cAAc,UACpBC,EAAIH,EAAEI,qBAAqB,UAAU,GACxCH,EAAEI,KAAO,kBACTJ,EAAEK,OAAQ,EACVL,EAAEM,OAAQ,EACVN,EAAEO,IAAM/B,QAAQoB,IAAM,WACtBM,EAAEM,WAAWC,aAAaT,EAAGE,IAjGnC,IAAIQ,MAEJ,GAA4B,oBAAjBC,aAA8B,CACtC,IAAIC,YAAcD,aAAaE,QAAQ,SAEvC,IACGH,MAAQI,KAAKC,MAAMH,aACpB,MAAOI,OAGRN,QAAUA,MAAMO,YAAc,IAAK,IAAKC,MAAQC,YAAcC,SAE/D7C,MAAMmC,OAGNxB,EAAEmC,MACIC,OAAQ,MACR1B,IAAKP,GAAGkC,YAAY,yBAEtBC,KAAK,SAASC,UACZ,IAAIC,KAAOD,SAAWA,SAASC,QAE3BA,KAAK7B,QAAU6B,KAAK9B,MACrB8B,KAAKT,YAAa,IAAKC,MAAQC,UAA6B,IAAhBO,KAAKC,SAEjDhB,aAAaiB,QAAQ,QAASd,KAAKe,UAAUH,OAE7CnD,MAAMmD,SA9BrB","file":"track.min.js"}
\ No newline at end of file diff --git a/build/lib/Config.php b/build/lib/Config.php new file mode 100644 index 0000000..0889d41 --- /dev/null +++ b/build/lib/Config.php @@ -0,0 +1,34 @@ +<?php +namespace OCA\Piwik; + +use OCP\IConfig; + +class Config +{ + public function __construct($appName, IConfig $config) + { + $this->appName = $appName; + $this->config = $config; + } + + public function getAppValue($key, $default = null) + { + $value = $this->config->getAppValue($this->appName, $key, $default); + return (empty($value)) ? $default : $value; + } + + public function setAppValue($key, $value) + { + return $this->config->setAppValue($this->appName, $key, $value); + } + + public function getBooleanAppValue($key) + { + return $this->validateBoolean($this->getAppValue($key)); + } + + private function validateBoolean($val) + { + return $val === true || $val === 'true'; + } +} diff --git a/build/lib/Controller/JavaScriptController.php b/build/lib/Controller/JavaScriptController.php new file mode 100644 index 0000000..bc15c76 --- /dev/null +++ b/build/lib/Controller/JavaScriptController.php @@ -0,0 +1,52 @@ +<?php +namespace OCA\Piwik\Controller; + +use OCP\AppFramework\Controller; +use OCP\AppFramework\Http\DataDownloadResponse; +use OCP\AppFramework\Http\Response; +use OCP\IConfig; +use OCP\IRequest; +use OCA\Piwik\Config; + +class JavaScriptController extends Controller +{ + /** @var \OCP\IConfig */ + protected $config; + + /** + * constructor of the controller + * + * @param string $appName + * @param IRequest $request + * @param IConfig $config + */ + public function __construct($appName, + IRequest $request, + Config $config) { + parent::__construct($appName, $request); + $this->config = $config; + } + + /** + * @NoAdminRequired + * @NoCSRFRequired + * @PublicPage + * + * @return Response + */ + public function tracking() + { + $options = [ + 'url' => $this->config->getAppValue('url'), + 'siteId' => $this->config->getAppValue('siteId'), + 'trackDir' => $this->config->getBooleanAppValue('trackDir'), + 'trackUser' => $this->config->getBooleanAppValue('trackUser'), + ]; + + $script = "var cloudPiwikOptions = '".json_encode($options)."';"; + $script = file_get_contents(__DIR__ . '/../../js/track.js'); + $script = str_replace('%OPTIONS%', json_encode($options), $script); + + return new DataDownloadResponse($script, 'script', 'text/javascript'); + } +} diff --git a/build/lib/Controller/SettingsController.php b/build/lib/Controller/SettingsController.php index 36745a5..bbfe123 100644 --- a/build/lib/Controller/SettingsController.php +++ b/build/lib/Controller/SettingsController.php @@ -2,8 +2,8 @@ namespace OCA\Piwik\Controller; use OCP\AppFramework\Controller; -use OCP\IConfig; use OCP\IRequest; +use OCA\Piwik\Config; class SettingsController extends Controller { @@ -12,7 +12,7 @@ class SettingsController extends Controller public function __construct( $appName, IRequest $request, - IConfig $config + Config $config ) { parent::__construct($appName, $request); @@ -28,51 +28,29 @@ class SettingsController extends Controller return [ 'result' => 'success', 'data' => [ - 'url' => $this->getAppValue('url'), - 'siteId' => $this->getAppValue('siteId'), - 'trackDir' => $this->getBooleanAppValue('trackDir'), - 'validity' => 2*60, + 'url' => $this->config->getAppValue('url'), + 'siteId' => $this->config->getAppValue('siteId'), + 'trackDir' => $this->config->getBooleanAppValue('trackDir') ], ]; } public function update($key) { - if (!in_array($key, ['url', 'siteId', 'trackDir'])) { + if (!in_array($key, ['url', 'siteId', 'trackDir', 'trackUser'])) { return [ 'result' => 'error', 'message' => 'Tried to update not allowed param.', ]; } - $this->setAppValue($key, $this->getTrimParam('value')); + $this->config->setAppValue($key, $this->getTrimParam('value')); return [ 'status' => 'success', ]; } - private function getAppValue($key, $default = null) - { - $value = $this->config->getAppValue($this->appName, $key, $default); - return (empty($value)) ? $default : $value; - } - - private function setAppValue($key, $value) - { - return $this->config->setAppValue($this->appName, $key, $value); - } - - private function getBooleanAppValue($key) - { - return $this->validateBoolean($this->getAppValue($key)); - } - - private function validateBoolean($val) - { - return $val === true || $val === 'true'; - } - private function getTrimParam($key) { return trim($this->request->getParam($key)); diff --git a/build/lib/Settings/Admin.php b/build/lib/Settings/Admin.php index dcb5a6e..2478445 100644 --- a/build/lib/Settings/Admin.php +++ b/build/lib/Settings/Admin.php @@ -30,6 +30,7 @@ class Admin implements ISettings 'url' => $this->config->getAppValue('piwik', 'url'), 'siteId' => $this->config->getAppValue('piwik', 'siteId'), 'trackDir' => $this->config->getAppValue('piwik', 'trackDir'), + 'trackUser' => $this->config->getAppValue('piwik', 'trackUser'), ]; return new TemplateResponse('piwik', 'settings/admin', $parameters); diff --git a/build/templates/settings/admin.php b/build/templates/settings/admin.php index edda4b1..ed4ec9e 100644 --- a/build/templates/settings/admin.php +++ b/build/templates/settings/admin.php @@ -6,7 +6,6 @@ style('piwik', 'settings'); <div id="piwikSettings" class="section"> <h2>Piwik/Matomo Tracking</h2> <p class="settings-hint">If you have no Piwik/Matomo instance, go to <a href="https://matomo.org" target="_blank">matomo.org</a> for further instructions.</p> - <p class="settings-hint">Please take into account that the old values are cached for 2 minutes in your browser.</p> <form> <table> @@ -21,7 +20,13 @@ style('piwik', 'settings'); <tr> <td colspan="2"> <input type="checkbox" name="trackDir" id="piwikTrackDir" class="checkbox" <?php if ($_['trackDir']): ?> checked="checked"<?php endif; ?> /> - <label for="piwikTrackDir">Track file browsing </label> + <label for="piwikTrackDir">Track file browsing</label> + </td> + </tr> + <tr> + <td colspan="2"> + <input type="checkbox" name="trackUser" id="piwikTrackUser" class="checkbox" <?php if ($_['trackUser']): ?> checked="checked"<?php endif; ?> /> + <label for="piwikTrackUser">Track user id</label> </td> </tr> </table> diff --git a/js/track.js b/js/track.js index ccd9f14..62a41af 100644 --- a/js/track.js +++ b/js/track.js @@ -1,4 +1,4 @@ -/* global OC, oc_debug */ +/* global OC */ var _paq = _paq || []; diff --git a/package.json b/package.json index 0ae8c44..0bf9267 100644 --- a/package.json +++ b/package.json @@ -1,10 +1,10 @@ { - "name": "owncloud_piwik", - "version": "0.4.1", + "name": "cloud_piwik", + "version": "0.5.0", "description": "Track owncloud/nextcloud users with piwik", "repository": { "type": "git", - "url": "https://github.com/sualko/owncloud_piwik.git" + "url": "https://github.com/sualko/cloud_piwik.git" }, "keywords": [ "nextcloud", @@ -15,9 +15,9 @@ "author": "Klaus Herberth <klaus@jsxc.org>", "license": "MIT", "bugs": { - "url": "https://github.com/sualko/owncloud_piwik/issues" + "url": "https://github.com/sualko/cloud_piwik/issues" }, - "homepage": "https://github.com/sualko/owncloud_piwik", + "homepage": "https://github.com/sualko/cloud_piwik", "devDependencies": { "grunt": "^1.0.1", "grunt-banner": "^0.6.0", |