import logging | |
import operator | |
import ckan.lib.base as base | |
import ckan.model as model | |
_log = logging.getLogger(__name__) | |
def most_popular_datasets(publisher, count=20): | |
from ckanext.ga_report.ga_model import GA_Url | |
if not publisher: | |
_log.error("No valid publisher passed to 'most_popular_datasets'") | |
return "" | |
datasets = {} | |
entries = model.Session.query(GA_Url).\ | |
filter(GA_Url.department_id==publisher.name).\ | |
filter(GA_Url.url.like('/dataset/%')).\ | |
order_by('ga_url.pageviews::int desc')[:count] | |
for entry in entries: | |
p = model.Package.get(entry.url[len('/dataset/'):]) | |
if not p in datasets: | |
datasets[p] = {'views':0, 'visits': 0} | |
datasets[p]['views'] = datasets[p]['views'] + int(entry.pageviews) | |
datasets[p]['visits'] = datasets[p]['visits'] + int(entry.visitors) | |
results = [] | |
for k, v in datasets.iteritems(): | |
results.append((k,v['views'],v['visits'])) | |
results = sorted(results, key=operator.itemgetter(1), reverse=True) | |
ctx = { | |
'dataset_count': len(datasets), | |
'datasets': results, | |
'publisher': publisher | |
} | |
return base.render_snippet('ga_report/publisher/popular.html', **ctx) | |
import logging | import logging |
import ckan.lib.helpers as h | import ckan.lib.helpers as h |
import ckan.plugins as p | import ckan.plugins as p |
from ckan.plugins import implements, toolkit | from ckan.plugins import implements, toolkit |
#import gasnippet | |
#import commands | |
#import dbutil | |
log = logging.getLogger('ckanext.ga-report') | log = logging.getLogger('ckanext.ga-report') |
class GAReportPlugin(p.SingletonPlugin): | class GAReportPlugin(p.SingletonPlugin): |
implements(p.IConfigurer, inherit=True) | implements(p.IConfigurer, inherit=True) |
implements(p.IRoutes, inherit=True) | implements(p.IRoutes, inherit=True) |
implements(p.ITemplateHelpers, inherit=True) | |
def update_config(self, config): | def update_config(self, config): |
toolkit.add_template_directory(config, 'templates') | toolkit.add_template_directory(config, 'templates') |
toolkit.add_public_directory(config, 'public') | toolkit.add_public_directory(config, 'public') |
def get_helpers(self): | |
""" | |
A dictionary of extra helpers that will be available to provide | |
ga report info to templates. | |
""" | |
from ckanext.ga_report.helpers import most_popular_datasets | |
return { | |
'most_popular_datasets': most_popular_datasets | |
} | |
def after_map(self, map): | def after_map(self, map): |
map.connect( | map.connect( |
'/data/analytics/publisher', | '/data/analytics/publisher', |
controller='ckanext.ga_report.controller:GaPublisherReport', | controller='ckanext.ga_report.controller:GaPublisherReport', |
action='index' | action='index' |
) | ) |
map.connect( | map.connect( |
'/data/analytics/publisher/{id}', | '/data/analytics/publisher/{id}', |
controller='ckanext.ga_report.controller:GaPublisherReport', | controller='ckanext.ga_report.controller:GaPublisherReport', |
action='read' | action='read' |
) | ) |
map.connect( | map.connect( |
'/data/analytics', | '/data/analytics', |
controller='ckanext.ga_report.controller:GaReport', | controller='ckanext.ga_report.controller:GaReport', |
action='index' | action='index' |
) | ) |
map.connect( | map.connect( |
'/data/analytics/data_{month}.csv', | '/data/analytics/data_{month}.csv', |
controller='ckanext.ga_report.controller:GaReport', | controller='ckanext.ga_report.controller:GaReport', |
action='csv' | action='csv' |
) | ) |
return map | return map |
<html xmlns:py="http://genshi.edgewall.org/" | |
xmlns:i18n="http://genshi.edgewall.org/i18n" | |
xmlns:xi="http://www.w3.org/2001/XInclude" | |
py:strip=""> | |
<py:if test="dataset_count > 0"> | |
<div class="popular_datasets"> | |
<ul class="popular_dataset_list"> | |
<py:for each="dataset,views,visits in datasets"> | |
<li> | |
${h.link_to(dataset.title, h.url_for(controller='package', action='read', id=dataset.name))} | |
</li> | |
</py:for> | |
</ul> | |
<p>${h.link_to("More analytics for " + publisher.title, h.url_for(controller='ckanext.ga_report.controller:GaPublisherReport',action='read',id=publisher.name))}</p> | |
</div> | |
</py:if> | |
</html> | |
<html xmlns:py="http://genshi.edgewall.org/" | <html xmlns:py="http://genshi.edgewall.org/" |
xmlns:i18n="http://genshi.edgewall.org/i18n" | xmlns:i18n="http://genshi.edgewall.org/i18n" |
xmlns:xi="http://www.w3.org/2001/XInclude" | xmlns:xi="http://www.w3.org/2001/XInclude" |
py:strip=""> | py:strip=""> |
<py:def function="page_title">Analytics for ${g.site_title}</py:def> | <py:def function="page_title">Analytics for ${g.site_title}</py:def> |
<py:match path="primarysidebar"> | <py:match path="primarysidebar"> |
<li class="widget-container boxed widget_text"> | <li class="widget-container boxed widget_text"> |
<h4>${c.publisher.title}</h4> | <h4>${c.publisher.title}</h4> |
<p> | <p> |
The table shows the top 20 most viewed datasets belonging to ${c.publisher.title}. | The table shows the top 20 most viewed datasets belonging to ${c.publisher.title}. |
</p> | </p> |
<p> | <p> |
As well as showing the number of views within ${c.month_desc}, it will also show the | As well as showing the number of views within ${c.month_desc}, it will also show the |
number of visitors that viewed each dataset. | number of visitors that viewed each dataset. |
</p> | </p> |
<p>The dataset list page for <a href="${h.url_for(controller='ckanext.dgu.controllers.publisher:PublisherController', action='read', id=c.publisher.name)}">${c.publisher.title}</a> was viewed ${c.publisher_page_views} times during ${c.month_desc}</p> | <p>The dataset list page for <a href="${h.url_for(controller='ckanext.dgu.controllers.publisher:PublisherController', action='read', id=c.publisher.name)}">${c.publisher.title}</a> was viewed ${c.publisher_page_views} times during ${c.month_desc}</p> |
<p>View the <a href="${h.url_for(controller='ckanext.ga_report.controller:GaPublisherReport', action='index')}">publishers</a> leaderboard</p> | <p>View the <a href="${h.url_for(controller='ckanext.ga_report.controller:GaPublisherReport', action='index')}">publishers</a> leaderboard</p> |
</li> | </li> |
</py:match> | </py:match> |
<div py:match="content"> | <div py:match="content"> |
<h1>Analytics for ${c.publisher.title}</h1> | <h1>Analytics for ${c.publisher.title}</h1> |
<h2>Top 20 most viewed datasets</h2> | <h2>Top 20 most viewed datasets</h2> |
<p><em>Note: this data does not include API calls</em></p> | <p><em>Note: this data does not include API calls</em></p> |
<form class="form-inline" action="${h.url_for(controller='ckanext.ga_report.controller:GaPublisherReport',action='read',id=c.publisher.name)}" method="get"> | <form class="form-inline" action="${h.url_for(controller='ckanext.ga_report.controller:GaPublisherReport',action='read',id=c.publisher.name)}" method="get"> |
<div class="controls"> | <div class="controls"> |
<select name="month"> | <select name="month"> |
<py:for each="val,desc in c.months"> | <py:for each="val,desc in c.months"> |
<option value='${val}' py:attrs="{'selected': 'selected' if c.month == val else None}">${desc}</option> | <option value='${val}' py:attrs="{'selected': 'selected' if c.month == val else None}">${desc}</option> |
</py:for> | </py:for> |
</select> | </select> |
<input class="btn button" type='submit' value="Update"/> | <input class="btn button" type='submit' value="Update"/> |
</div> | </div> |
</form> | </form> |
<table class="table table-condensed table-bordered table-striped"> | <table class="table table-condensed table-bordered table-striped"> |
<tr> | <tr> |
<th>Dataset</th> | <th>Dataset</th> |
<th>Views</th> | <th>Views</th> |
<th>Visits</th> | <th>Visits</th> |
</tr> | </tr> |
<py:for each="package, views, visits in c.top_packages"> | <py:for each="package, views, visits in c.top_packages"> |
<tr> | <tr> |
<td>${h.link_to(package.title or package.name, h.url_for(controller='package', action='read', id=package.name))} | <td>${h.link_to(package.title or package.name, h.url_for(controller='package', action='read', id=package.name))} |
</td> | </td> |
<td>${views}</td> | <td>${views}</td> |
<td>${visits}</td> | <td>${visits}</td> |
</tr> | </tr> |
</py:for> | </py:for> |
</table> | </table> |
</div> | </div> |
<xi:include href="../../layout.html" /> | <xi:include href="../../layout.html" /> |
</html> | </html> |