Skip to content

Commit

Permalink
Merge branch 'master' of github.com:okfn/ckan
Browse files Browse the repository at this point in the history
  • Loading branch information
tobes committed May 2, 2012
2 parents 112438f + 93b4377 commit 06bd2fb
Show file tree
Hide file tree
Showing 26 changed files with 260 additions and 760 deletions.
14 changes: 7 additions & 7 deletions ckan/config/environment.py
Expand Up @@ -30,12 +30,12 @@ class _Helpers(object):
def __init__(self, helpers, restrict=True):
functions = {}
allowed = helpers.__allowed_functions__
# list of functions due to be depreciated
self.depreciated = []
# list of functions due to be deprecated
self.deprecated = []

for helper in dir(helpers):
if helper not in allowed:
self.depreciated.append(helper)
self.deprecated.append(helper)
if restrict:
continue
functions[helper] = getattr(helpers, helper)
Expand Down Expand Up @@ -63,14 +63,14 @@ def null_function(cls, *args, **kw):
def __getattr__(self, name):
''' return the function/object requested '''
if name in self.functions:
if name in self.depreciated:
msg = 'Template helper function `%s` is depriciated' % name
if name in self.deprecated:
msg = 'Template helper function `%s` is deprecated' % name
self.log.warn(msg)
return self.functions[name]
else:
if name in self.depreciated:
if name in self.deprecated:
msg = 'Template helper function `%s` is not available ' \
'as it has been depriciated.\nYou can enable it ' \
'as it has been deprecated.\nYou can enable it ' \
'by setting ckan.restrict_template_vars = true ' \
'in your .ini file.' % name
self.log.critical(msg)
Expand Down
3 changes: 2 additions & 1 deletion ckan/controllers/group.py
Expand Up @@ -72,7 +72,8 @@ def index(self):
group_type = self._guess_group_type()

context = {'model': model, 'session': model.Session,
'user': c.user or c.author, 'for_view': True}
'user': c.user or c.author, 'for_view': True,
'with_private': False}

data_dict = {'all_fields': True}

Expand Down
5 changes: 3 additions & 2 deletions ckan/controllers/home.py
Expand Up @@ -14,8 +14,8 @@ class HomeController(BaseController):
repo = model.repo

def __before__(self, action, **env):
BaseController.__before__(self, action, **env)
try:
BaseController.__before__(self, action, **env)
context = {'model':model,'user': c.user or c.author}
ckan.logic.check_access('site_read',context)
except ckan.logic.NotAuthorized:
Expand All @@ -31,7 +31,7 @@ def __before__(self, action, **env):
# TODO: send an email to the admin person (#1285)
else:
raise


def index(self):
try:
Expand All @@ -43,6 +43,7 @@ def index(self):
'facet.field':g.facets,
'rows':0,
'start':0,
'fq': 'capacity:"public"'
}
query = ckan.logic.get_action('package_search')(context,data_dict)
c.package_count = query['count']
Expand Down
14 changes: 11 additions & 3 deletions ckan/controllers/user.py
Expand Up @@ -52,6 +52,11 @@ def _setup_template_variables(self, context):

## end hooks

def _get_repoze_handler(self, handler_name):
'''Returns the URL that repoze.who will respond to and perform a
login or logout.'''
return getattr(request.environ['repoze.who.plugins']['friendlyform'], handler_name)

def index(self):
LIMIT = 20

Expand Down Expand Up @@ -165,7 +170,9 @@ def _save_new(self, context):
return self.new(data_dict, errors, error_summary)
if not c.user:
# Redirect to a URL picked up by repoze.who which performs the login
h.redirect_to('/login_generic?login=%s&password=%s' % (
login_url = self._get_repoze_handler('login_handler_path')
h.redirect_to('%s?login=%s&password=%s' % (
login_url,
str(data_dict['name']),
quote(data_dict['password1'].encode('utf-8'))))
else:
Expand Down Expand Up @@ -257,6 +264,7 @@ def login(self):
g.openid_enabled = False

if not c.user:
c.login_handler = h.url_for(self._get_repoze_handler('login_handler_path'))
return render('user/login.html')
else:
return render('user/logout_first.html')
Expand All @@ -283,10 +291,10 @@ def logged_in(self):
h.redirect_to(locale=lang, controller='user', action='login')

def logout(self):
# save our language in the session so we don't loose it
# save our language in the session so we don't lose it
session['lang'] = request.environ.get('CKAN_LANG')
session.save()
h.redirect_to('/user/logout')
h.redirect_to(self._get_repoze_handler('logout_handler_path'))

def set_lang(self, lang):
# this allows us to set the lang in session. Used for logging
Expand Down
67 changes: 37 additions & 30 deletions ckan/lib/base.py
Expand Up @@ -169,9 +169,11 @@ def _identify_user(self):
b) For API calls he may set a header with his API key.
If the user is identified then:
c.user = user name (unicode)
c.userobj = user object
c.author = user name
otherwise:
c.user = None
c.userobj = None
c.author = user\'s IP address (unicode)
'''
# see if it was proxied first
Expand All @@ -180,8 +182,10 @@ def _identify_user(self):
c.remote_addr = request.environ.get('REMOTE_ADDR', 'Unknown IP Address')

# environ['REMOTE_USER'] is set by repoze.who if it authenticates a user's
# cookie or OpenID. (But it doesn't check the user (still) exists in our
# database - we need to do that here.
# cookie or OpenID. But repoze.who doesn't check the user (still)
# exists in our database - we need to do that here. (Another way would
# be with an userid_checker, but that would mean another db access.
# See: http://docs.repoze.org/who/1.0/narr.html#module-repoze.who.plugins.sql )
c.user = request.environ.get('REMOTE_USER', '')
if c.user:
c.user = c.user.decode('utf8')
Expand Down Expand Up @@ -210,38 +214,41 @@ def __call__(self, environ, start_response):
# the request is routed to. This routing information is
# available in environ['pylons.routes_dict']

try:
res = WSGIController.__call__(self, environ, start_response)
finally:
model.Session.remove()

# Clean out any old cookies as they may contain api keys etc
# This also improves the cachability of our pages as cookies
# prevent proxy servers from caching content unless they have
# been configured to ignore them.
# we do not want to clear cookies when setting the user lang
if not environ.get('PATH_INFO').startswith('/user/set_lang'):
for cookie in request.cookies:
if cookie.startswith('ckan') and cookie not in ['ckan']:
response.delete_cookie(cookie)
# Remove the ckan session cookie if not used e.g. logged out
elif cookie == 'ckan' and not c.user:
# Check session for valid data (including flash messages)
# (DGU also uses session for a shopping basket-type behaviour)
is_valid_cookie_data = False
for key, value in session.items():
if not key.startswith('_') and value:
is_valid_cookie_data = True
break
if not is_valid_cookie_data:
if session.id:
if not session.get('lang'):
session.delete()
else:
response.delete_cookie(cookie)
# Remove auth_tkt repoze.who cookie if user not logged in.
elif cookie == 'auth_tkt' and not session.id:
response.delete_cookie(cookie)

try:
return WSGIController.__call__(self, environ, start_response)
finally:
model.Session.remove()
for cookie in request.cookies:
if cookie.startswith('ckan') and cookie not in ['ckan']:
response.delete_cookie(cookie)
# Remove the ckan session cookie if not used e.g. logged out
elif cookie == 'ckan' and not c.user:
# Check session for valid data (including flash messages)
# (DGU also uses session for a shopping basket-type behaviour)
is_valid_cookie_data = False
for key, value in session.items():
if not key.startswith('_') and value:
is_valid_cookie_data = True
break
if not is_valid_cookie_data:
if session.id:
if not session.get('lang'):
self.log.debug('No session data any more - deleting session')
self.log.debug('Session: %r', session.items())
session.delete()
else:
response.delete_cookie(cookie)
self.log.debug('No session data any more - deleting session cookie')
# Remove auth_tkt repoze.who cookie if user not logged in.
elif cookie == 'auth_tkt' and not session.id:
response.delete_cookie(cookie)

return res

def __after__(self, action, **params):
self._set_cors()
Expand Down
5 changes: 3 additions & 2 deletions ckan/lib/dictization/model_dictize.py
Expand Up @@ -15,7 +15,7 @@ def group_list_dictize(obj_list, context,
sort_key=lambda x:x['display_name'], reverse=False):

active = context.get('active', True)

with_private = context.get('include_private_packages', False)
result_list = []

for obj in obj_list:
Expand All @@ -30,7 +30,8 @@ def group_list_dictize(obj_list, context,

group_dict['display_name'] = obj.display_name

group_dict['packages'] = len(obj.active_packages().all())
group_dict['packages'] = \
len(obj.active_packages(with_private=with_private).all())

if context.get('for_view'):
for item in plugins.PluginImplementations(
Expand Down
26 changes: 15 additions & 11 deletions ckan/lib/helpers.py
Expand Up @@ -156,10 +156,14 @@ def lang():
''' Return the language code for the current locale eg `en` '''
return request.environ.get('CKAN_LANG')

def lang_native_name():
''' Return the langage name currently used in it's localised form '''
locale = get_locales_dict().get(lang())
return locale.display_name or locale.english_name
def lang_native_name(lang=None):
''' Return the langage name currently used in it's localised form
either from parameter or current environ setting'''
lang = lang or lang()
locale = get_locales_dict().get(lang)
if locale:
return locale.display_name or locale.english_name
return lang

class Message(object):
"""A message returned by ``Flash.pop_messages()``.
Expand Down Expand Up @@ -259,7 +263,7 @@ def are_there_flash_messages():

def nav_link(*args, **kwargs):
# nav_link() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) > 2 or (len(args) > 1 and 'controller' in kwargs):
Expand All @@ -282,7 +286,7 @@ def _nav_link(text, controller, **kwargs):

def nav_named_link(*args, **kwargs):
# subnav_link() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) > 3 or (len(args) > 0 and 'text' in kwargs) or \
Expand All @@ -303,7 +307,7 @@ def _nav_named_link(text, name, **kwargs):

def subnav_link(*args, **kwargs):
# subnav_link() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) > 2 or (len(args) > 1 and 'action' in kwargs):
Expand All @@ -321,7 +325,7 @@ def _subnav_link(text, action, **kwargs):

def subnav_named_route(*args, **kwargs):
# subnav_link() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) > 2 or (len(args) > 0 and 'text' in kwargs) or \
Expand Down Expand Up @@ -378,7 +382,7 @@ def facet_items(*args, **kwargs):
"""
_log.warning('Deprecated function: ckan.lib.helpers:facet_items(). Will be removed in v1.8')
# facet_items() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) > 2 or (len(args) > 0 and 'name' in kwargs) or (len(args) > 1 and 'limit' in kwargs):
Expand Down Expand Up @@ -686,7 +690,7 @@ def dump_json(obj, **kw):

def auto_log_message(*args):
# auto_log_message() used to need c passing as the first arg
# this is depriciated as pointless
# this is deprecated as pointless
# throws error if ckan.restrict_template_vars is True
# When we move to strict helpers then this should be removed as a wrapper
if len(args) and asbool(config.get('ckan.restrict_template_vars', 'false')):
Expand Down Expand Up @@ -773,7 +777,7 @@ def process_names(items):
'default_group_type',
'facet_items',
'facet_title',
# am_authorized, # depreciated
# am_authorized, # deprecated
'check_access',
'linked_user',
'linked_authorization_group',
Expand Down
2 changes: 1 addition & 1 deletion ckan/logic/__init__.py
Expand Up @@ -227,7 +227,7 @@ def get_action(action):

def get_or_bust(data_dict, keys):
'''Try and get values from dictionary and if they are not there
raise a validataion error.
raise a validation error.
data_dict: a dictionary
keys: either a single string key in which case will return a single value,
Expand Down
6 changes: 3 additions & 3 deletions ckan/logic/action/get.py
Expand Up @@ -491,9 +491,9 @@ def resource_status_show(context, data_dict):
check_access('resource_status_show', context, data_dict)

# needs to be text query as celery tables are not in our model
q = text("""select status, date_done, traceback, task_status.*
from task_status left join celery_taskmeta
on task_status.value = celery_taskmeta.task_id and key = 'celery_task_id'
q = text("""select status, date_done, traceback, task_status.*
from task_status left join celery_taskmeta
on task_status.value = celery_taskmeta.task_id and key = 'celery_task_id'
where entity_id = :entity_id """)

result = model.Session.connection().execute(q, entity_id=id)
Expand Down
11 changes: 8 additions & 3 deletions ckan/model/group.py
Expand Up @@ -166,13 +166,18 @@ def get_children_groups(self, type='group'):
from_statement(HIERARCHY_CTE).params(id=self.id, type=type).all()
return [ { "id":idf, "name": name, "title": title } for idf,name,title in results ]

def active_packages(self, load_eager=True):
def active_packages(self, load_eager=True, with_private=False):
query = Session.query(Package).\
filter_by(state=vdm.sqlalchemy.State.ACTIVE).\
filter(group_table.c.id == self.id).\
filter(member_table.c.state == 'active').\
join(member_table, member_table.c.table_id == Package.id).\
filter(member_table.c.state == 'active')

if not with_private:
query = query.filter(member_table.c.capacity == 'public')

query = query.join(member_table, member_table.c.table_id == Package.id).\
join(group_table, group_table.c.id == member_table.c.group_id)

return query

@classmethod
Expand Down

0 comments on commit 06bd2fb

Please sign in to comment.