2014-07-11 13:55:23 +02:00
|
|
|
import constants
|
2014-07-10 12:26:31 +02:00
|
|
|
import db
|
|
|
|
|
2014-07-10 13:24:41 +02:00
|
|
|
from ckan.plugins import toolkit
|
2014-07-10 12:26:31 +02:00
|
|
|
from ckan.common import _
|
|
|
|
from itertools import count
|
|
|
|
|
|
|
|
|
|
|
|
def private_datasets_metadata_checker(key, data, errors, context):
|
|
|
|
|
2014-07-10 13:24:41 +02:00
|
|
|
dataset_id = data.get(('id',))
|
2014-07-10 12:26:31 +02:00
|
|
|
private_val = data.get(('private',))
|
2014-07-10 13:24:41 +02:00
|
|
|
|
|
|
|
# If the private field is not included in the data dict, we must check the current value
|
2014-07-14 17:05:46 +02:00
|
|
|
if private_val is None and dataset_id:
|
2014-07-10 13:24:41 +02:00
|
|
|
dataset_dict = toolkit.get_action('package_show')({'ignore_auth': True}, {'id': dataset_id})
|
|
|
|
private_val = dataset_dict.get('private')
|
|
|
|
|
2014-07-10 12:26:31 +02:00
|
|
|
private = private_val is True if isinstance(private_val, bool) else private_val == "True"
|
|
|
|
metadata_value = data[key]
|
|
|
|
|
|
|
|
# If allowed users are included and the dataset is not private outside and organization, an error will be raised.
|
|
|
|
if metadata_value != '' and not private:
|
2014-07-10 13:24:41 +02:00
|
|
|
errors[key].append(_('This field is only valid when you create a private dataset'))
|
2014-07-10 12:26:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
def allowed_users_convert(key, data, errors, context):
|
|
|
|
if isinstance(data[key], basestring):
|
|
|
|
allowed_users = [allowed_user for allowed_user in data[key].split(',')]
|
|
|
|
else:
|
|
|
|
allowed_users = data[key]
|
|
|
|
|
2014-07-11 13:55:23 +02:00
|
|
|
current_index = max([int(k[1]) for k in data.keys() if len(k) == 2 and k[0] == constants.ALLOWED_USERS] + [-1])
|
2014-07-10 12:26:31 +02:00
|
|
|
|
|
|
|
for num, allowed_user in zip(count(current_index + 1), allowed_users):
|
2014-07-14 17:05:46 +02:00
|
|
|
data[(constants.ALLOWED_USERS, num)] = allowed_user.strip()
|
2014-07-10 12:26:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
def get_allowed_users(key, data, errors, context):
|
|
|
|
pkg_id = data[('id',)]
|
|
|
|
|
|
|
|
if db.package_allowed_users_table is None:
|
|
|
|
db.init_db(context['model'])
|
|
|
|
|
|
|
|
users = db.AllowedUser.get(package_id=pkg_id)
|
|
|
|
counter = 0
|
|
|
|
|
|
|
|
for user in users:
|
|
|
|
data[(key[0], counter)] = user.user_name
|
|
|
|
counter += 1
|