ckanext-googleanalytics


Nameckanext-googleanalytics JSON
Version 2.3.0 PyPI version JSON
download
home_pagehttps://github.com/ckan/ckanext-googleanalytics
SummaryAdd GA tracking and reporting to CKAN instance
upload_time2023-06-14 17:30:23
maintainer
docs_urlNone
authorSeb Bacon
requires_python
licenseAGPL
keywords ckan
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # CKAN Google Analytics Extension

**Status:** Production

**CKAN Version:** >= 2.8

A CKAN extension that both sends tracking data to Google Analytics and
retrieves statistics from Google Analytics and inserts them into CKAN pages.

## Features


* Puts the Google Analytics asynchronous tracking code into your page headers
  for basic Google Analytics page tracking.

* Adds Google Analytics Event Tracking to resource download links, so that
  resource downloads will be displayed as Events in the Google Analytics
  reporting interface.

* Adds Google Analytics Event Tracking to some API calls so that usage of the
  API can be reported on via Google Analytics.

* Add Google Analytics Event Tracking function that can be used in any exstension
  to create your custom events tracking.

		ckanext.googleanalytics.plugin._post_analytics

## Installation


1. Install the extension as usual, e.g. (from an activated virtualenv):

		$ pip install -e  git+https://github.com/ckan/ckanext-googleanalytics.git#egg=ckanext-googleanalytics
		$ pip install -r ckanext-googleanalytics/requirements.txt

2. Edit your development.ini (or similar) to provide these necessary parameters:

		googleanalytics.id = UA-1010101-1
		googleanalytics.account = Account name (i.e. data.gov.uk, see top level item at https://www.google.com/analytics)
		googleanalytics.username = googleaccount@gmail.com
        googleanalytics.password = googlepassword

   Note that your password will probably be readable by other people;
   so you may want to set up a new gmail account specifically for
   accessing your gmail profile.

3. Edit again your configuration ini file to activate the plugin
   with:

		ckan.plugins = googleanalytics

   (If there are other plugins activated, add this to the list.  Each
   plugin should be separated with a space).

4. Finally, there are some optional configuration settings (shown here
   with their default settings)

		googleanalytics_resource_prefix = /downloads/
		googleanalytics.domain = auto
        googleanalytics.fields = {}
        googleanalytics.enable_user_id = false
        googleanalytics.download_handler = ckan.views.resource:download

   ``resource_prefix`` is an arbitrary identifier so that we can query
   for downloads in Google Analytics.  It can theoretically be any
   string, but should ideally resemble a URL path segment, to make
   filtering for all resources easier in the Google Analytics web
   interface.

   ``domain`` allows you to specify a domain against which Analytics
   will track users.  You will usually want to leave this as ``auto``;
   if you are tracking users from multiple subdomains, you might want
   to specify something like ``.mydomain.com``.
   See `Google's documentation
   <http://code.google.com/apis/analytics/docs/gaJS/gaJSApiDomainDirectory.html#_gat.GA_Tracker_._setDomainName>`_
   for more info.

   ``fields`` allows you to specify various options when creating the tracker. See `Google's documentation <https://developers.google.com/analytics/devguides/collection/analyticsjs/field-reference>`.

   If ``enable_user_id`` is set to ``true``, then logged in users will be tracked into the Google Analytics' dashboard.
   This way metrics can be tracked for every logged in user. You can read more
   about this feature and its benefits `here <https://support.google.com/analytics/answer/3123662>`_.

   When resource is downloaded, ckanext-googleanalytics posts event to
   GA and calls default download callback. If you are using CKAN>=2.9
   and some of your plugins redefines `resource.download`
   route(ckanext-cloudstorage, for example), you can specify which
   function must be called instead of `ckan.views.resource:download`
   via `ckanext.googleanalytics.download_handler` config variable. For ckanext-cloudstorage you can use:

		ckanext.googleanalytics.download_handler = ckanext.cloudstorage.views:download

# Domain Linking


This plugin supports cross-domain tracking using Googles' site linking feature.

To use this, set the ``googleanalytics.linked_domains`` configuration option to a (comma seperated) list of domains to report for.

See `Googles' documentation<https://support.google.com/analytics/answer/1034342?hl=en>`_ for more information

# Setting Up Statistics Retrieval from Google Analytics


1. Run the following command from ``src/ckanext-googleanalytics`` to
   set up the required database tables (of course, altering the
   ``--config`` option to point to your site config file):

		ckan -c ../ckan/ckan.ini initdb

3. Follow the steps in the *Authorization* section below.

4. Restart CKAN (e.g. by restarting Apache)

5. Wait a while for some stats to be recorded in Google

6. Import Google stats by running the following command from
   ``src/ckanext-googleanalytics``::

		paster loadanalytics credentials.json --config=../ckan/development.ini

   (Of course, pointing config at your specific site config and credentials.json at the
   key file obtained from the authorization step)
   Ignore warning `ImportError: file_cache is unavailable when using oauth2client >= 4.0.0`

7. Look at some stats within CKAN

   Once your GA account has gathered some data, you can see some basic
   information about the most popular packages at:
   http://mydomain.com/analytics/dataset/top

   By default the only data that is injected into the public-facing
   website is on the package page, where number of downloads are
   displayed next to each resource.

8. Consider running the import command reguarly as a cron job, or
   remember to run it by hand, or your statistics won't get updated.


## Authorization


Before ckanext-googleanalytics can retrieve statistics from Google Analytics, you need to set up the OAUTH details which you can do by following the `instructions <https://developers.google.com/analytics/devguides/reporting/core/v3/quickstart/service-py>`_ the outcome of which will be a file with authentication key. These steps are below for convenience:

1. Visit the `Google APIs Console <https://code.google.com/apis/console>`_

2. Sign-in and create a project or use an existing project.

3. In the `Service accounts pane <https://console.developers.google.com/iam-admin/serviceaccounts>`_ choose your project and create new account. During creation check "Furnish a new private key" -> JSON type. Write down "Service account ID"(looks like email) - it will be used later.

4. Save downloaded file - it will be used by `loadanalytics` command(referenced as <credentials.json>)

5. Go to `GoogleAnalytics console <https://analytics.google.com/analytics/web/#management>`_ and chose ADMIN tab.

6. Find "User management" button in corresponding column. Add service account using Service account ID(email) generated in 3rd step and grant "Read" role to it.


## Testing


There are some very high-level functional tests that you can run using::

   $ pip install -r dev-requirements.txt
	$ pytest --ckan-ini=test.ini 


## Future

This is a bare-bones, first release of the software.  There are
several directions it could take in the future.

Because we use Google Analytics for recording statistics, we can hook
into any of its features.  For example, as a measure of popularity, we
could record bounce rate, or new visits only; we could also display
which datasets are popular where, or highlight packages that have been
linked to from other locations.

We could also embed extra metadata information in tracking links, to
enable reports on particular types of data (e.g. most popular data
format by country of origin, or most downloaded resource by license)

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/ckan/ckanext-googleanalytics",
    "name": "ckanext-googleanalytics",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "CKAN",
    "author": "Seb Bacon",
    "author_email": "seb.bacon@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/ba/76/ed97e0b63440818f25c0460770926beeaad13243310ca8d055df766d408e/ckanext-googleanalytics-2.3.0.tar.gz",
    "platform": null,
    "description": "# CKAN Google Analytics Extension\n\n**Status:** Production\n\n**CKAN Version:** >= 2.8\n\nA CKAN extension that both sends tracking data to Google Analytics and\nretrieves statistics from Google Analytics and inserts them into CKAN pages.\n\n## Features\n\n\n* Puts the Google Analytics asynchronous tracking code into your page headers\n  for basic Google Analytics page tracking.\n\n* Adds Google Analytics Event Tracking to resource download links, so that\n  resource downloads will be displayed as Events in the Google Analytics\n  reporting interface.\n\n* Adds Google Analytics Event Tracking to some API calls so that usage of the\n  API can be reported on via Google Analytics.\n\n* Add Google Analytics Event Tracking function that can be used in any exstension\n  to create your custom events tracking.\n\n\t\tckanext.googleanalytics.plugin._post_analytics\n\n## Installation\n\n\n1. Install the extension as usual, e.g. (from an activated virtualenv):\n\n\t\t$ pip install -e  git+https://github.com/ckan/ckanext-googleanalytics.git#egg=ckanext-googleanalytics\n\t\t$ pip install -r ckanext-googleanalytics/requirements.txt\n\n2. Edit your development.ini (or similar) to provide these necessary parameters:\n\n\t\tgoogleanalytics.id = UA-1010101-1\n\t\tgoogleanalytics.account = Account name (i.e. data.gov.uk, see top level item at https://www.google.com/analytics)\n\t\tgoogleanalytics.username = googleaccount@gmail.com\n        googleanalytics.password = googlepassword\n\n   Note that your password will probably be readable by other people;\n   so you may want to set up a new gmail account specifically for\n   accessing your gmail profile.\n\n3. Edit again your configuration ini file to activate the plugin\n   with:\n\n\t\tckan.plugins = googleanalytics\n\n   (If there are other plugins activated, add this to the list.  Each\n   plugin should be separated with a space).\n\n4. Finally, there are some optional configuration settings (shown here\n   with their default settings)\n\n\t\tgoogleanalytics_resource_prefix = /downloads/\n\t\tgoogleanalytics.domain = auto\n        googleanalytics.fields = {}\n        googleanalytics.enable_user_id = false\n        googleanalytics.download_handler = ckan.views.resource:download\n\n   ``resource_prefix`` is an arbitrary identifier so that we can query\n   for downloads in Google Analytics.  It can theoretically be any\n   string, but should ideally resemble a URL path segment, to make\n   filtering for all resources easier in the Google Analytics web\n   interface.\n\n   ``domain`` allows you to specify a domain against which Analytics\n   will track users.  You will usually want to leave this as ``auto``;\n   if you are tracking users from multiple subdomains, you might want\n   to specify something like ``.mydomain.com``.\n   See `Google's documentation\n   <http://code.google.com/apis/analytics/docs/gaJS/gaJSApiDomainDirectory.html#_gat.GA_Tracker_._setDomainName>`_\n   for more info.\n\n   ``fields`` allows you to specify various options when creating the tracker. See `Google's documentation <https://developers.google.com/analytics/devguides/collection/analyticsjs/field-reference>`.\n\n   If ``enable_user_id`` is set to ``true``, then logged in users will be tracked into the Google Analytics' dashboard.\n   This way metrics can be tracked for every logged in user. You can read more\n   about this feature and its benefits `here <https://support.google.com/analytics/answer/3123662>`_.\n\n   When resource is downloaded, ckanext-googleanalytics posts event to\n   GA and calls default download callback. If you are using CKAN>=2.9\n   and some of your plugins redefines `resource.download`\n   route(ckanext-cloudstorage, for example), you can specify which\n   function must be called instead of `ckan.views.resource:download`\n   via `ckanext.googleanalytics.download_handler` config variable. For ckanext-cloudstorage you can use:\n\n\t\tckanext.googleanalytics.download_handler = ckanext.cloudstorage.views:download\n\n# Domain Linking\n\n\nThis plugin supports cross-domain tracking using Googles' site linking feature.\n\nTo use this, set the ``googleanalytics.linked_domains`` configuration option to a (comma seperated) list of domains to report for.\n\nSee `Googles' documentation<https://support.google.com/analytics/answer/1034342?hl=en>`_ for more information\n\n# Setting Up Statistics Retrieval from Google Analytics\n\n\n1. Run the following command from ``src/ckanext-googleanalytics`` to\n   set up the required database tables (of course, altering the\n   ``--config`` option to point to your site config file):\n\n\t\tckan -c ../ckan/ckan.ini initdb\n\n3. Follow the steps in the *Authorization* section below.\n\n4. Restart CKAN (e.g. by restarting Apache)\n\n5. Wait a while for some stats to be recorded in Google\n\n6. Import Google stats by running the following command from\n   ``src/ckanext-googleanalytics``::\n\n\t\tpaster loadanalytics credentials.json --config=../ckan/development.ini\n\n   (Of course, pointing config at your specific site config and credentials.json at the\n   key file obtained from the authorization step)\n   Ignore warning `ImportError: file_cache is unavailable when using oauth2client >= 4.0.0`\n\n7. Look at some stats within CKAN\n\n   Once your GA account has gathered some data, you can see some basic\n   information about the most popular packages at:\n   http://mydomain.com/analytics/dataset/top\n\n   By default the only data that is injected into the public-facing\n   website is on the package page, where number of downloads are\n   displayed next to each resource.\n\n8. Consider running the import command reguarly as a cron job, or\n   remember to run it by hand, or your statistics won't get updated.\n\n\n## Authorization\n\n\nBefore ckanext-googleanalytics can retrieve statistics from Google Analytics, you need to set up the OAUTH details which you can do by following the `instructions <https://developers.google.com/analytics/devguides/reporting/core/v3/quickstart/service-py>`_ the outcome of which will be a file with authentication key. These steps are below for convenience:\n\n1. Visit the `Google APIs Console <https://code.google.com/apis/console>`_\n\n2. Sign-in and create a project or use an existing project.\n\n3. In the `Service accounts pane <https://console.developers.google.com/iam-admin/serviceaccounts>`_ choose your project and create new account. During creation check \"Furnish a new private key\" -> JSON type. Write down \"Service account ID\"(looks like email) - it will be used later.\n\n4. Save downloaded file - it will be used by `loadanalytics` command(referenced as <credentials.json>)\n\n5. Go to `GoogleAnalytics console <https://analytics.google.com/analytics/web/#management>`_ and chose ADMIN tab.\n\n6. Find \"User management\" button in corresponding column. Add service account using Service account ID(email) generated in 3rd step and grant \"Read\" role to it.\n\n\n## Testing\n\n\nThere are some very high-level functional tests that you can run using::\n\n   $ pip install -r dev-requirements.txt\n\t$ pytest --ckan-ini=test.ini \n\n\n## Future\n\nThis is a bare-bones, first release of the software.  There are\nseveral directions it could take in the future.\n\nBecause we use Google Analytics for recording statistics, we can hook\ninto any of its features.  For example, as a measure of popularity, we\ncould record bounce rate, or new visits only; we could also display\nwhich datasets are popular where, or highlight packages that have been\nlinked to from other locations.\n\nWe could also embed extra metadata information in tracking links, to\nenable reports on particular types of data (e.g. most popular data\nformat by country of origin, or most downloaded resource by license)\n",
    "bugtrack_url": null,
    "license": "AGPL",
    "summary": "Add GA tracking and reporting to CKAN instance",
    "version": "2.3.0",
    "project_urls": {
        "Homepage": "https://github.com/ckan/ckanext-googleanalytics"
    },
    "split_keywords": [
        "ckan"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "18d84d446ff52a9926fe17505dfa9bc138b9f76cce7e9b76fdd89c03f12d26ba",
                "md5": "15badb8243c840af44950d3423d09ede",
                "sha256": "19c421b6bad58169a40a8e0b028b30187c7f4970af37a137a118ae7e8423c322"
            },
            "downloads": -1,
            "filename": "ckanext_googleanalytics-2.3.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "15badb8243c840af44950d3423d09ede",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 47746,
            "upload_time": "2023-06-14T17:30:21",
            "upload_time_iso_8601": "2023-06-14T17:30:21.275718Z",
            "url": "https://files.pythonhosted.org/packages/18/d8/4d446ff52a9926fe17505dfa9bc138b9f76cce7e9b76fdd89c03f12d26ba/ckanext_googleanalytics-2.3.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ba76ed97e0b63440818f25c0460770926beeaad13243310ca8d055df766d408e",
                "md5": "d82b3ec26c0ab0925e7b85c1da6238b5",
                "sha256": "0f1d438dd470c597ffbd6aa04c6f51a516613520706d573430339d79119b2996"
            },
            "downloads": -1,
            "filename": "ckanext-googleanalytics-2.3.0.tar.gz",
            "has_sig": false,
            "md5_digest": "d82b3ec26c0ab0925e7b85c1da6238b5",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 38852,
            "upload_time": "2023-06-14T17:30:23",
            "upload_time_iso_8601": "2023-06-14T17:30:23.543470Z",
            "url": "https://files.pythonhosted.org/packages/ba/76/ed97e0b63440818f25c0460770926beeaad13243310ca8d055df766d408e/ckanext-googleanalytics-2.3.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-06-14 17:30:23",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "ckan",
    "github_project": "ckanext-googleanalytics",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "ckanext-googleanalytics"
}
        
Elapsed time: 0.09986s